From e6b6f41cb519c1a98af591a0c631ef254d2f4a2c Mon Sep 17 00:00:00 2001 From: Micah Clegg <31600957+Trajkov@users.noreply.github.com> Date: Sat, 29 Jul 2023 17:02:29 -0600 Subject: [PATCH 1/7] Fix interface card not rendering --- src/components/layouts/cardRenderer.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/components/layouts/cardRenderer.js b/src/components/layouts/cardRenderer.js index 8f3869e53..b81d03d31 100644 --- a/src/components/layouts/cardRenderer.js +++ b/src/components/layouts/cardRenderer.js @@ -121,6 +121,7 @@ function renderCards(props) { return { ...card, in: card.name === cardName, + component: Views.Interface, props: { ...props, interfaceId: card.component.replace("interface-id:", ""), From ec24f6a571645a29aedc1c06f0fe907f5401db2b Mon Sep 17 00:00:00 2001 From: Alex Anderson Date: Fri, 18 Aug 2023 06:49:40 -0400 Subject: [PATCH 2/7] fix(Import): Fixed an issue where probes did not appear after importing a flight. Sponsored by the Space Place at Renaissance Academy --- server/imports/flights/export.js | 3 ++- server/imports/flights/import.js | 8 ++++++-- server/triggers/remoteAccess.ts | 2 -- server/typeDefs/flight.ts | 17 +++++++++++------ server/typeDefs/hullPlating.ts | 1 - src/components/views/Armory/index.js | 5 +++-- 6 files changed, 22 insertions(+), 14 deletions(-) diff --git a/server/imports/flights/export.js b/server/imports/flights/export.js index 6243bcceb..04e344b0b 100644 --- a/server/imports/flights/export.js +++ b/server/imports/flights/export.js @@ -22,7 +22,8 @@ export default function exportFlight(id, res) { return res.end("No flight"); } const zipfile = new yazl.ZipFile(); - const data = {flight: flight, simulators: []}; + const {timeouts, ...flightData} = flight; + const data = {flight: flightData, simulators: []}; data.simulators = flight.simulators.map(simId => { const sim = App.simulators.find(s => s.id === simId); aspectList.forEach(aspect => { diff --git a/server/imports/flights/import.js b/server/imports/flights/import.js index 88661bd2e..4fdff4b5e 100644 --- a/server/imports/flights/import.js +++ b/server/imports/flights/import.js @@ -34,10 +34,14 @@ export default function ImportFlight(filepath, cb) { streamToString(readStream, str => { const data = JSON.parse(str); // Create a duplicate flight with a different ID + let name = data.flight.name; + if (App.flights.some(f => f.name === data.flight.name)) { + name = `${data.flight.name} - Imported`; + } const flight = new Classes.Flight({ ...data.flight, id: uuid.v4(), - name: `${data.flight.name} - Imported`, + name, }); flight.simulators = flight.simulators.map(s => { const newId = uuid.v4(); @@ -51,7 +55,7 @@ export default function ImportFlight(filepath, cb) { sim.stations = sim.stations.map(s => new Classes.Station(s)); App.simulators.push(sim); - addAspects(oldSim, sim, data); + addAspects(oldSim, sim, data, true); App.handleEvent( {simulatorId: sim.id, count: sim.exocomps}, diff --git a/server/triggers/remoteAccess.ts b/server/triggers/remoteAccess.ts index 32e997821..f83ad53d1 100644 --- a/server/triggers/remoteAccess.ts +++ b/server/triggers/remoteAccess.ts @@ -1,7 +1,6 @@ import App from "../app"; export function remoteAccessSendCode({simulatorId, code}) { - console.log(simulatorId, code); return {simulatorId, code}; } @@ -16,7 +15,6 @@ export function remoteAccessUpdateCode({ }) { const simulator = App.simulators.find(s => s.id === simulatorId); const code = simulator.ship.remoteAccessCodes.find(c => c.id === codeId); - console.log(simulatorId, state, code.code); return { simulatorId, state: state === "Accepted" ? "true" : "false", diff --git a/server/typeDefs/flight.ts b/server/typeDefs/flight.ts index 5e68496ad..8e7e52ef8 100644 --- a/server/typeDefs/flight.ts +++ b/server/typeDefs/flight.ts @@ -33,7 +33,12 @@ export const aspectList = [ "taskFlows", ]; -export function addAspects(template, sim: Classes.Simulator, data = App) { +export function addAspects( + template, + sim: Classes.Simulator, + data = App, + isImport = false, +) { // Duplicate all of the other stuff attached to the simulator too. aspectList.forEach(aspect => { @@ -142,7 +147,7 @@ export function addAspects(template, sim: Classes.Simulator, data = App) { } const classItem = new Classes[newAspect.class]( cloneDeep(newAspect), - true, + isImport ? false : true, ); App[aspect].push(classItem); }); @@ -167,7 +172,7 @@ export function addAspects(template, sim: Classes.Simulator, data = App) { ), }), ); - data.softwarePanels.push( + App.softwarePanels.push( new Classes.SoftwarePanel({ id, templateId: panel.id, @@ -194,7 +199,7 @@ export function addAspects(template, sim: Classes.Simulator, data = App) { id, simulatorId: sim.id, }; - data.commandLine.push(new Classes.CommandLine(commandLine)); + App.commandLine.push(new Classes.CommandLine(commandLine)); return id; }) .filter(Boolean); @@ -211,7 +216,7 @@ export function addAspects(template, sim: Classes.Simulator, data = App) { id, simulatorId: sim.id, }; - data.triggerGroups.push(new Classes.Trigger(trigger)); + App.triggerGroups.push(new Classes.Trigger(trigger)); return id; }) .filter(Boolean); @@ -228,7 +233,7 @@ export function addAspects(template, sim: Classes.Simulator, data = App) { id, simulatorId: sim.id, }; - data.interfaces.push(new Classes.Interface(interfaceObj)); + App.interfaces.push(new Classes.Interface(interfaceObj)); // Update any clients assigned to this interface as a station App.clients diff --git a/server/typeDefs/hullPlating.ts b/server/typeDefs/hullPlating.ts index 5910a45a4..06fb40631 100644 --- a/server/typeDefs/hullPlating.ts +++ b/server/typeDefs/hullPlating.ts @@ -75,7 +75,6 @@ const resolver = { s => s.simulatorId === simulatorId, ); } - console.log(returnSystems); return returnSystems; }, subscribe: withFilter( diff --git a/src/components/views/Armory/index.js b/src/components/views/Armory/index.js index 3a8300333..cdaec51b7 100644 --- a/src/components/views/Armory/index.js +++ b/src/components/views/Armory/index.js @@ -462,8 +462,9 @@ class Armory extends Component { const TeamList = ({team, teams, crew, selectedCrew, selectCrew}) => { if (team) { return teams - .find(t => t.id === team) - .officers.map(o => crew.find(c => c.id === o.id)) + .find(t => t?.id === team) + .officers.map(o => crew.find(c => c?.id === o?.id)) + .filter(Boolean) .map(o => (

Date: Fri, 18 Aug 2023 20:44:50 -0400 Subject: [PATCH 3/7] fix(Import): Fixed an issue where interfaces would not appear correctly after importing a flight. Sponsored by the Space Place at Renaissance Academy --- server/bootstrap/express.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/bootstrap/express.ts b/server/bootstrap/express.ts index f20004a18..e8a5f0196 100644 --- a/server/bootstrap/express.ts +++ b/server/bootstrap/express.ts @@ -204,7 +204,7 @@ export default () => { `/import${pascalCase(exportObj.exportable)}`, upload.any(), async (req: express.Request & {files: MulterFile[]}, res) => { - console.log(`Importing ${pascalCase(exportObj.exportable)}`); + console.info(`Importing ${pascalCase(exportObj.exportable)}`); if (req.files[0]) { const importZip = await new Promise( (resolve, reject) => From 3146e601f60c7808056da79b40c77b5c49fb1a6f Mon Sep 17 00:00:00 2001 From: Alex Anderson Date: Fri, 18 Aug 2023 20:45:19 -0400 Subject: [PATCH 4/7] fix(Import): Fixed an issue where team crew members would not be present after importing a flight. Sponsored by the Space Place at Renaissance Academy --- server/imports/flights/import.js | 2 -- 1 file changed, 2 deletions(-) diff --git a/server/imports/flights/import.js b/server/imports/flights/import.js index 4fdff4b5e..5df2ee7ee 100644 --- a/server/imports/flights/import.js +++ b/server/imports/flights/import.js @@ -52,8 +52,6 @@ export default function ImportFlight(filepath, cb) { id: newId, }); - sim.stations = sim.stations.map(s => new Classes.Station(s)); - App.simulators.push(sim); addAspects(oldSim, sim, data, true); From c9169c926860f57172a1de9dd317e23c3adafa3b Mon Sep 17 00:00:00 2001 From: Alex Anderson Date: Fri, 18 Aug 2023 20:45:53 -0400 Subject: [PATCH 5/7] fix(Import): Fixed an issue where tasks and task flows would not behave correctly after importing a flight. Sponsored by the Space Place at Renaissance Academy --- server/typeDefs/flight.ts | 56 ++++++++++++++++++++++++++++++++++++--- 1 file changed, 53 insertions(+), 3 deletions(-) diff --git a/server/typeDefs/flight.ts b/server/typeDefs/flight.ts index 8e7e52ef8..273b95cde 100644 --- a/server/typeDefs/flight.ts +++ b/server/typeDefs/flight.ts @@ -40,7 +40,7 @@ export function addAspects( isImport = false, ) { // Duplicate all of the other stuff attached to the simulator too. - + const aspectMap: Record = {}; aspectList.forEach(aspect => { if ( aspect === "softwarePanels" || @@ -48,14 +48,14 @@ export function addAspects( aspect === "triggers" || aspect === "midiSets" || aspect === "interfaces" || - aspect === "dmxFixtures" || - aspect === "taskFlows" + aspect === "dmxFixtures" ) { return; } const filterAspect = data[aspect].filter( a => a.simulatorId === template.simulatorId, ); + filterAspect.forEach(a => { const newAspect = cloneDeep(a); newAspect.templateId = newAspect.id; @@ -145,10 +145,48 @@ export function addAspects( newAspect.heat = 0; } } + // Teams need to reference crew + if (aspect === "teams") { + newAspect.officers = newAspect.officers.map(o => aspectMap[o]); + newAspect.location = + aspectMap[newAspect.location] || + aspectMap[newAspect.location] || + newAspect.location; + } + if (aspect === "taskReports") { + newAspect.systemId = + aspectMap[newAspect.systemId] || newAspect.systemId; + newAspect.tasks.forEach(t => { + t.id = aspectMap[t.id] || t.id; + t.systemId = aspectMap[t.systemId] || t.systemId; + t.simulatorId = sim.id; + }); + } + if (aspect === "taskFlows") { + newAspect.steps.forEach(s => { + s.activeTaskIds = s.activeTaskIds.map(t => aspectMap[t] || t); + s.tasks.forEach(t => { + t.id = aspectMap[t.id] || t.id; + t.simulatorId = sim.id; + }); + }); + } + if (aspect === "tasks") { + newAspect.simulatorId = sim.id; + newAspect.systemId = + aspectMap[newAspect.systemId] || newAspect.systemId; + newAspect.deck = aspectMap[newAspect.deck] || newAspect.deck; + newAspect.room = aspectMap[newAspect.room] || newAspect.room; + } + const classItem = new Classes[newAspect.class]( cloneDeep(newAspect), isImport ? false : true, ); + + // Set up references + aspectMap[newAspect.templateId] = classItem.id; + App[aspect].push(classItem); }); }); @@ -245,6 +283,18 @@ export function addAspects( .forEach(client => { client.setStation(`interface-id:${id}`); }); + + // Update any stations that have this interface as a card. + sim.stations.forEach(station => { + station.cards.forEach(card => { + if ( + card.component.match(/interface-id:.{8}-.{4}-.{4}-.{4}-.{12}/gi) + ) { + card.component = `interface-id:${interfaceObj.templateId}`; + } + }); + }); + return id; }) .filter(Boolean); From 010ae09b5a8ff607e4a4e272e2943b66d5c7c935 Mon Sep 17 00:00:00 2001 From: Alex Anderson Date: Sat, 19 Aug 2023 10:37:16 -0400 Subject: [PATCH 6/7] feat(Sensors): Enable moving contacts over a specific number of seconds. Sponsored by the Space Place at Renaissance Academy --- .../views/Sensors/gridCore/CoreSidebar.js | 2 +- .../views/Sensors/gridCore/index.js | 20 ++++++++++++++++--- .../views/Sensors/gridCore/speedAsker.js | 1 + 3 files changed, 19 insertions(+), 4 deletions(-) diff --git a/src/components/views/Sensors/gridCore/CoreSidebar.js b/src/components/views/Sensors/gridCore/CoreSidebar.js index 11b41b483..1487666fc 100644 --- a/src/components/views/Sensors/gridCore/CoreSidebar.js +++ b/src/components/views/Sensors/gridCore/CoreSidebar.js @@ -59,7 +59,7 @@ export const CoreSidebar = ({ ))} - +