2020-05-15 17:52:59 +02:00
|
|
|
<template>
|
2020-07-30 19:12:29 +02:00
|
|
|
<div
|
|
|
|
id="notifications-board"
|
|
|
|
@mouseenter="clearTimeouts"
|
|
|
|
@mouseleave="rearmTimeouts"
|
|
|
|
>
|
2020-05-15 17:52:59 +02:00
|
|
|
<transition-group name="slide-fade">
|
|
|
|
<BaseNotification
|
|
|
|
v-for="notification in latestNotifications"
|
|
|
|
:key="notification.uid"
|
|
|
|
:message="notification.message"
|
|
|
|
:status="notification.status"
|
|
|
|
@close="removeNotification(notification.uid)"
|
|
|
|
/>
|
|
|
|
</transition-group>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import { mapGetters, mapActions } from 'vuex';
|
|
|
|
import BaseNotification from '@/components/BaseNotification';
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'TheNotificationsBoard',
|
|
|
|
components: {
|
|
|
|
BaseNotification
|
|
|
|
},
|
2020-07-30 19:12:29 +02:00
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
timeouts: {}
|
|
|
|
};
|
|
|
|
},
|
2020-05-15 17:52:59 +02:00
|
|
|
computed: {
|
|
|
|
...mapGetters({
|
2020-07-30 19:12:29 +02:00
|
|
|
notifications: 'notifications/getNotifications',
|
|
|
|
notificationsTimeout: 'settings/getNotificationsTimeout'
|
2020-05-15 17:52:59 +02:00
|
|
|
}),
|
|
|
|
latestNotifications () {
|
|
|
|
return this.notifications.slice(0, 10);
|
|
|
|
}
|
|
|
|
},
|
2020-07-30 19:12:29 +02:00
|
|
|
watch: {
|
2021-11-24 16:59:07 +01:00
|
|
|
'notifications.length': function (val) {
|
|
|
|
if (val > 0) {
|
|
|
|
const nUid = this.notifications[0].uid;
|
|
|
|
this.timeouts[nUid] = setTimeout(() => {
|
|
|
|
this.removeNotification(nUid);
|
|
|
|
delete this.timeouts[nUid];
|
|
|
|
}, this.notificationsTimeout * 1000);
|
2020-07-30 19:12:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2020-05-15 17:52:59 +02:00
|
|
|
methods: {
|
|
|
|
...mapActions({
|
|
|
|
removeNotification: 'notifications/removeNotification'
|
2020-07-30 19:12:29 +02:00
|
|
|
}),
|
|
|
|
clearTimeouts () {
|
|
|
|
for (const uid in this.timeouts) {
|
|
|
|
clearTimeout(this.timeouts[uid]);
|
|
|
|
delete this.timeouts[uid];
|
|
|
|
}
|
|
|
|
},
|
|
|
|
rearmTimeouts () {
|
2021-11-24 16:59:07 +01:00
|
|
|
const delay = 50;
|
|
|
|
let i = this.notifications.length * delay;
|
2020-07-30 19:12:29 +02:00
|
|
|
for (const notification of this.notifications) {
|
|
|
|
this.timeouts[notification.uid] = setTimeout(() => {
|
|
|
|
this.removeNotification(notification.uid);
|
|
|
|
delete this.timeouts[notification.uid];
|
2021-11-24 16:59:07 +01:00
|
|
|
}, (this.notificationsTimeout * 1000) + i);
|
|
|
|
i = i > delay ? i - delay : 0;
|
2020-07-30 19:12:29 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-15 17:52:59 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="scss">
|
2020-07-31 18:16:28 +02:00
|
|
|
#notifications-board {
|
|
|
|
position: absolute;
|
2020-08-12 18:11:48 +02:00
|
|
|
z-index: 999;
|
2020-07-31 18:16:28 +02:00
|
|
|
right: 1rem;
|
|
|
|
bottom: 1rem;
|
|
|
|
}
|
2020-05-15 17:52:59 +02:00
|
|
|
</style>
|