Module: YeshuaCrm::FormTagHelper
- Defined in:
- lib/yeshua_crm/helpers/form_tag_helper.rb
Instance Method Summary collapse
-
#select2_tag(name, option_tags = nil, options = {}) ⇒ Object
(also: #select2)
Allows include select2 into your views.
-
#transform_to_select2(field, options = {}) ⇒ Object
Transforms select filter field into select2.
Instance Method Details
#select2_tag(name, option_tags = nil, options = {}) ⇒ Object Also known as: select2
Allows include select2 into your views.
Examples
select2_tag 'city_id', '<option value="1">Lisbon</option>...'
select2_tag 'city_id', options_for_select(...)
select2_tag 'tag_list', nil, :multiple => true, :data => [{ id: 0, text: 'deal' }, ...], :tags => true, :include_hidden => false %>
select2_tag 'tag_list', options_for_select(...), :multiple => true, :style => 'width: 100%;', :url => '/tags', :placeholder => '+ add tag', :tags => true %>
You may use select_tag options and additional options.
Additional options
-
:url
Allows searches for remote data using the ajax. -
:data
Load dropdown options from a local array ifurl
option not set. -
:placeholder
Supports displaying a placeholder value. -
:include_hidden
Adds hidden field after select whenmultiple
option true. Default value true.
Note: The HTML specification says when multiple
parameter passed to select and all options got deselected web browsers do not send any value to server.
In case if you don’t want the helper to generate this hidden field you can specify include_hidden: false
option.
Also aliased as: select2
select2 'city_id', options_for_select(...)
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/yeshua_crm/helpers/form_tag_helper.rb', line 29 def select2_tag(name, = nil, = {}) id = sanitize_to_id(name) placeholder = [:placeholder] || 'Select ...' content_for(:header_tags) { select2_assets } result = select_tag(name, , ) if [:multiple] && .fetch(:include_hidden, true) result << hidden_field_tag("#{name}[]", '') end result << javascript_tag(<<-JS) $(function () { $('select#' + '#{id}').select2({ #{()}, #{()}, placeholder: '#{placeholder}' }); }); JS end |
#transform_to_select2(field, options = {}) ⇒ Object
Transforms select filter field into select2
Examples
transform_to_select2 'issue_tags', url:
transform_to_select2 'manager_id', format_state: 'formatStateWithAvatar', min_input_length: 1, url: '/managers'
Options
-
:url
Defines URL to search remote data using the ajax. -
:format_state
Defines template of search results in the drop-down. -
:min_input_length
Minimum number of characters required to start a search. Default value 0. -
:width
Sets the width of the control. Default value ‘60%’.
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/yeshua_crm/helpers/form_tag_helper.rb', line 64 def transform_to_select2(field, = {}) return if field.empty? result = ''.html_safe unless @transform_to_select2_included result << javascript_include_tag('select2_helpers', plugin: 'yeshua_crm') @transform_to_select2_included = true end result << javascript_tag(<<-JS) select2Filters['#{field}'] = { url: '#{[:url].to_s}', formatState: #{.fetch(:format_state, 'undefined')}, minimumInputLength: #{.fetch(:min_input_length, 0)}, width: '#{.fetch(:with, '60%')}' }; JS end |