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,6 +59,16 @@ class MpogSoftwarePluginMyprofileController < MyProfileController | ||
59 | 59 | ||
60 | if valid_software_info && valid_community && valid_libraries && valid_license && valid_language && valid_database && valid_operating_system | 60 | if valid_software_info && valid_community && valid_libraries && valid_license && valid_language && valid_database && valid_operating_system |
61 | @community = Community.create_after_moderation(user, {:environment => environment}.merge(params[:community]), @software_info, @license_info, @controlled_vocabulary) | 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 | redirect_to :controller => 'memberships', :action => 'index' | 72 | redirect_to :controller => 'memberships', :action => 'index' |
63 | else | 73 | else |
64 | @list_libraries.each do |lib| | 74 | @list_libraries.each do |lib| |
@@ -82,4 +92,9 @@ class MpogSoftwarePluginMyprofileController < MyProfileController | @@ -82,4 +92,9 @@ class MpogSoftwarePluginMyprofileController < MyProfileController | ||
82 | end | 92 | end |
83 | end | 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 | end | 100 | end |
test/functional/mpog_software_plugin_myprofile_controller_test.rb
0 → 100644
@@ -0,0 +1,30 @@ | @@ -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,7 +97,13 @@ | ||
97 | <%= swf.text_field(:demonstration_url) %> | 97 | <%= swf.text_field(:demonstration_url) %> |
98 | </div> | 98 | </div> |
99 | <% end %> | 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 | <div id='libraries_fields'> | 107 | <div id='libraries_fields'> |
102 | <h4> <%= _("Libraries") %> </h4> | 108 | <h4> <%= _("Libraries") %> </h4> |
103 | <%= render :partial => 'library_fields', :locals => { :f => f, :object_name => 'community', :profile => @community, :libraries => @list_libraries } %> | 109 | <%= render :partial => 'library_fields', :locals => { :f => f, :object_name => 'community', :profile => @community, :libraries => @list_libraries } %> |