forked from MapComplete/MapComplete
		
	Add search for filters
This commit is contained in:
		
							parent
							
								
									1378c1a779
								
							
						
					
					
						commit
						c94393e825
					
				
					 24 changed files with 405 additions and 254 deletions
				
			
		|  | @ -10,10 +10,7 @@ import { | |||
|     SetDefault, | ||||
| } from "./Conversion" | ||||
| import { LayerConfigJson } from "../Json/LayerConfigJson" | ||||
| import { | ||||
|     MinimalTagRenderingConfigJson, | ||||
|     TagRenderingConfigJson, | ||||
| } from "../Json/TagRenderingConfigJson" | ||||
| import { MinimalTagRenderingConfigJson, TagRenderingConfigJson } from "../Json/TagRenderingConfigJson" | ||||
| import { Utils } from "../../../Utils" | ||||
| import RewritableConfigJson from "../Json/RewritableConfigJson" | ||||
| import SpecialVisualizations from "../../../UI/SpecialVisualizations" | ||||
|  | @ -21,7 +18,7 @@ import Translations from "../../../UI/i18n/Translations" | |||
| import { Translation } from "../../../UI/i18n/Translation" | ||||
| import tagrenderingconfigmeta from "../../../../src/assets/schemas/tagrenderingconfigmeta.json" | ||||
| import { AddContextToTranslations } from "./AddContextToTranslations" | ||||
| import FilterConfigJson from "../Json/FilterConfigJson" | ||||
| import FilterConfigJson, { FilterConfigOptionJson } from "../Json/FilterConfigJson" | ||||
| import predifined_filters from "../../../../assets/layers/filters/filters.json" | ||||
| import { TagConfigJson } from "../Json/TagConfigJson" | ||||
| import PointRenderingConfigJson, { IconConfigJson } from "../Json/PointRenderingConfigJson" | ||||
|  | @ -33,7 +30,7 @@ import LineRenderingConfigJson from "../Json/LineRenderingConfigJson" | |||
| import { ConversionContext } from "./ConversionContext" | ||||
| import { ExpandRewrite } from "./ExpandRewrite" | ||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||
| import { Translatable } from "../Json/Translatable" | ||||
| import FilterConfig, { FilterConfigOption } from "../FilterConfig" | ||||
| 
 | ||||
| class ExpandFilter extends DesugaringStep<LayerConfigJson> { | ||||
|     private static readonly predefinedFilters = ExpandFilter.load_filters() | ||||
|  | @ -41,9 +38,11 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
| 
 | ||||
|     constructor(state: DesugaringContext) { | ||||
|         super( | ||||
|             "Expands filters: replaces a shorthand by the value found in 'filters.json'. If the string is formatted 'layername.filtername, it will be looked up into that layer instead. If a tagRendering sets 'filter', this filter will also be included", | ||||
|             ["Expands filters: replaces a shorthand by the value found in 'filters.json'.", | ||||
|                 "If the string is formatted 'layername.filtername, it will be looked up into that layer instead. If a tagRendering sets 'filter', this filter will also be included", | ||||
|                 ""].join(" "), | ||||
|             ["filter"], | ||||
|             "ExpandFilter" | ||||
|             "ExpandFilter", | ||||
|         ) | ||||
|         this._state = state | ||||
|     } | ||||
|  | @ -56,6 +55,38 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|         return filters | ||||
|     } | ||||
| 
 | ||||
