package Pod::ProjectDocs::IndexPage;

use strict;
use warnings;

our $VERSION = '0.53';    # VERSION

use Moose;
with 'Pod::ProjectDocs::File', 'Pod::ProjectDocs::Template';

has 'default_name' => (
    is      => 'ro',
    isa     => 'Str',
    default => 'index.html',
);

has 'json' => (
    is  => 'rw',
    isa => 'Str',
);

has 'components' => (
    is  => 'rw',
    isa => 'HashRef',
);

has 'data' => (
    is      => 'ro',
    default => <<'DATA',
<!DOCTYPE html>
<html lang="[% lang %]" xml:lang="[% lang %]">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=[% charset %]" />
<title>[% title | html %]</title>
<link rel="stylesheet" href="[% css_relative_url %]" type="text/css" />
<script type="text/javascript">
//<![CDATA[
var managers = [% json %];
function render(pattern) {
    var html = '';
    for ( var i = 0; i < managers.length; i++ ) {
        var manager   = managers[i];
        var rows_html = get_rows_html(manager, pattern);
        var listbox = "<div class='box'><h2 class='t2'>"
                    + manager.desc
                    + "</h2><table width='100%'>"
                    + rows_html
                    + "</table></div>";
        html += listbox;
    }
    var list = document.getElementById('list');
    list.innerHTML = html;
}
function get_rows_html (manager, pattern) {
    var html   = '';
    var regexp = new RegExp( "(" + pattern + ")", "gi");
    var seq    = 0;
    for (var i = 0; i < manager.entries.length; i++) {
        var entry = manager.entries[i];
        if ( entry.name.match(regexp) ) {
            var module_name = manager.entries[i].name;
            if(pattern != '' ) {
                var replace_text = "<span class='search_highlight'>$1</span>";
                module_name = module_name.replace(regexp, replace_text);
            }
            html += get_entry_html(entry, module_name, seq);
            seq++;
        }
    }
    return html;
}
function get_entry_html (entry, name, i) {
    var row_class  = ( i % 2 == 0 ) ? 'r' : 's';
    var row_html   = "<tr class='"
                   + row_class
                   + "'><td nowrap='nowrap'><a href='"
                   + entry.path
                   + "'>"
                   + name + "</a></td><td width='99%'><small>"
                   + (entry.title || '')
                   + "</small></td></tr>";
    return row_html;
}
//]]>
</script>
</head>
<body onload="render('')">
<div class="box">
  <h1 class="t1">[% title | html %]</h1>
  <table>
    <tr>
      <td class="label">Description</td>
      <td class="cell">[% desc | html_line_break %]</td>
    </tr>
  </table>
</div>

<div class="box">
  <h2 class="t2">Search</h2>
  <table>
    <tr>
       <td class="cell"><input type="text" size="60" onkeyup="render(this.value)" /></td>
    </tr>
  </table>
</div>

<div id="list"></div>

<div class="footer">generated by <a href="http://metacpan.org/module/Pod::ProjectDocs">Pod::ProjectDocs</a></div>
</body>
</html>
DATA
);

sub _get_data {
    my $self   = shift;
    my $params = {
        title            => $self->config->title,
        desc             => $self->config->desc,
        lang             => $self->config->lang,
        json             => $self->json,
        charset          => 'UTF-8',
        css_relative_url => $self->components->{css}->relative_url($self),
    };
    my $text = $self->process( $self, $self->data, $params );
    return $text;
}

no Moose;

1;
