Commit 50da456b by Torkel Ödegaard Committed by GitHub

Alerts: Dedupe alerts so that we do not fill the screen with the same alert messsage (#30935)

parent ae64dcf0
...@@ -116,4 +116,46 @@ describe('notify', () => { ...@@ -116,4 +116,46 @@ describe('notify', () => {
expect(result).toEqual(expectedResult); expect(result).toEqual(expectedResult);
}); });
it('Dedupe identical alerts', () => {
const initialState = {
appNotifications: [
{
id: 'id1',
severity: AppNotificationSeverity.Success,
icon: 'success',
title: 'test',
text: 'test alert',
timeout: AppNotificationTimeout.Success,
},
],
};
const result = appNotificationsReducer(
initialState,
notifyApp({
id: 'id2',
severity: AppNotificationSeverity.Success,
icon: 'success',
title: 'test',
text: 'test alert',
timeout: AppNotificationTimeout.Success,
})
);
const expectedResult = {
appNotifications: [
{
id: 'id1',
severity: AppNotificationSeverity.Success,
icon: 'success',
title: 'test',
text: 'test alert',
timeout: AppNotificationTimeout.Success,
},
],
};
expect(result).toEqual(expectedResult);
});
}); });
...@@ -15,10 +15,23 @@ const appNotificationsSlice = createSlice({ ...@@ -15,10 +15,23 @@ const appNotificationsSlice = createSlice({
name: 'appNotifications', name: 'appNotifications',
initialState, initialState,
reducers: { reducers: {
notifyApp: (state, action: PayloadAction<AppNotification>): AppNotificationsState => ({ notifyApp: (state, action: PayloadAction<AppNotification>) => {
...state, const newAlert = action.payload;
appNotifications: state.appNotifications.concat([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 => ({ clearAppNotification: (state, action: PayloadAction<string>): AppNotificationsState => ({
...state, ...state,
appNotifications: state.appNotifications.filter((appNotification) => appNotification.id !== action.payload), appNotifications: state.appNotifications.filter((appNotification) => appNotification.id !== action.payload),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment