All files / src/store/features/navigation navigationState.ts

100% Statements 10/10
100% Branches 0/0
100% Functions 4/4
100% Lines 10/10

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 4627x 27x                                 27x         27x         1x     1x       1x     1x       27x   27x  
import { createSlice, PayloadAction } from "@reduxjs/toolkit";
import entitiesActions from "store/features/entities/entitiesActions";
 
export type NavigationSection =
  | "world"
  | "sprites"
  | "backgrounds"
  | "music"
  | "sounds"
  | "palettes"
  | "dialogue"
  | "settings";
 
export interface NavigationState {
  section: NavigationSection;
  id: string;
}
 
export const initialState: NavigationState = {
  section: "world",
  id: "",
};
 
const navigationSlice = createSlice({
  name: "navigation",
  initialState,
  reducers: {
    setSection: (state, action: PayloadAction<NavigationSection>) => {
      state.section = action.payload;
    },
    setNavigationId: (state, action: PayloadAction<string>) => {
      state.id = action.payload;
    },
  },
  extraReducers: (builder) =>
    builder
      // Select newly created palette in sidebar
      .addCase(entitiesActions.addPalette, (state, action) => {
        state.id = action.payload.paletteId;
      }),
});
 
export const { reducer, actions } = navigationSlice;
 
export default reducer;