refinerycms-blog 2.0.4 → 4.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/.gitignore +6 -1
- data/.travis.yml +10 -14
- data/Gemfile +30 -50
- data/Rakefile +2 -1
- data/app/assets/javascripts/refinery/blog/backend.js +18 -59
- data/app/assets/stylesheets/refinery/blog/backend.css.scss +10 -61
- data/app/assets/stylesheets/refinery/blog/frontend.css.scss +87 -76
- data/app/controllers/refinery/blog/admin/categories_controller.rb +7 -1
- data/app/controllers/refinery/blog/admin/comments_controller.rb +19 -21
- data/app/controllers/refinery/blog/admin/posts_controller.rb +43 -15
- data/app/controllers/refinery/blog/blog_controller.rb +31 -5
- data/app/controllers/refinery/blog/categories_controller.rb +10 -3
- data/app/controllers/refinery/blog/posts_controller.rb +40 -26
- data/app/helpers/refinery/blog/controller_helper.rb +1 -22
- data/app/helpers/refinery/blog/posts_helper.rb +9 -4
- data/app/models/refinery/blog/categorization.rb +11 -0
- data/app/models/refinery/blog/category.rb +15 -5
- data/app/models/refinery/blog/comment.rb +17 -28
- data/app/models/refinery/blog/post.rb +100 -30
- data/app/views/refinery/blog/admin/_submenu.html.erb +1 -6
- data/app/views/refinery/blog/admin/categories/_category.html.erb +23 -10
- data/app/views/refinery/blog/admin/categories/_form.html.erb +10 -11
- data/app/views/refinery/blog/admin/categories/_sortable_list.html.erb +2 -4
- data/app/views/refinery/blog/admin/categories/edit.html.erb +1 -1
- data/app/views/refinery/blog/admin/categories/index.html.erb +9 -15
- data/app/views/refinery/blog/admin/categories/new.html.erb +1 -1
- data/app/views/refinery/blog/admin/comments/_comment.html.erb +4 -12
- data/app/views/refinery/blog/admin/comments/_sortable_list.html.erb +2 -4
- data/app/views/refinery/blog/admin/comments/index.html.erb +14 -23
- data/app/views/refinery/blog/admin/comments/show.html.erb +6 -4
- data/app/views/refinery/blog/admin/posts/_form.html.erb +31 -28
- data/app/views/refinery/blog/admin/posts/_form_part.html.erb +1 -1
- data/app/views/refinery/blog/admin/posts/_post.html.erb +28 -11
- data/app/views/refinery/blog/admin/posts/_sortable_list.html.erb +2 -4
- data/app/views/refinery/blog/admin/posts/_teaser_part.html.erb +1 -1
- data/app/views/refinery/blog/admin/posts/edit.html.erb +1 -1
- data/app/views/refinery/blog/admin/posts/index.html.erb +9 -15
- data/app/views/refinery/blog/admin/posts/new.html.erb +1 -1
- data/app/views/refinery/blog/admin/posts/uncategorized.html.erb +2 -2
- data/app/views/refinery/blog/admin/settings/notification_recipients.html.erb +5 -7
- data/app/views/refinery/blog/categories/show.html.erb +4 -4
- data/app/views/refinery/blog/comment_mailer/notification.html.erb +5 -0
- data/app/views/refinery/blog/posts/_comment.html.erb +4 -4
- data/app/views/refinery/blog/posts/_comments.html.erb +28 -31
- data/app/views/refinery/blog/posts/_nav.html.erb +6 -6
- data/app/views/refinery/blog/posts/_post.html.erb +9 -9
- data/app/views/refinery/blog/posts/archive.html.erb +7 -6
- data/app/views/refinery/blog/posts/index.html.erb +6 -6
- data/app/views/refinery/blog/posts/index.rss.builder +8 -2
- data/app/views/refinery/blog/posts/show.html.erb +5 -7
- data/app/views/refinery/blog/posts/tagged.html.erb +5 -5
- data/app/views/refinery/blog/shared/_body_content_right.html.erb +7 -7
- data/app/views/refinery/blog/shared/_categories.html.erb +4 -4
- data/app/views/refinery/blog/shared/_post.html.erb +18 -18
- data/app/views/refinery/blog/shared/_posts.html.erb +1 -1
- data/app/views/refinery/blog/shared/_rss_feed.html.erb +2 -0
- data/app/views/refinery/blog/shared/_tags.html.erb +1 -1
- data/app/views/refinery/shared/admin/_autocomplete.html.erb +44 -3
- data/bin/rails +11 -0
- data/bin/refinerycms +62 -0
- data/certs/parndt.pem +25 -0
- data/changelog.md +4 -1
- data/config/initializers/url_validator.rb +15 -11
- data/config/locales/bg.yml +8 -10
- data/config/locales/cs.yml +7 -9
- data/config/locales/de.yml +27 -8
- data/config/locales/en.yml +18 -12
- data/config/locales/es.yml +2 -4
- data/config/locales/fr.yml +34 -16
- data/config/locales/it.yml +8 -10
- data/config/locales/ja.yml +22 -11
- data/config/locales/nb.yml +154 -16
- data/config/locales/nl.yml +42 -7
- data/config/locales/pl.yml +6 -8
- data/config/locales/pt-BR.yml +39 -8
- data/config/locales/ru.yml +49 -5
- data/config/locales/sk.yml +59 -20
- data/config/locales/sv.yml +165 -0
- data/config/locales/uk.yml +172 -0
- data/config/locales/zh-CN.yml +34 -5
- data/config/locales/zh-TW.yml +160 -0
- data/config/routes.rb +11 -8
- data/db/migrate/20110803223522_create_blog_structure.rb +16 -15
- data/db/migrate/20110803223523_add_user_id_to_blog_posts.rb +3 -3
- data/db/migrate/20110803223524_acts_as_taggable_on_migration.rb +1 -1
- data/db/migrate/20110803223526_add_cached_slugs.rb +3 -3
- data/db/migrate/20110803223527_add_custom_url_field_to_blog_posts.rb +2 -2
- data/db/migrate/20110803223528_add_custom_teaser_field_to_blog_posts.rb +2 -2
- data/db/migrate/20110803223529_add_primary_key_to_categorizations.rb +5 -5
- data/db/migrate/20120103055909_add_source_url_to_blog_posts.rb +2 -2
- data/db/migrate/20120223022021_add_access_count_to_posts.rb +4 -4
- data/db/migrate/20120227022021_add_slug_to_posts_and_categories.rb +2 -2
- data/db/migrate/20120530102901_create_blog_translations.rb +17 -0
- data/db/migrate/20120531113632_delete_cached_slugs.rb +6 -0
- data/db/migrate/20120601151114_create_category_translations.rb +14 -0
- data/db/migrate/20140622132537_add_missing_unique_indices.acts_as_taggable_on_engine.rb +20 -0
- data/db/migrate/20140622132538_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +15 -0
- data/db/migrate/20160602042848_add_username_to_blog_posts.rb +5 -0
- data/db/migrate/20161223024527_create_multi_user_model.rb +13 -0
- data/db/migrate/20180420132008_remove_translated_columns_to_refinery_blog_categories.rb +5 -0
- data/db/seeds.rb +5 -5
- data/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb +6 -0
- data/lib/refinery/blog.rb +4 -1
- data/lib/refinery/blog/configuration.rb +25 -1
- data/lib/refinery/blog/engine.rb +9 -3
- data/readme.md +31 -5
- data/refinerycms-blog.gemspec +19 -15
- data/script/rails +1 -3
- data/spec/controllers/refinery/blog/admin/comments_controller_spec.rb +84 -0
- data/spec/controllers/refinery/blog/admin/posts_controller_spec.rb +35 -0
- data/spec/controllers/refinery/blog/posts_controller_spec.rb +24 -0
- data/spec/factories/blog_categories.rb +1 -1
- data/spec/factories/blog_comments.rb +1 -1
- data/spec/factories/blog_posts.rb +7 -3
- data/spec/factories/blog_test_users.rb +6 -0
- data/spec/features/refinery/blog/admin/categories_spec.rb +121 -0
- data/spec/{requests → features}/refinery/blog/admin/comments_spec.rb +30 -30
- data/spec/features/refinery/blog/admin/menu_spec.rb +19 -0
- data/spec/features/refinery/blog/admin/posts_spec.rb +365 -0
- data/spec/features/refinery/blog/categories_spec.rb +29 -0
- data/spec/features/refinery/blog/posts_spec.rb +171 -0
- data/spec/helpers/refinery/blog/posts_helper_spec.rb +23 -11
- data/spec/lib/refinery/blog/engine_spec.rb +1 -11
- data/spec/models/refinery/blog/category_spec.rb +18 -11
- data/spec/models/refinery/blog/comment_spec.rb +4 -4
- data/spec/models/refinery/blog/post_spec.rb +97 -60
- data/spec/spec_helper.rb +20 -46
- data/spec/support/refinery_blog_test_user.rb +2 -0
- metadata +168 -95
- metadata.gz.sig +0 -0
- data/Guardfile +0 -20
- data/app/assets/images/refinery/blog/icons/cog.png +0 -0
- data/app/assets/images/refinery/blog/icons/comment.png +0 -0
- data/app/assets/images/refinery/blog/icons/comment_cross.png +0 -0
- data/app/assets/images/refinery/blog/icons/comment_tick.png +0 -0
- data/app/assets/images/refinery/blog/icons/comments.png +0 -0
- data/app/assets/images/refinery/blog/icons/down.gif +0 -0
- data/app/assets/images/refinery/blog/icons/folder.png +0 -0
- data/app/assets/images/refinery/blog/icons/folder_add.png +0 -0
- data/app/assets/images/refinery/blog/icons/folder_edit.png +0 -0
- data/app/assets/images/refinery/blog/icons/page.png +0 -0
- data/app/assets/images/refinery/blog/icons/page_add.png +0 -0
- data/app/assets/images/refinery/blog/icons/page_copy.png +0 -0
- data/app/assets/images/refinery/blog/icons/up.gif +0 -0
- data/app/assets/images/refinerycms-blog/.gitkeep +0 -0
- data/app/assets/javascripts/refinerycms-blog/.gitkeep +0 -0
- data/app/assets/stylesheets/refinerycms-blog/.gitkeep +0 -0
- data/app/models/refinery/blog/comment_mailer.rb +0 -1
- data/app/models/refinery/categorization.rb +0 -10
- data/app/sweepers/refinery/blog_sweeper.rb +0 -26
- data/lib/refinery/blog/version.rb +0 -17
- data/spec/requests/refinery/blog/admin/categories_spec.rb +0 -20
- data/spec/requests/refinery/blog/admin/menu_spec.rb +0 -13
- data/spec/requests/refinery/blog/admin/posts_spec.rb +0 -175
- data/spec/requests/refinery/blog/categories_spec.rb +0 -24
- data/spec/requests/refinery/blog/posts_spec.rb +0 -160
- data/todo.md +0 -5
@@ -4,17 +4,9 @@
|
|
4
4
|
<span class="preview"> - <%= truncate(comment.message, :length => 75) %></span>
|
5
5
|
</span>
|
6
6
|
<span class='actions'>
|
7
|
-
<%=
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
<%= link_to refinery_icon_tag('zoom.png'), refinery.blog_admin_comment_path(comment),
|
12
|
-
:title => t('.read') %>
|
13
|
-
<%= link_to refinery_icon_tag("cross.png"),
|
14
|
-
refinery.rejected_blog_admin_comment_path(comment, :return_to => request.path.split('/').last.gsub(/^comments$/, 'index')),
|
15
|
-
:title => t('.reject') unless comment.rejected? %>
|
16
|
-
<%= link_to refinery_icon_tag("tick.png"),
|
17
|
-
refinery.approved_blog_admin_comment_path(comment, :return_to => request.path.split('/').last.gsub(/^comments$/, 'index')),
|
18
|
-
:title => t('.approve') unless comment.approved? %>
|
7
|
+
<%= action_icon(:preview, refinery.blog_post_path(comment.post, :anchor => "comment-#{comment.to_param}"), t('.view_live_html')) unless comment.unmoderated? %>
|
8
|
+
<%= action_icon(:search, refinery.blog_admin_comment_path(comment), t('.read')) %>
|
9
|
+
<%= action_icon(:failure, refinery.reject_blog_admin_comment_path(comment), t('.reject'), method: 'post') unless comment.rejected? %>
|
10
|
+
<%= action_icon(:success, refinery.approve_blog_admin_comment_path(comment), t('.approve'), method: 'post') unless comment.approved? %>
|
19
11
|
</span>
|
20
12
|
</li>
|
@@ -1,7 +1,5 @@
|
|
1
1
|
<ul id='sortable_list'>
|
2
2
|
<%= render :partial => 'comment', :collection => @comments %>
|
3
3
|
</ul>
|
4
|
-
<%= render
|
5
|
-
:
|
6
|
-
:continue_reordering => (defined?(continue_reordering) ? continue_reordering : true)
|
7
|
-
} %>
|
4
|
+
<%= render "/refinery/admin/sortable_list",
|
5
|
+
:continue_reordering => (defined?(continue_reordering) ? continue_reordering : true) %>
|
@@ -1,30 +1,21 @@
|
|
1
|
-
<%= render
|
1
|
+
<%= render 'refinery/blog/admin/submenu' %>
|
2
|
+
<%= render 'refinery/admin/search_header', :url => request.path %>
|
2
3
|
<div id='records'>
|
3
|
-
<% if
|
4
|
-
|
5
|
-
<% if @comments.any? %>
|
6
|
-
<%= will_paginate @comments %>
|
4
|
+
<% if @comments.any? %>
|
5
|
+
<%= will_paginate @comments %>
|
7
6
|
|
8
|
-
|
9
|
-
<%= render :partial => "blog_comments",
|
10
|
-
:collection => @comments %>
|
11
|
-
</ul>
|
7
|
+
<%= render "sortable_list" %>
|
12
8
|
|
13
|
-
|
14
|
-
<% else %>
|
15
|
-
<p><%= t('search_no_results', :scope => 'admin') %></p>
|
16
|
-
<% end %>
|
9
|
+
<%= will_paginate @comments %>
|
17
10
|
<% else %>
|
18
|
-
<% if
|
19
|
-
<%=
|
20
|
-
|
21
|
-
<%= render :partial => "sortable_list" %>
|
22
|
-
|
23
|
-
<%= will_paginate @comments %>
|
11
|
+
<% if searching? %>
|
12
|
+
<%= t('no_results', :scope => 'refinery.admin.search') %>
|
24
13
|
<% else %>
|
25
|
-
<
|
26
|
-
|
27
|
-
|
28
|
-
|
14
|
+
<p>
|
15
|
+
<strong>
|
16
|
+
<%= t('.no_items_yet', :type => action_name.gsub('index', 'new').downcase) %>
|
17
|
+
</strong>
|
18
|
+
</p>
|
29
19
|
<% end %>
|
20
|
+
<% end %>
|
30
21
|
</div>
|
@@ -9,12 +9,14 @@
|
|
9
9
|
<%= link_to t('.back'), refinery.blog_admin_comments_path, :class => "back_icon" %>
|
10
10
|
</li>
|
11
11
|
<li>
|
12
|
-
|
13
|
-
|
12
|
+
<%= link_to t('.reject'), refinery.reject_blog_admin_comment_path(@comment),
|
13
|
+
:method => :post,
|
14
|
+
:class => 'comment_cross_icon' unless @comment.rejected? %>
|
14
15
|
</li>
|
15
16
|
<li>
|
16
|
-
<%= link_to t('.approve'), refinery.
|
17
|
-
|
17
|
+
<%= link_to t('.approve'), refinery.approve_blog_admin_comment_path(@comment),
|
18
|
+
:method => :post,
|
19
|
+
:class => 'comment_tick_icon' unless @comment.approved? %>
|
18
20
|
</li>
|
19
21
|
</ul>
|
20
22
|
</div>
|
@@ -1,9 +1,10 @@
|
|
1
1
|
<%= form_for [refinery, :blog_admin, @post] do |f| -%>
|
2
|
-
<%= render
|
3
|
-
:
|
4
|
-
|
5
|
-
|
6
|
-
|
2
|
+
<%= render "/refinery/admin/error_messages",
|
3
|
+
:object => f.object,
|
4
|
+
:include_object_name => true %>
|
5
|
+
|
6
|
+
<%= render '/refinery/admin/locale_picker',
|
7
|
+
:current_locale => Globalize.locale %>
|
7
8
|
|
8
9
|
<div class='field'>
|
9
10
|
<%= f.label :title -%>
|
@@ -14,10 +15,10 @@
|
|
14
15
|
<div id='page-tabs' class='clearfix ui-tabs ui-widget ui-widget-content ui-corner-all'>
|
15
16
|
<ul id='page_parts'>
|
16
17
|
<li class='ui-state-default ui-state-active'>
|
17
|
-
<%= link_to t('body', :scope => 'activerecord.attributes.refinery/
|
18
|
+
<%= link_to t('body', :scope => 'activerecord.attributes.refinery/blog/post'), "#page_part_body" %>
|
18
19
|
</li>
|
19
20
|
<li class='ui-state-default'>
|
20
|
-
<%= link_to t('teaser', :scope => 'activerecord.attributes.refinery/
|
21
|
+
<%= link_to t('teaser', :scope => 'activerecord.attributes.refinery/blog/post'), "#page_part_teaser" %>
|
21
22
|
</li>
|
22
23
|
<% Refinery::Blog.tabs.each_with_index do |tab, tab_index| %>
|
23
24
|
<li class='ui-state-default' id="custom_<%= tab.name %>_tab">
|
@@ -41,21 +42,12 @@
|
|
41
42
|
|
42
43
|
<div class='field'>
|
43
44
|
<%= f.label :tag_list, t('refinery.blog.shared.tags.title') -%>
|
44
|
-
<%= f.text_field :tag_list, :class => 'larger' -%>
|
45
|
+
<%= f.text_field :tag_list, value: @post.tag_list.to_s, :class => 'larger' -%>
|
45
46
|
</div>
|
46
47
|
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
:id => 'toggle_advanced_options',
|
51
|
-
:title => t('.toggle_advanced_options') %>
|
52
|
-
</p>
|
53
|
-
<span id='draft_field'>
|
54
|
-
<%= f.check_box :draft %>
|
55
|
-
<%= f.label :draft, t('.save_as_draft'), :class => "stripped" %>
|
56
|
-
</span>
|
57
|
-
</div>
|
58
|
-
<div id='more_options' style="display:none;">
|
48
|
+
<%= render '/refinery/admin/form_advanced_options_menu', :f => f %>
|
49
|
+
|
50
|
+
<div id='more_options'>
|
59
51
|
<div class="hemisquare">
|
60
52
|
<h3><%= t('title', :scope => 'refinery.blog.admin.submenu.categories') %></h3>
|
61
53
|
<ul class='blog_categories'>
|
@@ -102,7 +94,11 @@
|
|
102
94
|
<%= f.label :user_id, t('.author') %>
|
103
95
|
<%= refinery_help_tag t('.author_help') %>
|
104
96
|
<br/>
|
105
|
-
|
97
|
+
<% if @authors.present? %>
|
98
|
+
<%= f.collection_select :user_id, @authors, :id, :username %>
|
99
|
+
<% else %>
|
100
|
+
<%= f.text_field :username, id: :post_user_id, :class => "widest" %>
|
101
|
+
<% end %>
|
106
102
|
</span>
|
107
103
|
</div>
|
108
104
|
|
@@ -111,14 +107,21 @@
|
|
111
107
|
<%= render '/seo_meta/form', :form => f %>
|
112
108
|
</div>
|
113
109
|
</div>
|
114
|
-
<%= render
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
110
|
+
<%= render "/refinery/admin/form_actions",
|
111
|
+
:f => f,
|
112
|
+
:continue_editing => true,
|
113
|
+
:delete_title => t('delete', :scope => 'refinery.blog.admin.posts.post'),
|
114
|
+
:before_delete_button => (link_to(t('delete_translation', :scope => 'refinery.blog.admin.posts.post'),
|
115
|
+
refinery.delete_translation_blog_admin_post_path(@post, :locale_to_delete => Globalize.locale),
|
116
|
+
:method => :post,
|
117
|
+
:data => {
|
118
|
+
:confirm => t('delete_translation_confirmation', :scope => 'refinery.blog.admin.posts.post')
|
119
|
+
},
|
120
|
+
:class => "button confirm-delete") if Refinery::I18n.frontend_locales.many? && @post.translations.size > 1) %>
|
120
121
|
<% end -%>
|
121
122
|
|
122
123
|
<% content_for :stylesheets, stylesheet_link_tag('refinery/blog/backend') %>
|
123
124
|
<% content_for :javascripts, javascript_include_tag('refinery/blog/backend') %>
|
124
|
-
<%= render 'refinery/shared/admin/autocomplete',
|
125
|
+
<%= render 'refinery/shared/admin/autocomplete',
|
126
|
+
:dom_id => '#post_tag_list',
|
127
|
+
:url => refinery.tags_blog_admin_posts_url %>
|
@@ -1,21 +1,38 @@
|
|
1
1
|
<li class='clearfix record <%= cycle("on", "on-hover") %>' id="<%= dom_id(post) -%>">
|
2
2
|
<span class='title'>
|
3
|
-
<%= post.title %>
|
3
|
+
<%= post.title.presence || post.translations.detect {|t| t.title.present?}.title %>
|
4
4
|
<span class="preview">
|
5
|
+
<% if Refinery::I18n.frontend_locales.many? %>
|
6
|
+
<span class='locales'>
|
7
|
+
<% post.translations.sort_by{ |t| Refinery::I18n.frontend_locales.index(t.locale)}.each do |translation| %>
|
8
|
+
<% if translation.title.present? %>
|
9
|
+
<%= link_to refinery.edit_blog_admin_post_path(post, :switch_locale => translation.locale), :class => 'locale', title: translation.locale.upcase do %>
|
10
|
+
|
11
|
+
<div class="<%=translation.locale %> locale_marker">
|
12
|
+
<%= locale_text_icon(translation.locale.upcase) %>
|
13
|
+
</div>
|
14
|
+
<% end %>
|
15
|
+
<% end %>
|
16
|
+
<% end %>
|
17
|
+
</span>
|
18
|
+
<% end %>
|
19
|
+
|
5
20
|
<%= post.published_at.try(:strftime, '%b %d, %Y') || 'draft' %>
|
6
21
|
<%= " by #{post.author.username}" if post.author.present? %>
|
22
|
+
<% if post.draft? %>
|
23
|
+
<span class="label notice"><%= t('refinery.blog.admin.posts.post.draft') %></span>
|
24
|
+
<% else %>
|
25
|
+
<%= post.published_at.strftime('%b %d, %Y') %>
|
26
|
+
<% end %>
|
7
27
|
</span>
|
8
28
|
</span>
|
9
29
|
<span class='actions'>
|
10
|
-
<%=
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
<%= link_to refinery_icon_tag("delete.png"), refinery.blog_admin_post_path(post),
|
16
|
-
:class => "cancel confirm-delete",
|
17
|
-
:title => t('.delete'),
|
18
|
-
:method => :delete,
|
19
|
-
:confirm => t('message', :scope => 'refinery.admin.delete', :title => post.title) %>
|
30
|
+
<%= action_icon(:preview, refinery.blog_post_path(post), t('.view_live_html')) %>
|
31
|
+
<%= action_icon(:edit, refinery.edit_blog_admin_post_path(post), t('.edit') ) %>
|
32
|
+
<%= action_icon(:delete, refinery.blog_admin_post_path(post), t('.delete'),
|
33
|
+
{ class: "cancel confirm-delete",
|
34
|
+
data: {confirm: t('message', scope: 'refinery.admin.delete', title: post.title)}} ) %>
|
20
35
|
</span>
|
21
36
|
</li>
|
37
|
+
|
38
|
+
|
@@ -1,7 +1,5 @@
|
|
1
1
|
<ul id='sortable_list'>
|
2
2
|
<%= render :partial => 'post', :collection => @posts %>
|
3
3
|
</ul>
|
4
|
-
<%= render
|
5
|
-
:
|
6
|
-
:continue_reordering => (defined?(continue_reordering) ? continue_reordering : true)
|
7
|
-
} %>
|
4
|
+
<%= render "/refinery/admin/sortable_list",
|
5
|
+
:continue_reordering => (defined?(continue_reordering) ? continue_reordering : true) %>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
<div class='page_part' id='page_part_teaser'>
|
2
|
-
<%= f.text_area :custom_teaser, :rows => 20, :class => '
|
2
|
+
<%= f.text_area :custom_teaser, :rows => 20, :class => 'visual_editor widest' -%>
|
3
3
|
<p>
|
4
4
|
<span class='clearfix label_inline_with_link'>
|
5
5
|
<%= link_to t('copy_body', :scope => 'refinery.blog.admin.posts.form'), "#",
|
@@ -1 +1 @@
|
|
1
|
-
<%= render
|
1
|
+
<%= render "form" %>
|
@@ -1,21 +1,15 @@
|
|
1
|
-
<%= render
|
1
|
+
<%= render '/refinery/blog/admin/submenu' %>
|
2
|
+
<%= render 'refinery/admin/search_header', :url => request.path %>
|
2
3
|
<div id='records'>
|
3
|
-
<% if
|
4
|
-
|
5
|
-
<% if @posts.any? %>
|
6
|
-
<ul>
|
7
|
-
<%= render :partial => "post", :collection => @posts %>
|
8
|
-
</ul>
|
9
|
-
<% else %>
|
10
|
-
<p><%= t('no_results', :scope => 'refinery.admin.search') %></p>
|
11
|
-
<% end %>
|
12
|
-
<% else %>
|
13
|
-
<% if @posts.any? %>
|
14
|
-
<%= will_paginate @posts %>
|
4
|
+
<% if @posts.any? %>
|
5
|
+
<%= will_paginate @posts %>
|
15
6
|
|
16
|
-
|
7
|
+
<%= render "sortable_list" %>
|
17
8
|
|
18
|
-
|
9
|
+
<%= will_paginate @posts %>
|
10
|
+
<% else %>
|
11
|
+
<% if searching? %>
|
12
|
+
<%= t('no_results', :scope => 'refinery.admin.search') %>
|
19
13
|
<% else %>
|
20
14
|
<p>
|
21
15
|
<strong>
|
@@ -1 +1 @@
|
|
1
|
-
<%= render
|
1
|
+
<%= render "form" %>
|
@@ -1,4 +1,4 @@
|
|
1
|
-
<%= render
|
1
|
+
<%= render '/refinery/blog/admin/submenu' %>
|
2
2
|
<div id='records'>
|
3
3
|
<% if searching? %>
|
4
4
|
<h2><%= t('results_for', :scope => 'refinery.admin.search',
|
@@ -13,7 +13,7 @@
|
|
13
13
|
<% if @posts.any? %>
|
14
14
|
<%= will_paginate @posts %>
|
15
15
|
|
16
|
-
<%= render
|
16
|
+
<%= render "sortable_list" %>
|
17
17
|
|
18
18
|
<%= will_paginate @posts %>
|
19
19
|
<% else %>
|
@@ -14,11 +14,9 @@
|
|
14
14
|
<%= t('.example') %>
|
15
15
|
</p>
|
16
16
|
|
17
|
-
<%= render
|
18
|
-
:
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
:hide_delete => true
|
23
|
-
} %>
|
17
|
+
<%= render "/refinery/admin/form_actions",
|
18
|
+
:f => nil,
|
19
|
+
:continue_editing => false,
|
20
|
+
:cancel_url => refinery.blog_admin_posts_url,
|
21
|
+
:hide_delete => true %>
|
24
22
|
<% end %>
|
@@ -1,6 +1,6 @@
|
|
1
1
|
<% content_for :body_content_title, @category.title %>
|
2
2
|
|
3
|
-
<% content_for :
|
3
|
+
<% content_for :body do %>
|
4
4
|
<% if @posts.any? %>
|
5
5
|
<section id="blog_posts">
|
6
6
|
<%= render :partial => "/refinery/blog/shared/post", :collection => @posts %>
|
@@ -13,9 +13,9 @@
|
|
13
13
|
<% end %>
|
14
14
|
<% end %>
|
15
15
|
|
16
|
-
<% content_for :
|
17
|
-
<%= render
|
16
|
+
<% content_for :side_body do %>
|
17
|
+
<%= render "/refinery/blog/shared/categories" %>
|
18
18
|
<% end %>
|
19
19
|
|
20
|
-
<%= render
|
20
|
+
<%= render "/refinery/content_page" %>
|
21
21
|
<% content_for :stylesheets, stylesheet_link_tag('refinery/blog/frontend') %>
|
@@ -11,6 +11,11 @@
|
|
11
11
|
|
12
12
|
<%=raw t('.comment_ends') %>
|
13
13
|
|
14
|
+
<%=raw link_to t('.approve'), refinery.approve_blog_admin_comment_url(@comment) -%>
|
15
|
+
<%=raw t('.or') -%>
|
16
|
+
<%=raw link_to t('.reject'), refinery.reject_blog_admin_comment_url(@comment) -%>
|
17
|
+
<%=raw t('.this_comment') %>
|
18
|
+
|
14
19
|
<%=raw t('.closing_line') %>,
|
15
20
|
<%=raw Refinery::Core.site_name %>
|
16
21
|
|
@@ -1,10 +1,10 @@
|
|
1
|
-
|
2
|
-
<%= image_tag comment.
|
1
|
+
<%= content_tag(:article, class: "blog_comment_message", id: ("comment-#{comment.to_param}")) do %>
|
2
|
+
<%= image_tag avatar_url(comment.email), :alt => comment.name, :class => 'avatar' %>
|
3
3
|
<%= simple_format auto_link(comment.message.to_s) %>
|
4
|
-
<footer class=
|
4
|
+
<footer class="blog_comment_author">
|
5
5
|
<p>
|
6
6
|
<%= t('by', :scope => 'refinery.blog.posts.comments', :who => comment.name) %>,
|
7
7
|
<%= t('time_ago', :scope => 'refinery.blog.posts.comments', :time => time_ago_in_words(comment.created_at)) %>
|
8
8
|
</p>
|
9
9
|
</footer>
|
10
|
-
|
10
|
+
<% end %>
|
@@ -1,40 +1,37 @@
|
|
1
1
|
<aside id="comments">
|
2
|
-
<h2><%= t('title', :scope => 'refinery.blog.posts.show.comments') %></h2>
|
3
2
|
<% if (comments = @post.comments.approved).any? %>
|
3
|
+
<h2><%= t('title', :scope => 'refinery.blog.posts.show.comments') %></h2>
|
4
4
|
<%= render :partial => "comment", :collection => comments %>
|
5
|
-
<% else %>
|
6
|
-
<p>
|
7
|
-
<%= t('none', :scope => 'refinery.blog.shared.comments') %>.
|
8
|
-
</p>
|
9
5
|
<% end %>
|
10
6
|
|
11
|
-
<%
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
7
|
+
<% if Refinery::Blog::Post.comments_allowed? %>
|
8
|
+
|
9
|
+
<% flash.each do |key, value| %>
|
10
|
+
<div id="flash" class="flash flash_<%= key %>">
|
11
|
+
<%= value %>
|
12
|
+
</div>
|
13
|
+
<% end %>
|
16
14
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
:locals => {
|
15
|
+
<h2><%= t('add', :scope => 'refinery.blog.posts.show.comments') %></h2>
|
16
|
+
<%= form_for [refinery, :blog, @comment] do |f| %>
|
17
|
+
<%= render "/refinery/admin/error_messages",
|
21
18
|
:object => f.object,
|
22
|
-
:include_object_name => true
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
19
|
+
:include_object_name => true %>
|
20
|
+
<div class="field">
|
21
|
+
<%= f.label :name %>
|
22
|
+
<%= f.text_field :name %>
|
23
|
+
</div>
|
24
|
+
<div class="field">
|
25
|
+
<%= f.label :email %>
|
26
|
+
<%= f.email_field :email %>
|
27
|
+
</div>
|
28
|
+
<div class="field message_field">
|
29
|
+
<%= f.label :message %>
|
30
|
+
<%= f.text_area :message, :rows => 6 %>
|
31
|
+
</div>
|
32
|
+
<div class="field form-actions">
|
33
|
+
<%= f.submit t('submit', :scope => 'refinery.blog.posts.show') %>
|
34
|
+
</div>
|
35
|
+
<% end %>
|
39
36
|
<% end %>
|
40
37
|
</aside>
|