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

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

92 lines
2.9 KiB
Ruby
Raw Normal View History

2021-01-03 14:25:43 +05:30
# frozen_string_literal: true
module InviteMembersHelper
include Gitlab::Utils::StrongMemoize
2021-06-08 01:23:25 +05:30
def can_invite_members_for_project?(project)
2021-10-27 15:23:28 +05:30
# do not use the can_admin_project_member? helper here due to structure of the view and how membership_locked?
# is leveraged for inviting groups
2022-05-07 20:08:51 +05:30
can?(current_user, :admin_project_member, project)
2021-01-03 14:25:43 +05:30
end
2021-06-08 01:23:25 +05:30
def invite_accepted_notice(member)
case member.source
when Project
_("You have been granted %{member_human_access} access to project %{name}.") %
{ member_human_access: member.human_access, name: member.source.name }
when Group
_("You have been granted %{member_human_access} access to group %{name}.") %
{ member_human_access: member.human_access, name: member.source.name }
end
end
2023-03-04 22:38:38 +05:30
# Overridden in EE
2022-04-04 11:22:00 +05:30
def common_invite_group_modal_data(source, member_class, is_project)
{
id: source.id,
2022-07-16 23:28:13 +05:30
root_id: source.root_ancestor.id,
2022-04-04 11:22:00 +05:30
name: source.name,
default_access_level: Gitlab::Access::GUEST,
invalid_groups: source.related_group_ids,
help_link: help_page_url('user/permissions'),
is_project: is_project,
2023-03-04 22:38:38 +05:30
access_levels: member_class.permissible_access_level_roles(current_user, source).to_json,
full_path: source.full_path
2022-07-16 23:28:13 +05:30
}.merge(group_select_data(source))
2022-04-04 11:22:00 +05:30
end
2022-06-21 17:19:12 +05:30
# Overridden in EE
2021-10-27 15:23:28 +05:30
def common_invite_modal_dataset(source)
dataset = {
id: source.id,
2022-06-21 17:19:12 +05:30
root_id: source.root_ancestor&.id,
2021-10-27 15:23:28 +05:30
name: source.name,
2023-03-04 22:38:38 +05:30
default_access_level: Gitlab::Access::GUEST,
full_path: source.full_path
2021-10-27 15:23:28 +05:30
}
2022-01-26 12:08:38 +05:30
if show_invite_members_for_task?(source)
2021-12-11 22:18:48 +05:30
dataset.merge!(
tasks_to_be_done_options: tasks_to_be_done_options.to_json,
projects: projects_for_source(source).to_json,
new_project_path: source.is_a?(Group) ? new_project_path(namespace_id: source.id) : ''
)
end
2021-10-27 15:23:28 +05:30
dataset
end
private
2022-07-16 23:28:13 +05:30
def group_select_data(source)
if source.root_ancestor.prevent_sharing_groups_outside_hierarchy
{ groups_filter: 'descendant_groups', parent_id: source.root_ancestor.id }
else
{}
end
end
2021-10-27 15:23:28 +05:30
# Overridden in EE
def users_filter_data(group)
{}
end
2021-12-11 22:18:48 +05:30
2022-01-26 12:08:38 +05:30
def show_invite_members_for_task?(source)
return unless current_user
2021-12-11 22:18:48 +05:30
2022-05-07 20:08:51 +05:30
invite_for_help_continuous_onboarding = source.is_a?(Project) && experiment(:invite_for_help_continuous_onboarding, namespace: source.namespace).assigned.name == 'candidate'
2022-01-26 12:08:38 +05:30
params[:open_modal] == 'invite_members_for_task' || invite_for_help_continuous_onboarding
2021-12-11 22:18:48 +05:30
end
def tasks_to_be_done_options
::MemberTask::TASKS.keys.map { |task| { value: task, text: localized_tasks_to_be_done_choices[task] } }
end
def projects_for_source(source)
projects = source.is_a?(Project) ? [source] : source.projects
projects.map { |project| { id: project.id, title: project.title } }
end
2021-01-03 14:25:43 +05:30
end
2022-04-04 11:22:00 +05:30
InviteMembersHelper.prepend_mod_with('InviteMembersHelper')