forked from MapComplete/MapComplete
		
	Merge branch 'master' into develop
This commit is contained in:
		
						commit
						6d39e4e808
					
				
					 131 changed files with 6525 additions and 2861 deletions
				
			
		|  | @ -3,7 +3,11 @@ import { FixedUiElement } from "./Base/FixedUiElement" | |||
| import BaseUIElement from "./BaseUIElement" | ||||
| import Title from "./Base/Title" | ||||
| import { default as FeatureTitle } from "./Popup/Title.svelte" | ||||
| import { RenderingSpecification, SpecialVisualization, SpecialVisualizationState } from "./SpecialVisualization" | ||||
| import { | ||||
|     RenderingSpecification, | ||||
|     SpecialVisualization, | ||||
|     SpecialVisualizationState, | ||||
| } from "./SpecialVisualization" | ||||
| import { HistogramViz } from "./Popup/HistogramViz" | ||||
| import MinimapViz from "./Popup/MinimapViz.svelte" | ||||
| import { ShareLinkViz } from "./Popup/ShareLinkViz" | ||||
|  | @ -122,7 +126,7 @@ class NearbyImageVis implements SpecialVisualization { | |||
|         tags: UIEventSource<Record<string, string>>, | ||||
|         args: string[], | ||||
|         feature: Feature, | ||||
|         layer: LayerConfig, | ||||
|         layer: LayerConfig | ||||
|     ): SvelteUIElement { | ||||
|         const isOpen = args[0] === "open" | ||||
|         const readonly = args[1] === "readonly" || args[1] === "yes" | ||||
|  | @ -189,7 +193,7 @@ class StealViz implements SpecialVisualization { | |||
|                                 selectedElement: otherFeature, | ||||
|                                 state, | ||||
|                                 layer, | ||||
|                             }), | ||||
|                             }) | ||||
|                         ) | ||||
|                     } | ||||
|                     if (elements.length === 1) { | ||||
|  | @ -197,8 +201,8 @@ class StealViz implements SpecialVisualization { | |||
|                     } | ||||
|                     return new Combine(elements).SetClass("flex flex-col") | ||||
|                 }, | ||||
|                 [state.indexedFeatures.featuresById], | ||||
|             ), | ||||
|                 [state.indexedFeatures.featuresById] | ||||
|             ) | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -250,11 +254,11 @@ class CloseNoteViz implements SpecialVisualization { | |||
|     public constr( | ||||
|         state: SpecialVisualizationState, | ||||
|         tags: UIEventSource<Record<string, string>>, | ||||
|         args: string[], | ||||
|         args: string[] | ||||
|     ): SvelteUIElement { | ||||
|         const { text, icon, idkey, comment, minZoom, zoomButton } = Utils.ParseVisArgs( | ||||
|             this.args, | ||||
|             args, | ||||
|             args | ||||
|         ) | ||||
| 
 | ||||
|         return new SvelteUIElement(CloseNoteButton, { | ||||
|  | @ -295,7 +299,7 @@ export class QuestionViz implements SpecialVisualization { | |||
|         tags: UIEventSource<Record<string, string>>, | ||||
|         args: string[], | ||||
|         feature: Feature, | ||||
|         layer: LayerConfig, | ||||
|         layer: LayerConfig | ||||
|     ): SvelteUIElement { | ||||
|         const labels = args[0] | ||||
|             ?.split(";") | ||||
|  | @ -327,7 +331,7 @@ export default class SpecialVisualizations { | |||
|         for (const specialVisualization of SpecialVisualizations.specialVisualizations) { | ||||
|             SpecialVisualizations.specialVisualisationsDict.set( | ||||
|                 specialVisualization.funcName, | ||||
|                 specialVisualization, | ||||
|                 specialVisualization | ||||
|             ) | ||||
|         } | ||||
|     } | ||||
|  | @ -347,15 +351,15 @@ export default class SpecialVisualizations { | |||
|             viz.docs, | ||||
|             viz.args.length > 0 | ||||
|                 ? MarkdownUtils.table( | ||||
|                     ["name", "default", "description"], | ||||
|                     viz.args.map((arg) => { | ||||
|                         let defaultArg = arg.defaultValue ?? "_undefined_" | ||||
|                         if (defaultArg == "") { | ||||
|                             defaultArg = "_empty string_" | ||||
|                         } | ||||
|                         return [arg.name, defaultArg, arg.doc] | ||||
|                     }), | ||||
|                 ) | ||||
|                       ["name", "default", "description"], | ||||
|                       viz.args.map((arg) => { | ||||
|                           let defaultArg = arg.defaultValue ?? "_undefined_" | ||||
|                           if (defaultArg == "") { | ||||
|                               defaultArg = "_empty string_" | ||||
|                           } | ||||
|                           return [arg.name, defaultArg, arg.doc] | ||||
|                       }) | ||||
|                   ) | ||||
|                 : undefined, | ||||
|             "#### Example usage of " + viz.funcName, | ||||
|             "<code>" + example + "</code>", | ||||
|  | @ -364,18 +368,18 @@ export default class SpecialVisualizations { | |||
| 
 | ||||
|     public static constructSpecification( | ||||
|         template: string, | ||||
|         extraMappings: SpecialVisualization[] = [], | ||||
|         extraMappings: SpecialVisualization[] = [] | ||||
|     ): RenderingSpecification[] { | ||||
|         return SpecialVisualisationUtils.constructSpecification( | ||||
|             template, | ||||
|             SpecialVisualizations.specialVisualisationsDict, | ||||
|             extraMappings, | ||||
|             extraMappings | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|     public static HelpMessage(): string { | ||||
|         const helpTexts: string[] = SpecialVisualizations.specialVisualizations.map((viz) => | ||||
|             SpecialVisualizations.DocumentationFor(viz), | ||||
|             SpecialVisualizations.DocumentationFor(viz) | ||||
|         ) | ||||
| 
 | ||||
|         const firstPart = new Combine([ | ||||
|  | @ -408,10 +412,10 @@ export default class SpecialVisualizations { | |||
|                         }, | ||||
|                     }, | ||||
|                     null, | ||||
|                     "  ", | ||||
|                 ), | ||||
|                     "  " | ||||
|                 ) | ||||
|             ).SetClass("code"), | ||||
|             "In other words: use `{ \"before\": ..., \"after\": ..., \"special\": {\"type\": ..., \"argname\": ...argvalue...}`. The args are in the `special` block; an argvalue can be a string, a translation or another value. (Refer to class `RewriteSpecial` in case of problems)", | ||||
|             'In other words: use `{ "before": ..., "after": ..., "special": {"type": ..., "argname": ...argvalue...}`. The args are in the `special` block; an argvalue can be a string, a translation or another value. (Refer to class `RewriteSpecial` in case of problems)', | ||||
|         ]) | ||||
|             .SetClass("flex flex-col") | ||||
|             .AsMarkdown() | ||||
|  | @ -449,10 +453,10 @@ export default class SpecialVisualizations { | |||
|                                 assignTo: state.userRelatedState.language, | ||||
|                                 availableLanguages: languages, | ||||
|                                 preferredLanguages: state.osmConnection.userDetails.map( | ||||
|                                     (ud) => ud.languages, | ||||
|                                     (ud) => ud.languages | ||||
|                                 ), | ||||
|                             }) | ||||
|                         }), | ||||
|                         }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -491,7 +495,7 @@ export default class SpecialVisualizations { | |||
|                     state: SpecialVisualizationState, | ||||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     feature: Feature | ||||
|                 ): SvelteUIElement { | ||||
|                     return new SvelteUIElement(MinimapViz, { state, args, feature, tagSource }) | ||||
|                 }, | ||||
|  | @ -503,7 +507,7 @@ export default class SpecialVisualizations { | |||
| 
 | ||||
|                 constr( | ||||
|                     state: SpecialVisualizationState, | ||||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     tagSource: UIEventSource<Record<string, string>> | ||||
|                 ): BaseUIElement { | ||||
|                     return new VariableUiElement( | ||||
|                         tagSource | ||||
|  | @ -513,7 +517,7 @@ export default class SpecialVisualizations { | |||
|                                     return new SvelteUIElement(SplitRoadWizard, { id, state }) | ||||
|                                 } | ||||
|                                 return undefined | ||||
|                             }), | ||||
|                             }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -527,7 +531,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     if (feature.geometry.type !== "Point") { | ||||
|                         return undefined | ||||
|  | @ -550,7 +554,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     if (!layer.deletion) { | ||||
|                         return undefined | ||||
|  | @ -576,7 +580,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ) { | ||||
|                     if (feature.geometry.type !== "LineString") { | ||||
|                         return undefined | ||||
|  | @ -608,7 +612,7 @@ export default class SpecialVisualizations { | |||
|                     state: SpecialVisualizationState, | ||||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     feature: Feature | ||||
|                 ): BaseUIElement { | ||||
|                     const [lon, lat] = GeoOperations.centerpointCoordinates(feature) | ||||
|                     return new SvelteUIElement(CreateNewNote, { | ||||
|  | @ -671,7 +675,7 @@ export default class SpecialVisualizations { | |||
|                             .map((tags) => tags[args[0]]) | ||||
|                             .map((wikidata) => { | ||||
|                                 wikidata = Utils.NoEmpty( | ||||
|                                     wikidata?.split(";")?.map((wd) => wd.trim()) ?? [], | ||||
|                                     wikidata?.split(";")?.map((wd) => wd.trim()) ?? [] | ||||
|                                 )[0] | ||||
|                                 const entry = Wikidata.LoadWikidataEntry(wikidata) | ||||
|                                 return new VariableUiElement( | ||||
|  | @ -681,9 +685,9 @@ export default class SpecialVisualizations { | |||
|                                         } | ||||
|                                         const response = <WikidataResponse>e["success"] | ||||
|                                         return Translation.fromMap(response.labels) | ||||
|                                     }), | ||||
|                                     }) | ||||
|                                 ) | ||||
|                             }), | ||||
|                             }) | ||||
|                     ), | ||||
|             }, | ||||
|             new MapillaryLinkVis(), | ||||
|  | @ -697,7 +701,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     _, | ||||
|                     __, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ) => new SvelteUIElement(AllTagsPanel, { tags, layer }), | ||||
|             }, | ||||
|             { | ||||
|  | @ -782,7 +786,7 @@ export default class SpecialVisualizations { | |||
|                             nameKey: nameKey, | ||||
|                             fallbackName, | ||||
|                         }, | ||||
|                         state.featureSwitchIsTesting, | ||||
|                         state.featureSwitchIsTesting | ||||
|                     ) | ||||
|                     return new SvelteUIElement(StarsBarIcon, { | ||||
|                         score: reviews.average, | ||||
|  | @ -821,9 +825,16 @@ export default class SpecialVisualizations { | |||
|                             nameKey: nameKey, | ||||
|                             fallbackName, | ||||
|                         }, | ||||
|                         state.featureSwitchIsTesting, | ||||
|                         state.featureSwitchIsTesting | ||||
|                     ) | ||||
|                     return new SvelteUIElement(ReviewForm, { reviews, state, tags, feature, layer, question }) | ||||
|                     return new SvelteUIElement(ReviewForm, { | ||||
|                         reviews, | ||||
|                         state, | ||||
|                         tags, | ||||
|                         feature, | ||||
|                         layer, | ||||
|                         question, | ||||
|                     }) | ||||
|                 }, | ||||
|             }, | ||||
|             { | ||||
|  | @ -852,7 +863,7 @@ export default class SpecialVisualizations { | |||
|                             nameKey: nameKey, | ||||
|                             fallbackName, | ||||
|                         }, | ||||
|                         state.featureSwitchIsTesting, | ||||
|                         state.featureSwitchIsTesting | ||||
|                     ) | ||||
|                     return new SvelteUIElement(AllReviews, { reviews, state, tags, feature, layer }) | ||||
|                 }, | ||||
|  | @ -882,23 +893,15 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new Combine([ | ||||
|                         SpecialVisualizations.specialVisualisationsDict.get("create_review").constr( | ||||
|                             state, | ||||
|                             tagSource, | ||||
|                             args, | ||||
|                             feature, | ||||
|                             layer, | ||||
|                         ), | ||||
|                         SpecialVisualizations.specialVisualisationsDict.get("list_reviews").constr( | ||||
|                             state, | ||||
|                             tagSource, | ||||
|                             args, | ||||
|                             feature, | ||||
|                             layer, | ||||
|                         ), | ||||
|                         SpecialVisualizations.specialVisualisationsDict | ||||
|                             .get("create_review") | ||||
|                             .constr(state, tagSource, args, feature, layer), | ||||
|                         SpecialVisualizations.specialVisualisationsDict | ||||
|                             .get("list_reviews") | ||||
|                             .constr(state, tagSource, args, feature, layer), | ||||
|                     ]) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -915,7 +918,7 @@ export default class SpecialVisualizations { | |||
|                 constr( | ||||
|                     state: SpecialVisualizationState, | ||||
|                     _: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     argument: string[] | ||||
|                 ): BaseUIElement { | ||||
|                     const [text] = argument | ||||
|                     return new SvelteUIElement(ImportReviewIdentity, { state, text }) | ||||
|  | @ -972,7 +975,7 @@ export default class SpecialVisualizations { | |||
|                 constr( | ||||
|                     state: SpecialVisualizationState, | ||||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     args: string[] | ||||
|                 ): SvelteUIElement { | ||||
|                     const keyToUse = args[0] | ||||
|                     const prefix = args[1] | ||||
|  | @ -1009,17 +1012,17 @@ export default class SpecialVisualizations { | |||
|                                     return undefined | ||||
|                                 } | ||||
|                                 const allUnits: Unit[] = [].concat( | ||||
|                                     ...(state?.theme?.layers?.map((lyr) => lyr.units) ?? []), | ||||
|                                     ...(state?.theme?.layers?.map((lyr) => lyr.units) ?? []) | ||||
|                                 ) | ||||
|                                 const unit = allUnits.filter((unit) => | ||||
|                                     unit.isApplicableToKey(key), | ||||
|                                     unit.isApplicableToKey(key) | ||||
|                                 )[0] | ||||
|                                 if (unit === undefined) { | ||||
|                                     return value | ||||
|                                 } | ||||
|                                 const getCountry = () => tagSource.data._country | ||||
|                                 return unit.asHumanLongValue(value, getCountry) | ||||
|                             }), | ||||
|                             }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1073,7 +1076,7 @@ export default class SpecialVisualizations { | |||
|                 constr: (state) => { | ||||
|                     return new SubtleButton( | ||||
|                         new SvelteUIElement(Trash), | ||||
|                         Translations.t.general.removeLocationHistory, | ||||
|                         Translations.t.general.removeLocationHistory | ||||
|                     ).onClick(() => { | ||||
|                         state.historicalUserLocations.features.setData([]) | ||||
|                         state.selectedElement.setData(undefined) | ||||
|  | @ -1114,10 +1117,10 @@ export default class SpecialVisualizations { | |||
|                                                 new SvelteUIElement(NoteCommentElement, { | ||||
|                                                     comment, | ||||
|                                                     state, | ||||
|                                                 }), | ||||
|                                         ), | ||||
|                                                 }) | ||||
|                                         ) | ||||
|                                 ).SetClass("flex flex-col") | ||||
|                             }), | ||||
|                             }) | ||||
|                     ), | ||||
|             }, | ||||
|             { | ||||
|  | @ -1150,7 +1153,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     _: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ) => { | ||||
|                     return new SvelteUIElement(FeatureTitle, { state, tags, feature, layer }) | ||||
|                 }, | ||||
|  | @ -1168,8 +1171,8 @@ export default class SpecialVisualizations { | |||
|                     const challenge = Stores.FromPromise( | ||||
|                         Utils.downloadJsonCached<MaprouletteTask>( | ||||
|                             `${Maproulette.defaultEndpoint}/challenge/${parentId}`, | ||||
|                             24 * 60 * 60 * 1000, | ||||
|                         ), | ||||
|                             24 * 60 * 60 * 1000 | ||||
|                         ) | ||||
|                     ) | ||||
| 
 | ||||
