From 4242dbec4d14708e238cb7faa5c594187a62425d Mon Sep 17 00:00:00 2001 From: Alexander Goryushkin Date: Fri, 29 Dec 2023 17:17:31 -0300 Subject: [PATCH] fix save/load mapbox scene - move environment and cameraRig to a-acene parent - fix saving mapbox component data --- mapbox.html | 107 ++++++++-------------------------------------- src/json-utils.js | 17 ++++++-- 2 files changed, 31 insertions(+), 93 deletions(-) diff --git a/mapbox.html b/mapbox.html index 194a9a2e0..ba1621781 100644 --- a/mapbox.html +++ b/mapbox.html @@ -98,17 +98,17 @@ streetmix-loader="streetmixStreetURL: https://streetmix.net/scott/31/south-van-ness-idea-short-term; showBuildings: false;" > - - - - - - - - + + + + + + + + - diff --git a/src/json-utils.js b/src/json-utils.js index 05d471845..d81083aa0 100644 --- a/src/json-utils.js +++ b/src/json-utils.js @@ -108,7 +108,7 @@ function getAttributes (entity) { if (isEmpty(modifiedProperty)) { elemObj['components'][componentName] = ''; } else { - elemObj['components'][componentName] = toPropString(modifiedProperty); + elemObj['components'][componentName] = toPropString(componentName, modifiedProperty); } } } @@ -116,7 +116,14 @@ function getAttributes (entity) { return elemObj; } -function toPropString (propData) { +// properties or attributes that should be stored as a string in saved JSON +const propsToString = ["mapbox"]; + +function toPropString (componentName, propData) { + if (propsToString.includes(componentName)) { + // return a string if key is an attribute or property listed in the propsToString array + return AFRAME.utils.styleParser.stringify(propData); + } if ( typeof propData === 'string' || typeof propData === 'number' || @@ -143,7 +150,7 @@ function toPropString (propData) { return `${key}: ${value}`; } } else { - return `${key}: ${toPropString(value)}`; + return `${key}: ${toPropString(key, value)}`; } }) .join('; '); @@ -184,6 +191,10 @@ function filterJSONstreet (removeProps, renameProps, streetJSON) { } let stringJSON = JSON.stringify(streetJSON, function replacer (key, value) { + if (propsToString.includes(key)) { + // don't parse if key is an attribute or property listed in the propsToString array + return value; + } const compAttributes = AFRAME.utils.styleParser.parse(value); for (var removeKey in removeProps) { // check for removing components