gancio/components/admin/Moderation.vue

137 lines
5.3 KiB
Vue
Raw Normal View History

2020-02-05 00:41:23 +01:00
<template lang='pug'>
2020-07-28 12:24:39 +02:00
v-container
2020-08-05 17:11:06 +02:00
v-card-title {{$t('common.moderation')}}
v-card-text
v-row
v-col(:span='12')
span {{$t('common.instances')}}
2021-05-07 23:15:01 +02:00
v-text-field(v-model='instancesFilter' :placeholder="$t('admin.filter_instances')")
2020-08-05 17:11:06 +02:00
v-data-table(:items='instances'
2021-01-24 18:37:20 +01:00
:items-per-page='5'
2021-05-07 23:15:01 +02:00
:search='instancesFilter'
2021-01-24 18:37:20 +01:00
:hide-default-footer='instances.length<5'
2020-08-05 17:11:06 +02:00
dense :headers='instancesHeader'
@click:row='instanceSelected')
2021-04-26 23:13:37 +02:00
template(v-slot:item.blocked="{ item }")
2021-07-01 12:19:44 +02:00
v-icon(@click='toggleBlock(item)') {{item.blocked ? 'mdi-checkbox-intermediate' : 'mdi-checkbox-blank-outline'}}
2020-02-05 00:41:23 +01:00
2021-01-24 18:37:20 +01:00
v-col(:span='11')
2020-08-05 17:11:06 +02:00
span {{$t('common.users')}}
2021-05-07 23:15:01 +02:00
v-text-field(v-model='usersFilter' :placeholder="$t('admin.filter_users')")
2020-08-05 17:11:06 +02:00
v-data-table(:items='users'
2021-01-24 18:37:20 +01:00
:items-per-page='5'
2021-05-07 23:15:01 +02:00
:search='usersFilter'
2021-01-24 18:37:20 +01:00
:hide-default-footer='users.length<5'
2020-08-05 17:11:06 +02:00
dense :headers='usersHeader')
2021-07-01 12:19:44 +02:00
template(v-slot:item.blocked="{ item }")
v-icon(@click='toggleUserBlock(item)') {{item.blocked?'mdi-checkbox-intermediate':'mdi-checkbox-blank-outline'}}
2020-08-05 17:11:06 +02:00
div
2021-01-24 18:37:20 +01:00
v-card-title {{$t('common.resources')}}
2021-07-01 12:19:44 +02:00
v-data-table(:items='resources' dense
:headers='resourcesHeader'
2021-01-24 18:37:20 +01:00
:hide-default-footer='resources.length<10'
2021-07-01 12:19:44 +02:00
:items-per-page='10')
template(v-slot:item.content='{ item }')
span(v-html='item.data.content')
template(v-slot:item.user='{ item }')
span {{item.ap_user.preferredUsername}}
template(v-slot:item.event='{ item }')
span {{item.event.title}}
template(v-slot:item.actions='{ item }')
v-menu(offset-y)
template(v-slot:activator="{ on }")
v-btn.mr-2(v-on='on' color='primary' small icon)
v-icon mdi-dots-vertical
v-list
v-list-item(v-if='!item.hidden' @click='hideResource(item, true)')
v-list-item-title <v-icon left>mdi-eye-off</v-icon> {{$t('admin.hide_resource')}}
v-list-item(v-else @click='hideResource(item, false)')
v-list-item-title <v-icon left>mdi-eye</v-icon> {{$t('admin.show_resource')}}
v-list-item(@click='deleteResource(item)')
v-list-item-title <v-icon left>mdi-delete</v-icon> {{$t('admin.delete_resource')}}
//- v-list-item(@click='toggleUserBlock(item.ap_user)')
//- v-list-item-title <v-icon left>mdi-lock</v-icon> {{$t('admin.block_user')}}
2020-02-05 00:41:23 +01:00
</template>
<script>
import { mapState, mapActions } from 'vuex'
2021-07-01 12:19:44 +02:00
import get from 'lodash/get'
2020-02-05 00:41:23 +01:00
export default {
name: 'Moderation',
data () {
return {
2020-06-04 23:34:27 +02:00
instances: [],
resources: [],
2020-02-05 00:41:23 +01:00
users: [],
2020-08-05 17:11:06 +02:00
usersHeader: [
2021-07-01 12:19:44 +02:00
{ value: 'object.preferredUsername', text: 'Name' },
{ value: 'blocked', text: 'Blocked' }
2020-08-05 17:11:06 +02:00
],
instancesHeader: [
{ value: 'domain', text: 'Domain' },
{ value: 'name', text: 'Name' },
2021-04-26 23:13:37 +02:00
{ value: 'blocked', text: 'Blocked' },
{ value: 'users', text: 'known users' }
2020-08-05 17:11:06 +02:00
],
resourcesHeader: [
2021-07-01 12:19:44 +02:00
{ value: 'created', text: 'Created' },
{ value: 'event', text: 'Event' },
{ value: 'user', text: 'user' },
{ value: 'content', text: 'Content' },
{ value: 'actions', text: 'Actions' }
2021-05-07 23:15:01 +02:00
],
usersFilter: '',
instancesFilter: ''
2020-02-05 00:41:23 +01:00
}
},
2021-07-01 12:19:44 +02:00
computed: mapState(['settings']),
2020-02-05 00:41:23 +01:00
async mounted () {
this.instances = await this.$axios.$get('/instances')
2021-07-01 12:19:44 +02:00
if (!this.instances.length) {
return
}
this.users = await this.$axios.$get(`/instances/${this.instances[0].domain}`)
2020-02-05 00:41:23 +01:00
this.resources = await this.$axios.$get('/resources')
},
methods: {
...mapActions(['setSetting']),
resourceStyle ({ row }) {
if (row.hidden) {
return { opacity: 0.5 }
}
},
async instanceSelected (instance) {
this.users = await this.$axios.$get(`/instances/${instance.domain}`)
2021-07-01 12:19:44 +02:00
this.resources = await this.$axios.$get('/resources', { filters: { instance: instance.domain } })
2020-02-05 00:41:23 +01:00
},
async hideResource (resource, hidden) {
await this.$axios.$put(`/resources/${resource.id}`, { hidden })
resource.hidden = hidden
},
2020-02-20 23:47:31 +01:00
async toggleUserBlock (ap_user) {
2020-08-05 17:11:06 +02:00
if (!ap_user.blocked) {
2021-07-01 12:19:44 +02:00
const ret = await this.$root.$confirm('admin.user_block_confirm', { user: get(ap_user, 'object.preferredUsername', ap_user.preferredUsername) })
2020-08-05 17:11:06 +02:00
if (!ret) { return }
}
await this.$axios.post('/instances/toggle_user_block', { ap_id: ap_user.ap_id })
ap_user.blocked = !ap_user.blocked
2020-02-05 00:41:23 +01:00
},
2020-08-05 17:11:06 +02:00
async deleteResource (resource) {
2020-10-07 13:05:19 +02:00
const ret = await this.$root.$confirm('admin.delete_resource_confirm')
2020-08-05 17:11:06 +02:00
if (!ret) { return }
await this.$axios.delete(`/resources/${resource.id}`)
this.resources = this.resources.filter(r => r.id !== resource.id)
2020-02-05 00:41:23 +01:00
},
async toggleBlock (instance) {
2021-07-01 12:19:44 +02:00
if (!instance.blocked) {
const ret = await this.$root.$confirm('admin.instance_block_confirm', { instance: instance.domain })
if (!ret) { return }
}
2020-02-05 00:41:23 +01:00
await this.$axios.post('/instances/toggle_block', { instance: instance.domain, blocked: !instance.blocked })
instance.blocked = !instance.blocked
}
}
}
</script>