summaryrefslogtreecommitdiff
path: root/app/views/groups/group_members/index.html.haml
blob: 048edb80d99c2603eb75e802aa74f807b7c8a547 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
- page_title _("Group members")
- can_manage_members = can?(current_user, :admin_group_member, @group)
- show_invited_members = can_manage_members && @invited_members.exists?
- pending_active = params[:search_invited].present?
- total_count = @members.count + @group.shared_with_group_links.count

.project-members-page.prepend-top-default
  %h4
    = _("Group members")
  %hr
  - if can_manage_members
    - if Feature.enabled?(:share_group_with_group, default_enabled: true)
      %ul.nav-links.nav.nav-tabs.gitlab-tabs{ role: 'tablist' }
        %li.nav-tab{ role: 'presentation' }
          %a.nav-link.active{ href: '#invite-member-pane', id: 'invite-member-tab', data: { toggle: 'tab' }, role: 'tab' }= _("Invite member")
          %li.nav-tab{ role: 'presentation' }
            %a.nav-link{ href: '#invite-group-pane', id: 'invite-group-tab', data: { toggle: 'tab', qa_selector: 'invite_group_tab' }, role: 'tab' }= _("Invite group")
      .tab-content.gitlab-tab-content
        .tab-pane.active{ id: 'invite-member-pane', role: 'tabpanel' }
          = render_invite_member_for_group(@group, @group_member.access_level)
        - if Feature.enabled?(:share_group_with_group, default_enabled: true)
          .tab-pane{ id: 'invite-group-pane', role: 'tabpanel' }
            = render 'shared/members/invite_group', submit_url: group_group_links_path(@group), access_levels: GroupMember.access_level_roles, default_access_level: @group_member.access_level, group_link_field: 'shared_with_group_id', group_access_field: 'shared_group_access'
    - else
      = render_invite_member_for_group(@group, @group_member.access_level)

    = render 'shared/members/requests', membership_source: @group, requesters: @requesters

  = render_if_exists 'groups/group_members/ldap_sync'

  %ul.nav-links.mobile-separator.nav.nav-tabs.clearfix
    %li.nav-item
      = link_to "#existing_shares", class: ["nav-link", ("active" unless pending_active)] , 'data-toggle' => 'tab' do
        %span
          = _("Existing shares")
        %span.badge.badge-pill= total_count
    - if show_invited_members
      %li.nav-item
        = link_to "#invited_members", class: ["nav-link", ("active" if pending_active)], 'data-toggle' => 'tab' do
          %span
            = _("Pending")
          %span.badge.badge-pill= @invited_members.total_count

  .tab-content
    #existing_shares.tab-pane{ :class => ("active" unless pending_active) }
      - if @group.shared_with_group_links.any?
        .card.card-without-border
          .d-flex.flex-column.flex-md-row.row-content-block.second-block
            %span.flex-grow-1.align-self-md-center.col-form-label
              = _("Groups with access to %{strong_start}%{group_name}%{strong_end}").html_safe % { group_name: @group.name, strong_start: '<strong>'.html_safe, strong_end: '</strong>'.html_safe }
          %ul.content-list.members-list{ data: { qa_selector: "groups_list" } }
            - can_admin_member = can?(current_user, :admin_group_member, @group)
            - @group.shared_with_group_links.each do |group_link|
              = render 'shared/members/group', group_link: group_link, can_admin_member: can_admin_member, group_link_path: group_group_link_path(@group, group_link)
      .card.card-without-border
        .d-flex.flex-column.flex-md-row.row-content-block.second-block
          %span.flex-grow-1.align-self-md-center.col-form-label
            = _("Members with access to %{strong_start}%{group_name}%{strong_end}").html_safe % { group_name: @group.name, strong_start: '<strong>'.html_safe, strong_end: '</strong>'.html_safe }
          = form_tag group_group_members_path(@group), method: :get, class: 'form-inline user-search-form' do
            .form-group.flex-grow
              .position-relative.mr-md-2
                = search_field_tag :search, params[:search], { placeholder: _('Search'), class: 'form-control', spellcheck: false }
                %button.user-search-btn.border-left{ type: "submit", "aria-label" => _("Submit search") }
                  = icon("search")
              - if can_manage_members
                = label_tag '2fa', '2FA', class: 'col-form-label label-bold pr-md-2'
                = render 'shared/members/filter_2fa_dropdown'
              = render 'shared/members/sort_dropdown'
        %ul.content-list.members-list{ data: { qa_selector: "members_list" } }
          = render partial: 'shared/members/member', collection: @members, as: :member
      = paginate @members, theme: 'gitlab'

    - if show_invited_members
      #invited_members.tab-pane{ :class => ("active" if pending_active) }
        .card.card-without-border
          .d-flex.flex-column.flex-md-row.row-content-block.second-block
            %span.flex-grow-1
              = _("Members with pending access to %{strong_start}%{group_name}%{strong_end}").html_safe % { group_name: @group.name, strong_start: '<strong>'.html_safe, strong_end: '</strong>'.html_safe }
            = form_tag group_group_members_path(@group), method: :get, class: 'form-inline user-search-form' do
              .form-group
                .position-relative.mr-md-2
                  = search_field_tag :search_invited, params[:search_invited], { placeholder: _('Search'), class: 'form-control', spellcheck: false }
                  %button.user-search-btn.border-left{ type: "submit", "aria-label" => _("Submit search") }
                    = icon("search")
          %ul.content-list.members-list
            = render partial: 'shared/members/member', collection: @invited_members, as: :member
        = paginate @invited_members, param_name: 'invited_members_page', theme: 'gitlab'