2018-08-11 07:47:10 +02:00
|
|
|
<template>
|
2022-02-19 06:39:14 +01:00
|
|
|
<section v-if="notifications.length > 0" class="fd-notifications">
|
2018-08-11 07:47:10 +02:00
|
|
|
<div class="columns is-centered">
|
|
|
|
<div class="column is-half">
|
2022-02-19 06:39:14 +01:00
|
|
|
<div
|
|
|
|
v-for="notification in notifications"
|
|
|
|
:key="notification.id"
|
|
|
|
class="notification has-shadow"
|
|
|
|
:class="[
|
|
|
|
'notification',
|
|
|
|
notification.type ? `is-${notification.type}` : ''
|
|
|
|
]"
|
|
|
|
>
|
|
|
|
<button class="delete" @click="remove(notification)" />
|
2018-08-11 07:47:10 +02:00
|
|
|
{{ notification.text }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import * as types from '@/store/mutation_types'
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'Notifications',
|
2022-02-19 06:39:14 +01:00
|
|
|
components: {},
|
2018-08-11 07:47:10 +02:00
|
|
|
|
2022-02-19 06:39:14 +01:00
|
|
|
data() {
|
2018-08-11 07:47:10 +02:00
|
|
|
return { showNav: false }
|
|
|
|
},
|
|
|
|
|
|
|
|
computed: {
|
2022-02-19 06:39:14 +01:00
|
|
|
notifications() {
|
2018-08-11 07:47:10 +02:00
|
|
|
return this.$store.state.notifications.list
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
remove: function (notification) {
|
|
|
|
this.$store.commit(types.DELETE_NOTIFICATION, notification)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
.fd-notifications {
|
|
|
|
position: fixed;
|
|
|
|
bottom: 60px;
|
|
|
|
z-index: 20000;
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
.fd-notifications .notification {
|
|
|
|
margin-bottom: 10px;
|
|
|
|
margin-left: 24px;
|
|
|
|
margin-right: 24px;
|
|
|
|
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
|
|
|
|
}
|
|
|
|
</style>
|