All files / src/store/features/entities/reducers emotesReducers.ts

63.64% Statements 7/11
100% Branches 0/0
0% Functions 0/3
63.64% Lines 7/11

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 46 47 48 49 50 51 52 53 54 55 56 57 58 59            46x             46x         46x                             46x                           46x       46x           46x  
import {
  PayloadAction,
  CaseReducer,
  SliceCaseReducers,
} from "@reduxjs/toolkit";
import { EntitiesState } from "shared/lib/entities/entitiesTypes";
import {
  ensureSymbolsUnique,
  removeAssetEntity,
  upsertAssetEntity,
  updateEntitySymbol,
} from "shared/lib/entities/entitiesHelpers";
import { EmoteResourceAsset } from "shared/lib/resources/types";
import { emotesAdapter } from "store/features/entities/adapters";
 
const setEmoteSymbol: CaseReducer<
  EntitiesState,
  PayloadAction<{ emoteId: string; symbol: string }>
> = (state, action) => {
  updateEntitySymbol(
    state,
    state.emotes,
    emotesAdapter,
    action.payload.emoteId,
    action.payload.symbol,
  );
};
 
const loadEmote: CaseReducer<
  EntitiesState,
  PayloadAction<{
    data: EmoteResourceAsset;
  }>
> = (state, action) => {
  upsertAssetEntity(state.emotes, emotesAdapter, action.payload.data, [
    "id",
    "symbol",
  ]);
  ensureSymbolsUnique(state);
};
 
const removeEmote: CaseReducer<
  EntitiesState,
  PayloadAction<{
    filename: string;
    plugin?: string;
  }>
> = (state, action) => {
  removeAssetEntity(state.emotes, emotesAdapter, action.payload);
};
 
const emotesReducers = {
  loadEmote,
  setEmoteSymbol,
  removeEmote,
} satisfies SliceCaseReducers<EntitiesState>;
 
export default emotesReducers;