forked from MapComplete/MapComplete
		
	Refactoring: move all code files into a src directory
This commit is contained in:
		
							parent
							
								
									de99f56ca8
								
							
						
					
					
						commit
						e75d2789d2
					
				
					 389 changed files with 0 additions and 12 deletions
				
			
		
							
								
								
									
										60
									
								
								src/Logic/FeatureSource/Sources/LastClickFeatureSource.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								src/Logic/FeatureSource/Sources/LastClickFeatureSource.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,60 @@ | |||
| import LayoutConfig from "../../../Models/ThemeConfig/LayoutConfig" | ||||
| import { WritableFeatureSource } from "../FeatureSource" | ||||
| import { ImmutableStore, Store, UIEventSource } from "../../UIEventSource" | ||||
| import { Feature, Point } from "geojson" | ||||
| import { TagUtils } from "../../Tags/TagUtils" | ||||
| import BaseUIElement from "../../../UI/BaseUIElement" | ||||
| import { Utils } from "../../../Utils" | ||||
| 
 | ||||
| /** | ||||
|  * Highly specialized feature source. | ||||
|  * Based on a lon/lat UIEVentSource, will generate the corresponding feature with the correct properties | ||||
|  */ | ||||
| export class LastClickFeatureSource implements WritableFeatureSource { | ||||
|     public readonly features: UIEventSource<Feature[]> = new UIEventSource<Feature[]>([]) | ||||
| 
 | ||||
|     constructor(location: Store<{ lon: number; lat: number }>, layout: LayoutConfig) { | ||||
|         const allPresets: BaseUIElement[] = [] | ||||
|         for (const layer of layout.layers) | ||||
|             for (let i = 0; i < (layer.presets ?? []).length; i++) { | ||||
|                 const preset = layer.presets[i] | ||||
|                 const tags = new ImmutableStore(TagUtils.KVtoProperties(preset.tags)) | ||||
|                 const { html } = layer.mapRendering[0].RenderIcon(tags, false, { | ||||
|                     noSize: true, | ||||
|                     includeBadges: false, | ||||
|                 }) | ||||
|                 allPresets.push(html) | ||||
|             } | ||||
| 
 | ||||
|         const renderings = Utils.Dedup( | ||||
|             allPresets.map((uiElem) => | ||||
|                 Utils.runningFromConsole ? "" : uiElem.ConstructElement().innerHTML | ||||
|             ) | ||||
|         ) | ||||
| 
 | ||||
|         let i = 0 | ||||
| 
 | ||||
|         location.addCallbackAndRunD(({ lon, lat }) => { | ||||
|             const properties = { | ||||
|                 lastclick: "yes", | ||||
|                 id: "last_click_" + i, | ||||
|                 has_note_layer: layout.layers.some((l) => l.id === "note") ? "yes" : "no", | ||||
|                 has_presets: layout.layers.some((l) => l.presets?.length > 0) ? "yes" : "no", | ||||
|                 renderings: renderings.join(""), | ||||
|                 number_of_presets: "" + renderings.length, | ||||
|                 first_preset: renderings[0], | ||||
|             } | ||||
|             i++ | ||||
| 
 | ||||
|             const point = <Feature<Point>>{ | ||||
|                 type: "Feature", | ||||
|                 properties, | ||||
|                 geometry: { | ||||
|                     type: "Point", | ||||
|                     coordinates: [lon, lat], | ||||
|                 }, | ||||
|             } | ||||
|             this.features.setData([point]) | ||||
|         }) | ||||
|     } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue