Commit a6385b0e58ee25b414986dd3b22a4a8cc49fc1d5
Exists in
master
and in
5 other branches
Merge branch 'fix_communities_search' into 'master'
Fix communities search See merge request !4
Showing
6 changed files
with
24 additions
and
21 deletions
Show diff stats
lib/ext/communities_block.rb
| ... | ... | @@ -4,16 +4,9 @@ class CommunitiesBlock |
| 4 | 4 | |
| 5 | 5 | def profile_list |
| 6 | 6 | result = get_visible_profiles |
| 7 | + valid_communities_string = Community.get_valid_communities_string | |
| 7 | 8 | |
| 8 | - list_without_software = [] | |
| 9 | - | |
| 10 | - result.each do |profile| | |
| 11 | - if profile.class == Community && !profile.software? | |
| 12 | - list_without_software << profile | |
| 13 | - end | |
| 14 | - end | |
| 15 | - | |
| 16 | - result = list_without_software | |
| 9 | + result.each{|community| @scope.delete(community) unless eval(valid_communities_string)} | |
| 17 | 10 | |
| 18 | 11 | result.slice(0..get_limit-1) |
| 19 | 12 | end |
| ... | ... | @@ -45,5 +38,4 @@ class CommunitiesBlock |
| 45 | 38 | ).sort_by {rand} |
| 46 | 39 | end |
| 47 | 40 | end |
| 48 | - | |
| 49 | 41 | end | ... | ... |
lib/ext/community.rb
| ... | ... | @@ -26,6 +26,15 @@ class Community |
| 26 | 26 | community |
| 27 | 27 | end |
| 28 | 28 | |
| 29 | + def self.get_valid_communities_string | |
| 30 | + remove_of_communities_methods = Community.instance_methods.select{|m| m =~ /remove_of_community_search/} | |
| 31 | + valid_communities_string = "" | |
| 32 | + remove_of_communities_methods.each do |method| | |
| 33 | + valid_communities_string += "!community.send('#{method}') && " | |
| 34 | + end | |
| 35 | + valid_communities_string[0..-5] | |
| 36 | + end | |
| 37 | + | |
| 29 | 38 | def software? |
| 30 | 39 | return !software_info.nil? |
| 31 | 40 | end |
| ... | ... | @@ -39,4 +48,8 @@ class Community |
| 39 | 48 | self.visible = true |
| 40 | 49 | self.save! |
| 41 | 50 | end |
| 51 | + | |
| 52 | + def remove_of_community_search_software? | |
| 53 | + return software? | |
| 54 | + end | |
| 42 | 55 | end | ... | ... |
lib/ext/search_controller.rb
| ... | ... | @@ -3,12 +3,12 @@ require_dependency 'search_controller' |
| 3 | 3 | class SearchController |
| 4 | 4 | |
| 5 | 5 | def communities |
| 6 | - results = filter_communities_list do |community| | |
| 7 | - !community.software? | |
| 8 | - end | |
| 9 | - results = results.paginate(:per_page => 24, :page => params[:page]) | |
| 10 | - @searches[@asset] = {:results => results} | |
| 11 | - @search = results | |
| 6 | + valid_communities_string = Community.get_valid_communities_string | |
| 7 | + | |
| 8 | + @scope = visible_profiles(Community) | |
| 9 | + @scope.each{|community| @scope.delete(community) unless eval(valid_communities_string)} | |
| 10 | + | |
| 11 | + full_text_search | |
| 12 | 12 | end |
| 13 | 13 | |
| 14 | 14 | def software_infos |
| ... | ... | @@ -162,5 +162,4 @@ class SearchController |
| 162 | 162 | end |
| 163 | 163 | end |
| 164 | 164 | end |
| 165 | - | |
| 166 | 165 | end | ... | ... |
lib/tasks/create_categories.rake
| ... | ... | @@ -2,7 +2,7 @@ namespace :software do |
| 2 | 2 | desc "Create software categories" |
| 3 | 3 | task :create_categories => :environment do |
| 4 | 4 | Environment.all.each do |env| |
| 5 | - if env.plugin_enabled?("MpogSoftware") or env.plugin_enabled?("SoftwareCommunities") | |
| 5 | + if env.plugin_enabled?("SoftwareCommunitiesPlugin") | |
| 6 | 6 | print 'Creating categories: ' |
| 7 | 7 | software = Category.create(:name => _("Software"), :environment => env) |
| 8 | 8 | Category::SOFTWARE_CATEGORIES.each do |category_name| | ... | ... |
lib/tasks/create_licenses.rake
| ... | ... | @@ -3,7 +3,7 @@ namespace :software do |
| 3 | 3 | |
| 4 | 4 | task :create_licenses => :environment do |
| 5 | 5 | Environment.all.each do |env| |
| 6 | - if env.plugin_enabled?("MpogSoftware") or env.plugin_enabled?("SoftwareCommunities") | |
| 6 | + if env.plugin_enabled?("SoftwareCommunitiesPlugin") | |
| 7 | 7 | list_file = File.open "plugins/software_communities/public/static/licences.txt", "r" |
| 8 | 8 | |
| 9 | 9 | version_or_link = 'version' | ... | ... |
lib/tasks/create_sample_softwares.rake
| ... | ... | @@ -4,8 +4,7 @@ namespace :software do |
| 4 | 4 | desc "Create sample softwares" |
| 5 | 5 | task :create_sample_softwares => :environment do |
| 6 | 6 | Environment.all.each do |env| |
| 7 | - if env.plugin_enabled?("SoftwareCommunities") or env.plugin_enabled?("SoftwareCommunitiesPlugin") | |
| 8 | - | |
| 7 | + if env.plugin_enabled?("SoftwareCommunitiesPlugin") | |
| 9 | 8 | print "Creating softwares: " |
| 10 | 9 | |
| 11 | 10 | NUMBER_OF_SOFTWARES.times do |i| | ... | ... |