mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 19:48:08 +00:00
Fixes https://github.com/chatwoot/chatwoot/issues/8436 Fixes https://github.com/chatwoot/chatwoot/issues/9767 Fixes https://github.com/chatwoot/chatwoot/issues/10156 Fixes https://github.com/chatwoot/chatwoot/issues/6031 Fixes https://github.com/chatwoot/chatwoot/issues/5696 Fixes https://github.com/chatwoot/chatwoot/issues/9250 Fixes https://github.com/chatwoot/chatwoot/issues/9762 --------- Co-authored-by: Pranav <pranavrajs@gmail.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
121 lines
3.2 KiB
Vue
121 lines
3.2 KiB
Vue
<script>
|
|
const MINUTE_IN_MILLI_SECONDS = 60000;
|
|
const HOUR_IN_MILLI_SECONDS = MINUTE_IN_MILLI_SECONDS * 60;
|
|
const DAY_IN_MILLI_SECONDS = HOUR_IN_MILLI_SECONDS * 24;
|
|
|
|
import {
|
|
dynamicTime,
|
|
dateFormat,
|
|
shortTimestamp,
|
|
} from 'shared/helpers/timeHelper';
|
|
|
|
export default {
|
|
name: 'TimeAgo',
|
|
props: {
|
|
isAutoRefreshEnabled: {
|
|
type: Boolean,
|
|
default: true,
|
|
},
|
|
lastActivityTimestamp: {
|
|
type: [String, Date, Number],
|
|
default: '',
|
|
},
|
|
createdAtTimestamp: {
|
|
type: [String, Date, Number],
|
|
default: '',
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
lastActivityAtTimeAgo: dynamicTime(this.lastActivityTimestamp),
|
|
createdAtTimeAgo: dynamicTime(this.createdAtTimestamp),
|
|
timer: null,
|
|
};
|
|
},
|
|
computed: {
|
|
lastActivityTime() {
|
|
return shortTimestamp(this.lastActivityAtTimeAgo);
|
|
},
|
|
createdAtTime() {
|
|
return shortTimestamp(this.createdAtTimeAgo);
|
|
},
|
|
createdAt() {
|
|
const createdTimeDiff = Date.now() - this.createdAtTimestamp * 1000;
|
|
const isBeforeAMonth = createdTimeDiff > DAY_IN_MILLI_SECONDS * 30;
|
|
return !isBeforeAMonth
|
|
? `${this.$t('CHAT_LIST.CHAT_TIME_STAMP.CREATED.LATEST')} ${
|
|
this.createdAtTimeAgo
|
|
}`
|
|
: `${this.$t('CHAT_LIST.CHAT_TIME_STAMP.CREATED.OLDEST')} ${dateFormat(
|
|
this.createdAtTimestamp
|
|
)}`;
|
|
},
|
|
lastActivity() {
|
|
const lastActivityTimeDiff =
|
|
Date.now() - this.lastActivityTimestamp * 1000;
|
|
const isNotActive = lastActivityTimeDiff > DAY_IN_MILLI_SECONDS * 30;
|
|
return !isNotActive
|
|
? `${this.$t('CHAT_LIST.CHAT_TIME_STAMP.LAST_ACTIVITY.ACTIVE')} ${
|
|
this.lastActivityAtTimeAgo
|
|
}`
|
|
: `${this.$t(
|
|
'CHAT_LIST.CHAT_TIME_STAMP.LAST_ACTIVITY.NOT_ACTIVE'
|
|
)} ${dateFormat(this.lastActivityTimestamp)}`;
|
|
},
|
|
tooltipText() {
|
|
return `${this.createdAt}
|
|
${this.lastActivity}`;
|
|
},
|
|
},
|
|
watch: {
|
|
lastActivityTimestamp() {
|
|
this.lastActivityAtTimeAgo = dynamicTime(this.lastActivityTimestamp);
|
|
},
|
|
createdAtTimestamp() {
|
|
this.createdAtTimeAgo = dynamicTime(this.createdAtTimestamp);
|
|
},
|
|
},
|
|
mounted() {
|
|
if (this.isAutoRefreshEnabled) {
|
|
this.createTimer();
|
|
}
|
|
},
|
|
unmounted() {
|
|
clearTimeout(this.timer);
|
|
},
|
|
methods: {
|
|
createTimer() {
|
|
this.timer = setTimeout(() => {
|
|
this.lastActivityAtTimeAgo = dynamicTime(this.lastActivityTimestamp);
|
|
this.createdAtTimeAgo = dynamicTime(this.createdAtTimestamp);
|
|
this.createTimer();
|
|
}, this.refreshTime());
|
|
},
|
|
refreshTime() {
|
|
const timeDiff = Date.now() - this.lastActivityTimestamp * 1000;
|
|
if (timeDiff > DAY_IN_MILLI_SECONDS) {
|
|
return DAY_IN_MILLI_SECONDS;
|
|
}
|
|
if (timeDiff > HOUR_IN_MILLI_SECONDS) {
|
|
return HOUR_IN_MILLI_SECONDS;
|
|
}
|
|
|
|
return MINUTE_IN_MILLI_SECONDS;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
v-tooltip.top="{
|
|
content: tooltipText,
|
|
delay: { show: 1500, hide: 0 },
|
|
hideOnClick: true,
|
|
}"
|
|
class="ml-auto leading-4 text-xxs text-slate-500 dark:text-slate-500 hover:text-slate-900 dark:hover:text-slate-100"
|
|
>
|
|
<span>{{ `${createdAtTime} • ${lastActivityTime}` }}</span>
|
|
</div>
|
|
</template>
|