Closes GH-44. Authors are now associated with blog posts by current_user Merge branch 'addingusers'
Conflicts: app/models/blog_post.rb
This commit is contained in:
commit
c9c38df5ba
8 changed files with 80 additions and 4 deletions
|
@ -10,6 +10,52 @@ class Admin::Blog::PostsController < Admin::BaseController
|
|||
:per_page => BlogPost.per_page
|
||||
})
|
||||
end
|
||||
|
||||
def create
|
||||
# if the position field exists, set this object as last object, given the conditions of this class.
|
||||
if BlogPost.column_names.include?("position")
|
||||
params[:blog_post].merge!({
|
||||
:position => ((BlogPost.maximum(:position, :conditions => "")||-1) + 1)
|
||||
})
|
||||
end
|
||||
|
||||
if BlogPost.column_names.include?("user_id")
|
||||
params[:blog_post].merge!({
|
||||
:user_id => current_user.id
|
||||
})
|
||||
end
|
||||
|
||||
if (@blog_post = BlogPost.create(params[:blog_post])).valid?
|
||||
(request.xhr? ? flash.now : flash).notice = t(
|
||||
'refinery.crudify.created',
|
||||
:what => "'#{@blog_post.title}'"
|
||||
)
|
||||
|
||||
unless from_dialog?
|
||||
unless params[:continue_editing] =~ /true|on|1/
|
||||
redirect_back_or_default(admin_blog_posts_url)
|
||||
else
|
||||
unless request.xhr?
|
||||
redirect_to :back
|
||||
else
|
||||
render :partial => "/shared/message"
|
||||
end
|
||||
end
|
||||
else
|
||||
render :text => "<script>parent.window.location = '#{admin_blog_posts_url}';</script>"
|
||||
end
|
||||
else
|
||||
unless request.xhr?
|
||||
render :action => 'new'
|
||||
else
|
||||
render :partial => "/shared/admin/error_messages",
|
||||
:locals => {
|
||||
:object => @blog_post,
|
||||
:include_object_name => true
|
||||
}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
before_filter :find_all_categories,
|
||||
:only => [:new, :edit, :create, :update]
|
||||
|
|
|
@ -2,7 +2,9 @@ class BlogPost < ActiveRecord::Base
|
|||
|
||||
default_scope :order => 'published_at DESC'
|
||||
#.first & .last will be reversed -- consider a with_exclusive_scope on these?
|
||||
|
||||
|
||||
belongs_to :author, :class_name => 'User', :foreign_key => :user_id
|
||||
|
||||
has_many :comments, :class_name => 'BlogComment', :dependent => :destroy
|
||||
|
||||
has_many :categorizations
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<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' %></span>
|
||||
<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"), blog_post_url(post),
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
<details>
|
||||
<time datetime="<%=l @blog_post.published_at.to_date, :format => :default %>" class='posted_at'>
|
||||
<%= t('blog.shared.posts.created_at', :when => l(@blog_post.published_at.to_date, :format => :short)) %>.
|
||||
</time>
|
||||
</time><%= " by #{@blog_post.author.username}" if @blog_post.author.present? %>
|
||||
<% if (categories = @blog_post.categories).any? %>
|
||||
<aside class='filed_in'>
|
||||
<%= t('blog.posts.show.filed_in') %>
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
<details>
|
||||
<time datetime="<%=l post.published_at.to_date, :format => :default %>" class='posted_at'>
|
||||
<%= t('blog.shared.posts.created_at', :when => l(post.published_at.to_date, :format => :short)) %>.
|
||||
</time>
|
||||
</time><%= " by #{@blog_post.author.username}" if @blog_post.author.present? %>
|
||||
<% if (categories = post.categories).any? %>
|
||||
<aside class='filed_in'>
|
||||
<%= t('filed_in', :scope => 'blog.posts.show') %>
|
||||
|
|
15
features/authors.feature
Normal file
15
features/authors.feature
Normal file
|
@ -0,0 +1,15 @@
|
|||
@blog
|
||||
Feature: Blog Post Authors
|
||||
Blog posts can be assigned authors through the given user model
|
||||
current_user is assumed through admin screens
|
||||
|
||||
Scenario: Saving a blog post in blog_posts#new associates the current_user as the author
|
||||
Given I am a logged in refinery user
|
||||
|
||||
When I am on the new blog post form
|
||||
And I fill in "Title" with "This is my blog post"
|
||||
And I fill in "Body" with "And I love it"
|
||||
And I press "Save"
|
||||
|
||||
Then there should be 1 blog post
|
||||
And the blog post should belong to me
|
7
features/support/step_definitions/authors_steps.rb
Normal file
7
features/support/step_definitions/authors_steps.rb
Normal file
|
@ -0,0 +1,7 @@
|
|||
Then /^there should be (\d+) blog posts?$/ do |num|
|
||||
BlogPost.all.size == num
|
||||
end
|
||||
|
||||
Then /^the blog post should belong to me$/ do
|
||||
BlogPost.first.author.login == User.last.login
|
||||
end
|
|
@ -46,6 +46,12 @@ describe BlogPost do
|
|||
@blog_post.should respond_to(:categories)
|
||||
end
|
||||
end
|
||||
|
||||
describe "authors" do
|
||||
it "are authored" do
|
||||
BlogPost.instance_methods.map(&:to_sym).include? :author
|
||||
end
|
||||
end
|
||||
|
||||
describe "by_archive scope" do
|
||||
it "returns all posts from specified month" do
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue