debian-mirror-gitlab/app/helpers/selects_helper.rb

95 lines
2.6 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module SelectsHelper
def users_select_tag(id, opts = {})
2018-12-05 23:21:45 +05:30
css_class = ["ajax-users-select"]
css_class << "multiselect" if opts[:multiple]
css_class << "skip_ldap" if opts[:skip_ldap]
2014-09-02 18:07:02 +05:30
css_class << (opts[:class] || '')
value = opts[:selected] || ''
2015-04-26 12:48:37 +05:30
html = {
2018-12-05 23:21:45 +05:30
class: css_class.join(' '),
2016-09-13 17:45:13 +05:30
data: users_select_data_attributes(opts)
2015-04-26 12:48:37 +05:30
}
unless opts[:scope] == :all
2016-06-02 11:05:42 +05:30
project = opts[:project] || @project
2015-09-11 14:41:01 +05:30
if project
html['data-project-id'] = project.id
2015-04-26 12:48:37 +05:30
elsif @group
html['data-group-id'] = @group.id
end
end
hidden_field_tag(id, value, html)
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
def groups_select_tag(id, opts = {})
2018-12-05 23:21:45 +05:30
classes = Array.wrap(opts[:class])
classes << 'ajax-groups-select'
2019-02-15 15:39:39 +05:30
# EE requires this line to be present, but there is no easy way of injecting
# this into EE without causing merge conflicts. Given this line is very
# simple and not really EE specific on its own, we just include it in CE.
classes << 'multiselect' if opts[:multiple]
2018-12-05 23:21:45 +05:30
opts[:class] = classes.join(' ')
2015-12-23 02:04:40 +05:30
select2_tag(id, opts)
end
def namespace_select_tag(id, opts = {})
2018-12-05 23:21:45 +05:30
opts[:class] = [*opts[:class], 'ajax-namespace-select'].join(' ')
2015-12-23 02:04:40 +05:30
select2_tag(id, opts)
end
def project_select_tag(id, opts = {})
2018-12-05 23:21:45 +05:30
opts[:class] = [*opts[:class], 'ajax-project-select'].join(' ')
2015-12-23 02:04:40 +05:30
unless opts.delete(:scope) == :all
if @group
opts['data-group-id'] = @group.id
end
end
2017-09-10 17:25:29 +05:30
with_feature_enabled_data_attribute =
case opts.delete(:with_feature_enabled)
when 'issues' then 'data-with-issues-enabled'
when 'merge_requests' then 'data-with-merge-requests-enabled'
end
opts[with_feature_enabled_data_attribute] = true
2015-12-23 02:04:40 +05:30
hidden_field_tag(id, opts[:selected], opts)
end
def select2_tag(id, opts = {})
2018-12-05 23:21:45 +05:30
klass_opts = [opts[:class]]
klass_opts << 'multiselect' if opts[:multiple]
opts[:class] = klass_opts.join(' ')
2014-09-02 18:07:02 +05:30
value = opts[:selected] || ''
2015-04-26 12:48:37 +05:30
2016-11-03 12:29:30 +05:30
hidden_field_tag(id, value, opts)
2014-09-02 18:07:02 +05:30
end
2016-09-13 17:45:13 +05:30
private
def users_select_data_attributes(opts)
{
placeholder: opts[:placeholder] || 'Search for a user',
null_user: opts[:null_user] || false,
any_user: opts[:any_user] || false,
email_user: opts[:email_user] || false,
first_user: opts[:first_user] && current_user ? current_user.username : false,
current_user: opts[:current_user] || false,
author_id: opts[:author_id] || '',
2020-03-13 15:44:24 +05:30
skip_users: opts[:skip_users] ? opts[:skip_users].map(&:id) : nil,
qa_selector: opts[:qa_selector] || ''
2016-09-13 17:45:13 +05:30
}
end
2014-09-02 18:07:02 +05:30
end
2019-12-04 20:38:33 +05:30
SelectsHelper.prepend_if_ee('EE::SelectsHelper')