forked from MapComplete/MapComplete
		
	Accessibility: improve keyboard only flow (see #1181); remove some legacy use of Svelte
This commit is contained in:
		
							parent
							
								
									d1a6c11513
								
							
						
					
					
						commit
						4ee83cfe5c
					
				
					 35 changed files with 613 additions and 683 deletions
				
			
		|  | @ -1,19 +1,23 @@ | |||
| <script lang="ts"> | ||||
|   import type { Feature } from "geojson" | ||||
|   import { UIEventSource } from "../../Logic/UIEventSource" | ||||
|   import { Store, UIEventSource } from "../../Logic/UIEventSource"; | ||||
|   import LayerConfig from "../../Models/ThemeConfig/LayerConfig" | ||||
|   import type { SpecialVisualizationState } from "../SpecialVisualization" | ||||
|   import TagRenderingEditable from "../Popup/TagRendering/TagRenderingEditable.svelte" | ||||
|   import { onDestroy } from "svelte" | ||||
|   import Translations from "../i18n/Translations" | ||||
|   import Tr from "../Base/Tr.svelte" | ||||
|   import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig"; | ||||
| 
 | ||||
|   export let state: SpecialVisualizationState | ||||
|   export let layer: LayerConfig | ||||
|   export let selectedElement: Feature | ||||
|   export let tags: UIEventSource<Record<string, string>> | ||||
|   export let highlightedRendering: UIEventSource<string> = undefined | ||||
| 
 | ||||
|   let tags: UIEventSource<Record<string, string>> = state.featureProperties.getStore(selectedElement.properties.id) | ||||
|   $: { | ||||
|     tags = state.featureProperties.getStore(selectedElement.properties.id) | ||||
|   } | ||||
|   let _metatags: Record<string, string> | ||||
|   onDestroy( | ||||
|     state.userRelatedState.preferencesAsTags.addCallbackAndRun((tags) => { | ||||
|  | @ -21,20 +25,12 @@ | |||
|     }) | ||||
|   ) | ||||
| 
 | ||||
|   let knownTagRenderings = layer.tagRenderings.filter( | ||||
|   let knownTagRenderings: Store<TagRenderingConfig[]> =  tags.mapD(tgs =>  layer.tagRenderings.filter( | ||||
|     (config) => | ||||
|       (config.condition?.matchesProperties($tags) ?? true) && | ||||
|       config.metacondition?.matchesProperties({ ...$tags, ..._metatags } ?? true) && | ||||
|       config.IsKnown($tags) | ||||
|   ) | ||||
|   $: { | ||||
|     knownTagRenderings = layer.tagRenderings.filter( | ||||
|       (config) => | ||||
|         (config.condition?.matchesProperties($tags) ?? true) && | ||||
|         config.metacondition?.matchesProperties({ ...$tags, ..._metatags } ?? true) && | ||||
|         config.IsKnown($tags) | ||||
|     ) | ||||
|   } | ||||
|       (config.condition?.matchesProperties(tgs) ?? true) && | ||||
|       config.metacondition?.matchesProperties({ ...tgs, ..._metatags } ?? true) && | ||||
|       config.IsKnown(tgs) | ||||
|   )) | ||||
| </script> | ||||
| 
 | ||||
| {#if $tags._deleted === "yes"} | ||||
|  | @ -43,8 +39,8 @@ | |||
|     <Tr t={Translations.t.general.returnToTheMap} /> | ||||
|   </button> | ||||
| {:else} | ||||
|   <div class="flex h-full flex-col gap-y-2 overflow-y-auto p-1 px-2"> | ||||
|     {#each knownTagRenderings as config (config.id)} | ||||
|   <div class="flex h-full flex-col gap-y-2 overflow-y-auto p-1 px-2 focusable" tabindex="-1"> | ||||
|     {#each $knownTagRenderings as config (config.id)} | ||||
|       <TagRenderingEditable | ||||
|         {tags} | ||||
|         {config} | ||||
|  | @ -52,7 +48,7 @@ | |||
|         {selectedElement} | ||||
|         {layer} | ||||
|         {highlightedRendering} | ||||
|         clss={knownTagRenderings.length === 1 ? "h-full" : "tr-length-" + knownTagRenderings.length} | ||||
|         clss={$knownTagRenderings.length === 1 ? "h-full" : "tr-length-" + $knownTagRenderings.length} | ||||
|       /> | ||||
|     {/each} | ||||
|   </div> | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue