aboutsummaryrefslogtreecommitdiff
path: root/src/components/moderation_tools/moderation_tools.vue
blob: 785fe7ba5e01c4d08eb30f8ad05d2b9f615ca9a6 (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
<template>
<div>
  <Popper
    trigger="click"
    @hide='showDropDown = false'
    append-to-body
    :options="{
      placement: 'bottom-end',
      modifiers: {
        arrow: { enabled: true },
        offset: { offset: '0, 5px' },
      }
    }">
    <div class="popper-wrapper">
      <div class="dropdown-menu">
        <span v-if='user.is_local'>
          <button class="dropdown-item" @click='toggleRight("admin")'>
            {{ $t(!!user.rights.admin ? 'user_card.admin_menu.revoke_admin' : 'user_card.admin_menu.grant_admin') }}
          </button>
          <button class="dropdown-item" @click='toggleRight("moderator")'>
            {{ $t(!!user.rights.moderator ? 'user_card.admin_menu.revoke_moderator' : 'user_card.admin_menu.grant_moderator') }}
          </button>
          <div role="separator" class="dropdown-divider"></div>
        </span>
        <button class="dropdown-item" @click='toggleActivationStatus()'>
          {{ $t(!!user.deactivated ? 'user_card.admin_menu.activate_account' : 'user_card.admin_menu.deactivate_account') }}
        </button>
        <button class="dropdown-item" @click='deleteUserDialog(true)'>
          {{ $t('user_card.admin_menu.delete_account') }}
        </button>
        <div role="separator" class="dropdown-divider" v-if='hasTagPolicy'></div>
        <span v-if='hasTagPolicy'>
          <button class="dropdown-item" @click='toggleTag(tags.FORCE_NSFW)'>
            {{ $t('user_card.admin_menu.force_nsfw') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.FORCE_NSFW) }"></span>
          </button>
          <button class="dropdown-item" @click='toggleTag(tags.STRIP_MEDIA)'>
            {{ $t('user_card.admin_menu.strip_media') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.STRIP_MEDIA) }"></span>
          </button>
          <button class="dropdown-item" @click='toggleTag(tags.FORCE_UNLISTED)'>
            {{ $t('user_card.admin_menu.force_unlisted') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.FORCE_UNLISTED) }"></span>
          </button>
          <button class="dropdown-item" @click='toggleTag(tags.SANDBOX)'>
            {{ $t('user_card.admin_menu.sandbox') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.SANDBOX) }"></span>
          </button>
          <button class="dropdown-item" v-if='user.is_local' @click='toggleTag(tags.DISABLE_REMOTE_SUBSCRIPTION)'>
            {{ $t('user_card.admin_menu.disable_remote_subscription') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.DISABLE_REMOTE_SUBSCRIPTION) }"></span>
          </button>
          <button class="dropdown-item" v-if='user.is_local' @click='toggleTag(tags.DISABLE_ANY_SUBSCRIPTION)'>
            {{ $t('user_card.admin_menu.disable_any_subscription') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.DISABLE_ANY_SUBSCRIPTION) }"></span>
          </button>
          <button class="dropdown-item" v-if='user.is_local' @click='toggleTag(tags.QUARANTINE)'>
            {{ $t('user_card.admin_menu.quarantine') }}
            <span class="menu-checkbox" v-bind:class="{ 'menu-checkbox-checked': hasTag(tags.QUARANTINE) }"></span>
          </button>
        </span>
      </div>
    </div>
    <button slot="reference" class="btn btn-default moderation-toggle-btn" v-bind:class="{ pressed: showDropDown }" @click='toggleMenu'>
      {{ $t('user_card.admin_menu.moderation') }}
    </button>
  </Popper>
  <portal to="modal">
    <DialogModal v-if="showDeleteUserDialog" :onCancel='deleteUserDialog.bind(this, false)'>
      <template slot="header">{{ $t('user_card.admin_menu.delete_user') }}</template>
      <p>{{ $t('user_card.admin_menu.delete_user_confirmation') }}</p>
      <template slot="footer">
        <button class="btn btn-default" @click='deleteUserDialog(false)'>
          {{ $t('general.cancel') }}
        </button>
        <button class="btn btn-default danger" @click='deleteUser()'>
          {{ $t('user_card.admin_menu.delete_user') }}
        </button>
      </template>
    </DialogModal>
  </portal>
</div>
</template>

<script src="./moderation_tools.js"></script>

<style lang="scss">
@import '../../_variables.scss';
@import '../popper/popper.scss';

.menu-checkbox {
  float: right;
  min-width: 22px;
  max-width: 22px;
  min-height: 22px;
  max-height: 22px;
  line-height: 22px;
  text-align: center;
  border-radius: 0px;
  background-color: $fallback--fg;
  background-color: var(--input, $fallback--fg);
  box-shadow: 0px 0px 2px black inset;
  box-shadow: var(--inputShadow);

  &.menu-checkbox-checked::after {
    content: '✔';
  }
}

.moderation-toggle-btn {
  &#{&} {
    margin: 0;
    width: 100%;
  }
}

</style>