pleroma-fe/src/components/moderation_tools/moderation_tools.js

107 lines
3.2 KiB
JavaScript
Raw Normal View History

import { library } from '@fortawesome/fontawesome-svg-core'
import { faChevronDown } from '@fortawesome/free-solid-svg-icons'
2019-02-18 14:49:32 +00:00
import DialogModal from '../dialog_modal/dialog_modal.vue'
2020-02-28 16:39:47 +00:00
import Popover from '../popover/popover.vue'
2019-02-18 14:49:32 +00:00
library.add(faChevronDown)
2019-02-18 14:49:32 +00:00
const FORCE_NSFW = 'mrf_tag:media-force-nsfw'
const STRIP_MEDIA = 'mrf_tag:media-strip'
const FORCE_UNLISTED = 'mrf_tag:force-unlisted'
const DISABLE_REMOTE_SUBSCRIPTION = 'mrf_tag:disable-remote-subscription'
const DISABLE_ANY_SUBSCRIPTION = 'mrf_tag:disable-any-subscription'
const SANDBOX = 'mrf_tag:sandbox'
const QUARANTINE = 'mrf_tag:quarantine'
const ModerationTools = {
props: [
'user'
],
data () {
return {
tags: {
FORCE_NSFW,
STRIP_MEDIA,
FORCE_UNLISTED,
DISABLE_REMOTE_SUBSCRIPTION,
DISABLE_ANY_SUBSCRIPTION,
SANDBOX,
QUARANTINE
},
2020-02-28 16:39:47 +00:00
showDeleteUserDialog: false,
toggled: false
2019-02-18 14:49:32 +00:00
}
},
components: {
2020-02-28 16:39:47 +00:00
DialogModal,
Popover
2019-02-18 14:49:32 +00:00
},
computed: {
tagsSet () {
return new Set(this.user.tags)
},
hasTagPolicy () {
return this.$store.state.instance.tagPolicyAvailable
}
},
methods: {
hasTag (tagName) {
return this.tagsSet.has(tagName)
},
toggleTag (tag) {
const store = this.$store
if (this.tagsSet.has(tag)) {
store.state.api.backendInteractor.untagUser({ user: this.user, tag }).then(response => {
2019-02-18 14:49:32 +00:00
if (!response.ok) { return }
2019-07-05 07:02:14 +00:00
store.commit('untagUser', { user: this.user, tag })
2019-02-18 14:49:32 +00:00
})
} else {
store.state.api.backendInteractor.tagUser({ user: this.user, tag }).then(response => {
2019-02-18 14:49:32 +00:00
if (!response.ok) { return }
2019-07-05 07:02:14 +00:00
store.commit('tagUser', { user: this.user, tag })
2019-02-18 14:49:32 +00:00
})
}
},
toggleRight (right) {
const store = this.$store
if (this.user.rights[right]) {
store.state.api.backendInteractor.deleteRight({ user: this.user, right }).then(response => {
2019-02-18 14:49:32 +00:00
if (!response.ok) { return }
store.commit('updateRight', { user: this.user, right, value: false })
2019-02-18 14:49:32 +00:00
})
} else {
store.state.api.backendInteractor.addRight({ user: this.user, right }).then(response => {
2019-02-18 14:49:32 +00:00
if (!response.ok) { return }
store.commit('updateRight', { user: this.user, right, value: true })
2019-02-18 14:49:32 +00:00
})
}
},
toggleActivationStatus () {
this.$store.dispatch('toggleActivationStatus', { user: this.user })
2019-02-18 14:49:32 +00:00
},
deleteUserDialog (show) {
this.showDeleteUserDialog = show
},
deleteUser () {
const store = this.$store
const user = this.user
2019-07-05 07:02:14 +00:00
const { id, name } = user
store.state.api.backendInteractor.deleteUser({ user })
2019-02-18 14:49:32 +00:00
.then(e => {
this.$store.dispatch('markStatusesAsDeleted', status => user.id === status.user.id)
const isProfile = this.$route.name === 'external-user-profile' || this.$route.name === 'user-profile'
const isTargetUser = this.$route.params.name === name || this.$route.params.id === id
if (isProfile && isTargetUser) {
window.history.back()
}
})
2020-02-28 16:39:47 +00:00
},
setToggled (value) {
this.toggled = value
2019-02-18 14:49:32 +00:00
}
}
}
export default ModerationTools