Please wait a few seconds...
, - footer:All Parsers have been configured.
, - footer: ( -There was an issue trying to configure your parsers
, - css: 'emumodal--xs', - }; - console.log({ modalData }); - } - setStatePage({ - ...statePage, - modal: modalData, - }); - }); - }, [emulatorAlternative]); - const installEmu = (emulator, code) => { const modalData = { active: true, @@ -865,437 +724,17 @@ function EmulatorsDetailPage() { emulator === 'rmg' || emulator === 'flycast' ) { - let emuOption1; - let emuOption2; - let emuID1; - let emuID2; - let system; - let multiemulatorName; - let multiemulatorID; - let modalData; - // //RA || ARES + mGBA - if ( - (emulator === 'mgba' && installEmus.ra.status) || - (emulator === 'mgba' && installEmus.ares.status) - ) { - if (emulatorAlternative.gba !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'mGBA'; - emuOption2 = multiemulatorName; - emuID2 = 'mgba'; - emuID1 = multiemulatorID; - system = 'gba'; - modalData = { - active: true, - body: ( - <> -- Which emulator do you want to use for GameBoy Advance. -
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - // //RA || ARES + rmg - if ( - (emulator === 'rmg' && installEmus.ra.status) || - (emulator === 'rmg' && installEmus.ares.status) - ) { - // alert(emuModified); - if (emulatorAlternative.n64 !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'rmg'; - emuOption2 = multiemulatorName; - emuID2 = 'rmg'; - emuID1 = multiemulatorID; - system = 'n64'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - if ( - (emulator === 'duckstation' && installEmus.ra.status) || - (emulator === 'duckstation' && installEmus.ares.status) - ) { - if (emulatorAlternative.psx !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'DuckStation'; - emuOption2 = multiemulatorName; - emuID2 = 'duckstation'; - emuID1 = multiemulatorID; - system = 'psx'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - if ( - (emulator === 'flycast' && installEmus.ra.status) || - (emulator === 'flycast' && installEmus.ares.status) - ) { - if (emulatorAlternative.dreamcast !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'Flycast'; - emuOption2 = multiemulatorName; - emuID2 = 'flycast'; - emuID1 = multiemulatorID; - system = 'dreamcast'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - if ( - (emulator === 'melonds' && installEmus.ra.status) || - (emulator === 'melonds' && installEmus.ares.status) - ) { - if (emulatorAlternative.nds !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'melonDS'; - emuOption2 = multiemulatorName; - emuID2 = 'melonds'; - emuID1 = multiemulatorID; - system = 'nds'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - if ( - (emulator === 'ppsspp' && installEmus.ra.status) || - (emulator === 'ppsspp' && installEmus.ares.status) - ) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'PPSSPP'; - emuOption2 = multiemulatorName; - emuID2 = 'ppsspp'; - emuID1 = multiemulatorID; - system = 'psp'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection so - you don't end up with duplicates in your library. -
- > - ), - }; - console.log({ modalData }); - const myTimeout = setTimeout(launchModal, 500); - } - - if ( - (emulator === 'mame' && installEmus.ra.status) || - (emulator === 'mame' && installEmus.ares.status) - ) { - if (emulatorAlternative.mame !== 'both') { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'RetroArch'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - multiemulatorName = 'ares'; - } - - emuOption1 = 'MAME'; - emuOption2 = multiemulatorName; - emuID2 = 'mame'; - emuID1 = multiemulatorID; - system = 'mame'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - - if ( - (emulator === 'scummvm' && installEmus.ra.status) || - (emulator === 'scummvm' && installEmus.ares.status) - ) { - if (emulatorAlternative.scummvm !== 'both') { - multiemulatorID = 'multiemulator'; - if (installEmus.ares.status) { - multiemulatorID = 'multiemulator'; - } - - emuOption1 = 'ScummVM'; - emuOption2 = multiemulatorName; - emuID2 = 'scummvm'; - emuID1 = multiemulatorID; - system = 'scummvm'; - modalData = { - active: true, - body: ( - <> -Which emulator do you want to use
-- We will only add the parser according to your selection - so you don't end up with duplicates in your library. -
- > - ), - }; - const myTimeout = setTimeout(launchModal, 500); - } - } - console.log({ modalData }); - function launchModal() { - modalData = { - ...modalData, - header: ( - RetroArch or Standalone Emulator? - ), - css: 'emumodal--sm', - footer: ( - <> -+ If you want to use this new Standalone emulator in Steam you + need to go to Steam Rom Manager and pick the proper parser. +
+ ), + css: 'emumodal--xs', + }; } } else { const modalData = { @@ -1614,13 +1053,23 @@ function EmulatorsDetailPage() { }); }; + const selectEmu = (e) => { + const emu = e.target.value; + if (emu != '-1') { + setStatePage({ + ...statePage, + emulatorSelected: emu, + }); + } + }; + useEffect(() => { // We save it on localstorage const json = JSON.stringify(state); localStorage.setItem('settings_emudeck', json); }, [state]); - useEffect(() => { + // Check for bios switch (emulator) { case 'ra': checkBios('checkPS1BIOS'); @@ -1644,18 +1093,8 @@ function EmulatorsDetailPage() { break; default: } - }, []); - const selectEmu = (e) => { - const emu = e.target.value; - if (emu != '-1') { - setStatePage({ - ...statePage, - emulatorSelected: emu, - }); - } - }; - useEffect(() => { + // Check for updates ipcChannel.sendMessage('check-versions'); ipcChannel.once('check-versions', (repoVersions) => { // No versioning found, what to do? @@ -1671,7 +1110,10 @@ function EmulatorsDetailPage() { }); }); - // eslint-disable-next-line react-hooks/exhaustive-deps + // save OG Alternatives + const ogStateAlternativeValues = emulatorAlternative; + const json = JSON.stringify(ogStateAlternativeValues); + localStorage.setItem('ogStateAlternative', json); }, []); useEffect(() => { @@ -1688,6 +1130,91 @@ function EmulatorsDetailPage() { } }, [modal]); + useEffect(() => { + if (lastSelected !== null) { + saveParsers(); + } + }, [lastSelected]); + + useEffect(() => { + const ogStateAlternative = JSON.parse( + localStorage.getItem('ogStateAlternative') + ); + + function sameObjects(obj1, obj2) { + const keys1 = Object.keys(obj1); + const keys2 = Object.keys(obj2); + + if (keys1.length !== keys2.length) { + return false; + } + + for (const key of keys1) { + if (obj1[key] !== obj2[key]) { + return false; + } + } + + return true; + } + + const sameObject = sameObjects(ogStateAlternative, emulatorAlternative); + + if (sameObject) { + return; + } + + if (system === 'win32') { + ipcChannel.sendMessage('emudeck', [ + `parsersUpdatePrev|||setSetting emuGBA ${state.emulatorAlternative.gba}; setSetting emuMAME ${state.emulatorAlternative.mame}; setSetting emuMULTI ${state.emulatorAlternative.multiemulator}; setSetting emuN64 ${state.emulatorAlternative.n64}; setSetting emuNDS ${state.emulatorAlternative.nds}; setSetting emuPSP ${state.emulatorAlternative.psp}; setSetting emuPSX ${state.emulatorAlternative.psx}; setSetting emuSCUMMVM ${state.emulatorAlternative.scummvm}; setSetting doInstallPPSSPP ${state.installEmus.ppsspp.status};setSetting doInstallmelonDS ${state.installEmus.melonds.status};setSetting doInstallDuck ${state.installEmus.duckstation.status};;setSetting doInstallFlycast ${state.installEmus.dreamcast.status}`, + ]); + } else { + ipcChannel.sendMessage('emudeck', [ + `parsersUpdatePrev|||$(. ~/.config/EmuDeck/backend/functions/all.sh && setSetting emuGBA ${state.emulatorAlternative.gba} >/dev/null && setSetting emuMAME ${state.emulatorAlternative.mame} >/dev/null && setSetting emuMULTI ${state.emulatorAlternative.multiemulator} >/dev/null && setSetting emuN64 ${state.emulatorAlternative.n64} >/dev/null && setSetting emuNDS ${state.emulatorAlternative.nds} >/dev/null && setSetting emuPSP ${state.emulatorAlternative.psp} >/dev/null && setSetting emuPSX ${state.emulatorAlternative.psx} >/dev/null && setSetting emuSCUMMVM ${state.emulatorAlternative.scummvm} && setSetting doInstallPPSSPP ${state.installEmus.ppsspp.status} >/dev/null && setSetting doInstallMAME ${state.installEmus.mame.status} >/dev/null && setSetting doInstallmelonDS ${state.installEmus.melonds.status} >/dev/null && setSetting doInstallDuck ${state.installEmus.duckstation.status} >/dev/null && setSetting doInstallFlycast ${state.installEmus.flycast.status} >/dev/null && setSetting doInstallMAME ${state.installEmus.mame} >/dev/null && setSetting doInstallRMG ${state.installEmus.rmg.status} >/dev/null && setSetting doInstallScummVM ${state.installEmus.scummvm.status} >/dev/null && setSetting doInstallScummVM ${state.installEmus.scummvm.status}} >/dev/null) >/dev/null`, + ]); + } + + ipcChannel.once(`parsersUpdatePrev`, () => { + ipcChannel.sendMessage('emudeck', [`parsersUpdate|||SRM_init`]); + }); + + ipcChannel.once(`parsersUpdate`, (message) => { + const status = message.stdout; + status.replace('\n', ''); + console.log({ message }); + let modalData; + if (status.includes('true')) { + modalData = { + active: true, + header: Success!, + body:All Parsers have been configured.
, + footer: ( +There was an issue trying to configure your parsers
, + css: 'emumodal--xs', + }; + console.log({ modalData }); + } + setStatePage({ + ...statePage, + modal: modalData, + }); + }); + }, [emulatorAlternative]); + return (