|     private static buildFilterFromTagRendering(tr: TagRenderingConfigJson, context: ConversionContext): FilterConfigJson { | ||||
|         if (!(tr.mappings?.length >= 1)) { | ||||
|             context.err( | ||||
|                 "Found a matching tagRendering to base a filter on, but this tagRendering does not contain any mappings", | ||||
|             ) | ||||
|         } | ||||
|         const options = (<QuestionableTagRenderingConfigJson>tr).mappings.map((mapping) => { | ||||
|             let icon : string= mapping.icon?.["path"] ?? mapping.icon | ||||
|             let emoji: string = undefined | ||||
|             if(Utils.isEmoji(icon)){ | ||||
|                 emoji = icon | ||||
|                 icon = undefined | ||||
|             } | ||||
|             return (<FilterConfigOptionJson>{ | ||||
|                 question: mapping.then, | ||||
|                 osmTags: mapping.if, | ||||
|                 searchTerms: mapping.searchTerms, | ||||
|                 icon, emoji | ||||
|             }) | ||||
|         }) | ||||
|         // Add default option
 | ||||
|         options.unshift({ | ||||
|             question: tr["question"] ?? Translations.t.general.filterPanel.allTypes, | ||||
|             osmTags: undefined, | ||||
|             searchTerms: undefined, | ||||
|         }) | ||||
|         return ({ | ||||
|             id: tr["id"], | ||||
|             options, | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     convert(json: LayerConfigJson, context: ConversionContext): LayerConfigJson { | ||||
|         if (json?.filter === undefined || json?.filter === null) { | ||||
|             return json // Nothing to change here
 | ||||
|  | @ -68,6 +99,16 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|         const newFilters: FilterConfigJson[] = [] | ||||
|         const filters = <(FilterConfigJson | string)[]>json.filter | ||||
| 
 | ||||
|         function filterExists(filterName: string): boolean{ | ||||
|            return filters.some((existing) => { | ||||
|                 const id: string = existing["id"] ?? existing | ||||
|                 return ( | ||||
|                     filterName === id || | ||||
|                     (filterName.startsWith("filters.") && filterName.endsWith("." + id)) | ||||
|                 ) | ||||
|             }) | ||||
|         } | ||||
| 
 | ||||
|         /** | ||||
|          * Checks all tagRendering. If a tagrendering has 'filter' set, add this filter to the layer config | ||||
|          */ | ||||
|  | @ -76,18 +117,18 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|             if (!tagRendering?.filter) { | ||||
|                 continue | ||||
|             } | ||||
|             if (tagRendering.filter === true) { | ||||
|                 if(filterExists(tagRendering["id"])){ | ||||
|                 continue | ||||
|                 } | ||||
|                     filters.push(ExpandFilter.buildFilterFromTagRendering(tagRendering, context.enters("tagRenderings", i, "filter"))) | ||||
|                 continue | ||||
|             } | ||||
|             for (const filterName of tagRendering.filter ?? []) { | ||||
|                 if (typeof filterName !== "string") { | ||||
|                     context.enters("tagRenderings", i, "filter").err("Not a string: " + filterName) | ||||
|                 } | ||||
|                 const exists = filters.some((existing) => { | ||||
|                     const id: string = existing["id"] ?? existing | ||||
|                     return ( | ||||
|                         filterName === id || | ||||
|                         (filterName.startsWith("filters.") && filterName.endsWith("." + id)) | ||||
|                     ) | ||||
|                 }) | ||||
|                 if (exists) { | ||||
|                 if (filterExists(filterName)) { | ||||
|                     continue | ||||
|                 } | ||||
|                 if (!filterName) { | ||||
|  | @ -99,7 +140,7 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|         } | ||||
| 
 | ||||
|         /** | ||||
|          * Create filters based on builtin filters | ||||
|          * Create filters based on builtin filters or create them based on the tagRendering | ||||
|          */ | ||||
|         for (let i = 0; i < filters.length; i++) { | ||||
|             const filter = filters[i] | ||||
|  | @ -115,28 +156,8 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|                 json.tagRenderings.find((tr) => !!tr && tr["id"] === filter) | ||||
|             ) | ||||
|             if (matchingTr) { | ||||
|                 if (!(matchingTr.mappings?.length >= 1)) { | ||||
|                     context | ||||
|                         .enters("filter", i) | ||||
|                         .err( | ||||
|                             "Found a matching tagRendering to base a filter on, but this tagRendering does not contain any mappings" | ||||
|                         ) | ||||
|                 } | ||||
|                 const options = (<QuestionableTagRenderingConfigJson> matchingTr).mappings.map((mapping) => ({ | ||||
|                     question: mapping.then, | ||||
|                     osmTags: mapping.if, | ||||
|                     searchTerms: mapping.searchTerms | ||||
| 
 | ||||
|                 })) | ||||
|                 options.unshift({ | ||||
|                     question: matchingTr["question"] ?? Translations.t.general.filterPanel.allTypes, | ||||
|                     osmTags: undefined, | ||||
|                     searchTerms: undefined | ||||
|                 }) | ||||
|                 newFilters.push({ | ||||
|                     id: filter, | ||||
|                     options, | ||||
|                 }) | ||||
|                 const filter = ExpandFilter.buildFilterFromTagRendering(matchingTr, context.enters("filter", i)) | ||||
|                 newFilters.push(filter) | ||||
|                 continue | ||||
|             } | ||||
| 
 | ||||
|  | @ -145,7 +166,7 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|                     const split = filter.split(".") | ||||
|                     if (split.length > 2) { | ||||
|                         context.err( | ||||
|                             "invalid filter name: " + filter + ", expected `layername.filterid`" | ||||
|                             "invalid filter name: " + filter + ", expected `layername.filterid`", | ||||
|                         ) | ||||
|                     } | ||||
|                     const layer = this._state.sharedLayers.get(split[0]) | ||||
|  | @ -154,7 +175,7 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|                     } | ||||
|                     const expectedId = split[1] | ||||
|                     const expandedFilter = (<(FilterConfigJson | string)[]>layer.filter).find( | ||||
|                         (f) => typeof f !== "string" && f.id === expectedId | ||||
|                         (f) => typeof f !== "string" && f.id === expectedId, | ||||
|                     ) | ||||
|                     if (expandedFilter === undefined) { | ||||
|                         context.err("Did not find filter with name " + filter) | ||||
|  | @ -172,15 +193,15 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|                 const suggestions = Utils.sortedByLevenshteinDistance( | ||||
|                     filter, | ||||
|                     Array.from(ExpandFilter.predefinedFilters.keys()), | ||||
|                     (t) => t | ||||
|                     (t) => t, | ||||
|                 ) | ||||
|                 context | ||||
|                     .enter(filter) | ||||
|                     .err( | ||||
|                         "While searching for predefined filter " + | ||||
|                             filter + | ||||
|                             ": this filter is not found. Perhaps you meant one of: " + | ||||
|                             suggestions | ||||
|                         filter + | ||||
|                         ": this filter is not found. Perhaps you meant one of: " + | ||||
|                         suggestions, | ||||
|                     ) | ||||
|             } | ||||
|             newFilters.push(found) | ||||
|  | @ -193,9 +214,9 @@ class ExpandTagRendering extends Conversion< | |||
|     | string | ||||
|     | TagRenderingConfigJson | ||||
|     | { | ||||
|           builtin: string | string[] | ||||
|           override: any | ||||
|       }, | ||||
|     builtin: string | string[] | ||||
|     override: any | ||||
| }, | ||||
|     TagRenderingConfigJson[] | ||||
| > { | ||||
|     private readonly _state: DesugaringContext | ||||
|  | @ -217,12 +238,12 @@ class ExpandTagRendering extends Conversion< | |||
|             noHardcodedStrings?: false | boolean | ||||
|             // If set, a question will be added to the 'sharedTagRenderings'. Should only be used for 'questions.json'
 | ||||
|             addToContext?: false | boolean | ||||
|         } | ||||
|         }, | ||||
|     ) { | ||||
|         super( | ||||
|             "Converts a tagRenderingSpec into the full tagRendering, e.g. by substituting the tagRendering by the shared-question and reusing the builtins", | ||||
|             [], | ||||
|             "ExpandTagRendering" | ||||
|             "ExpandTagRendering", | ||||
|         ) | ||||
|         this._state = state | ||||
|         this._self = self | ||||
|  | @ -242,7 +263,7 @@ class ExpandTagRendering extends Conversion< | |||
| 
 | ||||
|     public convert( | ||||
|         spec: string | any, | ||||
|         ctx: ConversionContext | ||||
|         ctx: ConversionContext, | ||||
|     ): QuestionableTagRenderingConfigJson[] { | ||||
|         const trs = this.convertOnce(spec, ctx) | ||||
| 
 | ||||
|  | @ -355,8 +376,8 @@ class ExpandTagRendering extends Conversion< | |||
|                 found, | ||||
|                 ConversionContext.construct( | ||||
|                     [layer.id, "tagRenderings", found["id"]], | ||||
|                     ["AddContextToTranslations"] | ||||
|                 ) | ||||
|                     ["AddContextToTranslations"], | ||||
|                 ), | ||||
|             ) | ||||
|             matchingTrs[i] = found | ||||
|         } | ||||
|  | @ -384,17 +405,17 @@ class ExpandTagRendering extends Conversion< | |||
|                     ctx.warn( | ||||
|                         `A literal rendering was detected: ${tr} | ||||
|                       Did you perhaps forgot to add a layer name as 'layername.${tr}'? ` +
 | ||||
|                             Array.from(state.sharedLayers.keys()).join(", ") | ||||
|                         Array.from(state.sharedLayers.keys()).join(", "), | ||||
|                     ) | ||||
|                 } | ||||
| 
 | ||||
|                 if (this._options?.noHardcodedStrings && this._state?.sharedLayers?.size > 0) { | ||||
|                     ctx.err( | ||||
|                         "Detected an invocation to a builtin tagRendering, but this tagrendering was not found: " + | ||||
|                             tr + | ||||
|                             " \n    Did you perhaps forget to add the layer as prefix, such as `icons." + | ||||
|                             tr + | ||||
|                             "`? " | ||||
|                         tr + | ||||
|                         " \n    Did you perhaps forget to add the layer as prefix, such as `icons." + | ||||
|                         tr + | ||||
|                         "`? ", | ||||
|                     ) | ||||
|                 } | ||||
| 
 | ||||
|  | @ -429,9 +450,9 @@ class ExpandTagRendering extends Conversion< | |||
|                 } | ||||
|                 ctx.err( | ||||
|                     "An object calling a builtin can only have keys `builtin` or `override`, but a key with name `" + | ||||
|                         key + | ||||
|                         "` was found. This won't be picked up! The full object is: " + | ||||
|                         JSON.stringify(tr) | ||||
|                     key + | ||||
|                     "` was found. This won't be picked up! The full object is: " + | ||||
|                     JSON.stringify(tr), | ||||
|                 ) | ||||
|             } | ||||
| 
 | ||||
