import { Action } from 'redux' import { v1 } from 'uuid' import { AppThunkAction, NotificationType } from '../types' export interface AddNotificationAction extends Action { type: 'NOTIFICATIONS_ADD_NOTIFICATION' payload: { id: string type: NotificationType content: string } } export interface RemoveNotificationAction extends Action { type: 'NOTIFICATIONS_REMOVE_NOTIFICATION' payload: string } export interface ClearNotificationAction extends Action { type: 'NOTIFICATIONS_CLEAR_NOTIFICATION' payload: string } export interface SetNotificationAutoAction extends Action { type: 'NOTIFICATIONS_SET_AUTO' payload: string } export type NotificationActions = AddNotificationAction | RemoveNotificationAction | ClearNotificationAction | SetNotificationAutoAction export const addNotification = (id: string, type: NotificationType, content: string): AddNotificationAction => ({ type: 'NOTIFICATIONS_ADD_NOTIFICATION', payload: { id, type, content, } }) export const removeNotification = (id: string): RemoveNotificationAction => ({ type: 'NOTIFICATIONS_REMOVE_NOTIFICATION', payload: id, }) export const clearNotification = (id: string): ClearNotificationAction => ({ type: 'NOTIFICATIONS_CLEAR_NOTIFICATION', payload: id, }) export const setNotificationAuto = (id: string): SetNotificationAutoAction => ({ type: 'NOTIFICATIONS_SET_AUTO', payload: id, }) export const showNotification = (type: NotificationType, content: string, expiration: number = 5000): AppThunkAction => { return async dispatch => { const id = v1() dispatch(addNotification(id, type, content)) setTimeout(() => { dispatch(clearNotification(id)) }, expiration) } }