X-Git-Url: http://git.rot13.org/?p=angular-mojolicious.git;a=blobdiff_plain;f=angular-server.pl;h=1ef37788791a33e99029a0bcd24fab8310ef3a6d;hp=948759928ee073f0f6a416978e284164c6181e9f;hb=73263cc2aa4d6bded8e8898861a071b211171594;hpb=1c641d9c92981bab0e0fe9ad2e89bdf2e6d3f088 diff --git a/angular-server.pl b/angular-server.pl index 9487599..1ef3778 100755 --- a/angular-server.pl +++ b/angular-server.pl @@ -136,7 +136,7 @@ any [ 'post' ] => '/data/:database/:entity' => sub { $json->{'_'.$_} = $new->{$_} foreach ( 'rev','id' ); } else { warn "ERROR: ",dump($new); - $json->{_error} = $new; + $json->{error} = $new; } _render_jsonp( $self, $json ); @@ -228,6 +228,8 @@ get '/json/:database/:entity' => sub { use Encode; use iCal::Parser; +plugin 'proxy'; + get '/reservations/get/(*url)' => sub { my $self = shift; @@ -240,7 +242,7 @@ get '/reservations/get/(*url)' => sub { my $c = iCal::Parser->new->parse_strings( $text ); - warn "# iCal::Parser = ",dump($c); +# warn "# iCal::Parser = ",dump($c); my $ical = { cal => $c->{cals}->[0], # FIXME assume single calendar @@ -257,6 +259,19 @@ get '/reservations/get/(*url)' => sub { } } + @events = map { + foreach my $check_slot ( qw( + DESCRIPTION + LOCATION + STATUS + SUMMARY + )) { + next unless exists $_->{$check_slot}; + $_->{slots} = $1 if $_->{$check_slot} =~ m/(\d+)\s*mjesta/s; + } + $_; + } @events; + $ical->{events} = [ sort { $a->{DTSTART} cmp $b->{DTSTART} } @events ]; @@ -264,6 +279,40 @@ get '/reservations/get/(*url)' => sub { _render_jsonp( $self, $ical ); }; +get '/reservations/events/:view_name' => sub { + my $self = shift; + + my $view = _couchdb_get('/reservations/_design/events/_view/' . $self->param('view_name') . '?group=true'); + my $hash; + + if ( exists $view->{error} ) { + _couchdb_put "/reservations/_design/events", { + _id => '_design/events', + language => 'javascript', + views => { + submited => { + map => q| + function(doc) { + if ( doc.event && doc.event.UID ) emit(doc.event.UID, 1) + } + |, + reduce => q|_sum|, + } + } + }; + } + + _render_jsonp( $self, {} ) unless ref $view->{rows} eq 'ARRAY'; + + foreach my $row ( @{ $view->{rows} } ) { + $hash->{ $row->{key} } = $row->{value}; + } + + _render_jsonp( $self, $hash ); +}; + +get '/_utils/script/(*url)' => sub { $_[0]->proxy_to( "$couchdb/_utils/script/" . $_[0]->param('url') , with_query_params => 1 ) }; + app->start; __DATA__