summaryrefslogtreecommitdiff
path: root/app/helpers/groups/group_members_helper.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/helpers/groups/group_members_helper.rb')
-rw-r--r--app/helpers/groups/group_members_helper.rb32
1 files changed, 25 insertions, 7 deletions
diff --git a/app/helpers/groups/group_members_helper.rb b/app/helpers/groups/group_members_helper.rb
index a719d80a1a1..80ab303357b 100644
--- a/app/helpers/groups/group_members_helper.rb
+++ b/app/helpers/groups/group_members_helper.rb
@@ -9,10 +9,10 @@ module Groups::GroupMembersHelper
{ multiple: true, class: 'input-clamp qa-member-select-field ', scope: :all, email_user: true }
end
- def group_members_app_data(group, members:, invited:, access_requests:)
+ def group_members_app_data(group, members:, invited:, access_requests:, include_relations:, search:)
{
user: group_members_list_data(group, members, { param_name: :page, params: { invited_members_page: nil, search_invited: nil } }),
- group: group_group_links_list_data(group),
+ group: group_group_links_list_data(group, include_relations, search),
invite: group_members_list_data(group, invited.nil? ? [] : invited, { param_name: :invited_members_page, params: { page: nil } }),
access_request: group_members_list_data(group, access_requests.nil? ? [] : access_requests),
source_id: group.id,
@@ -26,8 +26,8 @@ module Groups::GroupMembersHelper
MemberSerializer.new.represent(members, { current_user: current_user, group: group, source: group })
end
- def group_group_links_serialized(group_links)
- GroupLink::GroupGroupLinkSerializer.new.represent(group_links, { current_user: current_user })
+ def group_group_links_serialized(group, group_links)
+ GroupLink::GroupGroupLinkSerializer.new.represent(group_links, { current_user: current_user, source: group })
end
# Overridden in `ee/app/helpers/ee/groups/group_members_helper.rb`
@@ -39,11 +39,29 @@ module Groups::GroupMembersHelper
}
end
- def group_group_links_list_data(group)
- group_links = group.shared_with_group_links
+ def group_group_links(group, include_relations)
+ group_links = case include_relations
+ when [:direct]
+ group.shared_with_group_links
+ when [:inherited]
+ group.shared_with_group_links.of_ancestors
+ else
+ group.shared_with_group_links.of_ancestors_and_self
+ end
+
+ group_links.distinct_on_shared_with_group_id_with_group_access
+ end
+
+ def group_group_links_list_data(group, include_relations, search)
+ if ::Feature.enabled?(:group_member_inherited_group, group, default_enabled: :yaml)
+ group_links = group_group_links(group, include_relations)
+ group_links = group_links.search(search) if search
+ else
+ group_links = group.shared_with_group_links
+ end
{
- members: group_group_links_serialized(group_links),
+ members: group_group_links_serialized(group, group_links),
pagination: members_pagination_data(group_links),
member_path: group_group_link_path(group, ':id')
}