1
0
mirror of https://github.com/axllent/mailpit.git synced 2025-01-10 00:43:53 +02:00
mailpit/server/ui-src/stores/mailbox.js
2023-09-14 22:30:20 +12:00

49 lines
1003 B
JavaScript

// State Management
import { reactive, watch } from 'vue'
import Tinycon from 'tinycon'
Tinycon.setOptions({
height: 11,
background: '#dd0000',
fallback: false
})
// global mailbox info
export const mailbox = reactive({
total: 0, // total number of messages
unread: 0, // total unread
count: 0, // total in mailbox or search
messages: [], // current messages
tags: [], // all tags
showTagColors: false, // show tag colors?
selected: [], // currently selected
connected: false, // websocket connection
searching: false, // whether we are currently searching
refresh: false, // to listen from MessagesMixin
notificationsSupported: false,
notificationsEnabled: false,
})
watch(
() => mailbox.total,
(v) => {
if (v == 0) {
Tinycon.reset()
} else {
Tinycon.setBubble(v)
}
}
)
watch(
() => mailbox.showTagColors,
(v) => {
if (v) {
localStorage.setItem('showTagsColors', '1')
} else {
localStorage.removeItem('showTagsColors')
}
}
)