From c75cf8a00e916e795a0299a55e933c8b3cad17ac Mon Sep 17 00:00:00 2001 From: Joe Sak Date: Thu, 24 Feb 2011 20:46:20 -0600 Subject: Blog Posts belong to an author ("user_id") --- app/models/blog_post.rb | 2 ++ 1 file changed, 2 insertions(+) (limited to 'app') diff --git a/app/models/blog_post.rb b/app/models/blog_post.rb index 679a21c..0dd1246 100644 --- a/app/models/blog_post.rb +++ b/app/models/blog_post.rb @@ -2,6 +2,8 @@ class BlogPost < ActiveRecord::Base default_scope :order => 'published_at DESC' + belongs_to :author, :foreign_key => 'user_id' + has_many :comments, :class_name => 'BlogComment', :dependent => :destroy has_many :categorizations -- cgit v1.2.3 From 6a3cf5d6a695e9394a73bd429dbeae3787a3963e Mon Sep 17 00:00:00 2001 From: Joe Sak Date: Thu, 24 Feb 2011 21:32:37 -0600 Subject: WIP: trying to test user association as author --- app/controllers/admin/blog/posts_controller.rb | 46 ++++++++++++++++++++++++++ app/views/blog/posts/_post.html.erb | 2 +- 2 files changed, 47 insertions(+), 1 deletion(-) (limited to 'app') diff --git a/app/controllers/admin/blog/posts_controller.rb b/app/controllers/admin/blog/posts_controller.rb index 1b6efc3..e8ffed2 100644 --- a/app/controllers/admin/blog/posts_controller.rb +++ b/app/controllers/admin/blog/posts_controller.rb @@ -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 => "" + 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] diff --git a/app/views/blog/posts/_post.html.erb b/app/views/blog/posts/_post.html.erb index 6a16631..7600d26 100644 --- a/app/views/blog/posts/_post.html.erb +++ b/app/views/blog/posts/_post.html.erb @@ -9,7 +9,7 @@
+ by <%= @blog_post.author.try :login %> <% if (categories = @blog_post.categories).any? %>