-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathnotify.ts
55 lines (46 loc) · 1.68 KB
/
notify.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/********************************************************************************
* Copyright (c) 2023 BMW Group AG
* Copyright (c) 2023 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Apache License, Version 2.0 which is available at
* https://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* SPDX-License-Identifier: Apache-2.0
********************************************************************************/
import type { PayloadAction } from '@reduxjs/toolkit'
import { createSlice } from '@reduxjs/toolkit'
import type { RootState } from 'features/store'
const name = 'control/notify'
export enum SeverityType {
ERROR = 'error',
SUCCESS = 'success',
}
export type Notify = {
severity: SeverityType
title: string
msg?: string
data?: object | string | number | boolean
}
const initialState: Array<Notify> = []
export const slice = createSlice({
name,
initialState,
reducers: {
enq: (state, action: PayloadAction<Notify>) => [...state, action.payload],
deq: (state) => state.slice(1),
},
})
export const { enq, deq } = slice.actions
export const notifySelector = (state: RootState): Array<Notify> =>
state.control.notify
export default slice.reducer