mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 06:07:21 +01:00
* Added flagging to show to admins * Fixed filters in my guilds * Fixed login incentives style * Added inital rage bar * Added categoires to get group * Updated profile stats page * Added stat allocation * Updated tests to include categoires * Fixed lint issue * Added another lint fix
80 lines
2.3 KiB
Vue
80 lines
2.3 KiB
Vue
<template lang="pug">
|
|
b-modal#report-flag(:title='$t("abuseFlagModalHeading")', size='lg', :hide-footer='true')
|
|
.modal-header
|
|
h4(v-html="$t('abuseFlagModalHeading', reportData)")
|
|
.modal-body
|
|
blockquote
|
|
div(v-markdown='abuseObject.text')
|
|
p(v-html="$t('abuseFlagModalBody', abuseFlagModalBody)")
|
|
.modal-footer
|
|
button.pull-left.btn.btn-danger(@click='clearFlagCount()', v-if='user.contributor.admin && abuseObject.flagCount > 0')
|
|
| Reset Flag Count
|
|
button.btn.btn-primary(@click='close()') {{ $t('cancel') }}
|
|
button.btn.btn-danger(@click='reportAbuse()') {{ $t('abuseFlagModalButton') }}
|
|
</template>
|
|
|
|
<script>
|
|
import bModal from 'bootstrap-vue/lib/components/modal';
|
|
import { mapState } from 'client/libs/store';
|
|
import notifications from 'client/mixins/notifications';
|
|
import markdownDirective from 'client/directives/markdown';
|
|
|
|
export default {
|
|
mixins: [notifications],
|
|
components: {
|
|
bModal,
|
|
},
|
|
directives: {
|
|
markdown: markdownDirective,
|
|
},
|
|
computed: {
|
|
...mapState({user: 'user.data'}),
|
|
reportData () {
|
|
let reportMessage = this.abuseObject.user;
|
|
let isSystemMessage = this.abuseObject.uuid === 'system';
|
|
if (isSystemMessage) reportMessage = this.$t('systemMessage');
|
|
return {
|
|
name: `<span class='text-danger'>${reportMessage}</span>`,
|
|
};
|
|
},
|
|
abuseObject () {
|
|
return this.$store.state.flagChatOptions.message;
|
|
},
|
|
groupId () {
|
|
return this.$store.state.flagChatOptions.groupId;
|
|
},
|
|
},
|
|
data () {
|
|
let abuseFlagModalBody = {
|
|
firstLinkStart: '<a href="/static/community-guidelines" target="_blank">',
|
|
secondLinkStart: '<a href="/static/terms" target="_blank">',
|
|
linkEnd: '</a>',
|
|
};
|
|
|
|
return {
|
|
abuseFlagModalBody,
|
|
};
|
|
},
|
|
methods: {
|
|
close () {
|
|
this.$root.$emit('hide::modal', 'report-flag');
|
|
},
|
|
async reportAbuse () {
|
|
this.notify('Thank you for reporting this violation. The moderators have been notified.');
|
|
await this.$store.dispatch('chat:flag', {
|
|
groupId: this.groupId,
|
|
chatId: this.abuseObject.id,
|
|
});
|
|
this.close();
|
|
},
|
|
async clearFlagCount () {
|
|
await this.$store.dispatch('chat:clearFlagCount', {
|
|
groupId: this.groupId,
|
|
chatId: this.abuseObject.id,
|
|
});
|
|
this.close();
|
|
},
|
|
},
|
|
};
|
|
</script>
|