|                     return new VariableUiElement( | ||||
|  | @ -1194,7 +1197,7 @@ export default class SpecialVisualizations { | |||
|                             } else { | ||||
|                                 return [title, new List(listItems)] | ||||
|                             } | ||||
|                         }), | ||||
|                         }) | ||||
|                     ) | ||||
|                 }, | ||||
|                 docs: "Fetches the metadata of MapRoulette campaign that this task is part of and shows those details (namely `title`, `description` and `instruction`).\n\nThis reads the property `mr_challengeId` to detect the parent campaign.", | ||||
|  | @ -1208,15 +1211,15 @@ export default class SpecialVisualizations { | |||
|                     "\n" + | ||||
|                     "```json\n" + | ||||
|                     "{\n" + | ||||
|                     "   \"id\": \"mark_duplicate\",\n" + | ||||
|                     "   \"render\": {\n" + | ||||
|                     "      \"special\": {\n" + | ||||
|                     "         \"type\": \"maproulette_set_status\",\n" + | ||||
|                     "         \"message\": {\n" + | ||||
|                     "            \"en\": \"Mark as not found or false positive\"\n" + | ||||
|                     '   "id": "mark_duplicate",\n' + | ||||
|                     '   "render": {\n' + | ||||
|                     '      "special": {\n' + | ||||
|                     '         "type": "maproulette_set_status",\n' + | ||||
|                     '         "message": {\n' + | ||||
|                     '            "en": "Mark as not found or false positive"\n' + | ||||
|                     "         },\n" + | ||||
|                     "         \"status\": \"2\",\n" + | ||||
|                     "         \"image\": \"close\"\n" + | ||||
|                     '         "status": "2",\n' + | ||||
|                     '         "image": "close"\n' + | ||||
|                     "      }\n" + | ||||
|                     "   }\n" + | ||||
|                     "}\n" + | ||||
|  | @ -1292,7 +1295,7 @@ export default class SpecialVisualizations { | |||
|                                 (l) => | ||||
|                                     l.name !== null && | ||||
|                                     l.title && | ||||
|                                     state.perLayer.get(l.id) !== undefined, | ||||
|                                     state.perLayer.get(l.id) !== undefined | ||||
|                             ) | ||||
|                             .map( | ||||
|                                 (l) => { | ||||
|  | @ -1302,8 +1305,8 @@ export default class SpecialVisualizations { | |||
|                                     const fsBboxed = new BBoxFeatureSourceForLayer(fs, bbox) | ||||
|                                     return new StatisticsPanel(fsBboxed) | ||||
|                                 }, | ||||
|                                 [state.mapProperties.bounds], | ||||
|                             ), | ||||
|                                 [state.mapProperties.bounds] | ||||
|                             ) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1373,7 +1376,7 @@ export default class SpecialVisualizations { | |||
|                 constr( | ||||
|                     state: SpecialVisualizationState, | ||||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     args: string[] | ||||
|                 ): SvelteUIElement { | ||||
|                     let [text, href, classnames, download, ariaLabel, icon] = args | ||||
|                     if (download === "") { | ||||
|  | @ -1411,7 +1414,7 @@ export default class SpecialVisualizations { | |||
|                             }, | ||||
|                         }, | ||||
|                         null, | ||||
|                         "  ", | ||||
|                         "  " | ||||
|                     ) + | ||||
|                     "\n```", | ||||
|                 args: [ | ||||
|  | @ -1435,7 +1438,7 @@ export default class SpecialVisualizations { | |||
|                     featureTags: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ) { | ||||
|                     const [key, tr, classesRaw] = args | ||||
|                     let classes = classesRaw ?? "" | ||||
|  | @ -1453,7 +1456,7 @@ export default class SpecialVisualizations { | |||
|                                     "Could not create a special visualization for multi(", | ||||
|                                     args.join(", ") + ")", | ||||
|                                     "no properties found for object", | ||||
|                                     feature.properties.id, | ||||
|                                     feature.properties.id | ||||
|                                 ) | ||||
|                                 return undefined | ||||
|                             } | ||||
|  | @ -1470,7 +1473,7 @@ export default class SpecialVisualizations { | |||
|                                 elements.push(subsTr) | ||||
|                             } | ||||
|                             return elements | ||||
|                         }), | ||||
|                         }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1490,7 +1493,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new VariableUiElement( | ||||
|                         tagSource.map((tags) => { | ||||
|  | @ -1502,7 +1505,7 @@ export default class SpecialVisualizations { | |||
|                                 console.error("Cannot create a translation for", v, "due to", e) | ||||
|                                 return JSON.stringify(v) | ||||
|                             } | ||||
|                         }), | ||||
|                         }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1522,7 +1525,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const key = argument[0] | ||||
|                     return new SvelteUIElement(FediverseLink, { key, tags, state }) | ||||
|  | @ -1544,7 +1547,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new FixedUiElement("{" + args[0] + "}") | ||||
|                 }, | ||||
|  | @ -1565,7 +1568,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const key = argument[0] ?? "value" | ||||
|                     return new VariableUiElement( | ||||
|  | @ -1583,12 +1586,12 @@ export default class SpecialVisualizations { | |||
|                             } catch (e) { | ||||
|                                 return new FixedUiElement( | ||||
|                                     "Could not parse this tag: " + | ||||
|                                     JSON.stringify(value) + | ||||
|                                     " due to " + | ||||
|                                     e, | ||||
|                                         JSON.stringify(value) + | ||||
|                                         " due to " + | ||||
|                                         e | ||||
|                                 ).SetClass("alert") | ||||
|                             } | ||||
|                         }), | ||||
|                         }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1609,7 +1612,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const giggityUrl = argument[0] | ||||
|                     return new SvelteUIElement(Giggity, { tags: tagSource, state, giggityUrl }) | ||||
|  | @ -1625,12 +1628,12 @@ export default class SpecialVisualizations { | |||
|                     _: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const tags = (<ThemeViewState>( | ||||
|                         state | ||||
|                     )).geolocation.currentUserLocation.features.map( | ||||
|                         (features) => features[0]?.properties, | ||||
|                         (features) => features[0]?.properties | ||||
|                     ) | ||||
|                     return new Combine([ | ||||
|                         new SvelteUIElement(OrientationDebugPanel, {}), | ||||
|  | @ -1652,7 +1655,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new SvelteUIElement(MarkAsFavourite, { | ||||
|                         tags: tagSource, | ||||
|  | @ -1672,7 +1675,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new SvelteUIElement(MarkAsFavouriteMini, { | ||||
|                         tags: tagSource, | ||||
|  | @ -1692,7 +1695,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new SvelteUIElement(DirectionIndicator, { state, feature }) | ||||
|                 }, | ||||
|  | @ -1705,7 +1708,7 @@ export default class SpecialVisualizations { | |||
|                     state: SpecialVisualizationState, | ||||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     feature: Feature | ||||
|                 ): SvelteUIElement { | ||||
|                     return new SvelteUIElement(QrCode, { state, tags, feature }) | ||||
|                 }, | ||||
|  | @ -1724,7 +1727,7 @@ export default class SpecialVisualizations { | |||
|                 constr( | ||||
|                     state: SpecialVisualizationState, | ||||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     args: string[] | ||||
|                 ): BaseUIElement { | ||||
|                     const key = args[0] === "" ? "_direction:centerpoint" : args[0] | ||||
|                     return new VariableUiElement( | ||||
|  | @ -1735,11 +1738,11 @@ export default class SpecialVisualizations { | |||
|                             }) | ||||
|                             .mapD((value) => { | ||||
|                                 const dir = GeoOperations.bearingToHuman( | ||||
|                                     GeoOperations.parseBearing(value), | ||||
|                                     GeoOperations.parseBearing(value) | ||||
|                                 ) | ||||
|                                 console.log("Human dir", dir) | ||||
|                                 return Translations.t.general.visualFeedback.directionsAbsolute[dir] | ||||
|                             }), | ||||
|                             }) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1769,7 +1772,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const url = args[0] | ||||
|                     const readonly = args[3] === "yes" | ||||
|  | @ -1795,12 +1798,12 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     args: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     return new Toggle( | ||||
|                         undefined, | ||||
|                         new SvelteUIElement(LoginButton, { osmConnection: state.osmConnection }), | ||||
|                         state.osmConnection.isLoggedIn, | ||||
|                         state.osmConnection.isLoggedIn | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1838,7 +1841,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const key = argument[0] ?? "website" | ||||
|                     const useProxy = argument[1] !== "no" | ||||
|  | @ -1846,7 +1849,7 @@ export default class SpecialVisualizations { | |||
|                     const isClosed = (argument[4] ?? "yes") === "yes" | ||||
| 
 | ||||
|                     const countryStore: Store<string | undefined> = tags.mapD( | ||||
|                         (tags) => tags._country, | ||||
|                         (tags) => tags._country | ||||
|                     ) | ||||
|                     const sourceUrl: Store<string | undefined> = tags.mapD((tags) => { | ||||
|                         if (!tags[key] || tags[key] === "undefined") { | ||||
|  | @ -1868,24 +1871,24 @@ export default class SpecialVisualizations { | |||
|                                                 const features = | ||||
|                                                     await LinkedDataLoader.fetchVeloparkEntry( | ||||
|                                                         url, | ||||
|                                                         loadAll, | ||||
|                                                         loadAll | ||||
|                                                     ) | ||||
|                                                 const feature = | ||||
|                                                     features.find( | ||||
|                                                         (f) => f.properties["ref:velopark"] === url, | ||||
|                                                         (f) => f.properties["ref:velopark"] === url | ||||
|                                                     ) ?? features[0] | ||||
|                                                 const properties = feature.properties | ||||
|                                                 properties["ref:velopark"] = url | ||||
|                                                 console.log( | ||||
|                                                     "Got properties from velopark:", | ||||
|                                                     properties, | ||||
|                                                     properties | ||||
|                                                 ) | ||||
|                                                 return properties | ||||
|                                             } catch (e) { | ||||
|                                                 console.error(e) | ||||
|                                                 throw e | ||||
|                                             } | ||||
|                                         })(), | ||||
|                                         })() | ||||
|                                     ) | ||||
|                                 } | ||||
|                                 if (country === undefined) { | ||||
|  | @ -1897,29 +1900,29 @@ export default class SpecialVisualizations { | |||
|                                             return await LinkedDataLoader.fetchJsonLd( | ||||
|                                                 url, | ||||
|                                                 { country }, | ||||
|                                                 useProxy ? "proxy" : "fetch-lod", | ||||
|                                                 useProxy ? "proxy" : "fetch-lod" | ||||
|                                             ) | ||||
|                                         } catch (e) { | ||||
|                                             console.log( | ||||
|                                                 "Could not get with proxy/download LOD, attempting to download directly. Error for ", | ||||
|                                                 url, | ||||
|                                                 "is", | ||||
|                                                 e, | ||||
|                                                 e | ||||
|                                             ) | ||||
|                                             return await LinkedDataLoader.fetchJsonLd( | ||||
|                                                 url, | ||||
|                                                 { country }, | ||||
|                                                 "fetch-raw", | ||||
|                                                 "fetch-raw" | ||||
|                                             ) | ||||
|                                         } | ||||
|                                     })(), | ||||
|                                     })() | ||||
|                                 ) | ||||
|                             }, | ||||
|                             [countryStore], | ||||
|                             [countryStore] | ||||
|                         ) | ||||
| 
 | ||||
