From 86e9121f2558b4f2ceadd1b8acbcee41d1e55ae1 Mon Sep 17 00:00:00 2001 From: edo999 Date: Tue, 17 Sep 2024 11:53:58 +0100 Subject: [PATCH] =?UTF-8?q?Add=20names=20to=20costumes=20=F0=9F=8F=B7?= =?UTF-8?q?=EF=B8=8F.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/components/CostumesList.js | 3 +- src/components/ScreenNamesSelector.js | 2 +- src/containers/CostumesContainer.js | 3 +- src/containers/SettingsContainer.js | 34 ++++++++-------- src/lib/getCostumeLabel.js | 58 +++++++++++++++++++++++++++ 5 files changed, 80 insertions(+), 20 deletions(-) create mode 100644 src/lib/getCostumeLabel.js diff --git a/src/components/CostumesList.js b/src/components/CostumesList.js index 0f132fb..f98788e 100644 --- a/src/components/CostumesList.js +++ b/src/components/CostumesList.js @@ -1,3 +1,4 @@ +import getCostumeLabel from '../lib/getCostumeLabel'; import ColumnListHeader from './ColumnListHeader'; import ColumnListItem from './ColumnListItem'; @@ -10,7 +11,7 @@ const CostumesList = ({ costumeSets, currentSetId, currentId }) => { {costumeSet.map((unused, id) => { const selected = costumeSetId === currentSetId && id === currentId; const path = `/costumes/${costumeSetId}/${id}`; - const label = `Costume ${id}`; + const label = getCostumeLabel(costumeSetId, id); return (

- Screen names + Resource naming scheme

- + {currentSetId === 0 ? ( diff --git a/src/containers/SettingsContainer.js b/src/containers/SettingsContainer.js index 1cfdb62..2fbf915 100644 --- a/src/containers/SettingsContainer.js +++ b/src/containers/SettingsContainer.js @@ -3,7 +3,7 @@ import Main from '../components/Main'; import MainHeader from '../components/MainHeader'; import ThemeSwitcher from '../components/ThemeSwitcher'; import PaletteSelector from '../components/PaletteSelector'; -import ScreenNamesSelector from '../components/ScreenNamesSelector'; +import NameSelector from '../components/ScreenNamesSelector'; import { setColourTheme } from '../lib/colourThemeUtils'; import digitalPrimeFbxImg from '../assets/palettes/digital-prime-fbx.png'; @@ -39,16 +39,16 @@ const paletteOptions = [ }, ]; -const screenNameOptions = [ +const nameOptions = [ { value: 'mm', - name: 'Maniac Mansion screen names', + name: 'Names from Maniac Mansion', description: 'Useful when working on a Maniac Mansion ROM hack.', defaultOption: true, }, { value: 'numbers', - name: 'Numbered screen names', + name: 'Numbered items', description: 'Better if your ROM hack is a completely different game.', }, ]; @@ -65,14 +65,14 @@ const SettingsContainer = () => { paletteOptions.find(({ value }) => value === selectedPaletteValue) || paletteOptions.find(({ defaultOption }) => defaultOption); - const selectedScreenNameValue = localStorage.getItem('screen-name'); - const selectedScreenName = - screenNameOptions.find(({ value }) => value === selectedScreenNameValue) || - screenNameOptions.find(({ defaultOption }) => defaultOption); + const selectedNameValue = localStorage.getItem('screen-name'); + const selectedName = + nameOptions.find(({ value }) => value === selectedNameValue) || + nameOptions.find(({ defaultOption }) => defaultOption); const [theme, setTheme] = useState(selectedTheme); const [palette, setPalette] = useState(selectedPalette); - const [screenName, setScreenName] = useState(selectedScreenName); + const [name, setName] = useState(selectedName); // Keep the local storage and the DOM in sync with the state. const setThemeWrapper = (theme) => { @@ -99,15 +99,15 @@ const SettingsContainer = () => { localStorage.setItem('palette', palette.value); }; - const setScreenNameWrapper = (screenName) => { - setScreenName(screenName); + const setNameWrapper = (name) => { + setName(name); - if (screenName.defaultOption) { + if (name.defaultOption) { localStorage.removeItem('screen-name'); return; } - localStorage.setItem('screen-name', screenName.value); + localStorage.setItem('screen-name', name.value); }; return ( @@ -123,10 +123,10 @@ const SettingsContainer = () => { paletteOptions={paletteOptions} setPalette={setPaletteWrapper} /> -
); diff --git a/src/lib/getCostumeLabel.js b/src/lib/getCostumeLabel.js new file mode 100644 index 0000000..6c78870 --- /dev/null +++ b/src/lib/getCostumeLabel.js @@ -0,0 +1,58 @@ +import { zeroPad } from './utils'; + +const costumeNames = [ + [ + 'Unused', + 'Syd', + 'Razor', + 'Dave', + 'Michael', + 'Bernard', + 'Wendy', + 'Jeff', + 'Radioactive suit', + 'Fred Edison', + 'Nurse Edna', + 'Weird Ed', + 'Cousin Ted', + 'Purple tentacle', + 'Green tentacle', + 'Meteor police', + 'Meteor', + 'Mark Eteer', + 'Wink Smiley', + 'Man eating plant', + 'Bubble', + 'Unused', + 'Unused', + 'Sandy', + 'Suit w/ meteor', + ], + ['Flying Edsel', 'Meteor intro', 'Cursor arrow', 'Sprite0'], +]; + +const getCostumeLabel = (costumeSetId = 0, id = 0, long = false) => { + switch (localStorage.getItem('screen-name')) { + default: + case 'mm': + const costumeName = costumeNames[costumeSetId][id]; + if (!costumeName) { + throw new Error( + `Unknown costume id ${id} in costume set id ${costumeSetId}`, + ); + } + + if (long) { + return `Costume ${zeroPad(id)} - ${costumeName}`; + } + return `${id} ${costumeName}`; + + case 'numbers': + if (long) { + return `Costume ${zeroPad(id)}`; + } + return `Costume ${id}`; + } +}; + +export default getCostumeLabel;