diff --git a/Web/lib/MJB/Web.pm b/Web/lib/MJB/Web.pm index 8134afc..7daf3d8 100644 --- a/Web/lib/MJB/Web.pm +++ b/Web/lib/MJB/Web.pm @@ -114,13 +114,17 @@ sub startup ($self) { $auth->post( '/password' )->to('UserSettings#do_change_password' )->name('do_change_password' ); # Dashboard - $auth->get ( '/dashboard' )->to('Dashboard#index' )->name('show_dashboard' ); - $auth->get ( '/dashboard/blog/:id' )->to('Dashboard#blog' )->name('show_dashboard_blog' ); - $auth->get ( '/dashboard/blog/:id/posts' )->to('Dashboard#blog_posts' )->name('show_dashboard_blog_posts' ); - $auth->get ( '/dashboard/blog/:id/post/*mdfile' )->to('Dashboard#blog_post' )->name('show_dashboard_blog_post' ); - $auth->post( '/dashboard/blog/:id/post/*mdfile' )->to('Dashboard#do_blog_post' )->name('do_dashboard_blog_post' ); - $auth->get ( '/dashboard/blog/:id/post' )->to('Dashboard#blog_post_create' )->name('show_dashboard_blog_post_create' ); - $auth->post( '/dashboard/blog/:id/post' )->to('Dashboard#do_blog_post_create' )->name('do_dashboard_blog_post_create' ); + $auth->get ( '/dashboard' )->to('Dashboard#index' )->name('show_dashboard' ); + $auth->get ( '/dashboard/blog/:id' )->to('Dashboard#blog' )->name('show_dashboard_blog' ); + $auth->get ( '/dashboard/blog/:id/posts' )->to('Dashboard#blog_posts' )->name('show_dashboard_blog_posts' ); + $auth->get ( '/dashboard/blog/:id/post/*mdfile' )->to('Dashboard#blog_post' )->name('show_dashboard_blog_post' ); + $auth->post( '/dashboard/blog/:id/post/*mdfile' )->to('Dashboard#do_blog_post' )->name('do_dashboard_blog_post' ); + $auth->get ( '/dashboard/blog/:id/post' )->to('Dashboard#blog_post_create' )->name('show_dashboard_blog_post_create' ); + $auth->post( '/dashboard/blog/:id/post' )->to('Dashboard#do_blog_post_create' )->name('do_dashboard_blog_post_create' ); + $auth->get ( '/dashboard/blog/:id/settings' )->to('Dashboard#blog_settings' )->name('show_dashboard_blog_settings' ); + $auth->post( '/dashboard/blog/:id/settings' )->to('Dashboard#do_blog_settings' )->name('do_dashboard_blog_settings' ); + $auth->get ( '/dashboard/blog/:id/config' )->to('Dashboard#blog_config' )->name('show_dashboard_blog_config' ); + $auth->post( '/dashboard/blog/:id/config' )->to('Dashboard#do_blog_config' )->name('do_dashboard_blog_config' ); # Blog Management $auth->get ( '/blog/create' )->to('Blog#create' )->name('show_blog_create' ); diff --git a/Web/lib/MJB/Web/Controller/Dashboard.pm b/Web/lib/MJB/Web/Controller/Dashboard.pm index cf0ec4e..3395791 100644 --- a/Web/lib/MJB/Web/Controller/Dashboard.pm +++ b/Web/lib/MJB/Web/Controller/Dashboard.pm @@ -150,4 +150,101 @@ sub do_blog_post_create ( $c ) { $c->redirect_to( $c->url_for( 'show_dashboard_blog_posts', { id => $blog->id } ) ); } +sub blog_settings ($c) { + my $blog = $c->stash->{blog} = $c->db->blog( $c->param('id') ); + + if ( $blog->person->id ne $c->stash->{person}->id ) { + $c->render( + text => "Error: This blog isn't owned by you.", + status => 404, + format => 'txt', + ); + return; + } + + my $data = $c->jekyll($blog->domain->name)->config->data; + + my $title = $c->stash->{form_title} = $data->{title}; + my $desc = $c->stash->{form_desc} = $data->{description}; + my $email = $c->stash->{form_email} = $data->{email}; + my $url = $c->stash->{form_url} = $data->{url}; + + +} + +sub do_blog_settings ($c) { + my $blog = $c->stash->{blog} = $c->db->blog( $c->param('id') ); + + if ( $blog->person->id ne $c->stash->{person}->id ) { + $c->render( + text => "Error: This blog isn't owned by you.", + status => 404, + format => 'txt', + ); + return; + } + + my $jekyll = $c->jekyll($blog->domain->name); + + my $title = $c->stash->{form_title} = $c->param( 'configTitle' ); + my $desc = $c->stash->{form_desc} = $c->param( 'configDesc' ); + my $email = $c->stash->{form_email} = $c->param( 'configEmail' ); + my $url = $c->stash->{form_url} = $c->param( 'configURL' ); + + $jekyll->config->data->{title} = $title; + $jekyll->config->data->{description} = $desc; + $jekyll->config->data->{email} = $email; + $jekyll->config->data->{url} = $url; + + $jekyll->write_config; + + $c->flash( confirmation => "The settings have been updated!!" ); + $c->redirect_to( $c->url_for( 'show_dashboard_blog_settings', { id => $blog->id } ) ); +} + +sub blog_config ( $c ) { + my $blog = $c->stash->{blog} = $c->db->blog( $c->param('id') ); + + if ( $blog->person->id ne $c->stash->{person}->id ) { + $c->render( + text => "Error: This blog isn't owned by you.", + status => 404, + format => 'txt', + ); + return; + } + + my $jekyll = $c->jekyll($blog->domain->name); + my $config = $jekyll->config; + + my $config_text = $c->stash->{form_config} = $config->as_text; +} + +sub do_blog_config ( $c ) { + my $blog = $c->stash->{blog} = $c->db->blog( $c->param('id') ); + + if ( $blog->person->id ne $c->stash->{person}->id ) { + $c->render( + text => "Error: This blog isn't owned by you.", + status => 404, + format => 'txt', + ); + return; + } + + my $jekyll = $c->jekyll($blog->domain->name); + my $config = $jekyll->config; + + my $config_text = $c->stash->{form_config} = $c->param( 'blogConfig' ); + + $config->set_from_text( $config_text ); + + $jekyll->write_config; + + $c->flash( confirmation => "The config has been updated!!" ); + $c->redirect_to( $c->url_for( 'show_dashboard_blog_config', { id => $blog->id } ) ); +} + + + 1; diff --git a/Web/templates/dashboard/blog_config.html.ep b/Web/templates/dashboard/blog_config.html.ep new file mode 100644 index 0000000..0cfec02 --- /dev/null +++ b/Web/templates/dashboard/blog_config.html.ep @@ -0,0 +1,56 @@ +% layout 'standard', title => 'Dashboard', sb_active => 'dashboard'; + +%= include 'dashboard/_blog_nav' + +
+ +% if ( my $confirmation = flash 'confirmation' ) { +