X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=lib%2FGruntmaster%2FPage%2FCt.pm;h=19c4aad33cc319d4504768eb2b7fc8c30c4ac47a;hb=cd9af27e94244e6454c3db787a8ca6811f44fc16;hp=5a04b3adc20cbe33a4b8c307b80ad8e4df28ec91;hpb=832cb45e325364ca1de645a2256efa69284fcf06;p=plack-app-gruntmaster.git diff --git a/lib/Gruntmaster/Page/Ct.pm b/lib/Gruntmaster/Page/Ct.pm index 5a04b3a..19c4aad 100644 --- a/lib/Gruntmaster/Page/Ct.pm +++ b/lib/Gruntmaster/Page/Ct.pm @@ -9,16 +9,14 @@ our $VERSION = '0.001'; use constant TITLE => 'Contests'; -use Fcntl qw/:flock/; use HTML::Template::Compiled; -use IO::File; use POSIX qw/strftime/; -use YAML::Any qw/LoadFile/; use Gruntmaster::Page::Common qw/header footer/; +use Gruntmaster::Data qw/contest_name contest_start contest_end contest_owner/; my %templates = ( - en => <<'HTML', - + en => <<'HTML', +

Running contests

@@ -32,7 +30,7 @@ my %templates = (
- +

Pending contests

@@ -46,7 +44,7 @@ my %templates = (
- +

Finished contests

@@ -66,34 +64,26 @@ $templates{$_} = header($_, TITLE) . $templates{$_} for keys %templates; $templates{$_} .= footer $_ for keys %templates; sub generate{ - my $template = $templates{$_[1]}; - my $htc = HTML::Template::Compiled->new(scalarref => \$template); - IO::File->new('>ct/meta.yml')->close unless -f 'ct/meta.yml'; - flock my $metafh = IO::File->new('new(scalarref => \$templates{$_[1]}); - my (@running, @pending, @finished); - for () { - my $meta = LoadFile $_; - my $id = (m,^ct/(.*)/meta.yml$,)[0]; - my $ct = { id => $id, - name => $meta->{name}, - start => strftime ('%c', localtime $meta->{start}), - end => strftime ('%c', localtime $meta->{end}), - owner => $meta->{owner}}; + my (@running, @pending, @finished); + for (contests) { + my $ct = { id => $_, + name => contest_name, + start => strftime ('%c', localtime contest_start), + end => strftime ('%c', localtime contest_end), + owner => contest_owner }; - my $time = time; - push @pending, $ct if time < $meta->{start}; - push @running, $ct if time >= $meta->{start} && time < $meta->{end}; - push @finished, $ct if time > $meta->{end}; - } + my $time = time; + push @pending, $ct if time < contest_start; + push @running, $ct if time >= contest_start && time < contest_end; + push @finished, $ct if time > contest_end; + } - $htc->param(runningn => scalar @running); - $htc->param(pendingn => scalar @pending); - $htc->param(finishedn => scalar @finished); - $htc->param(running => \@running); - $htc->param(pending => \@pending); - $htc->param(finished => \@finished); - $htc->output + $htc->param(running => \@running); + $htc->param(pending => \@pending); + $htc->param(finished => \@finished); + $htc->output } 1