mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 15:17:25 +01:00
* feat(messages): big PMs refactor * add private messages route * move to page * WIP - header + begin with the sidebar * extract userLabel + style sidebar + extract converstation item * correct conversation item style * toggle switch style * add contributor / backer to conversation user-label * fix shadows * fix the conversations list (ignoring own sent) * selected conversation label * faceAvatar component * fix message / avatar height * fix message list / empty messages height * new message padding/styles/functionality - finished sidebar conversation styling - * fix loading messages + perfect-scrollbar * fix load more line * fix loading label * open new conversation from outside * if the user doesn't have avatar-data inside the conversation and does not exist anymore, just load/set the user name * search bar new icon / style * block using from conversation context-menu * fix lint * fix merge / lint * fix merge * first separate page * fix tooltips + full width private message + card max width + more responsive * separate conversations methods, to prevent circular deps * update eslint config * fix open new private message * remove unneeded close icon + fix toggle-switch layout * same content height on empty conversations - remove border / box-shadow * canLoadMore = false * remove inbox conditions on chat components * hide footer / fix empty sidebar * floating shadow * remove tooltip on selected conversation user + pm always full-size * show avatar on empty conversation * disable face-avatar * fix faceAvatar + story * fix loading conversation messages while switching the conversation * refresh private-messages page when you are already on it * add countbadge knob to change the example * fix lint * fix hide tooltip + align header correctly * disable perfect scroll * load messages on refresh event * fix header label + conversation actions not breaking layout on hover * add gifting banner to the max height calculation * correct chunk name Co-authored-by: negue <negue@users.noreply.github.com> Co-authored-by: Matteo Pagliazzi <matteopagliazzi@gmail.com>
217 lines
4.3 KiB
Vue
217 lines
4.3 KiB
Vue
<template>
|
|
<div class="card-body">
|
|
<user-link
|
|
:user-id="msg.uuid"
|
|
:name="msg.user"
|
|
:backer="msg.backer"
|
|
:contributor="msg.contributor"
|
|
/>
|
|
<p class="time">
|
|
<span
|
|
v-if="msg.username"
|
|
class="mr-1"
|
|
>@{{ msg.username }}</span><span
|
|
v-if="msg.username"
|
|
class="mr-1"
|
|
>•</span>
|
|
<span
|
|
v-b-tooltip.hover="messageDate"
|
|
>{{ msg.timestamp | timeAgo }} </span>
|
|
<span v-if="msg.client && user.contributor.level >= 4"> ({{ msg.client }})</span>
|
|
</p>
|
|
<div
|
|
class="text"
|
|
v-html="atHighlight(parseMarkdown(msg.text))"
|
|
></div>
|
|
<div
|
|
v-if="isMessageReported"
|
|
class="reported"
|
|
>
|
|
<span v-once>{{ $t('reportedMessage') }}</span><br>
|
|
<span v-once>{{ $t('canDeleteNow') }}</span>
|
|
</div>
|
|
<hr>
|
|
<div
|
|
v-if="msg.id"
|
|
class="d-flex"
|
|
>
|
|
<div
|
|
v-if="!isMessageReported"
|
|
class="action d-flex align-items-center"
|
|
@click="report(msg)"
|
|
>
|
|
<div
|
|
v-once
|
|
class="svg-icon"
|
|
v-html="icons.report"
|
|
></div>
|
|
<div v-once>
|
|
{{ $t('report') }}
|
|
</div>
|
|
</div>
|
|
<div
|
|
class="action d-flex align-items-center"
|
|
@click="remove()"
|
|
>
|
|
<div
|
|
v-once
|
|
class="svg-icon"
|
|
v-html="icons.delete"
|
|
></div>
|
|
<div v-once>
|
|
{{ $t('delete') }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss">
|
|
.at-highlight {
|
|
background-color: rgba(213, 200, 255, 0.32);
|
|
padding: 0.1rem;
|
|
}
|
|
|
|
.at-text {
|
|
color: #6133b4;
|
|
}
|
|
</style>
|
|
|
|
<style lang="scss" scoped>
|
|
@import '~@/assets/scss/colors.scss';
|
|
@import '~@/assets/scss/tiers.scss';
|
|
|
|
.action {
|
|
display: inline-block;
|
|
color: $gray-200;
|
|
margin-right: 1em;
|
|
font-size: 12px;
|
|
|
|
:hover {
|
|
cursor: pointer;
|
|
}
|
|
|
|
.svg-icon {
|
|
color: $gray-300;
|
|
margin-right: .2em;
|
|
width: 16px;
|
|
}
|
|
}
|
|
|
|
.active {
|
|
color: $purple-300;
|
|
|
|
.svg-icon {
|
|
color: $purple-400;
|
|
}
|
|
}
|
|
|
|
.card-body {
|
|
padding: 0.75rem 1.25rem 0.75rem 1.25rem;
|
|
|
|
.time {
|
|
font-size: 12px;
|
|
color: $gray-200;
|
|
margin-bottom: 0.5rem;
|
|
}
|
|
|
|
.text {
|
|
font-size: 14px;
|
|
color: $gray-50;
|
|
text-align: left !important;
|
|
min-height: 0rem;
|
|
margin-bottom: -0.5rem;
|
|
}
|
|
}
|
|
|
|
hr {
|
|
margin-bottom: 0.5rem;
|
|
margin-top: 0.5rem;
|
|
}
|
|
|
|
.reported {
|
|
margin-top: 18px;
|
|
color: $red-50;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
import axios from 'axios';
|
|
import moment from 'moment';
|
|
|
|
import habiticaMarkdown from 'habitica-markdown';
|
|
import { mapState } from '@/libs/store';
|
|
import userLink from '../userLink';
|
|
|
|
import deleteIcon from '@/assets/svg/delete.svg';
|
|
import reportIcon from '@/assets/svg/report.svg';
|
|
import { highlightUsers } from '../../libs/highlightUsers';
|
|
|
|
export default {
|
|
components: {
|
|
userLink,
|
|
},
|
|
filters: {
|
|
timeAgo (value) {
|
|
return moment(value).fromNow();
|
|
},
|
|
},
|
|
props: {
|
|
msg: {},
|
|
},
|
|
data () {
|
|
return {
|
|
icons: Object.freeze({
|
|
delete: deleteIcon,
|
|
report: reportIcon,
|
|
}),
|
|
reported: false,
|
|
};
|
|
},
|
|
computed: {
|
|
...mapState({ user: 'user.data' }),
|
|
isMessageReported () {
|
|
return (this.msg.flags && this.msg.flags[this.user.id]) || this.reported;
|
|
},
|
|
messageDate () {
|
|
const date = moment(this.msg.timestamp).toDate();
|
|
return date.toString();
|
|
},
|
|
},
|
|
mounted () {
|
|
this.$emit('message-card-mounted');
|
|
},
|
|
methods: {
|
|
report () {
|
|
this.$root.$on('habitica:report-result', data => {
|
|
if (data.ok) {
|
|
this.reported = true;
|
|
}
|
|
|
|
this.$root.$off('habitica:report-result');
|
|
});
|
|
|
|
this.$root.$emit('habitica::report-chat', {
|
|
message: this.msg,
|
|
groupId: 'privateMessage',
|
|
});
|
|
},
|
|
async remove () {
|
|
if (!window.confirm(this.$t('areYouSureDeleteMessage'))) return;
|
|
|
|
const message = this.msg;
|
|
this.$emit('message-removed', message);
|
|
|
|
await axios.delete(`/api/v4/inbox/messages/${message.id}`);
|
|
},
|
|
atHighlight (text) {
|
|
return highlightUsers(text, this.user.auth.local.username, this.user.profile.name);
|
|
},
|
|
parseMarkdown (text) {
|
|
if (!text) return null;
|
|
return habiticaMarkdown.render(String(text));
|
|
},
|
|
},
|
|
};
|
|
</script>
|