2023-07-08 14:01:08 -04:00
|
|
|
import { List as ImmutableList } from 'immutable';
|
2023-05-23 11:15:17 -04:00
|
|
|
|
2016-11-20 13:39:18 -05:00
|
|
|
import {
|
|
|
|
ALERT_SHOW,
|
|
|
|
ALERT_DISMISS,
|
2017-05-20 11:31:47 -04:00
|
|
|
ALERT_CLEAR,
|
2016-11-20 13:39:18 -05:00
|
|
|
} from '../actions/alerts';
|
|
|
|
|
2017-07-10 19:00:14 -04:00
|
|
|
const initialState = ImmutableList([]);
|
2016-11-20 13:39:18 -05:00
|
|
|
|
2023-07-08 14:01:08 -04:00
|
|
|
let id = 0;
|
|
|
|
|
|
|
|
const addAlert = (state, alert) =>
|
|
|
|
state.push({
|
|
|
|
key: id++,
|
|
|
|
...alert,
|
|
|
|
});
|
|
|
|
|
2016-11-20 13:39:18 -05:00
|
|
|
export default function alerts(state = initialState, action) {
|
|
|
|
switch(action.type) {
|
2017-04-15 07:27:27 -04:00
|
|
|
case ALERT_SHOW:
|
2023-07-08 14:01:08 -04:00
|
|
|
return addAlert(state, action.alert);
|
2017-04-15 07:27:27 -04:00
|
|
|
case ALERT_DISMISS:
|
2023-07-08 14:01:08 -04:00
|
|
|
return state.filterNot(item => item.key === action.alert.key);
|
2017-04-15 07:27:27 -04:00
|
|
|
case ALERT_CLEAR:
|
|
|
|
return state.clear();
|
|
|
|
default:
|
|
|
|
return state;
|
2016-11-20 13:39:18 -05:00
|
|
|
}
|
2022-12-18 10:51:37 -05:00
|
|
|
}
|