Commit 56b6ebc30a37579ea09dd6103eb0c243d7c51633
1 parent
90eb5f31
Exists in
master
and in
5 other branches
find_offerer: Add tokenized to find new offerers for software
Signed-off-by: Arthur Del Esposte <arthurmde@gmail.com> Signed-off-by: Parley Martins <parley@outlook.com>
Showing
3 changed files
with
52 additions
and
1 deletions
Show diff stats
controllers/mpog_software_plugin_myprofile_controller.rb
... | ... | @@ -59,6 +59,16 @@ class MpogSoftwarePluginMyprofileController < MyProfileController |
59 | 59 | |
60 | 60 | if valid_software_info && valid_community && valid_libraries && valid_license && valid_language && valid_database && valid_operating_system |
61 | 61 | @community = Community.create_after_moderation(user, {:environment => environment}.merge(params[:community]), @software_info, @license_info, @controlled_vocabulary) |
62 | + | |
63 | + unless params[:q].nil? | |
64 | + admins = params[:q].split(/,/).map{|n| environment.people.find n.to_i} | |
65 | + | |
66 | + admins.each do |admin| | |
67 | + @community.add_member(admin) | |
68 | + @community.add_admin(admin) | |
69 | + end | |
70 | + end | |
71 | + | |
62 | 72 | redirect_to :controller => 'memberships', :action => 'index' |
63 | 73 | else |
64 | 74 | @list_libraries.each do |lib| |
... | ... | @@ -82,4 +92,9 @@ class MpogSoftwarePluginMyprofileController < MyProfileController |
82 | 92 | end |
83 | 93 | end |
84 | 94 | |
95 | + def search_offerers | |
96 | + arg = params[:q].downcase | |
97 | + result = environment.people.find(:all, :conditions => ['LOWER(name) LIKE ?', "%#{arg}%"]) | |
98 | + render :text => prepare_to_token_input(result).to_json | |
99 | + end | |
85 | 100 | end | ... | ... |
test/functional/mpog_software_plugin_myprofile_controller_test.rb
0 → 100644
... | ... | @@ -0,0 +1,30 @@ |
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | |
2 | +require File.dirname(__FILE__) + | |
3 | +'/../../controllers/mark_comment_as_read_plugin_profile_controller' | |
4 | + | |
5 | +class MpogSoftwarePluginMyprofileController; def rescue_action(e) raise e end; | |
6 | +end | |
7 | + | |
8 | +class MpogSoftwarePluginMyprofileControllerTest < ActionController::TestCase | |
9 | + def setup | |
10 | + @controller = MpogSoftwarePluginMyprofileController.new | |
11 | + @request = ActionController::TestRequest.new | |
12 | + @response = ActionController::TestResponse.new | |
13 | + # @organization = Community.create!(:name => 'My Software', :identifier => | |
14 | + # 'my-software') | |
15 | + @person = create_user('person').person | |
16 | + #@organization.add_admin(@person) | |
17 | + login_as(@person.user.login) | |
18 | + e = Environment.default | |
19 | + e.enable_plugin('MpogSoftwarePlugin') | |
20 | + e.save! | |
21 | + end | |
22 | + | |
23 | + attr_accessor :person | |
24 | + | |
25 | + should 'search new offerers while creating a new software' do | |
26 | + end | |
27 | + | |
28 | + should 'search new offerers while edting a new software' do | |
29 | + end | |
30 | +end | ... | ... |
views/mpog_software_plugin_myprofile/new_software.html.erb
... | ... | @@ -97,7 +97,13 @@ |
97 | 97 | <%= swf.text_field(:demonstration_url) %> |
98 | 98 | </div> |
99 | 99 | <% end %> |
100 | - | |
100 | + | |
101 | + <div class="formfieldline"> | |
102 | + <%= content_tag('label', _('Fill in the search field to add offerers for this Software'), :id => "text-input-search-offerers") %> | |
103 | + <%= token_input_field_tag(:q, 'search-offerers', {:action => 'search_offerers'}, { :focus => true, :hint_text => _('Type in a search term for a person to be added as | |
104 | +offerers'), :pre_populate => @tokenized_children}) %> | |
105 | + </div> | |
106 | + | |
101 | 107 | <div id='libraries_fields'> |
102 | 108 | <h4> <%= _("Libraries") %> </h4> |
103 | 109 | <%= render :partial => 'library_fields', :locals => { :f => f, :object_name => 'community', :profile => @community, :libraries => @list_libraries } %> | ... | ... |