|                     externalData.addCallbackAndRunD((lod) => | ||||
|                         console.log("linked_data_from_website received the following data:", lod), | ||||
|                         console.log("linked_data_from_website received the following data:", lod) | ||||
|                     ) | ||||
| 
 | ||||
|                     return new Toggle( | ||||
|  | @ -1934,7 +1937,7 @@ export default class SpecialVisualizations { | |||
|                             collapsed: isClosed, | ||||
|                         }), | ||||
|                         undefined, | ||||
|                         sourceUrl.map((url) => !!url), | ||||
|                         sourceUrl.map((url) => !!url) | ||||
|                     ) | ||||
|                 }, | ||||
|             }, | ||||
|  | @ -1954,7 +1957,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const text = argument[0] | ||||
|                     const cssClasses = argument[1] | ||||
|  | @ -1976,7 +1979,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const translation = tagSource.map((tags) => { | ||||
|                         const layer = state.theme.getMatchingLayer(tags) | ||||
|  | @ -2008,7 +2011,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): SvelteUIElement { | ||||
|                     return new SvelteUIElement<any, any, any>(ClearCaches, { | ||||
|                         msg: argument[0] ?? "Clear local caches", | ||||
|  | @ -2033,7 +2036,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     selectedElement: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): SvelteUIElement { | ||||
|                     const [header, labelsStr] = argument | ||||
|                     const labels = labelsStr.split(";").map((x) => x.trim()) | ||||
|  | @ -2056,7 +2059,7 @@ export default class SpecialVisualizations { | |||
|                     tags: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     selectedElement: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): SvelteUIElement { | ||||
|                     const t = Translations.t.preset_type | ||||
|                     const question: QuestionableTagRenderingConfigJson = { | ||||
|  | @ -2096,7 +2099,7 @@ export default class SpecialVisualizations { | |||
|                     tagSource: UIEventSource<Record<string, string>>, | ||||
|                     argument: string[], | ||||
|                     feature: Feature, | ||||
|                     layer: LayerConfig, | ||||
|                     layer: LayerConfig | ||||
|                 ): BaseUIElement { | ||||
|                     const text = argument[0] | ||||
|                     return new SubtleButton(undefined, text).onClick(() => { | ||||
|  | @ -2127,7 +2130,7 @@ export default class SpecialVisualizations { | |||
|                 "Invalid special visualisation found: funcName is undefined or doesn't match " + | ||||
|                 regex + | ||||
|                 invalid.map((sp) => sp.i).join(", ") + | ||||
|                 ". Did you perhaps type \n  funcName: \"funcname\" // type declaration uses COLON\ninstead of:\n  funcName = \"funcName\" // value definition uses EQUAL" | ||||
|                 '. Did you perhaps type \n  funcName: "funcname" // type declaration uses COLON\ninstead of:\n  funcName = "funcName" // value definition uses EQUAL' | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue