Files
habitica/website/client/src/components/chat/reportFlagModal.vue
2023-02-16 14:34:24 -06:00

153 lines
3.5 KiB
Vue

<template>
<b-modal
id="report-flag"
:title="$t('abuseFlagModalHeading')"
size="md"
:hide-footer="true"
>
<div class="modal-body">
<strong v-html="$t('abuseFlagModalHeading')"></strong>
<blockquote>
<div v-markdown="abuseObject.text"></div>
</blockquote>
<div>
<strong>{{ $t('whyReportingPost') }}</strong>
<span class="optional">{{ $t('optional') }}</span>
<textarea
v-model="reportComment"
class="form-control"
:placeholder="$t('whyReportingPostPlaceholder')"
></textarea>
</div>
<small v-html="$t('abuseFlagModalBody', abuseFlagModalBody)"></small>
</div>
<div class="footer text-center">
<button
v-if="hasPermission(user, 'moderator')"
class="pull-left btn btn-danger"
@click="clearFlagCount()"
>
Reset Flag Count
</button>
<a
class="cancel-link"
@click.prevent="close()"
>{{ $t('cancel') }}</a>
<button
class="btn btn-danger"
@click="reportAbuse()"
>
{{ $t('report') }}
</button>
</div>
</b-modal>
</template>
<style>
#report-flag h5 {
color: #f23035;
}
</style>
<style lang="scss" scoped>
@import '~@/assets/scss/colors.scss';
.modal-body {
margin-top: 1em;
}
blockquote {
border-radius: 2px;
background-color: #f4f4f4;
padding: 1em;
margin-top: 1em;
}
textarea {
margin-top: 1em;
margin-bottom: 1em;
border-radius: 2px;
border: solid 1px $gray-400;
min-height: 106px;
}
.footer {
padding: 1em;
padding-bottom: 2em;
}
a.cancel-link {
margin-right: .5em;
}
.optional {
color: $gray-200;
float: right;
}
</style>
<script>
import notifications from '@/mixins/notifications';
import markdownDirective from '@/directives/markdown';
import { userStateMixin } from '../../mixins/userState';
export default {
directives: {
markdown: markdownDirective,
},
mixins: [notifications, userStateMixin],
data () {
const abuseFlagModalBody = {
firstLinkStart: '<a href="/static/community-guidelines" target="_blank">',
secondLinkStart: '<a href="/static/terms" target="_blank">',
linkEnd: '</a>',
};
return {
abuseFlagModalBody,
abuseObject: '',
groupId: '',
reportComment: '',
};
},
mounted () {
this.$root.$on('habitica::report-chat', this.handleReport);
},
beforeDestroy () {
this.$root.$off('habitica::report-chat', this.handleReport);
},
methods: {
close () {
this.$root.$emit('bv::hide::modal', 'report-flag');
},
async reportAbuse () {
this.text(this.$t(this.groupId === 'privateMessage' ? 'pmReported' : 'abuseReported'));
const result = await this.$store.dispatch('chat:flag', {
groupId: this.groupId,
chatId: this.abuseObject.id,
comment: this.reportComment,
});
this.$root.$emit('habitica:report-result', result);
this.close();
},
async clearFlagCount () {
await this.$store.dispatch('chat:clearFlagCount', {
groupId: this.groupId,
chatId: this.abuseObject.id,
});
this.close();
},
handleReport (data) {
if (!data.message || !data.groupId) return;
this.abuseObject = data.message;
this.groupId = data.groupId;
this.reportComment = '';
this.$root.$emit('bv::show::modal', 'report-flag');
},
},
};
</script>