2019-07-10 05:25:57 +01:00
|
|
|
import { Action, action } from 'easy-peasy';
|
|
|
|
import { FlashMessageType } from '@/components/MessageBox';
|
|
|
|
|
|
|
|
export interface FlashStore {
|
|
|
|
items: FlashMessage[];
|
|
|
|
addFlash: Action<FlashStore, FlashMessage>;
|
2019-07-28 04:23:44 +01:00
|
|
|
addError: Action<FlashStore, { message: string; key?: string }>;
|
2020-07-10 03:56:46 +01:00
|
|
|
clearAndAddError: Action<FlashStore, { message: string, key: string }>;
|
2019-07-10 05:25:57 +01:00
|
|
|
clearFlashes: Action<FlashStore, string | void>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface FlashMessage {
|
|
|
|
id?: string;
|
|
|
|
key?: string;
|
|
|
|
type: FlashMessageType;
|
|
|
|
title?: string;
|
|
|
|
message: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const flashes: FlashStore = {
|
|
|
|
items: [],
|
2020-07-10 03:56:46 +01:00
|
|
|
|
2019-07-10 05:25:57 +01:00
|
|
|
addFlash: action((state, payload) => {
|
|
|
|
state.items.push(payload);
|
|
|
|
}),
|
2020-07-10 03:56:46 +01:00
|
|
|
|
2019-07-28 04:23:44 +01:00
|
|
|
addError: action((state, payload) => {
|
|
|
|
state.items.push({ type: 'error', title: 'Error', ...payload });
|
|
|
|
}),
|
2020-07-10 03:56:46 +01:00
|
|
|
|
|
|
|
clearAndAddError: action((state, payload) => {
|
|
|
|
state.items = [ { type: 'error', title: 'Error', ...payload } ];
|
|
|
|
}),
|
|
|
|
|
2019-07-10 05:25:57 +01:00
|
|
|
clearFlashes: action((state, payload) => {
|
|
|
|
state.items = payload ? state.items.filter(flashes => flashes.key !== payload) : [];
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
|
|
|
export default flashes;
|