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 60 61 62 63 64 65 66 67 68 | 46x 46x 46x 46x 46x 2x 2x 46x 46x 46x 46x | import {
PayloadAction,
CaseReducer,
SliceCaseReducers,
} from "@reduxjs/toolkit";
import { EntitiesState } from "shared/lib/entities/entitiesTypes";
import {
ensureSymbolsUnique,
upsertAssetEntity,
updateEntitySymbol,
} from "shared/lib/entities/entitiesHelpers";
import { MusicAsset, MusicSettings } from "shared/lib/resources/types";
import { musicAdapter } from "store/features/entities/adapters";
import { localMusicSelectById } from "store/features/entities/helpers";
export const loadMusic: CaseReducer<
EntitiesState,
PayloadAction<{
data: MusicAsset;
}>
> = (state, action) => {
upsertAssetEntity(state.music, musicAdapter, action.payload.data, [
"id",
"symbol",
"settings",
]);
ensureSymbolsUnique(state);
};
const editMusicSettings: CaseReducer<
EntitiesState,
PayloadAction<{ musicId: string; changes: Partial<MusicSettings> }>
> = (state, action) => {
const music = localMusicSelectById(state, action.payload.musicId);
Iif (music) {
musicAdapter.updateOne(state.music, {
id: music.id,
changes: {
settings: {
...music.settings,
...action.payload.changes,
},
},
});
}
};
const setMusicSymbol: CaseReducer<
EntitiesState,
PayloadAction<{ musicId: string; symbol: string }>
> = (state, action) => {
updateEntitySymbol(
state,
state.music,
musicAdapter,
action.payload.musicId,
action.payload.symbol,
);
};
const musicReducers = {
loadMusic,
editMusicSettings,
setMusicSymbol,
} satisfies SliceCaseReducers<EntitiesState>;
export default musicReducers;
|