mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
45 lines
1.5 KiB
TypeScript
45 lines
1.5 KiB
TypeScript
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
import { AppNotification, AppNotificationsState } from 'app/types/';
|
|
|
|
export const initialState: AppNotificationsState = {
|
|
appNotifications: [] as AppNotification[],
|
|
};
|
|
|
|
/**
|
|
* Reducer and action to show toast notifications of various types (success, warnings, errors etc). Use to show
|
|
* transient info to user, like errors that cannot be otherwise handled or success after an action.
|
|
*
|
|
* Use factory functions in core/copy/appNotifications to create the payload.
|
|
*/
|
|
const appNotificationsSlice = createSlice({
|
|
name: 'appNotifications',
|
|
initialState,
|
|
reducers: {
|
|
notifyApp: (state, action: PayloadAction<AppNotification>) => {
|
|
const newAlert = action.payload;
|
|
|
|
for (const existingAlert of state.appNotifications) {
|
|
if (
|
|
newAlert.icon === existingAlert.icon &&
|
|
newAlert.severity === existingAlert.severity &&
|
|
newAlert.text === existingAlert.text &&
|
|
newAlert.title === existingAlert.title &&
|
|
newAlert.component === existingAlert.component
|
|
) {
|
|
return;
|
|
}
|
|
}
|
|
|
|
state.appNotifications.push(newAlert);
|
|
},
|
|
clearAppNotification: (state, action: PayloadAction<string>): AppNotificationsState => ({
|
|
...state,
|
|
appNotifications: state.appNotifications.filter((appNotification) => appNotification.id !== action.payload),
|
|
}),
|
|
},
|
|
});
|
|
|
|
export const { notifyApp, clearAppNotification } = appNotificationsSlice.actions;
|
|
|
|
export const appNotificationsReducer = appNotificationsSlice.reducer;
|