|  | @ -450,39 +471,39 @@ class ExpandTagRendering extends Conversion< | |||
|                             const candidates = Utils.sortedByLevenshteinDistance( | ||||
|                                 layerName, | ||||
|                                 Array.from(state.sharedLayers.keys()), | ||||
|                                 (s) => s | ||||
|                                 (s) => s, | ||||
|                             ) | ||||
|                             if (state.sharedLayers.size === 0) { | ||||
|                                 ctx.warn( | ||||
|                                     "BOOTSTRAPPING. Rerun generate layeroverview. While reusing tagrendering: " + | ||||
|                                         name + | ||||
|                                         ": layer " + | ||||
|                                         layerName + | ||||
|                                         " not found for now, but ignoring as this is a bootstrapping run. " | ||||
|                                     name + | ||||
|                                     ": layer " + | ||||
|                                     layerName + | ||||
|                                     " not found for now, but ignoring as this is a bootstrapping run. ", | ||||
|                                 ) | ||||
|                             } else { | ||||
|                                 ctx.err( | ||||
|                                     ": While reusing tagrendering: " + | ||||
|                                         name + | ||||
|                                         ": layer " + | ||||
|                                         layerName + | ||||
|                                         " not found. Maybe you meant one of " + | ||||
|                                         candidates.slice(0, 3).join(", ") | ||||
|                                     name + | ||||
|                                     ": layer " + | ||||
|                                     layerName + | ||||
|                                     " not found. Maybe you meant one of " + | ||||
|                                     candidates.slice(0, 3).join(", "), | ||||
|                                 ) | ||||
|                             } | ||||
|                             continue | ||||
|                         } | ||||
|                         candidates = Utils.NoNull(layer.tagRenderings.map((tr) => tr["id"])).map( | ||||
|                             (id) => layerName + "." + id | ||||
|                             (id) => layerName + "." + id, | ||||
|                         ) | ||||
|                     } | ||||
|                     candidates = Utils.sortedByLevenshteinDistance(name, candidates, (i) => i) | ||||
|                     ctx.err( | ||||
|                         "The tagRendering with identifier " + | ||||
|                             name + | ||||
|                             " was not found.\n\tDid you mean one of " + | ||||
|                             candidates.join(", ") + | ||||
|                             "?\n(Hint: did you add a new label and are you trying to use this label at the same time? Run 'reset:layeroverview' first" | ||||
|                         name + | ||||
|                         " was not found.\n\tDid you mean one of " + | ||||
|                         candidates.join(", ") + | ||||
|                         "?\n(Hint: did you add a new label and are you trying to use this label at the same time? Run 'reset:layeroverview' first", | ||||
|                     ) | ||||
|                     continue | ||||
|                 } | ||||
|  | @ -507,13 +528,13 @@ class DetectInline extends DesugaringStep<QuestionableTagRenderingConfigJson> { | |||
|         super( | ||||
|             "If no 'inline' is set on the freeform key, it will be automatically added. If no special renderings are used, it'll be set to true", | ||||
|             ["freeform.inline"], | ||||
|             "DetectInline" | ||||
|             "DetectInline", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|     convert( | ||||
|         json: QuestionableTagRenderingConfigJson, | ||||
|         context: ConversionContext | ||||
|         context: ConversionContext, | ||||
|     ): QuestionableTagRenderingConfigJson { | ||||
|         if (json.freeform === undefined) { | ||||
|             return json | ||||
|  | @ -536,7 +557,7 @@ class DetectInline extends DesugaringStep<QuestionableTagRenderingConfigJson> { | |||
|                 if (json.freeform.inline === true) { | ||||
|                     context.err( | ||||
|                         "'inline' is set, but the rendering contains a special visualisation...\n    " + | ||||
|                             spec[key] | ||||
|                         spec[key], | ||||
|                     ) | ||||
|                 } | ||||
|                 json = JSON.parse(JSON.stringify(json)) | ||||
|  | @ -559,7 +580,7 @@ export class AddQuestionBox extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "Adds a 'questions'-object if no question element is added yet", | ||||
|             ["tagRenderings"], | ||||
|             "AddQuestionBox" | ||||
|             "AddQuestionBox", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -583,18 +604,18 @@ export class AddQuestionBox extends DesugaringStep<LayerConfigJson> { | |||
|         json.tagRenderings = [...json.tagRenderings] | ||||
|         const allSpecials: Exclude<RenderingSpecification, string>[] = <any>( | ||||
|             ValidationUtils.getAllSpecialVisualisations( | ||||
|                 <QuestionableTagRenderingConfigJson[]>json.tagRenderings | ||||
|                 <QuestionableTagRenderingConfigJson[]>json.tagRenderings, | ||||
|             ).filter((spec) => typeof spec !== "string") | ||||
|         ) | ||||
| 
 | ||||
|         const questionSpecials = allSpecials.filter((sp) => sp.func.funcName === "questions") | ||||
|         const noLabels = questionSpecials.filter( | ||||
|             (sp) => sp.args.length === 0 || sp.args[0].trim() === "" | ||||
|             (sp) => sp.args.length === 0 || sp.args[0].trim() === "", | ||||
|         ) | ||||
| 
 | ||||
|         if (noLabels.length > 1) { | ||||
|             context.err( | ||||
|                 "Multiple 'questions'-visualisations found which would show _all_ questions. Don't do this" | ||||
|                 "Multiple 'questions'-visualisations found which would show _all_ questions. Don't do this", | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -602,9 +623,9 @@ export class AddQuestionBox extends DesugaringStep<LayerConfigJson> { | |||
|         const allLabels = new Set( | ||||
|             [].concat( | ||||
|                 ...json.tagRenderings.map( | ||||
|                     (tr) => (<QuestionableTagRenderingConfigJson>tr).labels ?? [] | ||||
|                 ) | ||||
|             ) | ||||
|                     (tr) => (<QuestionableTagRenderingConfigJson>tr).labels ?? [], | ||||
|                 ), | ||||
|             ), | ||||
|         ) | ||||
|         const seen: Set<string> = new Set() | ||||
|         for (const questionSpecial of questionSpecials) { | ||||
|  | @ -622,20 +643,20 @@ export class AddQuestionBox extends DesugaringStep<LayerConfigJson> { | |||
|             if (blacklisted?.length > 0 && used?.length > 0) { | ||||
|                 context.err( | ||||
|                     "The {questions()}-special rendering only supports either a blacklist OR a whitelist, but not both." + | ||||
|                         "\n    Whitelisted: " + | ||||
|                         used.join(", ") + | ||||
|                         "\n    Blacklisted: " + | ||||
|                         blacklisted.join(", ") | ||||
|                     "\n    Whitelisted: " + | ||||
|                     used.join(", ") + | ||||
|                     "\n    Blacklisted: " + | ||||
|                     blacklisted.join(", "), | ||||
|                 ) | ||||
|             } | ||||
|             for (const usedLabel of used) { | ||||
|                 if (!allLabels.has(usedLabel)) { | ||||
|                     context.err( | ||||
|                         "This layers specifies a special question element for label `" + | ||||
|                             usedLabel + | ||||
|                             "`, but this label doesn't exist.\n" + | ||||
|                             "    Available labels are " + | ||||
|                             Array.from(allLabels).join(", ") | ||||
|                         usedLabel + | ||||
|                         "`, but this label doesn't exist.\n" + | ||||
|                         "    Available labels are " + | ||||
|                         Array.from(allLabels).join(", "), | ||||
|                     ) | ||||
|                 } | ||||
|                 seen.add(usedLabel) | ||||
|  | @ -668,7 +689,7 @@ export class AddEditingElements extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "Add some editing elements, such as the delete button or the move button if they are configured. These used to be handled by the feature info box, but this has been replaced by special visualisation elements", | ||||
|             [], | ||||
|             "AddEditingElements" | ||||
|             "AddEditingElements", | ||||
|         ) | ||||
|         this._desugaring = desugaring | ||||
|         this.builtinQuestions = Array.from(this._desugaring.tagRenderings?.values() ?? []) | ||||
|  | @ -698,13 +719,13 @@ export class AddEditingElements extends DesugaringStep<LayerConfigJson> { | |||
|         json.tagRenderings = [...(json.tagRenderings ?? [])] | ||||
|         const allIds = new Set<string>(json.tagRenderings.map((tr) => tr["id"])) | ||||
|         const specialVisualisations = ValidationUtils.getAllSpecialVisualisations( | ||||
|             <any>json.tagRenderings | ||||
|             <any>json.tagRenderings, | ||||
|         ) | ||||
| 
 | ||||
|         const usedSpecialFunctions = new Set( | ||||
|             specialVisualisations.map((sv) => | ||||
|                 typeof sv === "string" ? undefined : sv.func.funcName | ||||
|             ) | ||||
|                 typeof sv === "string" ? undefined : sv.func.funcName, | ||||
|             ), | ||||
|         ) | ||||
| 
 | ||||
|         /***** ADD TO TOP ****/ | ||||
|  | @ -772,7 +793,7 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|         super( | ||||
|             "Converts a 'special' translation into a regular translation which uses parameters", | ||||
|             ["special"], | ||||
|             "RewriteSpecial" | ||||
|             "RewriteSpecial", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -863,12 +884,12 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|     private static convertIfNeeded( | ||||
|         input: | ||||
|             | (object & { | ||||
|                   special: { | ||||
|                       type: string | ||||
|                   } | ||||
|               }) | ||||
|             special: { | ||||
|                 type: string | ||||
|             } | ||||
|         }) | ||||
|             | any, | ||||
|         context: ConversionContext | ||||
|         context: ConversionContext, | ||||
|     ): any { | ||||
|         const special = input["special"] | ||||
|         if (special === undefined) { | ||||
|  | @ -878,7 +899,7 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|         const type = special["type"] | ||||
|         if (type === undefined) { | ||||
|             context.err( | ||||
|                 "A 'special'-block should define 'type' to indicate which visualisation should be used" | ||||
|                 "A 'special'-block should define 'type' to indicate which visualisation should be used", | ||||
|             ) | ||||
|             return undefined | ||||
|         } | ||||
|  | @ -888,10 +909,10 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|             const options = Utils.sortedByLevenshteinDistance( | ||||
|                 type, | ||||
|                 SpecialVisualizations.specialVisualizations, | ||||
|                 (sp) => sp.funcName | ||||
|                 (sp) => sp.funcName, | ||||
|             ) | ||||
|             context.err( | ||||
|                 `Special visualisation '${type}' not found. Did you perhaps mean ${options[0].funcName}, ${options[1].funcName} or ${options[2].funcName}?\n\tFor all known special visualisations, please see https://github.com/pietervdvn/MapComplete/blob/develop/Docs/SpecialRenderings.md` | ||||
|                 `Special visualisation '${type}' not found. Did you perhaps mean ${options[0].funcName}, ${options[1].funcName} or ${options[2].funcName}?\n\tFor all known special visualisations, please see https://github.com/pietervdvn/MapComplete/blob/develop/Docs/SpecialRenderings.md`, | ||||
|             ) | ||||
|             return undefined | ||||
|         } | ||||
|  | @ -912,7 +933,7 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|                 const byDistance = Utils.sortedByLevenshteinDistance( | ||||
|                     wrongArg, | ||||
|                     argNamesList, | ||||
|                     (x) => x | ||||
|                     (x) => x, | ||||
|                 ) | ||||
|                 return `Unexpected argument in special block at ${context} with name '${wrongArg}'. Did you mean ${ | ||||
|                     byDistance[0] | ||||
|  | @ -931,8 +952,8 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|                     `Obligated parameter '${arg.name}' in special rendering of type ${ | ||||
|                         vis.funcName | ||||
|                     } not found.\n    The full special rendering specification is: '${JSON.stringify( | ||||
|                         input | ||||
|                     )}'\n    ${arg.name}: ${arg.doc}` | ||||
|                         input, | ||||
|                     )}'\n    ${arg.name}: ${arg.doc}`,
 | ||||
|                 ) | ||||
|             } | ||||
|         } | ||||
|  | @ -1034,7 +1055,7 @@ export class RewriteSpecial extends DesugaringStep<TagRenderingConfigJson> { | |||
|                 continue | ||||
|             } | ||||
|             Utils.WalkPath(path.path, json, (leaf, travelled) => | ||||
|                 RewriteSpecial.convertIfNeeded(leaf, context.enter(travelled)) | ||||
|                 RewriteSpecial.convertIfNeeded(leaf, context.enter(travelled)), | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -1068,7 +1089,7 @@ class ExpandIconBadges extends DesugaringStep<PointRenderingConfigJson> { | |||
|             } = badgesJson[i] | ||||
|             const expanded = this._expand.convert( | ||||
|                 <QuestionableTagRenderingConfigJson>iconBadge.then, | ||||
|                 context.enters("iconBadges", i) | ||||
|                 context.enters("iconBadges", i), | ||||
|             ) | ||||
|             if (expanded === undefined) { | ||||
|                 iconBadges.push(iconBadge) | ||||
|  | @ -1079,7 +1100,7 @@ class ExpandIconBadges extends DesugaringStep<PointRenderingConfigJson> { | |||
|                 ...expanded.map((resolved) => ({ | ||||
|                     if: iconBadge.if, | ||||
|                     then: <MinimalTagRenderingConfigJson>resolved, | ||||
|                 })) | ||||
|                 })), | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -1096,11 +1117,11 @@ class PreparePointRendering extends Fuse<PointRenderingConfigJson> { | |||
|                 new Each( | ||||
|                     new On( | ||||
|                         "icon", | ||||
|                         new FirstOf(new ExpandTagRendering(state, layer, { applyCondition: false })) | ||||
|                     ) | ||||
|                 ) | ||||
|                         new FirstOf(new ExpandTagRendering(state, layer, { applyCondition: false })), | ||||
|                     ), | ||||
|                 ), | ||||
|             ), | ||||
|             new ExpandIconBadges(state, layer) | ||||
|             new ExpandIconBadges(state, layer), | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  | @ -1110,7 +1131,7 @@ class SetFullNodeDatabase extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "sets the fullNodeDatabase-bit if needed", | ||||
|             ["fullNodeDatabase"], | ||||
|             "SetFullNodeDatabase" | ||||
|             "SetFullNodeDatabase", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -1139,7 +1160,7 @@ class ExpandMarkerRenderings extends DesugaringStep<IconConfigJson> { | |||
|         super( | ||||
|             "Expands tagRenderings in the icons, if needed", | ||||
|             ["icon", "color"], | ||||
|             "ExpandMarkerRenderings" | ||||
|             "ExpandMarkerRenderings", | ||||
|         ) | ||||
|         this._layer = layer | ||||
|         this._state = state | ||||
|  | @ -1171,7 +1192,7 @@ class AddFavouriteBadges extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "Adds the favourite heart to the title and the rendering badges", | ||||
|             [], | ||||
|             "AddFavouriteBadges" | ||||
|             "AddFavouriteBadges", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -1196,7 +1217,7 @@ export class AddRatingBadge extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "Adds the 'rating'-element if a reviews-element is used in the tagRenderings", | ||||
|             ["titleIcons"], | ||||
|             "AddRatingBadge" | ||||
|             "AddRatingBadge", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -1215,8 +1236,8 @@ export class AddRatingBadge extends DesugaringStep<LayerConfigJson> { | |||
| 
 | ||||
|         const specialVis: Exclude<RenderingSpecification, string>[] = < | ||||
|             Exclude<RenderingSpecification, string>[] | ||||
|         >ValidationUtils.getAllSpecialVisualisations(<any>json.tagRenderings).filter( | ||||
|             (rs) => typeof rs !== "string" | ||||
|             >ValidationUtils.getAllSpecialVisualisations(<any>json.tagRenderings).filter( | ||||
|             (rs) => typeof rs !== "string", | ||||
|         ) | ||||
|         const funcs = new Set<string>(specialVis.map((rs) => rs.func.funcName)) | ||||
| 
 | ||||
|  | @ -1232,12 +1253,12 @@ export class AutoTitleIcon extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "The auto-icon creates a (non-clickable) title icon based on a tagRendering which has icons", | ||||
|             ["titleIcons"], | ||||
|             "AutoTitleIcon" | ||||
|             "AutoTitleIcon", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|     private createTitleIconsBasedOn( | ||||
|         tr: QuestionableTagRenderingConfigJson | ||||
|         tr: QuestionableTagRenderingConfigJson, | ||||
|     ): TagRenderingConfigJson | undefined { | ||||
|         const mappings: { if: TagConfigJson; then: string }[] = tr.mappings | ||||
|             ?.filter((m) => m.icon !== undefined) | ||||
|  | @ -1267,7 +1288,7 @@ export class AutoTitleIcon extends DesugaringStep<LayerConfigJson> { | |||
|                         return undefined | ||||
|                     } | ||||
|                     return this.createTitleIconsBasedOn(<any>tr) | ||||
|                 }) | ||||
|                 }), | ||||
|             ) | ||||
|             json.titleIcons.splice(allAutoIndex, 1, ...generated) | ||||
|             return json | ||||
|  | @ -1296,8 +1317,8 @@ export class AutoTitleIcon extends DesugaringStep<LayerConfigJson> { | |||
|                     .enters("titleIcons", i) | ||||
|                     .warn( | ||||
|                         "TagRendering with id " + | ||||
|                             trId + | ||||
|                             " does not have any icons, not generating an icon for this" | ||||
|                         trId + | ||||
|                         " does not have any icons, not generating an icon for this", | ||||
|                     ) | ||||
|                 continue | ||||
|             } | ||||
|  | @ -1312,7 +1333,7 @@ class DeriveSource extends DesugaringStep<LayerConfigJson> { | |||
|         super( | ||||
|             "If no source is given, automatically derives the osmTags by 'or'-ing all the preset tags", | ||||
|             ["source"], | ||||
|             "DeriveSource" | ||||
|             "DeriveSource", | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|  | @ -1322,7 +1343,7 @@ class DeriveSource extends DesugaringStep<LayerConfigJson> { | |||
|         } | ||||
|         if (!json.presets) { | ||||
|             context.err( | ||||
|                 "No source tags given. Trying to derive the source-tags based on the presets, but no presets are given" | ||||
|                 "No source tags given. Trying to derive the source-tags based on the presets, but no presets are given", | ||||
|             ) | ||||
|             return json | ||||
|         } | ||||
|  | @ -1348,7 +1369,7 @@ class DeriveSource extends DesugaringStep<LayerConfigJson> { | |||
| export class PrepareLayer extends Fuse<LayerConfigJson> { | ||||
|     constructor( | ||||
|         state: DesugaringContext, | ||||
|         options?: { addTagRenderingsToContext?: false | boolean } | ||||
|         options?: { addTagRenderingsToContext?: false | boolean }, | ||||
|     ) { | ||||
|         super( | ||||
|             "Fully prepares and expands a layer for the LayerConfig.", | ||||
|  | @ -1361,8 +1382,8 @@ export class PrepareLayer extends Fuse<LayerConfigJson> { | |||
|                     new Concat( | ||||
|                         new ExpandTagRendering(state, layer, { | ||||
|                             addToContext: options?.addTagRenderingsToContext ?? false, | ||||
|                         }) | ||||
|                     ) | ||||
|                         }), | ||||
|                     ), | ||||
|             ), | ||||
|             new On("tagRenderings", new Each(new DetectInline())), | ||||
|             new AddQuestionBox(), | ||||
|  | @ -1375,11 +1396,11 @@ export class PrepareLayer extends Fuse<LayerConfigJson> { | |||
|             new On<PointRenderingConfigJson[], LayerConfigJson>( | ||||
|                 "pointRendering", | ||||
|                 (layer) => | ||||
|                     new Each(new On("marker", new Each(new ExpandMarkerRenderings(state, layer)))) | ||||
|                     new Each(new On("marker", new Each(new ExpandMarkerRenderings(state, layer)))), | ||||
|             ), | ||||
|             new On<PointRenderingConfigJson[], LayerConfigJson>( | ||||
|                 "pointRendering", | ||||
|                 (layer) => new Each(new PreparePointRendering(state, layer)) | ||||
|                 (layer) => new Each(new PreparePointRendering(state, layer)), | ||||
|             ), | ||||
|             new SetDefault("titleIcons", ["icons.defaults"]), | ||||
|             new AddRatingBadge(), | ||||
|  | @ -1388,9 +1409,9 @@ export class PrepareLayer extends Fuse<LayerConfigJson> { | |||
|             new On( | ||||
|                 "titleIcons", | ||||
|                 (layer) => | ||||
|                     new Concat(new ExpandTagRendering(state, layer, { noHardcodedStrings: true })) | ||||
|                     new Concat(new ExpandTagRendering(state, layer, { noHardcodedStrings: true })), | ||||
|             ), | ||||
|             new ExpandFilter(state) | ||||
|             new ExpandFilter(state), | ||||
|         ) | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue