forked from MapComplete/MapComplete
		
	Studo: WIP
This commit is contained in:
		
							parent
							
								
									7ebb3d721c
								
							
						
					
					
						commit
						338599454c
					
				
					 30 changed files with 42794 additions and 749 deletions
				
			
		|  | @ -1,69 +1,75 @@ | |||
| <script lang="ts"> | ||||
| 
 | ||||
|     import EditLayerState from "./EditLayerState"; | ||||
|     import layerSchemaRaw from "../../assets/schemas/layerconfigmeta.json" | ||||
|     import Region from "./Region.svelte"; | ||||
|     import TabbedGroup from "../Base/TabbedGroup.svelte"; | ||||
|     import {UIEventSource} from "../../Logic/UIEventSource"; | ||||
|     import type {ConfigMeta} from "./configMeta"; | ||||
|     import {Utils} from "../../Utils"; | ||||
|   import EditLayerState, { LayerStateSender } from "./EditLayerState"; | ||||
|   import layerSchemaRaw from "../../assets/schemas/layerconfigmeta.json"; | ||||
|   import Region from "./Region.svelte"; | ||||
|   import TabbedGroup from "../Base/TabbedGroup.svelte"; | ||||
|   import { Store, UIEventSource } from "../../Logic/UIEventSource"; | ||||
|   import type { ConfigMeta } from "./configMeta"; | ||||
|   import { Utils } from "../../Utils"; | ||||
| 
 | ||||
|     import drinking_water from "../../../assets/layers/drinking_water/drinking_water.json" | ||||
|   const layerSchema: ConfigMeta[] = <any>layerSchemaRaw; | ||||
|   let state = new EditLayerState(layerSchema); | ||||
|   state.configuration.setData({}); | ||||
|   const configuration = state.configuration; | ||||
|   new LayerStateSender("http://localhost:1235", state); | ||||
|   /** | ||||
|    * Blacklist of regions for the general area tab | ||||
|    * These are regions which are handled by a different tab | ||||
|    */ | ||||
|   const regionBlacklist = ["hidden", undefined, "infobox", "tagrenderings", "maprendering", "editing", "title"]; | ||||
|   const allNames = Utils.Dedup(layerSchema.map(meta => meta.hints.group)); | ||||
| 
 | ||||
|     const layerSchema: ConfigMeta[] = <any> layerSchemaRaw | ||||
|     let state = new EditLayerState(layerSchema) | ||||
|     state.configuration.setData(drinking_water) | ||||
|     /** | ||||
|      * Blacklist for the general area tab | ||||
|      */ | ||||
|     const regionBlacklist = ["hidden",undefined,"infobox", "tagrenderings","maprendering", "editing", "title"] | ||||
|     const allNames =  Utils.Dedup(layerSchema.map(meta => meta.hints.group)) | ||||
|   const perRegion: Record<string, ConfigMeta[]> = {}; | ||||
|   for (const region of allNames) { | ||||
|     perRegion[region] = layerSchema.filter(meta => meta.hints.group === region); | ||||
|   } | ||||
| 
 | ||||
|     const perRegion: Record<string, ConfigMeta[]> = {} | ||||
|     for (const region of allNames) { | ||||
|         perRegion[region] = layerSchema.filter(meta => meta.hints.group === region) | ||||
|   const baselayerRegions: string[] = ["Basic", "presets", "filters", "advanced", "expert"]; | ||||
|   for (const baselayerRegion of baselayerRegions) { | ||||
|     if (perRegion[baselayerRegion] === undefined) { | ||||
|       console.error("BaseLayerRegions in editLayer: no items have group '" + baselayerRegion + "\""); | ||||
|     } | ||||
|      | ||||
|     const baselayerRegions: string[] = ["Basic", "presets","filters","advanced","expert"] | ||||
|     for (const baselayerRegion of baselayerRegions) { | ||||
|         if(perRegion[baselayerRegion] === undefined){ | ||||
|             console.error("BaseLayerRegions in editLayer: no items have group '"+baselayerRegion+'"') | ||||
|         } | ||||
|     } | ||||
|     const leftoverRegions : string[] = allNames.filter(r => regionBlacklist.indexOf(r) <0 && baselayerRegions.indexOf(r) <0 ) | ||||
|   } | ||||
|   const leftoverRegions: string[] = allNames.filter(r => regionBlacklist.indexOf(r) < 0 && baselayerRegions.indexOf(r) < 0); | ||||
|   const title: Store<string> = state.getStoreFor(["id"]); | ||||
| </script> | ||||
| 
 | ||||
| <h3>Edit layer</h3> | ||||
| 
 | ||||
| <h3>Editing layer {$title}</h3> | ||||
| <h4>Leftover regions</h4> | ||||
| {leftoverRegions.join("; ")} | ||||
| <div class="m4"> | ||||
|     {allNames} | ||||
| <TabbedGroup tab={new UIEventSource(1)}> | ||||
|   <TabbedGroup tab={new UIEventSource(2)}> | ||||
|     <div slot="title0">General properties</div> | ||||
|     <div class="flex flex-col" slot="content0"> | ||||
|         {#each baselayerRegions as region} | ||||
|             <Region {state} configs={perRegion[region]} title={region}/> | ||||
|         {/each} | ||||
|          | ||||
|         {#each leftoverRegions as region} | ||||
|             <Region {state} configs={perRegion[region]} title={region}/> | ||||
|         {/each} | ||||
|       {#each baselayerRegions as region} | ||||
|         <Region {state} configs={perRegion[region]} title={region} /> | ||||
|       {/each} | ||||
|       {#each leftoverRegions as region} | ||||
|         <Region {state} configs={perRegion[region]} title={region} /> | ||||
|       {/each} | ||||
|     </div> | ||||
| 
 | ||||
|     <div slot="title1">Information panel (questions and answers)</div> | ||||
|     <div slot="content1"> | ||||
|         <Region {state} configs={perRegion["tagrenderings"]} title="Popup contents"> | ||||
|             <div slot="description"> | ||||
|                 The bulk of the popup content | ||||
|             </div> | ||||
|         </Region> | ||||
|         <Region {state} configs={perRegion["title"]} title="Popup title"/> | ||||
|         <Region {state} configs={perRegion["editing"]} title="Other editing elements"/> | ||||
|       <Region configs={perRegion["title"]} {state} title="Popup title" /> | ||||
|       <Region configs={perRegion["tagrenderings"]} {state} title="Popup contents"/> | ||||
|       <Region configs={perRegion["editing"]} {state} title="Other editing elements" /> | ||||
|     </div> | ||||
| 
 | ||||
|     <div slot="title2">Rendering on the map</div> | ||||
|     <div slot="content2"> | ||||
|         TODO: rendering on the map | ||||
|       <Region configs={perRegion["maprendering"]} {state} /> | ||||
|     </div> | ||||
| </TabbedGroup> | ||||
|     <div slot="title3">Configuration file</div> | ||||
|     <div slot="content3"> | ||||
|       <div> | ||||
|         Below, you'll find the raw configuration file in `.json`-format. | ||||
|         This is mostly for debugging purposes | ||||
|       </div> | ||||
|       <div class="literal-code"> | ||||
|         {JSON.stringify($configuration, null, "  ")} | ||||
|       </div> | ||||
|     </div> | ||||
|   </TabbedGroup> | ||||
| 
 | ||||
| </div> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue