=================================================================== RCS file: /cvs/todotxt/Text-Todo/bin/dudelicious.pl,v retrieving revision 1.5 retrieving revision 1.14 diff -u -r1.5 -r1.14 --- todotxt/Text-Todo/bin/dudelicious.pl 2010/04/29 05:50:33 1.5 +++ todotxt/Text-Todo/bin/dudelicious.pl 2010/05/01 22:47:51 1.14 @@ -1,31 +1,67 @@ -#!/usr/bin/env perl +#!/usr/bin/perl package Dudelicious; +use 5.010; +use Data::Dumper; use version; our $VERSION = qv('0.1.0'); -BEGIN { use FindBin; use lib "$FindBin::Bin/mojo/lib" } +BEGIN { + use FindBin; + use lib "$FindBin::Bin/../lib"; + use lib "$FindBin::Bin/../mojo/lib"; +} use Carp qw/ carp croak /; +use Digest::MD5 qw/ md5_hex /; +use Text::Todo; use Mojolicious::Lite; -use Text::Todo; +use Mojo::JSON; -use Data::Dumper; +app->home->parse( $ENV{DUDELICIOUS_HOME} ) if $ENV{DUDELICIOUS_HOME}; -my %config = ( todo_dir => $ENV{DUDELICIOUS_HOME} || '.', ); +plugin 'json_config' => { + file => 'dudelicious.conf', + default => { todo_dir => $ENV{DUDELICIOUS_HOME} || '.', }, +}; -app->home->parse( $ENV{DUDELICIOUS_HOME} ) if $ENV{DUDELICIOUS_HOME}; -_read_config_from_file( app->home->rel_file('dudelicious.conf') ); +app->renderer->add_helper( + todo => sub { + my ($self) = @_; + state $todo = Text::Todo->new( $self->stash('config') ); -plugin 'default_helpers'; + my $file = $self->stash('file'); + if ($file) { + $file =~ s/(?:\.txt)?$/\.txt/ixms; + $todo->load($file); + } -my $todo = Text::Todo->new( \%config ); + return $todo; + } +); +app->renderer->add_helper( + get_list => sub { + my ($self) = @_; + + my $line = 1; + return [ + map { + line => $line++, + md5 => md5_hex( $_->text ), + text => $_->text, + done => $_->done, + }, + $self->helper('todo')->list + ]; + } +); + get '/' => sub { my $self = shift; - my $dir = $todo->file('todo_dir'); + my $dir = $self->helper('todo')->file('todo_dir'); opendir my $dh, $dir or croak "Unable to opendir $dir: $!"; my @files = grep {/\.te?xt$/ixms} readdir $dh; closedir $dh; @@ -33,109 +69,145 @@ $self->render( files => \@files, layout => 'todotxt' ); } => 'index'; +get '/todotxt' => 'todotxt'; + get '/l/:file' => sub { my $self = shift; - my $file = $self->stash('file') . '.txt'; - $self->render( list => [ $todo->listfile($file) ], layout => 'todotxt' ); + my $format = $self->stash('format') || 'html'; + + if ( $format eq 'json' ) { + $self->render_json( $self->helper('get_list') ); + } + else { + $self->render( + list => $self->helper('get_list'), + layout => 'todotxt' + ); + } } => 'list'; -get '/l/:file/e/:entry' => sub { - my $self = shift; - my $file = $self->stash('file') . '.txt'; - my $entry = $self->stash('entry') - 1; +get '/l/:file/e/:line' => sub { + my $self = shift; - $self->render( - entry => $todo->listfile($file)->[$entry], - layout => 'todotxt' - ); + my $format = $self->stash('format') || 'html'; + my $entry = $self->helper('get_list')->[ $self->stash('line') - 1 ]; + + if ( $format eq 'json' ) { + $self->render_json($entry); + } + else { + $self->render( entry => $entry, layout => 'todotxt' ); + } } => 'entry'; -app->start unless caller(); +get '/l/:file/t' => sub { + my $self = shift; -sub _read_config_from_file { - my ($conf_file) = @_; + my $format = $self->stash('format') || 'html'; - app->log->debug("Reading configuration from $conf_file."); + if ( $format eq 'json' ) { + $self->render_json( $self->helper('todo')->known_tags ); + } + else { + $self->render( + tags => $self->helper('todo')->known_tags, + layout => 'todotxt' + ); + } +} => 'tags'; - if ( -e $conf_file ) { - if ( open FILE, "<", $conf_file ) { - my @lines = ; - close FILE; +get '/l/:file/t/:tag' => sub { + my $self = shift; - my $line = ''; - foreach my $l (@lines) { - next if $l =~ m/^\s*#/; - $line .= $l; - } + my $format = $self->stash('format') || 'html'; + my $items = $self->helper('todo')->listtag( $self->stash('tag') ); - my $json = Mojo::JSON->new; - my $json_config = $json->decode($line) || {}; - die $json->error if !$json_config && $json->error; - - %config = ( %config, %$json_config ); - - unshift @INC, $_ - for ( - ref $config{perl5lib} eq 'ARRAY' - ? @{ $config{perl5lib} } - : $config{perl5lib} - ); - } + if ( $format eq 'json' ) { + $self->render_json($items); } else { - app->log->debug("Configuration [$conf_file] is not available."); + $self->render( items => $items, layout => 'todotxt' ); } +} => 'tag'; - $ENV{SCRIPT_NAME} = $config{base} if defined $config{base}; +app->start if !caller(); - # set proper templates base dir, if defined - app->renderer->root( app->home->rel_dir( $config{templatesdir} ) ) - if defined $config{templatesdir}; - - # set proper public base dir, if defined - app->static->root( app->home->rel_dir( $config{publicdir} ) ) - if defined $config{publicdir}; -} - +1; __DATA__ @@ list.txt.ep -% foreach my $i (0..$#{ $list }) { -%== include 'entry', entry => $list->[$i], line => $i + 1; +% foreach my $entry (@{ $list }) { +%== include 'entry', entry => $entry; % } @@ entry.txt.ep -<%= $entry->text %> +<%= $entry->{text} %> +@@ tags.txt.ep +% foreach my $tag (keys %{ $tags }) { +<%= $tag %>, <%= $tags->{$tag} %> +% } + +@@ tag.txt.ep +# <%= $tag %> +% foreach my $item (@{ $items}) { +<%= $item %> +% } + @@ layouts/todotxt.txt.ep %= content @@ index.html.ep % foreach my $file (@{ $files }) { -<%== $file %>
+% my ($basename) = $file =~ /^(.*?)(?:\.[^\.]+)?$/xms; +<%= $file %>
% } @@ list.html.ep

<%= $file %>

    -% foreach my $i (0..$#{ $list }) { +% foreach my $entry (@{ $list }) {
  1. -%= include 'entry', entry => $list->[$i], line => $i + 1; +%= include 'entry', entry => $entry;
  2. % }
@@ entry.html.ep -<%= $entry->text %> +<%= $entry->{text} %> +@@ tags.html.ep +% foreach my $tag (keys%{ $tags }) { +<%= $tag %> == <%= $tags->{$tag} %>
+% } + +@@ tag.html.ep +

<%= $tag %>

+% foreach my $item (@{ $items }) { +<%= $item %>
+% } + @@ layouts/todotxt.html.ep - Funky! + + Funky! + + <%== content %> +@@ todotxt.css.ep +body { + background: LightGoldenRodYellow; + color: DarkSlateBlue; +} +.inplaceeditor-saving { + background: url(images/saving.gif) bottom right no-repeat; +} + + __END__ =head1 NAME @@ -147,7 +219,7 @@ Since the $VERSION can't be automatically included, here is the RCS Id instead, you'll have to look up $VERSION. - $Id: dudelicious.pl,v 1.5 2010/04/29 04:50:33 andrew Exp $ + $Id: dudelicious.pl,v 1.14 2010/05/01 21:47:51 andrew Exp $ =head1 SYNOPSIS