refinerycms-blog 1.8.0 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +54 -0
- data/.rspec +3 -0
- data/.travis.yml +18 -0
- data/Gemfile +68 -5
- data/Guardfile +20 -0
- data/Rakefile +21 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/cog.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/comment.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/comment_cross.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/comment_tick.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/comments.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/down.gif +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/folder.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/folder_add.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/folder_edit.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/page.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/page_add.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/page_copy.png +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/icons/up.gif +0 -0
- data/{public/images/refinerycms-blog → app/assets/images/refinery/blog}/rss-feed.png +0 -0
- data/app/assets/images/refinerycms-blog/.gitkeep +0 -0
- data/{public/javascripts/refinery/refinerycms-blog.js → app/assets/javascripts/refinery/blog/backend.js} +66 -1
- data/{public/javascripts/refinerycms-blog.js → app/assets/javascripts/refinery/blog/frontend.js} +0 -0
- data/app/assets/javascripts/refinerycms-blog/.gitkeep +0 -0
- data/app/assets/stylesheets/refinery/blog/backend.css.scss +73 -0
- data/{public/stylesheets/refinerycms-blog.css → app/assets/stylesheets/refinery/blog/frontend.css.scss} +3 -3
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_flat_10_000000_40x100.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-icons_222222_256x240.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-icons_228ef1_256x240.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-icons_ef8c08_256x240.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-icons_ffd27a_256x240.png +0 -0
- data/{public/stylesheets → app/assets/stylesheets/refinery/blog}/ui-lightness/images/ui-icons_ffffff_256x240.png +0 -0
- data/{public/stylesheets/ui-lightness/jquery-ui-1.8.13.custom.css → app/assets/stylesheets/refinery/blog/ui-lightness/jquery-ui-1.8.13.custom.css.scss} +0 -0
- data/app/assets/stylesheets/refinerycms-blog/.gitkeep +0 -0
- data/app/controllers/.gitkeep +0 -0
- data/app/controllers/refinery/blog/admin/categories_controller.rb +12 -0
- data/app/controllers/refinery/blog/admin/comments_controller.rb +49 -0
- data/app/controllers/refinery/blog/admin/posts_controller.rb +90 -0
- data/app/controllers/refinery/blog/admin/settings_controller.rb +55 -0
- data/app/controllers/refinery/blog/blog_controller.rb +17 -0
- data/app/controllers/refinery/blog/categories_controller.rb +12 -0
- data/app/controllers/refinery/blog/posts_controller.rb +84 -0
- data/app/helpers/.gitkeep +0 -0
- data/app/helpers/refinery/blog/controller_helper.rb +29 -0
- data/app/helpers/refinery/blog/posts_helper.rb +72 -0
- data/app/mailers/refinery/blog/comment_mailer.rb +14 -0
- data/app/models/.gitkeep +0 -0
- data/app/models/refinery/blog/category.rb +23 -0
- data/app/models/refinery/blog/comment.rb +135 -0
- data/app/models/refinery/blog/comment_mailer.rb +1 -0
- data/app/models/refinery/blog/post.rb +115 -0
- data/app/models/refinery/categorization.rb +9 -0
- data/app/sweepers/refinery/blog_sweeper.rb +26 -0
- data/app/views/.gitkeep +0 -0
- data/app/views/{admin/blog → refinery/blog/admin}/_submenu.html.erb +21 -21
- data/app/views/{admin/blog → refinery/blog/admin}/categories/_category.html.erb +3 -3
- data/app/views/{admin/blog → refinery/blog/admin}/categories/_form.html.erb +4 -4
- data/app/views/{admin/blog/comments → refinery/blog/admin/categories}/_sortable_list.html.erb +2 -2
- data/app/views/{admin/blog → refinery/blog/admin}/categories/edit.html.erb +0 -0
- data/app/views/refinery/blog/admin/categories/index.html.erb +27 -0
- data/app/views/{admin/blog → refinery/blog/admin}/categories/new.html.erb +0 -0
- data/app/views/{admin/blog → refinery/blog/admin}/comments/_comment.html.erb +4 -4
- data/app/views/{admin/blog/categories → refinery/blog/admin/comments}/_sortable_list.html.erb +2 -2
- data/app/views/refinery/blog/admin/comments/index.html.erb +30 -0
- data/app/views/refinery/blog/admin/comments/show.html.erb +63 -0
- data/app/views/{admin/blog → refinery/blog/admin}/posts/_form.html.erb +53 -39
- data/app/views/{admin/blog → refinery/blog/admin}/posts/_form_part.html.erb +0 -0
- data/app/views/{admin/blog → refinery/blog/admin}/posts/_post.html.erb +4 -7
- data/app/views/{admin/blog → refinery/blog/admin}/posts/_sortable_list.html.erb +2 -2
- data/app/views/{admin/blog → refinery/blog/admin}/posts/_teaser_part.html.erb +2 -2
- data/app/views/{admin/blog → refinery/blog/admin}/posts/edit.html.erb +0 -0
- data/app/views/refinery/blog/admin/posts/index.html.erb +27 -0
- data/app/views/{admin/blog → refinery/blog/admin}/posts/new.html.erb +0 -0
- data/app/views/refinery/blog/admin/posts/uncategorized.html.erb +27 -0
- data/app/views/{admin/blog → refinery/blog/admin}/settings/notification_recipients.html.erb +3 -3
- data/app/views/refinery/blog/categories/show.html.erb +21 -0
- data/app/views/{blog → refinery/blog}/comment_mailer/notification.html.erb +1 -1
- data/app/views/{blog → refinery/blog}/posts/_comment.html.erb +2 -2
- data/app/views/refinery/blog/posts/_comments.html.erb +40 -0
- data/app/views/refinery/blog/posts/_nav.html.erb +17 -0
- data/app/views/refinery/blog/posts/_post.html.erb +37 -0
- data/app/views/refinery/blog/posts/archive.html.erb +17 -0
- data/app/views/refinery/blog/posts/index.html.erb +20 -0
- data/app/views/refinery/blog/posts/index.rss.builder +17 -0
- data/app/views/refinery/blog/posts/show.html.erb +21 -0
- data/app/views/refinery/blog/posts/tagged.html.erb +19 -0
- data/app/views/refinery/blog/shared/_body_content_right.html.erb +9 -0
- data/app/views/{blog → refinery/blog}/shared/_categories.html.erb +3 -3
- data/app/views/{blog → refinery/blog}/shared/_post.html.erb +11 -11
- data/app/views/refinery/blog/shared/_posts.html.erb +10 -0
- data/app/views/refinery/blog/shared/_rss_feed.html.erb +2 -0
- data/app/views/{blog → refinery/blog}/shared/_tags.html.erb +1 -1
- data/app/views/refinery/blog/widgets/_blog_archive.html.erb +10 -0
- data/app/views/refinery/shared/admin/_autocomplete.html.erb +5 -0
- data/changelog.md +2 -18
- data/config/initializers/url_validator.rb +84 -0
- data/config/locales/bg.yml +139 -139
- data/config/locales/cs.yml +119 -119
- data/config/locales/de.yml +121 -121
- data/config/locales/en.yml +147 -140
- data/config/locales/es.yml +119 -150
- data/config/locales/fr.yml +136 -136
- data/config/locales/it.yml +139 -139
- data/config/locales/ja.yml +2 -3
- data/config/locales/nb.yml +28 -27
- data/config/locales/nl.yml +125 -125
- data/config/locales/pl.yml +125 -125
- data/config/locales/pt-BR.yml +129 -134
- data/config/locales/ru.yml +119 -126
- data/config/locales/sk.yml +119 -119
- data/config/locales/zh-CN.yml +119 -119
- data/config/routes.rb +37 -33
- data/db/migrate/20110803223522_create_blog_structure.rb +52 -0
- data/db/migrate/20110803223523_add_user_id_to_blog_posts.rb +7 -0
- data/db/migrate/{3_acts_as_taggable_on_migration.rb → 20110803223524_acts_as_taggable_on_migration.rb} +2 -2
- data/db/migrate/20110803223526_add_cached_slugs.rb +6 -0
- data/db/migrate/20110803223527_add_custom_url_field_to_blog_posts.rb +5 -0
- data/db/migrate/20110803223528_add_custom_teaser_field_to_blog_posts.rb +6 -0
- data/db/migrate/20110803223529_add_primary_key_to_categorizations.rb +14 -0
- data/db/migrate/20120103055909_add_source_url_to_blog_posts.rb +7 -0
- data/db/migrate/20120223022021_add_access_count_to_posts.rb +8 -0
- data/db/migrate/20120227022021_add_slug_to_posts_and_categories.rb +9 -0
- data/db/{seeds/refinerycms_blog.rb → seeds.rb} +6 -7
- data/lib/generators/refinery/blog/blog_generator.rb +27 -0
- data/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb +11 -0
- data/lib/refinery/blog.rb +37 -0
- data/lib/refinery/blog/configuration.rb +14 -0
- data/lib/refinery/blog/engine.rb +25 -0
- data/lib/refinery/blog/tabs.rb +5 -11
- data/lib/refinery/blog/version.rb +3 -3
- data/lib/refinerycms-blog.rb +1 -41
- data/readme.md +24 -15
- data/refinerycms-blog.gemspec +19 -196
- data/script/rails +6 -0
- data/spec/factories/blog_categories.rb +5 -0
- data/spec/factories/blog_comments.rb +19 -0
- data/spec/factories/blog_posts.rb +13 -0
- data/spec/helpers/refinery/blog/posts_helper_spec.rb +71 -0
- data/spec/lib/refinery/blog/engine_spec.rb +26 -0
- data/spec/models/refinery/blog/category_spec.rb +42 -0
- data/spec/models/refinery/blog/comment_spec.rb +19 -0
- data/spec/models/refinery/blog/post_spec.rb +233 -0
- data/spec/requests/refinery/blog/admin/categories_spec.rb +20 -0
- data/spec/requests/refinery/blog/admin/comments_spec.rb +121 -0
- data/spec/requests/refinery/blog/admin/menu_spec.rb +13 -0
- data/spec/requests/refinery/blog/admin/posts_spec.rb +175 -0
- data/spec/requests/refinery/blog/categories_spec.rb +24 -0
- data/spec/requests/refinery/blog/posts_spec.rb +160 -0
- data/spec/spec_helper.rb +56 -0
- data/tasks/rspec.rake +4 -0
- data/tasks/testing.rake +9 -0
- metadata +281 -170
- data/app/controllers/admin/blog/categories_controller.rb +0 -11
- data/app/controllers/admin/blog/comments_controller.rb +0 -40
- data/app/controllers/admin/blog/posts_controller.rb +0 -97
- data/app/controllers/admin/blog/settings_controller.rb +0 -53
- data/app/controllers/blog/categories_controller.rb +0 -13
- data/app/controllers/blog/posts_controller.rb +0 -109
- data/app/controllers/blog_controller.rb +0 -16
- data/app/helpers/blog_posts_helper.rb +0 -56
- data/app/mailers/blog/comment_mailer.rb +0 -13
- data/app/models/blog/comment_mailer.rb +0 -1
- data/app/models/blog_category.rb +0 -19
- data/app/models/blog_comment.rb +0 -137
- data/app/models/blog_post.rb +0 -114
- data/app/models/categorization.rb +0 -7
- data/app/views/admin/blog/categories/index.html.erb +0 -26
- data/app/views/admin/blog/comments/index.html.erb +0 -35
- data/app/views/admin/blog/comments/show.html.erb +0 -63
- data/app/views/admin/blog/posts/_form.css.erb +0 -20
- data/app/views/admin/blog/posts/_form.js.erb +0 -23
- data/app/views/admin/blog/posts/index.html.erb +0 -28
- data/app/views/admin/blog/posts/uncategorized.html.erb +0 -26
- data/app/views/blog/categories/show.html.erb +0 -21
- data/app/views/blog/posts/_nav.html.erb +0 -11
- data/app/views/blog/posts/archive.html.erb +0 -20
- data/app/views/blog/posts/index.html.erb +0 -24
- data/app/views/blog/posts/index.rss.builder +0 -17
- data/app/views/blog/posts/show.html.erb +0 -98
- data/app/views/blog/posts/tagged.html.erb +0 -22
- data/app/views/blog/shared/_archive_list.html.erb +0 -9
- data/app/views/blog/shared/_related_posts.html.erb +0 -10
- data/app/views/blog/shared/_rss_feed.html.erb +0 -2
- data/app/views/shared/admin/_autocomplete.html.erb +0 -55
- data/db/migrate/1_create_blog_structure.rb +0 -54
- data/db/migrate/2_add_user_id_to_blog_posts.rb +0 -11
- data/db/migrate/4_create_seo_meta_for_blog.rb +0 -25
- data/db/migrate/5_add_cached_slugs.rb +0 -11
- data/db/migrate/6_add_custom_url_field_to_blog_posts.rb +0 -9
- data/db/migrate/7_add_custom_teaser_field_to_blog_posts.rb +0 -10
- data/db/migrate/8_add_primary_key_to_categorizations.rb +0 -12
- data/features/authors.feature +0 -15
- data/features/category.feature +0 -23
- data/features/support/factories/blog_categories.rb +0 -5
- data/features/support/factories/blog_comments.rb +0 -8
- data/features/support/factories/blog_posts.rb +0 -9
- data/features/support/paths.rb +0 -24
- data/features/support/step_definitions/authors_steps.rb +0 -7
- data/features/support/step_definitions/category_steps.rb +0 -11
- data/features/support/step_definitions/tags_steps.rb +0 -13
- data/features/tags.feature +0 -26
- data/lib/gemspec.rb +0 -37
- data/lib/generators/refinerycms_blog_generator.rb +0 -8
- data/public/stylesheets/refinery/refinerycms-blog.css +0 -55
- data/spec/models/blog_category_spec.rb +0 -41
- data/spec/models/blog_comment_spec.rb +0 -21
- data/spec/models/blog_post_spec.rb +0 -217
@@ -0,0 +1,49 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
module Admin
|
4
|
+
class CommentsController < ::Refinery::AdminController
|
5
|
+
|
6
|
+
cache_sweeper Refinery::BlogSweeper
|
7
|
+
|
8
|
+
crudify :'refinery/blog/comment',
|
9
|
+
:title_attribute => :name,
|
10
|
+
:order => 'published_at DESC'
|
11
|
+
|
12
|
+
def index
|
13
|
+
@comments = Refinery::Blog::Comment.unmoderated.page(params[:page])
|
14
|
+
|
15
|
+
render :action => 'index'
|
16
|
+
end
|
17
|
+
|
18
|
+
def approved
|
19
|
+
unless params[:id].present?
|
20
|
+
@comments = Refinery::Blog::Comment.approved.page(params[:page])
|
21
|
+
|
22
|
+
render :action => 'index'
|
23
|
+
else
|
24
|
+
@comment = Refinery::Blog::Comment.find(params[:id])
|
25
|
+
@comment.approve!
|
26
|
+
flash[:notice] = t('approved', :scope => 'refinery.blog.admin.comments', :author => @comment.name)
|
27
|
+
|
28
|
+
redirect_to refinery.url_for(:action => params[:return_to] || 'index', :id => nil)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def rejected
|
33
|
+
unless params[:id].present?
|
34
|
+
@comments = Refinery::Blog::Comment.rejected.page(params[:page])
|
35
|
+
|
36
|
+
render :action => 'index'
|
37
|
+
else
|
38
|
+
@comment = Refinery::Blog::Comment.find(params[:id])
|
39
|
+
@comment.reject!
|
40
|
+
flash[:notice] = t('rejected', :scope => 'refinery.blog.admin.comments', :author => @comment.name)
|
41
|
+
|
42
|
+
redirect_to refinery.url_for(:action => params[:return_to] || 'index', :id => nil)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
module Admin
|
4
|
+
class PostsController < ::Refinery::AdminController
|
5
|
+
|
6
|
+
cache_sweeper Refinery::BlogSweeper
|
7
|
+
|
8
|
+
crudify :'refinery/blog/post',
|
9
|
+
:order => 'published_at DESC'
|
10
|
+
|
11
|
+
before_filter :find_all_categories,
|
12
|
+
:only => [:new, :edit, :create, :update]
|
13
|
+
|
14
|
+
before_filter :check_category_ids, :only => :update
|
15
|
+
|
16
|
+
def uncategorized
|
17
|
+
@posts = Refinery::Blog::Post.uncategorized.page(params[:page])
|
18
|
+
end
|
19
|
+
|
20
|
+
def tags
|
21
|
+
if ActiveRecord::Base.connection.adapter_name.downcase == 'postgresql'
|
22
|
+
op = '~*'
|
23
|
+
wildcard = '.*'
|
24
|
+
else
|
25
|
+
op = 'LIKE'
|
26
|
+
wildcard = '%'
|
27
|
+
end
|
28
|
+
|
29
|
+
@tags = Refinery::Blog::Post.tag_counts_on(:tags).where(
|
30
|
+
["tags.name #{op} ?", "#{wildcard}#{params[:term].to_s.downcase}#{wildcard}"]
|
31
|
+
).map { |tag| {:id => tag.id, :value => tag.name}}
|
32
|
+
render :json => @tags.flatten
|
33
|
+
end
|
34
|
+
|
35
|
+
def new
|
36
|
+
@post = ::Refinery::Blog::Post.new(:author => current_refinery_user)
|
37
|
+
end
|
38
|
+
|
39
|
+
def create
|
40
|
+
# if the position field exists, set this object as last object, given the conditions of this class.
|
41
|
+
if Refinery::Blog::Post.column_names.include?("position")
|
42
|
+
params[:post].merge!({
|
43
|
+
:position => ((Refinery::Blog::Post.maximum(:position, :conditions => "")||-1) + 1)
|
44
|
+
})
|
45
|
+
end
|
46
|
+
|
47
|
+
if (@post = Refinery::Blog::Post.create(params[:post])).valid?
|
48
|
+
(request.xhr? ? flash.now : flash).notice = t(
|
49
|
+
'refinery.crudify.created',
|
50
|
+
:what => "'#{@post.title}'"
|
51
|
+
)
|
52
|
+
|
53
|
+
unless from_dialog?
|
54
|
+
unless params[:continue_editing] =~ /true|on|1/
|
55
|
+
redirect_back_or_default(refinery.blog_admin_posts_path)
|
56
|
+
else
|
57
|
+
unless request.xhr?
|
58
|
+
redirect_to :back
|
59
|
+
else
|
60
|
+
render :partial => "/shared/message"
|
61
|
+
end
|
62
|
+
end
|
63
|
+
else
|
64
|
+
render :text => "<script>parent.window.location = '#{refinery.blog_admin_posts_url}';</script>"
|
65
|
+
end
|
66
|
+
else
|
67
|
+
unless request.xhr?
|
68
|
+
render :action => 'new'
|
69
|
+
else
|
70
|
+
render :partial => "/refinery/admin/error_messages",
|
71
|
+
:locals => {
|
72
|
+
:object => @post,
|
73
|
+
:include_object_name => true
|
74
|
+
}
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
protected
|
80
|
+
def find_all_categories
|
81
|
+
@categories = Refinery::Blog::Category.find(:all)
|
82
|
+
end
|
83
|
+
|
84
|
+
def check_category_ids
|
85
|
+
params[:post][:category_ids] ||= []
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
module Admin
|
4
|
+
class SettingsController < ::Refinery::AdminController
|
5
|
+
|
6
|
+
def notification_recipients
|
7
|
+
@recipients = Refinery::Blog::Comment::Notification.recipients
|
8
|
+
|
9
|
+
if request.post?
|
10
|
+
Refinery::Blog::Comment::Notification.recipients = params[:recipients]
|
11
|
+
flash[:notice] = t('updated', :scope => 'refinery.blog.admin.settings.notification_recipients',
|
12
|
+
:recipients => Refinery::Blog::Comment::Notification.recipients)
|
13
|
+
unless request.xhr? or from_dialog?
|
14
|
+
redirect_back_or_default(refinery.blog_admin_posts_path)
|
15
|
+
else
|
16
|
+
render :text => "<script type='text/javascript'>parent.window.location = '#{refinery.blog_admin_posts_path}';</script>",
|
17
|
+
:layout => false
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def moderation
|
23
|
+
enabled = Refinery::Blog::Comment::Moderation.toggle!
|
24
|
+
unless request.xhr?
|
25
|
+
redirect_back_or_default(refinery.blog_admin_posts_path)
|
26
|
+
else
|
27
|
+
render :json => {:enabled => enabled},
|
28
|
+
:layout => false
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def comments
|
33
|
+
enabled = Refinery::Blog::Comment.toggle!
|
34
|
+
unless request.xhr?
|
35
|
+
redirect_back_or_default(refinery.blog_admin_posts_path)
|
36
|
+
else
|
37
|
+
render :json => {:enabled => enabled},
|
38
|
+
:layout => false
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
def teasers
|
43
|
+
enabled = Refinery::Blog::Post.teaser_enabled_toggle!
|
44
|
+
unless request.xhr?
|
45
|
+
redirect_back_or_default(refinery.blog_admin_posts_path)
|
46
|
+
else
|
47
|
+
render :json => {:enabled => enabled},
|
48
|
+
:layout => false
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
class BlogController < ::ApplicationController
|
4
|
+
|
5
|
+
include ControllerHelper
|
6
|
+
|
7
|
+
helper :'refinery/blog/posts'
|
8
|
+
before_filter :find_page, :find_all_blog_categories
|
9
|
+
|
10
|
+
protected
|
11
|
+
|
12
|
+
def find_page
|
13
|
+
@page = Refinery::Page.find_by_link_url("/blog")
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
class CategoriesController < BlogController
|
4
|
+
|
5
|
+
def show
|
6
|
+
@category = Refinery::Blog::Category.find(params[:id])
|
7
|
+
@posts = @category.posts.live.includes(:comments, :categories).page(params[:page])
|
8
|
+
end
|
9
|
+
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
class PostsController < BlogController
|
4
|
+
|
5
|
+
caches_page :index
|
6
|
+
|
7
|
+
before_filter :find_all_blog_posts, :except => [:archive]
|
8
|
+
before_filter :find_blog_post, :only => [:show, :comment, :update_nav]
|
9
|
+
before_filter :find_tags
|
10
|
+
|
11
|
+
respond_to :html, :js, :rss
|
12
|
+
|
13
|
+
def index
|
14
|
+
# Rss feeders are greedy. Let's give them every blog post instead of paginating.
|
15
|
+
(@posts = Post.live.includes(:comments, :categories).all) if request.format.rss?
|
16
|
+
respond_with (@posts) do |format|
|
17
|
+
format.html
|
18
|
+
format.rss
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def show
|
23
|
+
@comment = Comment.new
|
24
|
+
|
25
|
+
@canonical = url_for(:locale => ::Refinery::I18n.default_frontend_locale) if canonical?
|
26
|
+
|
27
|
+
@post.increment!(:access_count, 1)
|
28
|
+
|
29
|
+
respond_with (@post) do |format|
|
30
|
+
format.html { present(@post) }
|
31
|
+
format.js { render :partial => 'post', :layout => false }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def comment
|
36
|
+
if (@comment = @post.comments.create(params[:comment])).valid?
|
37
|
+
if Comment::Moderation.enabled? or @comment.ham?
|
38
|
+
begin
|
39
|
+
CommentMailer.notification(@comment, request).deliver
|
40
|
+
rescue
|
41
|
+
logger.warn "There was an error delivering a blog comment notification.\n#{$!}\n"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
if Comment::Moderation.enabled?
|
46
|
+
flash[:notice] = t('thank_you_moderated', :scope => 'refinery.blog.posts.comments')
|
47
|
+
redirect_to refinery.blog_post_url(params[:id])
|
48
|
+
else
|
49
|
+
flash[:notice] = t('thank_you', :scope => 'refinery.blog.posts.comments')
|
50
|
+
redirect_to refinery.blog_post_url(params[:id],
|
51
|
+
:anchor => "comment-#{@comment.to_param}")
|
52
|
+
end
|
53
|
+
else
|
54
|
+
render :action => 'show'
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
def archive
|
59
|
+
if params[:month].present?
|
60
|
+
date = "#{params[:month]}/#{params[:year]}"
|
61
|
+
@archive_date = Time.parse(date)
|
62
|
+
@date_title = @archive_date.strftime('%B %Y')
|
63
|
+
@posts = Post.live.by_archive(@archive_date).page(params[:page])
|
64
|
+
else
|
65
|
+
date = "01/#{params[:year]}"
|
66
|
+
@archive_date = Time.parse(date)
|
67
|
+
@date_title = @archive_date.strftime('%Y')
|
68
|
+
@posts = Post.live.by_year(@archive_date).page(params[:page])
|
69
|
+
end
|
70
|
+
respond_with (@posts)
|
71
|
+
end
|
72
|
+
|
73
|
+
def tagged
|
74
|
+
@tag = ActsAsTaggableOn::Tag.find(params[:tag_id])
|
75
|
+
@tag_name = @tag.name
|
76
|
+
@posts = Post.tagged_with(@tag_name).page(params[:page])
|
77
|
+
end
|
78
|
+
|
79
|
+
def canonical?
|
80
|
+
::Refinery.i18n_enabled? && ::Refinery::I18n.default_frontend_locale != ::Refinery::I18n.current_frontend_locale
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
File without changes
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
module ControllerHelper
|
4
|
+
|
5
|
+
protected
|
6
|
+
|
7
|
+
def find_blog_post
|
8
|
+
unless (@post = Refinery::Blog::Post.find(params[:id])).try(:live?)
|
9
|
+
if refinery_user? and current_refinery_user.authorized_plugins.include?("refinerycms_blog")
|
10
|
+
@post = Refinery::Blog::Post.find(params[:id])
|
11
|
+
else
|
12
|
+
error_404
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def find_all_blog_posts
|
18
|
+
@posts = Refinery::Blog::Post.live.includes(:comments, :categories).page(params[:page])
|
19
|
+
end
|
20
|
+
|
21
|
+
def find_tags
|
22
|
+
@tags = Refinery::Blog::Post.tag_counts_on(:tags)
|
23
|
+
end
|
24
|
+
def find_all_blog_categories
|
25
|
+
@categories = Refinery::Blog::Category.all
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,72 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
module PostsHelper
|
4
|
+
def next_or_previous?(post)
|
5
|
+
post.next.present? or post.prev.present?
|
6
|
+
end
|
7
|
+
|
8
|
+
def blog_post_teaser_enabled?
|
9
|
+
Refinery::Blog::Post.teasers_enabled?
|
10
|
+
end
|
11
|
+
|
12
|
+
def blog_post_teaser(post)
|
13
|
+
if post.respond_to?(:custom_teaser) && post.custom_teaser.present?
|
14
|
+
post.custom_teaser.html_safe
|
15
|
+
else
|
16
|
+
truncate(post.body, {
|
17
|
+
:length => Refinery::Blog.post_teaser_length,
|
18
|
+
:preserve_html_tags => true
|
19
|
+
}).html_safe
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
def blog_archive_widget(dates=blog_archive_dates)
|
24
|
+
ArchiveWidget.new(dates, self).display
|
25
|
+
end
|
26
|
+
|
27
|
+
def blog_archive_dates(cutoff=Time.now.beginning_of_month)
|
28
|
+
Refinery::Blog::Post.published_dates_older_than(cutoff)
|
29
|
+
end
|
30
|
+
|
31
|
+
class ArchiveWidget
|
32
|
+
delegate :t, :link_to, :refinery, :render, :to => :view_context
|
33
|
+
attr_reader :view_context
|
34
|
+
|
35
|
+
def initialize(dates, view_context, cutoff=3.years.ago.end_of_year)
|
36
|
+
@recent_dates, @old_dates = dates.sort_by {|date| -date.to_i }.
|
37
|
+
partition {|date| date > cutoff }
|
38
|
+
|
39
|
+
@view_context = view_context
|
40
|
+
end
|
41
|
+
|
42
|
+
def recent_links
|
43
|
+
@recent_dates.group_by {|date| [date.year, date.month] }.
|
44
|
+
map {|(year, month), dates| recent_link(year, month, dates.count) }
|
45
|
+
end
|
46
|
+
|
47
|
+
def recent_link(year, month, count)
|
48
|
+
link_to "#{t("date.month_names")[month]} #{year} (#{count})",
|
49
|
+
refinery.blog_archive_posts_path(:year => year, :month => month)
|
50
|
+
end
|
51
|
+
|
52
|
+
def old_links
|
53
|
+
@old_dates.group_by {|date| date.year }.
|
54
|
+
map {|year, dates| old_link(year, dates.size) }
|
55
|
+
end
|
56
|
+
|
57
|
+
def old_link(year, count)
|
58
|
+
link_to "#{year} (#{count})", refinery.blog_archive_posts_path(:year => year)
|
59
|
+
end
|
60
|
+
|
61
|
+
def links
|
62
|
+
recent_links + old_links
|
63
|
+
end
|
64
|
+
|
65
|
+
def display
|
66
|
+
return "" if links.empty?
|
67
|
+
render "refinery/blog/widgets/blog_archive", :links => links
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
class CommentMailer < ActionMailer::Base
|
4
|
+
|
5
|
+
def notification(comment, request)
|
6
|
+
@comment = comment
|
7
|
+
mail :subject => Blog::Comment::Notification.subject,
|
8
|
+
:recipients => Blog::Comment::Notification.recipients,
|
9
|
+
:from => "\"#{Refinery::Core.site_name}\" <no-reply@#{request.domain}>"
|
10
|
+
end
|
11
|
+
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
data/app/models/.gitkeep
ADDED
File without changes
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Refinery
|
2
|
+
module Blog
|
3
|
+
class Category < ActiveRecord::Base
|
4
|
+
extend FriendlyId
|
5
|
+
friendly_id :title, :use => [:slugged]
|
6
|
+
|
7
|
+
has_many :categorizations, :dependent => :destroy, :foreign_key => :blog_category_id
|
8
|
+
has_many :posts, :through => :categorizations, :source => :blog_post
|
9
|
+
|
10
|
+
acts_as_indexed :fields => [:title]
|
11
|
+
|
12
|
+
validates :title, :presence => true, :uniqueness => true
|
13
|
+
|
14
|
+
def post_count
|
15
|
+
posts.select(&:live?).count
|
16
|
+
end
|
17
|
+
|
18
|
+
# how many items to show per page
|
19
|
+
self.per_page = Refinery::Blog.posts_per_page
|
20
|
+
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|