summaryrefslogtreecommitdiff
path: root/app/views/shared/members/_member.html.haml
blob: 331283f7eecbbbeafaa6beb1d6d6000888141265 (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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
- show_roles = local_assigns.fetch(:show_roles, true)
- show_controls = local_assigns.fetch(:show_controls, true)
- force_mobile_view = local_assigns.fetch(:force_mobile_view, false)
- member = local_assigns.fetch(:member)
- user = local_assigns.fetch(:user, member.user)
- source = member.source
- override = member.try(:override)

-# Note this is just for individual members. For groups please see shared/members/_group

%li.member.py-2.px-3.d-flex.flex-column{ class: [dom_class(member), ("is-overridden" if override), ("flex-md-row" unless force_mobile_view)], id: dom_id(member) }
  %span.list-item-name.mb-2.m-md-0
    - if user
      = image_tag avatar_icon_for_user(user, 40), class: "avatar s40 flex-shrink-0 flex-grow-0", alt: ''
      .user-info
        = link_to user.name, user_path(user), class: 'member js-user-link', data: { user_id: user.id }
        = user_status(user)
        %span.cgray= user.to_reference

        = render_if_exists 'shared/members/ee/sso_badge', member: member

        - if user == current_user
          %span.badge.badge-success.prepend-left-5= _("It's you")

        - if user.blocked?
          %label.badge.badge-danger
            %strong= _("Blocked")

        - if user.two_factor_enabled?
          %label.badge.badge-info
            = _("2FA")

        - if source.instance_of?(Group) && source != @group
          ·
          = link_to source.full_name, source, class: "member-group-link"

        .cgray
          - if member.request?
            = _("Requested %{time_ago}").html_safe % { time_ago: time_ago_with_tooltip(member.requested_at) }
          - else
            = _("Given access %{time_ago}").html_safe % { time_ago: time_ago_with_tooltip(member.created_at) }
          - if member.expires?
            ยท
            %span{ class: "#{"text-warning" if member.expires_soon?} has-tooltip", title: member.expires_at.to_time.in_time_zone.to_s(:medium) }
              = _("Expires in %{expires_at}").html_safe % { expires_at: distance_of_time_in_words_to_now(member.expires_at) }

    - else
      = image_tag avatar_icon_for_email(member.invite_email, 40), class: "avatar s40 flex-shrink-0 flex-grow-0", alt: ''
      .user-info
        .member= member.invite_email
        .cgray
          Invited
          - if member.created_by
            by
            = link_to member.created_by.name, user_path(member.created_by)
          = time_ago_with_tooltip(member.created_at)
  - if show_roles
    - current_resource = @project || @group
    .controls.member-controls.align-items-center
      = render_if_exists 'shared/members/ee/ldap_tag', can_override: member.can_override?
      - if show_controls && member.source == current_resource

        - if member.can_resend_invite?
          = link_to icon('paper-plane'), polymorphic_path([:resend_invite, member]),
                    method: :post,
                    class: 'btn btn-default align-self-center mr-sm-2',
                    title: _('Resend invite')

        - if user != current_user && member.can_update?
          = form_for member, remote: true, html: { class: "js-edit-member-form form-group #{'d-sm-flex' unless force_mobile_view}" } do |f|
            = f.hidden_field :access_level
            .member-form-control.dropdown{ class: [("mr-sm-2 d-sm-inline-block" unless force_mobile_view)] }
              %button.dropdown-menu-toggle.js-member-permissions-dropdown{ type: "button",
                disabled: member.can_override? && !override,
                data: { toggle: "dropdown", field_name: "#{f.object_name}[access_level]" } }
                %span.dropdown-toggle-text
                  = member.human_access
                = icon("chevron-down")
              .dropdown-menu.dropdown-select.dropdown-menu-right.dropdown-menu-selectable
                = dropdown_title(_("Change permissions"))
                .dropdown-content
                  %ul
                    - member.valid_level_roles.each do |role, role_id|
                      %li
                        = link_to role, "javascript:void(0)",
                          class: ("is-active" if member.access_level == role_id),
                          data: { id: role_id, el_id: dom_id(member) }
                    = render_if_exists 'shared/members/ee/revert_ldap_group_sync_option',
                      group: @group,
                      member: member,
                      can_override: member.can_override?
            .clearable-input.member-form-control{ class: [("d-sm-inline-block" unless force_mobile_view)] }
              = f.text_field :expires_at,
                disabled: member.can_override? && !override,
                class: 'form-control js-access-expiration-date js-member-update-control',
                placeholder: _('Expiration date'),
                id: "member_expires_at_#{member.id}",
                data: { el_id: dom_id(member) }
              %i.clear-icon.js-clear-input
        - else
          %span.member-access-text.user-access-role= member.human_access

        - if member.can_approve?
          = link_to polymorphic_path([:approve_access_request, member]),
                    method: :post,
                    class: "btn btn-success align-self-center m-0 mb-2 #{'mb-sm-0 ml-sm-2' unless force_mobile_view}",
                    title: _('Grant access') do
            %span{ class: ('d-block d-sm-none' unless force_mobile_view) }
              = _('Grant access')
            - unless force_mobile_view
              = icon('check inverse', class: 'd-none d-sm-block')

        - if member.can_remove?
          - if current_user == user
            = link_to icon('sign-out', text: _('Leave')), polymorphic_path([:leave, member.source, :members]),
                      method: :delete,
                      data: { confirm: leave_confirmation_message(member.source) },
                      class: "btn btn-remove align-self-center m-0 #{'ml-sm-2' unless force_mobile_view}"
          - else
            = link_to member,
                      method: :delete,
                      data: { confirm: remove_member_message(member) },
                      class: "btn btn-remove align-self-center m-0 #{'ml-sm-2' unless force_mobile_view}",
                      title: remove_member_title(member) do
              %span{ class: ('d-block d-sm-none' unless force_mobile_view) }
                = _("Delete")
              - unless force_mobile_view
                = icon('trash', class: 'd-none d-sm-block')
        = render_if_exists 'shared/members/ee/override_member_buttons', group: @group, member: member, user: user, action: :edit, can_override: member.can_override?
      - else
        %span.member-access-text.user-access-role= member.human_access

= render_if_exists 'shared/members/ee/override_member_buttons', group: @group, member: member, user: user, action: :confirm, can_override: member.can_override?