summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/members/components/action_dropdowns/user_action_dropdown.vue
blob: 8f5c32956a25c4711373689558c4281cad37a9cc (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
134
<script>
import { GlDropdown, GlTooltipDirective } from '@gitlab/ui';
import { sprintf } from '~/locale';
import { parseUserDeletionObstacles } from '~/vue_shared/components/user_deletion_obstacles/utils';
import {
  MEMBER_MODEL_TYPE_GROUP_MEMBER,
  MEMBER_MODEL_TYPE_PROJECT_MEMBER,
} from '~/members/constants';
import { I18N } from './constants';
import LeaveGroupDropdownItem from './leave_group_dropdown_item.vue';
import RemoveMemberDropdownItem from './remove_member_dropdown_item.vue';

export default {
  name: 'UserActionDropdown',
  i18n: I18N,
  components: {
    GlDropdown,
    DisableTwoFactorDropdownItem: () =>
      import(
        'ee_component/members/components/action_dropdowns/disable_two_factor_dropdown_item.vue'
      ),
    LdapOverrideDropdownItem: () =>
      import('ee_component/members/components/ldap/ldap_override_dropdown_item.vue'),
    LeaveGroupDropdownItem,
    RemoveMemberDropdownItem,
  },
  directives: {
    GlTooltip: GlTooltipDirective,
  },
  props: {
    member: {
      type: Object,
      required: true,
    },
    isCurrentUser: {
      type: Boolean,
      required: true,
    },
    permissions: {
      type: Object,
      required: true,
    },
  },
  computed: {
    modalDisableTwoFactor() {
      const userName = this.member.user.username;
      return sprintf(this.$options.i18n.confirmDisableTwoFactor, { userName }, false);
    },
    modalRemoveUser() {
      const { user, source } = this.member;

      if (this.permissions.canRemoveBlockedByLastOwner) {
        if (this.member.type === MEMBER_MODEL_TYPE_PROJECT_MEMBER) {
          return I18N.personalProjectOwnerCannotBeRemoved;
        }

        if (this.member.type === MEMBER_MODEL_TYPE_GROUP_MEMBER) {
          return I18N.lastGroupOwnerCannotBeRemoved;
        }
      }

      if (user) {
        return sprintf(
          this.$options.i18n.confirmNormalUserRemoval,
          { userName: user.name, group: source.fullName },
          false,
        );
      }

      return sprintf(this.$options.i18n.confirmOrphanedUserRemoval, { group: source.fullName });
    },
    userDeletionObstaclesUserData() {
      return {
        name: this.member.user?.name,
        obstacles: parseUserDeletionObstacles(this.member.user),
      };
    },
    showDropdown() {
      return (
        this.permissions.canDisableTwoFactor || this.showLeaveOrRemove || this.showLdapOverride
      );
    },
    showLeaveOrRemove() {
      return this.permissions.canRemove || this.permissions.canRemoveBlockedByLastOwner;
    },
    showLdapOverride() {
      return this.permissions.canOverride && !this.member.isOverridden;
    },
  },
};
</script>

<template>
  <gl-dropdown
    v-if="showDropdown"
    v-gl-tooltip="$options.i18n.actions"
    :text="$options.i18n.actions"
    text-sr-only
    icon="ellipsis_v"
    category="tertiary"
    no-caret
    right
    data-testid="user-action-dropdown"
    data-qa-selector="user_action_dropdown"
  >
    <disable-two-factor-dropdown-item
      v-if="permissions.canDisableTwoFactor"
      :modal-message="modalDisableTwoFactor"
      :user-id="member.user.id"
    >
      {{ $options.i18n.disableTwoFactor }}
    </disable-two-factor-dropdown-item>

    <template v-if="showLeaveOrRemove">
      <leave-group-dropdown-item v-if="isCurrentUser" :member="member" :permissions="permissions">{{
        $options.i18n.leaveGroup
      }}</leave-group-dropdown-item>

      <remove-member-dropdown-item
        v-else
        :member-id="member.id"
        :member-model-type="member.type"
        :user-deletion-obstacles="userDeletionObstaclesUserData"
        :modal-message="modalRemoveUser"
        :prevent-removal="permissions.canRemoveBlockedByLastOwner"
        >{{ $options.i18n.removeMember }}</remove-member-dropdown-item
      >
    </template>

    <ldap-override-dropdown-item v-else-if="showLdapOverride" :member="member">{{
      $options.i18n.editPermissions
    }}</ldap-override-dropdown-item>
  </gl-dropdown>
</template>