aboutsummaryrefslogtreecommitdiffstats
path: root/app/views/refinery/blog
diff options
context:
space:
mode:
Diffstat (limited to 'app/views/refinery/blog')
-rw-r--r--app/views/refinery/blog/admin/_submenu.html.erb96
-rw-r--r--app/views/refinery/blog/admin/categories/_category.html.erb18
-rw-r--r--app/views/refinery/blog/admin/categories/_form.html.erb19
-rw-r--r--app/views/refinery/blog/admin/categories/_sortable_list.html.erb7
-rw-r--r--app/views/refinery/blog/admin/categories/edit.html.erb1
-rw-r--r--app/views/refinery/blog/admin/categories/index.html.erb27
-rw-r--r--app/views/refinery/blog/admin/categories/new.html.erb1
-rw-r--r--app/views/refinery/blog/admin/comments/_comment.html.erb20
-rw-r--r--app/views/refinery/blog/admin/comments/_sortable_list.html.erb7
-rw-r--r--app/views/refinery/blog/admin/comments/index.html.erb31
-rw-r--r--app/views/refinery/blog/admin/comments/show.html.erb63
-rw-r--r--app/views/refinery/blog/admin/posts/_form.html.erb116
-rw-r--r--app/views/refinery/blog/admin/posts/_form_part.html.erb3
-rw-r--r--app/views/refinery/blog/admin/posts/_post.html.erb21
-rw-r--r--app/views/refinery/blog/admin/posts/_sortable_list.html.erb7
-rw-r--r--app/views/refinery/blog/admin/posts/_teaser_part.html.erb11
-rw-r--r--app/views/refinery/blog/admin/posts/edit.html.erb1
-rw-r--r--app/views/refinery/blog/admin/posts/index.html.erb28
-rw-r--r--app/views/refinery/blog/admin/posts/new.html.erb1
-rw-r--r--app/views/refinery/blog/admin/posts/uncategorized.html.erb27
-rw-r--r--app/views/refinery/blog/admin/settings/notification_recipients.html.erb24
21 files changed, 529 insertions, 0 deletions
diff --git a/app/views/refinery/blog/admin/_submenu.html.erb b/app/views/refinery/blog/admin/_submenu.html.erb
new file mode 100644
index 0000000..d290ce8
--- /dev/null
+++ b/app/views/refinery/blog/admin/_submenu.html.erb
@@ -0,0 +1,96 @@
+<nav id='actions' class='multilist'>
+ <ul class='search_list'>
+ <li class='not_a_link'>
+ <%= render :partial => "/refinery/admin/search",
+ :locals => {
+ :url => main_app.refinery_blog_admin_posts_path
+ } %>
+ </li>
+ </ul>
+
+ <ul class='collapsible_menu'>
+ <li class='not_a_link'>
+ <%= link_to t('.posts.title'), '#',
+ :class => 'page_copy_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.posts.manage'), main_app.refinery_blog_admin_posts_path,
+ :class => 'page_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.posts.uncategorized'), main_app.uncategorized_refinery_blog_admin_posts_path,
+ :class => 'page_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.posts.new'), main_app.new_refinery_blog_admin_post_path,
+ :class => 'page_add_icon' %>
+ </li>
+ </ul>
+ <% if Refinery::Blog::Post.comments_allowed? %>
+ <ul class='collapsible_menu'>
+ <li class='not_a_link'>
+ <% if Refinery::Blog::Comment.unmoderated.any? %>
+ <% title = t('.comments.title_with_count', :new_count => Refinery::Blog::Comment.unmoderated.size) %>
+ <% else %>
+ <% title = t('.comments.title') %>
+ <% end %>
+ <%= link_to title, '#',
+ :class => 'comments_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.comments.new'), main_app.refinery_blog_admin_comments_path,
+ :class => 'comment_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.comments.approved'), main_app.approved_refinery_blog_admin_comments_path,
+ :class => 'comment_tick_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.comments.rejected'), main_app.rejected_refinery_blog_admin_comments_path,
+ :class => 'comment_cross_icon' %>
+ </li>
+ </ul>
+ <% end %>
+
+ <ul class='collapsible_menu'>
+ <li class='not_a_link'>
+ <%= link_to t('.categories.title'), '#',
+ :class => 'folder_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.categories.manage'), main_app.refinery_blog_admin_categories_path,
+ :class => 'folder_edit_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.categories.new'), main_app.new_refinery_blog_admin_category_path(:dialog => true, :height => 325),
+ :class => 'folder_add_icon' %>
+ </li>
+ </ul>
+
+ <ul class='collapsible_menu'>
+ <li class='not_a_link'>
+ <%= link_to t('.settings.title'), main_app.refinery_blog_admin_settings_path,
+ :class => 'settings_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.settings.comments'), main_app.comments_refinery_blog_admin_settings_path,
+ :class => "#{Refinery::Blog::Post.comments_allowed? ? 'success' : 'failure'}_icon" %>
+ </li>
+ <li>
+ <%= link_to t('.settings.moderation'), main_app.moderation_refinery_blog_admin_settings_path,
+ :class => "#{Refinery::Blog::Comment::Moderation.enabled? ? 'success' : 'failure'}_icon" %>
+ </li>
+ <li>
+ <%= link_to t('.settings.update_notified'),
+ main_app.notification_recipients_refinery_blog_admin_settings_path(:dialog => true, :height => 400),
+ :class => 'user_comment_icon' %>
+ </li>
+ <li>
+ <%= link_to t('.settings.teasers'),
+ main_app.teasers_refinery_blog_admin_settings_path, :class => "#{Refinery::Blog::Post.teasers_enabled? ? 'success' : 'failure'}_icon" %>
+ </li>
+ </ul>
+
+</nav>
+
+<% content_for :stylesheets, stylesheet_link_tag('refinery/blog/backend') %>
diff --git a/app/views/refinery/blog/admin/categories/_category.html.erb b/app/views/refinery/blog/admin/categories/_category.html.erb
new file mode 100644
index 0000000..d476439
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/_category.html.erb
@@ -0,0 +1,18 @@
+<li class='clearfix record <%= cycle("on", "on-hover") %>' id="<%= dom_id(category) -%>">
+ <span class='title'>
+ <%= category.title %>
+ <span class="preview">&nbsp;</span>
+ </span>
+ <span class='actions'>
+ <%= link_to refinery_icon_tag("application_edit.png"),
+ main_app.edit_refinery_blog_admin_category_path(category,
+ :dialog => true,
+ :height => 325),
+ :title => t('.edit') %>
+ <%= link_to refinery_icon_tag("delete.png"), main_app.refinery_blog_admin_category_path(category),
+ :class => "cancel confirm-delete",
+ :title => t('.delete'),
+ :method => :delete,
+ :confirm => t('message', :scope => 'refinery.admin.delete', :title => category.title) %>
+ </span>
+</li>
diff --git a/app/views/refinery/blog/admin/categories/_form.html.erb b/app/views/refinery/blog/admin/categories/_form.html.erb
new file mode 100644
index 0000000..a5d3de3
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/_form.html.erb
@@ -0,0 +1,19 @@
+<%= form_for [main_app, :refinery_admin, @blog_category] do |f| -%>
+ <%= render :partial => "/refinery/admin/error_messages",
+ :locals => {
+ :object => f.object,
+ :include_object_name => true
+ } %>
+
+ <div class='field'>
+ <%= f.label :title -%>
+ <%= f.text_field :title, :class => 'larger widest' -%>
+ </div>
+
+ <%= render :partial => "/refinery/admin/form_actions",
+ :locals => {
+ :f => f,
+ :continue_editing => false,
+ :delete_title => t('delete', :scope => 'refinery.admin.blog.categories.category')
+ } %>
+<% end %>
diff --git a/app/views/refinery/blog/admin/categories/_sortable_list.html.erb b/app/views/refinery/blog/admin/categories/_sortable_list.html.erb
new file mode 100644
index 0000000..f4e8641
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/_sortable_list.html.erb
@@ -0,0 +1,7 @@
+<ul id='sortable_list'>
+ <%= render :partial => 'category', :collection => @blog_categories %>
+</ul>
+<%= render :partial => "/refinery/admin/sortable_list",
+ :locals => {
+ :continue_reordering => (defined?(continue_reordering) ? continue_reordering : true)
+ } %>
diff --git a/app/views/refinery/blog/admin/categories/edit.html.erb b/app/views/refinery/blog/admin/categories/edit.html.erb
new file mode 100644
index 0000000..2872e82
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/edit.html.erb
@@ -0,0 +1 @@
+<%= render :partial => "form" %>
diff --git a/app/views/refinery/blog/admin/categories/index.html.erb b/app/views/refinery/blog/admin/categories/index.html.erb
new file mode 100644
index 0000000..4ad59ab
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/index.html.erb
@@ -0,0 +1,27 @@
+<%= render :partial => '/refinery/admin/blog/submenu' %>
+<div id='records'>
+ <% if searching? %>
+ <h2><%= t('results_for', :scope => 'refinery.admin.search',
+ :query => params[:search]) %></h2>
+ <% if @blog_categories.any? %>
+ <%= render :partial => "blog_categories",
+ :collection => @blog_categories %>
+ <% else %>
+ <p><%= t('no_results', :scope => 'refinery.admin.search') %></p>
+ <% end %>
+ <% else %>
+ <% if @blog_categories.any? %>
+ <%= will_paginate @blog_categories %>
+
+ <%= render :partial => "sortable_list" %>
+
+ <%= will_paginate @blog_categories %>
+ <% else %>
+ <p>
+ <strong>
+ <%= t('.no_items_yet', :create => t('new', :scope => 'refinery.admin.blog.submenu.categories')) %>
+ </strong>
+ </p>
+ <% end %>
+ <% end %>
+</div>
diff --git a/app/views/refinery/blog/admin/categories/new.html.erb b/app/views/refinery/blog/admin/categories/new.html.erb
new file mode 100644
index 0000000..2872e82
--- /dev/null
+++ b/app/views/refinery/blog/admin/categories/new.html.erb
@@ -0,0 +1 @@
+<%= render :partial => "form" %>
diff --git a/app/views/refinery/blog/admin/comments/_comment.html.erb b/app/views/refinery/blog/admin/comments/_comment.html.erb
new file mode 100644
index 0000000..51f2996
--- /dev/null
+++ b/app/views/refinery/blog/admin/comments/_comment.html.erb
@@ -0,0 +1,20 @@
+<li class='clearfix record <%= cycle("on", "on-hover") %>' id="<%= "comment-#{comment.to_param}" -%>">
+ <span class='title'>
+ <%= comment.name %>
+ <span class="preview"> - <%= truncate(comment.message, :length => 75) %></span>
+ </span>
+ <span class='actions'>
+ <%= link_to refinery_icon_tag("application_go.png"),
+ main_app.blog_post_path(comment.post, :anchor => "comment-#{comment.to_param}"),
+ :title => t('.view_live_html'),
+ :target => "_blank" unless comment.unmoderated? %>
+ <%= link_to refinery_icon_tag('zoom.png'), main_app.refinery_blog_admin_comment_path(comment),
+ :title => t('.read') %>
+ <%= link_to refinery_icon_tag("cross.png"),
+ main_app.rejected_refinery_blog_admin_comment_path(comment, :return_to => request.path.split('/').last.gsub(/^comments$/, 'index')),
+ :title => t('.reject') unless comment.rejected? %>
+ <%= link_to refinery_icon_tag("tick.png"),
+ main_app.approved_refinery_blog_admin_comment_path(comment, :return_to => request.path.split('/').last.gsub(/^comments$/, 'index')),
+ :title => t('.approve') unless comment.approved? %>
+ </span>
+</li>
diff --git a/app/views/refinery/blog/admin/comments/_sortable_list.html.erb b/app/views/refinery/blog/admin/comments/_sortable_list.html.erb
new file mode 100644
index 0000000..f781ba1
--- /dev/null
+++ b/app/views/refinery/blog/admin/comments/_sortable_list.html.erb
@@ -0,0 +1,7 @@
+<ul id='sortable_list'>
+ <%= render :partial => 'comment', :collection => @blog_comments %>
+</ul>
+<%= render :partial => "/refinery/admin/sortable_list",
+ :locals => {
+ :continue_reordering => (defined?(continue_reordering) ? continue_reordering : true)
+ } %>
diff --git a/app/views/refinery/blog/admin/comments/index.html.erb b/app/views/refinery/blog/admin/comments/index.html.erb
new file mode 100644
index 0000000..059ef59
--- /dev/null
+++ b/app/views/refinery/blog/admin/comments/index.html.erb
@@ -0,0 +1,31 @@
+<%= render :partial => '/refinery/admin/blog/submenu' %>
+<div id='records'>
+ <% if searching? %>
+ <h2><%= t('results_for', :scope => 'shared.admin.search', :query => params[:search]) %></h2>
+ <% if @blog_comments.any? %>
+ <%= will_paginate @blog_comments %>
+
+ <ul>
+ <%= render :partial => "blog_comments",
+ :collection => @blog_comments %>
+ </ul>
+
+ <%= will_paginate @blog_comments %>
+ <% else %>
+ <p><%= t('search_no_results', :scope => 'admin') %></p>
+ <% end %>
+ <% else %>
+ <% if @blog_comments.any? %>
+ <%= will_paginate @blog_comments %>
+
+ <%= render :partial => "sortable_list" %>
+
+ <%= will_paginate @blog_comments %>
+ <% else %>
+ <h3>
+ <%= t('.no_items_yet',
+ :type => action_name.gsub('index', 'new')).downcase %>
+ </h3>
+ <% end %>
+ <% end %>
+</div>
diff --git a/app/views/refinery/blog/admin/comments/show.html.erb b/app/views/refinery/blog/admin/comments/show.html.erb
new file mode 100644
index 0000000..2aa75f1
--- /dev/null
+++ b/app/views/refinery/blog/admin/comments/show.html.erb
@@ -0,0 +1,63 @@
+<div id='actions'>
+ <h2><%= t('.details')%></h2>
+ <p>
+ <strong><%= t('.age') %>:</strong> <%= time_ago_in_words(@blog_comment.created_at) %>
+ </p>
+ <h2><%= t('.actions') %></h2>
+ <ul>
+ <li>
+ <%= link_to t('.back'), main_app.refinery_blog_admin_comments_path, :class => "back_icon" %>
+ </li>
+ <li>
+ <%= link_to t('.reject'), main_app.rejected_refinery_blog_admin_comment_path(@blog_comment, :return_to => 'rejected'),
+ :class => 'comment_cross_icon' unless @blog_comment.rejected? %>
+ </li>
+ <li>
+ <%= link_to t('.approve'), main_app.approved_refinery_blog_admin_comment_path(@blog_comment, :return_to => 'approved'),
+ :class => 'comment_tick_icon' unless @blog_comment.approved? %>
+ </li>
+ </ul>
+</div>
+<div id='records'>
+ <h2><%= t('.comment') %></h2>
+ <table id='inquiry'>
+ <tr>
+ <td>
+ <strong><%= t('.blog_post') %></strong>
+ </td>
+ <td>
+ <%= link_to @blog_comment.post.title,
+ main_app.blog_post_path(@blog_comment.post, :anchor => "comment-#{@blog_comment.to_param}"),
+ :target => '_blank' %>
+ </td>
+ </tr>
+ <tr>
+ <td>
+ <strong><%= t('.from') %></strong>
+ </td>
+ <td>
+ <%= @blog_comment.name %> [<%= mail_to @blog_comment.email, @blog_comment.email, {:title => t('.click_to_email')} %>]
+ </td>
+ </tr>
+ <tr>
+ <td>
+ <strong><%= t('.date') %></strong>
+ </td>
+ <td>
+ <%= l(Date.parse(@blog_comment.created_at.to_s), :format => :long) %>
+ </td>
+ </tr>
+ <tr>
+ <td valign='top'>
+ <strong><%= t('.message') %></strong>
+ </td>
+ <td>
+ <p style='margin-top: 0px'>
+ <%= @blog_comment.message.gsub("\r\n\r\n", "\r\n").gsub("\r\n", "</p><p>") %>
+ </p>
+ </td>
+ </tr>
+ </table>
+</div>
+
+<% content_for :stylesheets, stylesheet_link_tag('refinery/blog/backend') %>
diff --git a/app/views/refinery/blog/admin/posts/_form.html.erb b/app/views/refinery/blog/admin/posts/_form.html.erb
new file mode 100644
index 0000000..656c9c6
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/_form.html.erb
@@ -0,0 +1,116 @@
+<%= form_for [main_app, :refinery_admin, @blog_post] do |f| -%>
+ <%= render :partial => "/refinery/admin/error_messages",
+ :locals => {
+ :object => f.object,
+ :include_object_name => true
+ } %>
+
+ <div class='field'>
+ <%= f.label :title -%>
+ <%= f.text_field :title, :class => 'larger widest' -%>
+ </div>
+
+ <div class='field'>
+ <div id='page-tabs' class='clearfix ui-tabs ui-widget ui-widget-content ui-corner-all'>
+ <ul id='page_parts'>
+ <li class='ui-state-default ui-state-active'>
+ <%= link_to t('body', :scope => 'activerecord.attributes.refinery/blog_post'), "#page_part_body" %>
+ </li>
+ <li class='ui-state-default'>
+ <%= link_to t('teaser', :scope => 'activerecord.attributes.refinery/blog_post'), "#page_part_teaser" %>
+ </li>
+ <% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
+ <li class='ui-state-default' id="custom_<%= tab.name %>_tab">
+ <%= link_to tab.name.titleize, "#custom_tab_#{tab_index}" %>
+ </li>
+ <% end %>
+ </ul>
+
+ <div id='page_part_editors'>
+ <% part_index = -1 %>
+ <%= render :partial => 'form_part',
+ :locals => {
+ :f => f,
+ :part_index => (part_index += 1),
+ } -%>
+ <%= render :partial => 'teaser_part',
+ :locals => {
+ :f => f,
+ :part_index => (part_index += 1),
+ } if f.object.respond_to?(:custom_teaser) -%>
+ <% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
+ <div class='page_part' id='<%= "custom_tab_#{tab_index}" %>'>
+ <%= render :partial => tab.partial, :locals => {:f => f} %>
+ </div>
+ <% end %>
+ </div>
+ </div>
+ </div>
+
+ <div class='field'>
+ <%= f.label :tag_list, t('refinery.blog.shared.tags.title') -%>
+ <%= f.text_field :tag_list, :class => 'larger' -%>
+ </div>
+
+ <div id='more_options_field'>
+ <p>
+ <%= link_to t('.advanced_options'), "#",
+ :id => 'toggle_advanced_options',
+ :title => t('.toggle_advanced_options') %>
+ </p>
+ <span id='draft_field'>
+ <%= f.check_box :draft %>
+ <%= f.label :draft, t('.save_as_draft'), :class => "stripped" %>
+ </span>
+ </div>
+ <div id='more_options' style="display:none;">
+ <div class="hemisquare">
+ <h3><%= t('title', :scope => 'refinery.admin.blog.submenu.categories') %></h3>
+ <ul class='blog_categories'>
+ <% @blog_categories.each do |category| %>
+ <li>
+ <%= check_box_tag 'blog_post[category_ids][]', category.id,
+ @blog_post.categories.include?(category),
+ :id => (id="blog_post_category_ids_#{category.id}") %>
+ <%= label_tag 'blog_post[category_ids][]', category.title,
+ :class => 'stripped',
+ :for => id %>
+ </li>
+ <% end %>
+ </ul>
+ <h3><%= t('.published_at') %></h3>
+ <%= f.datetime_select :published_at %>
+
+ <div class='field'>
+ <span class='label_with_help'>
+ <%= f.label :custom_url, t('.custom_url') %>
+ <%= refinery_help_tag t('.custom_url_help') %>
+ </span>
+ <%= f.text_field :custom_url, :class => "widest" %>
+ </div>
+
+ <div class='field'>
+ <span class='label_with_help'>
+ <%= f.label :user_id, t('.author') %>
+ <%= refinery_help_tag t('.author_help') %>
+ <br/>
+ <%= f.collection_select :user_id, ::Refinery::User.all, :id, :username %>
+ </span>
+ </div>
+
+ </div>
+ <div class='hemisquare right_side'>
+ <%= render :partial => '/seo_meta/form', :locals => {:form => f} %>
+ </div>
+ </div>
+ <%= render :partial => "/refinery/admin/form_actions",
+ :locals => {
+ :f => f,
+ :continue_editing => true,
+ :delete_title => t('delete', :scope => 'refinery.admin.blog.posts.post')
+ } %>
+<% end -%>
+
+<% content_for :stylesheets, stylesheet_link_tag('refinery/blog/backend') %>
+<% content_for :javascripts, javascript_include_tag('refinery/blog/backend') %>
+<%= render 'refinery/shared/admin/autocomplete', :dom_id => '#blog_post_tag_list', :url => main_app.tags_refinery_blog_admin_posts_url %>
diff --git a/app/views/refinery/blog/admin/posts/_form_part.html.erb b/app/views/refinery/blog/admin/posts/_form_part.html.erb
new file mode 100644
index 0000000..114e493
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/_form_part.html.erb
@@ -0,0 +1,3 @@
+<div class='page_part' id='page_part_body'>
+ <%= f.text_area :body, :rows => 20, :class => 'wymeditor widest' -%>
+</div>
diff --git a/app/views/refinery/blog/admin/posts/_post.html.erb b/app/views/refinery/blog/admin/posts/_post.html.erb
new file mode 100644
index 0000000..c8baa80
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/_post.html.erb
@@ -0,0 +1,21 @@
+<li class='clearfix record <%= cycle("on", "on-hover") %>' id="<%= dom_id(post) -%>">
+ <span class='title'>
+ <%= post.title %>
+ <span class="preview">
+ <%= post.published_at.try(:strftime, '%b %d, %Y') || 'draft' %>
+ <%= " by #{post.author.username}" if post.author.present? %>
+ </span>
+ </span>
+ <span class='actions'>
+ <%= link_to refinery_icon_tag("application_go.png"), main_app.blog_post_path(post),
+ :title => t('.view_live_html'),
+ :target => "_blank" %>
+ <%= link_to refinery_icon_tag("application_edit.png"), main_app.edit_refinery_blog_admin_post_path(post),
+ :title => t('.edit') %>
+ <%= link_to refinery_icon_tag("delete.png"), main_app.refinery_blog_admin_post_path(post),
+ :class => "cancel confirm-delete",
+ :title => t('.delete'),
+ :method => :delete,
+ :confirm => t('message', :scope => 'refinery.admin.delete', :title => post.title) %>
+ </span>
+</li>
diff --git a/app/views/refinery/blog/admin/posts/_sortable_list.html.erb b/app/views/refinery/blog/admin/posts/_sortable_list.html.erb
new file mode 100644
index 0000000..18d12cc
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/_sortable_list.html.erb
@@ -0,0 +1,7 @@
+<ul id='sortable_list'>
+ <%= render :partial => 'post', :collection => @blog_posts %>
+</ul>
+<%= render :partial => "/refinery/admin/sortable_list",
+ :locals => {
+ :continue_reordering => (defined?(continue_reordering) ? continue_reordering : true)
+ } %>
diff --git a/app/views/refinery/blog/admin/posts/_teaser_part.html.erb b/app/views/refinery/blog/admin/posts/_teaser_part.html.erb
new file mode 100644
index 0000000..dc9186a
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/_teaser_part.html.erb
@@ -0,0 +1,11 @@
+<div class='page_part' id='page_part_teaser'>
+ <%= f.text_area :custom_teaser, :rows => 20, :class => 'wymeditor widest' -%>
+ <p>
+ <span class='clearfix label_inline_with_link'>
+ <%= link_to t('copy_body', :scope => 'refinery.admin.blog.posts.form'), "#",
+ :id => 'copy_body_link',
+ :title => t('copy_body_help', :scope => 'refinery.admin.blog.posts.form') %>
+ </span>
+ </p>
+</div>
+
diff --git a/app/views/refinery/blog/admin/posts/edit.html.erb b/app/views/refinery/blog/admin/posts/edit.html.erb
new file mode 100644
index 0000000..2872e82
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/edit.html.erb
@@ -0,0 +1 @@
+<%= render :partial => "form" %>
diff --git a/app/views/refinery/blog/admin/posts/index.html.erb b/app/views/refinery/blog/admin/posts/index.html.erb
new file mode 100644
index 0000000..922353c
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/index.html.erb
@@ -0,0 +1,28 @@
+<%= render :partial => '/refinery/admin/blog/submenu' %>
+<div id='records'>
+ <% if searching? %>
+ <h2><%= t('results_for', :scope => 'refinery.admin.search', :query => params[:search]) %></h2>
+ <% if @blog_posts.any? %>
+ <ul>
+ <%= render :partial => "post",
+ :collection => @blog_posts %>
+ </ul>
+ <% else %>
+ <p><%= t('no_results', :scope => 'refinery.admin.search') %></p>
+ <% end %>
+ <% else %>
+ <% if @blog_posts.any? %>
+ <%= will_paginate @blog_posts %>
+
+ <%= render :partial => "sortable_list" %>
+
+ <%= will_paginate @blog_posts %>
+ <% else %>
+ <p>
+ <strong>
+ <%= t('.no_items_yet', :create => t('new', :scope => 'refinery.admin.blog.submenu.posts')) %>
+ </strong>
+ </p>
+ <% end %>
+ <% end %>
+</div>
diff --git a/app/views/refinery/blog/admin/posts/new.html.erb b/app/views/refinery/blog/admin/posts/new.html.erb
new file mode 100644
index 0000000..2872e82
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/new.html.erb
@@ -0,0 +1 @@
+<%= render :partial => "form" %>
diff --git a/app/views/refinery/blog/admin/posts/uncategorized.html.erb b/app/views/refinery/blog/admin/posts/uncategorized.html.erb
new file mode 100644
index 0000000..030e789
--- /dev/null
+++ b/app/views/refinery/blog/admin/posts/uncategorized.html.erb
@@ -0,0 +1,27 @@
+<%= render :partial => '/refinery/admin/blog/submenu' %>
+<div id='records'>
+ <% if searching? %>
+ <h2><%= t('results_for', :scope => 'refinery.admin.search',
+ :query => params[:search]) %></h2>
+ <% if @blog_posts.any? %>
+ <%= render :partial => "blog_posts",
+ :collection => @blog_posts %>
+ <% else %>
+ <p><%= t('no_results', :scope => 'refinery.admin.search') %></p>
+ <% end %>
+ <% else %>
+ <% if @blog_posts.any? %>
+ <%= will_paginate @blog_posts %>
+
+ <%= render :partial => "sortable_list" %>
+
+ <%= will_paginate @blog_posts %>
+ <% else %>
+ <p>
+ <strong>
+ <%= t('.no_items_yet') %>
+ </strong>
+ </p>
+ <% end %>
+ <% end %>
+</div>
diff --git a/app/views/refinery/blog/admin/settings/notification_recipients.html.erb b/app/views/refinery/blog/admin/settings/notification_recipients.html.erb
new file mode 100644
index 0000000..d321ded
--- /dev/null
+++ b/app/views/refinery/blog/admin/settings/notification_recipients.html.erb
@@ -0,0 +1,24 @@
+<%= form_tag do %>
+
+ <div class='field'>
+ <span class='label_with_help'>
+ <%= label_tag :recipients, t('.value') %>
+ </span>
+ <%= text_field_tag :recipients, @recipients, :class => "larger widest" %>
+ </div>
+
+ <p>
+ <%= t('.hint') %>
+ </p>
+ <p>
+ <%= t('.example') %>
+ </p>
+
+ <%= render :partial => "/refinery/admin/form_actions",
+ :locals => {
+ :f => nil,
+ :continue_editing => false,
+ :cancel_url => admin_blog_posts_url,
+ :hide_delete => true
+ } %>
+<% end %>