budibase/packages/client/src/stores/notification.js

64 lines
1.4 KiB
JavaScript
Raw Normal View History

import { writable, get } from "svelte/store"
import { generate } from "shortid"
import { routeStore } from "./routes"
2021-01-22 12:21:44 +01:00
2021-01-22 13:11:38 +01:00
const NOTIFICATION_TIMEOUT = 3000
2021-01-22 12:21:44 +01:00
const createNotificationStore = () => {
let timeout
let block = false
const store = writable(null, () => {
2021-03-02 14:26:37 +01:00
return () => {
clearTimeout(timeout)
2021-03-02 14:26:37 +01:00
}
})
const blockNotifications = (timeout = 1000) => {
block = true
setTimeout(() => (block = false), timeout)
}
2021-01-22 12:44:43 +01:00
const send = (message, type = "info", icon) => {
if (block) {
return
}
// If peeking, pass notifications back to parent window
if (get(routeStore).queryParams?.peek) {
window.dispatchEvent(
new CustomEvent("notification", {
detail: { message, type, icon },
})
)
return
}
store.set({
id: generate(),
type,
message,
icon,
delay: get(store) != null,
2021-03-02 14:26:37 +01:00
})
clearTimeout(timeout)
timeout = setTimeout(() => {
store.set(null)
2021-03-02 14:26:37 +01:00
}, NOTIFICATION_TIMEOUT)
}
return {
subscribe: store.subscribe,
actions: {
send,
info: msg => send(msg, "info", "Info"),
success: msg => send(msg, "success", "CheckmarkCircle"),
warning: msg => send(msg, "warning", "Alert"),
error: msg => send(msg, "error", "Alert"),
blockNotifications,
},
}
2021-01-22 12:21:44 +01:00
}
2021-03-02 14:26:37 +01:00
export const notificationStore = createNotificationStore()