forked from MapComplete/MapComplete
		
	Fix loading of themes in the custom generator: use compression
This commit is contained in:
		
							parent
							
								
									63187aab04
								
							
						
					
					
						commit
						d601896f79
					
				
					 2 changed files with 11 additions and 7 deletions
				
			
		|  | @ -39,6 +39,8 @@ import SelectedFeatureHandler from "./Logic/Actors/SelectedFeatureHandler"; | ||||||
| import LZString from "lz-string"; | import LZString from "lz-string"; | ||||||
| import {LayoutConfigJson} from "./Customizations/JSON/LayoutConfigJson"; | import {LayoutConfigJson} from "./Customizations/JSON/LayoutConfigJson"; | ||||||
| import AttributionPanel from "./UI/BigComponents/AttributionPanel"; | import AttributionPanel from "./UI/BigComponents/AttributionPanel"; | ||||||
|  | import AllKnownLayers from "./Customizations/AllKnownLayers"; | ||||||
|  | import LayerConfig from "./Customizations/JSON/LayerConfig"; | ||||||
| 
 | 
 | ||||||
| export class InitUiElements { | export class InitUiElements { | ||||||
| 
 | 
 | ||||||
|  | @ -83,13 +85,9 @@ export class InitUiElements { | ||||||
|             // This is purely for the personal theme to load the layers there
 |             // This is purely for the personal theme to load the layers there
 | ||||||
|             const favs = State.state.favouriteLayers.data ?? []; |             const favs = State.state.favouriteLayers.data ?? []; | ||||||
| 
 | 
 | ||||||
|  |              | ||||||
|             layoutToUse.layers.splice(0, layoutToUse.layers.length); |             layoutToUse.layers.splice(0, layoutToUse.layers.length); | ||||||
|             for (const fav of favs) { |             for (const fav of favs) { | ||||||
|                 const layer = AllKnownLayouts.allLayers[fav]; |  | ||||||
|                 if (!!layer) { |  | ||||||
|                     layoutToUse.layers.push(layer); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 for (const layouts of State.state.installedThemes.data) { |                 for (const layouts of State.state.installedThemes.data) { | ||||||
|                     for (const layer of layouts.layout.layers) { |                     for (const layer of layouts.layout.layers) { | ||||||
|                         if (typeof layer === "string") { |                         if (typeof layer === "string") { | ||||||
|  | @ -218,7 +216,7 @@ export class InitUiElements { | ||||||
|                json = JSON.parse(atob(hash)); |                json = JSON.parse(atob(hash)); | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
|                 // We try to decode with lz-string
 |                 // We try to decode with lz-string
 | ||||||
|                 json = JSON.parse( Utils.UnMinify(LZString.decompressFromBase64(hash))) |                 json = JSON.parse(atob(window.location.hash.substr(1))) as LayoutConfigJson; | ||||||
|             } |             } | ||||||
|             |             | ||||||
|             // @ts-ignore
 |             // @ts-ignore
 | ||||||
|  |  | ||||||
|  | @ -7,7 +7,13 @@ import {LocalStorageSource} from "./Logic/Web/LocalStorageSource"; | ||||||
| 
 | 
 | ||||||
| let layout = GenerateEmpty.createEmptyLayout(); | let layout = GenerateEmpty.createEmptyLayout(); | ||||||
| if (window.location.hash.length > 10) { | if (window.location.hash.length > 10) { | ||||||
|  |     try{ | ||||||
|         layout = JSON.parse(atob(window.location.hash.substr(1))) as LayoutConfigJson; |         layout = JSON.parse(atob(window.location.hash.substr(1))) as LayoutConfigJson; | ||||||
|  |     }catch(e){ | ||||||
|  |         console.log("Initial load of theme failed, attempt nr 2 with decompression", e) | ||||||
|  |         layout = JSON.parse(atob(window.location.hash.substr(1))) as LayoutConfigJson; | ||||||
|  |     } | ||||||
|  |      | ||||||
| } else { | } else { | ||||||
|     const hash = LocalStorageSource.Get("last-custom-theme").data |     const hash = LocalStorageSource.Get("last-custom-theme").data | ||||||
|     if (hash !== undefined) { |     if (hash !== undefined) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue