All files / src/components/world/entities/scenes/helpers scenePalettes.ts

0% Statements 0/12
0% Branches 0/18
0% Functions 0/3
0% Lines 0/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                                                                                                   
import { DMG_PALETTE } from "consts";
import { Palette } from "shared/lib/resources/types";
 
const PALETTE_COUNT = 8;
 
type PaletteLookup<Palette> = Record<string, Palette | undefined>;
 
export const dmgPalettes = [
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
  DMG_PALETTE,
];
 
const resolvePalette = (
  paletteIds: readonly (string | undefined)[] | undefined,
  defaultPaletteIds: readonly (string | undefined)[],
  palettesLookup: PaletteLookup<Palette>,
  paletteIndex: number,
): Palette => {
  const paletteId = paletteIds?.[paletteIndex];
 
  Iif (paletteId === "dmg") {
    return DMG_PALETTE;
  }
 
  return (
    palettesLookup[paletteId ?? ""] ||
    palettesLookup[defaultPaletteIds[paletteIndex] ?? ""] ||
    DMG_PALETTE
  );
};
 
export const resolveScenePalettes = (
  paletteIds: readonly (string | undefined)[] | undefined,
  defaultPaletteIds: readonly (string | undefined)[],
  palettesLookup: PaletteLookup<Palette>,
  colorsEnabled: boolean,
): Palette[] => {
  return colorsEnabled
    ? Array.from({ length: PALETTE_COUNT }, (_, index) =>
        resolvePalette(paletteIds, defaultPaletteIds, palettesLookup, index),
      )
    : dmgPalettes;
};