Commit 62248e7e4d1c978ba0dab23814aba06f4e6b4b36
Exists in
master
and in
48 other branches
Merge branch 'article-template-list' into 'master'
Article template list
This MR implements a Macro on software communities plugin that allows the use of {profile} variable in articles throw a menu button added to TinyMCE.
See merge request !100
Showing
5 changed files
with
46 additions
and
2 deletions
Show diff stats
src/noosfero-spb/software_communities/lib/macros/allow_variables.rb
0 → 100644
| ... | ... | @@ -0,0 +1,15 @@ |
| 1 | +class SoftwareCommunitiesPlugin::AllowVariables < Noosfero::Plugin::Macro | |
| 2 | + def self.configuration | |
| 3 | + { :params => [], | |
| 4 | + :skip_dialog => true, | |
| 5 | + :title => _("Insert Profile"), | |
| 6 | + :generator => 'insertProfile();', | |
| 7 | + :js_files => 'allow_variables.js', | |
| 8 | + :icon_path => '/designs/icons/tango/Tango/16x16/actions/document-properties.png' | |
| 9 | + } | |
| 10 | + end | |
| 11 | + | |
| 12 | + def parse(params, inner_html, source) | |
| 13 | + source.profile.identifier | |
| 14 | + end | |
| 15 | +end | ... | ... |
src/noosfero-spb/software_communities/lib/software_communities_plugin.rb
src/noosfero-spb/software_communities/lib/statistic_block.rb
| ... | ... | @@ -55,8 +55,13 @@ class StatisticBlock < Block |
| 55 | 55 | def get_software_statistics |
| 56 | 56 | statistics = {} |
| 57 | 57 | software = SoftwareInfo.find_by_community_id(self.owner.id) |
| 58 | - statistics[:saved_resources] = software.saved_resources | |
| 59 | - statistics[:benefited_people] = software.benefited_people | |
| 58 | + if software.present? | |
| 59 | + statistics[:saved_resources] = software.saved_resources | |
| 60 | + statistics[:benefited_people] = software.benefited_people | |
| 61 | + else | |
| 62 | + statistics[:saved_resources] = 0 | |
| 63 | + statistics[:benefited_people] = 0 | |
| 64 | + end | |
| 60 | 65 | statistics |
| 61 | 66 | end |
| 62 | 67 | end | ... | ... |
src/noosfero-spb/software_communities/lib/tasks/templates.rake
| ... | ... | @@ -39,4 +39,23 @@ namespace :templates do |
| 39 | 39 | end |
| 40 | 40 | end |
| 41 | 41 | |
| 42 | + desc "Copy mail list article from template to all Communities" | |
| 43 | + task :copy_mail_article => :environment do | |
| 44 | + article = Profile['software'].articles.find_by_slug('registro-na-lista') | |
| 45 | + puts "Copying article #{article.title}: " | |
| 46 | + if article.present? | |
| 47 | + SoftwareInfo.find_each do |software| | |
| 48 | + community = software.community | |
| 49 | + a_copy = article.copy_without_save | |
| 50 | + a_copy.profile = software.community | |
| 51 | + a_copy.save if a_copy.profile.present? | |
| 52 | + box = community.boxes.detect {|x| x.blocks.find_by_title("Participe") } if community.present? | |
| 53 | + block = box.blocks.find_by_title("Participe") if box.present? | |
| 54 | + link = block.links.detect { |l| l["name"] == "Lista de E-mails" } if block.present? | |
| 55 | + link["address"] = "/{profile}/#{a_copy.path}" if link.present? | |
| 56 | + block.save if block.present? | |
| 57 | + print "." | |
| 58 | + end | |
| 59 | + end | |
| 60 | + end | |
| 42 | 61 | end | ... | ... |
src/noosfero-spb/software_communities/public/allow_variables.js
0 → 100644