Commit 35a1c4f5ccda3045955337407afe0bef3a94e5cd
1 parent
89736c33
Exists in
master
and in
29 other branches
ActionItem234: users can publish theirs artcles to its communities
git-svn-id: https://svn.colivre.coop.br/svn/noosfero/trunk@2452 3f533792-8f58-4932-b0fe-aaf55b0a4547
Showing
8 changed files
with
140 additions
and
14 deletions
Show diff stats
app/controllers/my_profile/cms_controller.rb
| ... | ... | @@ -130,6 +130,23 @@ class CmsController < MyProfileController |
| 130 | 130 | render :partial => 'shared/select_categories', :locals => {:object_name => 'article', :multiple => true}, :layout => false |
| 131 | 131 | end |
| 132 | 132 | |
| 133 | + def publish | |
| 134 | + @article = profile.articles.find(params[:id]) | |
| 135 | + @groups = profile.memberships - [profile] | |
| 136 | + @marked_groups = [] | |
| 137 | + groups_ids = profile.memberships.map{|m|m.id.to_s} | |
| 138 | + @marked_groups = params[:marked_groups].map do |item| | |
| 139 | + if groups_ids.include?(item[:group_id]) | |
| 140 | + item.merge :group => Profile.find(item.delete(:group_id)) | |
| 141 | + end | |
| 142 | + end.compact unless params[:marked_groups].nil? | |
| 143 | + if request.post? | |
| 144 | + @marked_groups.each do |item| | |
| 145 | + PublishedArticle.create!(:reference_article => @article, :profile => item[:group], :name => item[:name]) | |
| 146 | + end | |
| 147 | + end | |
| 148 | + end | |
| 149 | + | |
| 133 | 150 | protected |
| 134 | 151 | |
| 135 | 152 | def redirect_back | ... | ... |
| ... | ... | @@ -0,0 +1,20 @@ |
| 1 | +class PublishedArticle < Article | |
| 2 | + belongs_to :reference_article, :class_name => "Article" | |
| 3 | + | |
| 4 | + def self.short_description | |
| 5 | + _('Reference to other article') | |
| 6 | + end | |
| 7 | + | |
| 8 | + def self.description | |
| 9 | + _('A reference to another article published in another profile') | |
| 10 | + end | |
| 11 | + | |
| 12 | + def body | |
| 13 | + reference_article.body | |
| 14 | + end | |
| 15 | + | |
| 16 | + before_validation_on_create :update_name | |
| 17 | + def update_name | |
| 18 | + self.name ||= self.reference_article.name | |
| 19 | + end | |
| 20 | +end | ... | ... |
app/views/content_viewer/view_page.rhtml
| ... | ... | @@ -35,6 +35,9 @@ |
| 35 | 35 | <%= link_to content_tag( 'span', _('Edit') ), |
| 36 | 36 | { :controller => 'cms', :action => 'edit', :id => @page }, |
| 37 | 37 | :class => 'button with-text icon-edit' %> |
| 38 | + <%= link_to content_tag( 'span', _('Publish') ), | |
| 39 | + { :controller => 'cms', :action => 'publish', :id => @page }, | |
| 40 | + :class => 'button with-text icon-edit' %> | |
| 38 | 41 | <%= lightbox_button(:new, _('New publication'), :controller => 'cms', :action => 'new', :parent_id => (@page.folder? ? @page : nil)) %> |
| 39 | 42 | </div> |
| 40 | 43 | <% end %> | ... | ... |
| ... | ... | @@ -0,0 +1,11 @@ |
| 1 | +class AddReferenceArticle < ActiveRecord::Migration | |
| 2 | + def self.up | |
| 3 | + add_column :articles, :reference_article_id, :integer | |
| 4 | + add_column :article_versions, :reference_article_id, :integer | |
| 5 | + end | |
| 6 | + | |
| 7 | + def self.down | |
| 8 | + remove_column :articles, :reference_article_id | |
| 9 | + remove_column :article_versions, :reference_article_id | |
| 10 | + end | |
| 11 | +end | ... | ... |
db/schema.rb
| ... | ... | @@ -9,14 +9,14 @@ |
| 9 | 9 | # |
| 10 | 10 | # It's strongly recommended to check this file into your version control system. |
| 11 | 11 | |
| 12 | -ActiveRecord::Schema.define(:version => 53) do | |
| 12 | +ActiveRecord::Schema.define(:version => 54) do | |
| 13 | 13 | |
| 14 | 14 | create_table "article_versions", :force => true do |t| |
| 15 | 15 | t.integer "article_id" |
| 16 | 16 | t.integer "version" |
| 17 | 17 | t.string "name" |
| 18 | 18 | t.string "slug" |
| 19 | - t.text "path", :default => "" | |
| 19 | + t.text "path", :default => "" | |
| 20 | 20 | t.integer "parent_id" |
| 21 | 21 | t.text "body" |
| 22 | 22 | t.text "abstract" |
| ... | ... | @@ -31,19 +31,20 @@ ActiveRecord::Schema.define(:version => 53) do |
| 31 | 31 | t.integer "width" |
| 32 | 32 | t.string "versioned_type" |
| 33 | 33 | t.integer "comments_count" |
| 34 | - t.boolean "advertise", :default => true | |
| 35 | - t.boolean "published", :default => true | |
| 34 | + t.boolean "advertise", :default => true | |
| 35 | + t.boolean "published", :default => true | |
| 36 | 36 | t.date "start_date" |
| 37 | 37 | t.date "end_date" |
| 38 | - t.integer "children_count", :default => 0 | |
| 39 | - t.boolean "public_article", :default => true | |
| 40 | - t.boolean "accept_comments", :default => true | |
| 38 | + t.integer "children_count", :default => 0 | |
| 39 | + t.boolean "public_article", :default => true | |
| 40 | + t.boolean "accept_comments", :default => true | |
| 41 | + t.integer "reference_article_id" | |
| 41 | 42 | end |
| 42 | 43 | |
| 43 | 44 | create_table "articles", :force => true do |t| |
| 44 | 45 | t.string "name" |
| 45 | 46 | t.string "slug" |
| 46 | - t.text "path", :default => "" | |
| 47 | + t.text "path", :default => "" | |
| 47 | 48 | t.integer "parent_id" |
| 48 | 49 | t.text "body" |
| 49 | 50 | t.text "abstract" |
| ... | ... | @@ -59,14 +60,15 @@ ActiveRecord::Schema.define(:version => 53) do |
| 59 | 60 | t.string "filename" |
| 60 | 61 | t.integer "height" |
| 61 | 62 | t.integer "width" |
| 62 | - t.integer "comments_count", :default => 0 | |
| 63 | - t.boolean "advertise", :default => true | |
| 64 | - t.boolean "published", :default => true | |
| 63 | + t.integer "comments_count", :default => 0 | |
| 64 | + t.boolean "advertise", :default => true | |
| 65 | + t.boolean "published", :default => true | |
| 65 | 66 | t.date "start_date" |
| 66 | 67 | t.date "end_date" |
| 67 | - t.integer "children_count", :default => 0 | |
| 68 | - t.boolean "public_article", :default => true | |
| 69 | - t.boolean "accept_comments", :default => true | |
| 68 | + t.integer "children_count", :default => 0 | |
| 69 | + t.boolean "public_article", :default => true | |
| 70 | + t.boolean "accept_comments", :default => true | |
| 71 | + t.integer "reference_article_id" | |
| 70 | 72 | end |
| 71 | 73 | |
| 72 | 74 | create_table "articles_categories", :id => false, :force => true do |t| | ... | ... |
test/functional/cms_controller_test.rb
| ... | ... | @@ -554,4 +554,26 @@ class CmsControllerTest < Test::Unit::TestCase |
| 554 | 554 | assert !folder.children[0].public? |
| 555 | 555 | end |
| 556 | 556 | |
| 557 | + should 'load communities for that the user belongs' do | |
| 558 | + c = Community.create!(:name => 'test comm', :identifier => 'test_comm') | |
| 559 | + c.affiliate(profile, Profile::Roles.all_roles) | |
| 560 | + a = profile.articles.create!(:name => 'something intresting', :body => 'ruby on rails') | |
| 561 | + | |
| 562 | + get :publish, :profile => profile.identifier, :id => a.id | |
| 563 | + | |
| 564 | + assert_equal [c], assigns(:groups) | |
| 565 | + assert_template 'publish' | |
| 566 | + end | |
| 567 | + | |
| 568 | + should 'publish the article in the selected community' do | |
| 569 | + c = Community.create!(:name => 'test comm', :identifier => 'test_comm') | |
| 570 | + c.affiliate(profile, Profile::Roles.all_roles) | |
| 571 | + a = profile.articles.create!(:name => 'something intresting', :body => 'ruby on rails') | |
| 572 | + | |
| 573 | + assert_difference PublishedArticle, :count do | |
| 574 | + post :publish, :profile => profile.identifier, :id => a.id, :marked_groups => [{:name => 'bli', :group_id => c.id.to_s}] | |
| 575 | + assert_equal [{'group' => c, 'name' => 'bli'}], assigns(:marked_groups) | |
| 576 | + end | |
| 577 | + end | |
| 578 | + | |
| 557 | 579 | end | ... | ... |
test/functional/content_viewer_controller_test.rb
| ... | ... | @@ -404,4 +404,13 @@ class ContentViewerControllerTest < Test::Unit::TestCase |
| 404 | 404 | end |
| 405 | 405 | end |
| 406 | 406 | |
| 407 | + should 'show link to publication on view' do | |
| 408 | + page = profile.articles.create!(:name => 'myarticle', :body => 'the body of the text') | |
| 409 | + login_as(profile.identifier) | |
| 410 | + | |
| 411 | + get :view_page, :profile => profile.identifier, :page => ['myarticle'] | |
| 412 | + | |
| 413 | + assert_tag :tag => 'a', :attributes => {:href => ('/myprofile/' + profile.identifier + '/cms/publish/' + page.id.to_s)} | |
| 414 | + end | |
| 415 | + | |
| 407 | 416 | end | ... | ... |
| ... | ... | @@ -0,0 +1,42 @@ |
| 1 | +require File.dirname(__FILE__) + '/../test_helper' | |
| 2 | + | |
| 3 | +class PublishedArticleTest < ActiveSupport::TestCase | |
| 4 | + | |
| 5 | + def setup | |
| 6 | + @profile = create_user('test_user').person | |
| 7 | + @article = @profile.articles.create!(:name => 'test_article', :body => 'some trivial body') | |
| 8 | + end | |
| 9 | + | |
| 10 | + | |
| 11 | + should 'have a reference article and profile' do | |
| 12 | + prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm') | |
| 13 | + p = PublishedArticle.create(:reference_article => @article, :profile => prof) | |
| 14 | + | |
| 15 | + assert p | |
| 16 | + assert_equal prof, p.profile | |
| 17 | + assert_equal @article, p.reference_article | |
| 18 | + end | |
| 19 | + | |
| 20 | + should 'have same content as reference article' do | |
| 21 | + prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm') | |
| 22 | + p = PublishedArticle.create(:reference_article => @article, :profile => prof) | |
| 23 | + | |
| 24 | + assert_equal @article.body, p.body | |
| 25 | + end | |
| 26 | + | |
| 27 | + should 'have a different name than reference article' do | |
| 28 | + prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm') | |
| 29 | + p = PublishedArticle.create(:reference_article => @article, :profile => prof, :name => 'other title') | |
| 30 | + | |
| 31 | + assert_equal 'other title', p.name | |
| 32 | + assert_not_equal @article.name, p.name | |
| 33 | + | |
| 34 | + end | |
| 35 | + | |
| 36 | + should 'use name of reference article a default name' do | |
| 37 | + prof = Community.create!(:name => 'test_comm', :identifier => 'test_comm') | |
| 38 | + p = PublishedArticle.create!(:reference_article => @article, :profile => prof) | |
| 39 | + | |
| 40 | + assert_equal @article.name, p.name | |
| 41 | + end | |
| 42 | +end | ... | ... |