# frozen_string_literal: true module InviteMembersHelper include Gitlab::Utils::StrongMemoize def can_invite_members_for_project?(project) # 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 can?(current_user, :admin_project_member, project) end 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 def group_select_data(group) # This should only be used for groups to load the invite group modal. # For instance the invite groups modal should not call this from a project scope # this is only to be called in scope of a group context as noted in this thread # https://gitlab.com/gitlab-org/gitlab/-/merge_requests/79036#note_821465513 # the group sharing in projects disabling is explained there as well if group.root_ancestor.namespace_settings.prevent_sharing_groups_outside_hierarchy { groups_filter: 'descendant_groups', parent_id: group.root_ancestor.id } else {} end end def common_invite_group_modal_data(source, member_class, is_project) { id: source.id, 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, access_levels: member_class.access_level_roles.to_json } end def common_invite_modal_dataset(source) dataset = { id: source.id, name: source.name, default_access_level: Gitlab::Access::GUEST } if show_invite_members_for_task?(source) 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 dataset end private # Overridden in EE def users_filter_data(group) {} end def show_invite_members_for_task?(source) return unless current_user invite_for_help_continuous_onboarding = source.is_a?(Project) && experiment(:invite_for_help_continuous_onboarding, namespace: source.namespace).assigned.name == 'candidate' params[:open_modal] == 'invite_members_for_task' || invite_for_help_continuous_onboarding 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 end InviteMembersHelper.prepend_mod_with('InviteMembersHelper')