Вы должны хранить свои вкладки с @ngrx/entity
.Состояние пользовательского интерфейса определенно принадлежит магазину, см. здесь .
Ваш редуктор может выглядеть как
import { createEntityAdapter, EntityState } from '@ngrx/entity';
import { TabsActions, TabsActionTypes } from '../actions';
import { Tab } from '../../models/tab';
export const adapter = createEntityAdapter<Tab>({
selectId: tab => tab.id,
sortComparer: (tabA, tabB) => tabA.id === tabB.id ? 0 : tabA.id > tabB.id ? 1 : -1
});
export interface State extends EntityState<Tab> {
currentTab: number
}
export const initialState = adapter.getInitialState({
currentTab: 0
});
export function reducer(state = initialState, action: TabsActions) {
switch (action.type) {
case TabsActionTypes.Add:
return adapter.add(action.payload, state);
case TabsActionTypes.Close:
return adapter.remove(action.payload, state);
case TabsActionTypes.SwitchTab:
return { ...state, currentTab: action.payload }
default:
return state;
}
}
С действиями, определенными как
import { Action } from '@ngrx/store';
import { Tab } from '../../models/tab';
export enum TabsActionTypes {
Add = '[Tabs] Add',
Close= '[Tabs] Close',
SwitchTab = '[Tabs] Switch'
}
export class AddTab implements Action {
readonly type = TabsActionTypes.Add;
constructor(public payload: Tab) {}
}
// Define other actions (CloseTab, SwitchTab) in a similar way
export type TabsActions =
AddTab |
CloseTab |
SwitchTab;