forked from MapComplete/MapComplete
		
	chore: automated housekeeping...
This commit is contained in:
		
							parent
							
								
									432122c7a0
								
							
						
					
					
						commit
						2f53b55faa
					
				
					 268 changed files with 5707 additions and 3555 deletions
				
			
		|  | @ -1,7 +1,10 @@ | |||
| import { DesugaringStep } from "./Conversion" | ||||
| import { TagRenderingConfigJson } from "../Json/TagRenderingConfigJson" | ||||
| import { LayerConfigJson } from "../Json/LayerConfigJson" | ||||
| import { MappingConfigJson, QuestionableTagRenderingConfigJson } from "../Json/QuestionableTagRenderingConfigJson" | ||||
| import { | ||||
|     MappingConfigJson, | ||||
|     QuestionableTagRenderingConfigJson, | ||||
| } from "../Json/QuestionableTagRenderingConfigJson" | ||||
| import { ConversionContext } from "./ConversionContext" | ||||
| import { Translation } from "../../../UI/i18n/Translation" | ||||
| import { TagUtils } from "../../../Logic/Tags/TagUtils" | ||||
|  | @ -194,10 +197,10 @@ export class MiscTagRenderingChecks extends DesugaringStep<TagRenderingConfigJso | |||
|             } | ||||
|             if ( | ||||
|                 this._layerConfig?.source?.["osmTags"] && | ||||
|                 NameSuggestionIndex.supportedTypes.indexOf(<any> json.freeform.key) >= 0 | ||||
|                 NameSuggestionIndex.supportedTypes.indexOf(<any>json.freeform.key) >= 0 | ||||
|             ) { | ||||
|                 const tags = TagUtils.TagD(this._layerConfig?.source?.["osmTags"])?.usedTags() | ||||
|                /* const suggestions = nameSuggestionIndexBundled.getSuggestionsFor(json.freeform.key, tags) | ||||
|                 /* const suggestions = nameSuggestionIndexBundled.getSuggestionsFor(json.freeform.key, tags) | ||||
|                 if (suggestions === undefined) { | ||||
|                     context | ||||
|                         .enters("freeform", "type") | ||||
|  |  | |||
|  | @ -109,7 +109,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     mercatorCrs: json.source["mercatorCrs"], | ||||
|                     idKey: json.source["idKey"], | ||||
|                 }, | ||||
|                 json.id, | ||||
|                 json.id | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -129,7 +129,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|         if (json.calculatedTags !== undefined) { | ||||
|             if (!official) { | ||||
|                 console.warn( | ||||
|                     `Unofficial theme ${this.id} with custom javascript! This is a security risk`, | ||||
|                     `Unofficial theme ${this.id} with custom javascript! This is a security risk` | ||||
|                 ) | ||||
|             } | ||||
|             this.calculatedTags = [] | ||||
|  | @ -199,7 +199,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 tags: pr.tags.map((t) => TagUtils.SimpleTag(t)), | ||||
|                 description: Translations.T( | ||||
|                     pr.description, | ||||
|                     `${translationContext}.presets.${i}.description`, | ||||
|                     `${translationContext}.presets.${i}.description` | ||||
|                 ), | ||||
|                 preciseInput: preciseInput, | ||||
|                 exampleImages: pr.exampleImages, | ||||
|  | @ -213,7 +213,7 @@ export default class LayerConfig extends WithContextLoader { | |||
| 
 | ||||
|         if (json.lineRendering) { | ||||
|             this.lineRendering = Utils.NoNull(json.lineRendering).map( | ||||
|                 (r, i) => new LineRenderingConfig(r, `${context}[${i}]`), | ||||
|                 (r, i) => new LineRenderingConfig(r, `${context}[${i}]`) | ||||
|             ) | ||||
|         } else { | ||||
|             this.lineRendering = [] | ||||
|  | @ -221,7 +221,7 @@ export default class LayerConfig extends WithContextLoader { | |||
| 
 | ||||
|         if (json.pointRendering) { | ||||
|             this.mapRendering = Utils.NoNull(json.pointRendering).map( | ||||
|                 (r, i) => new PointRenderingConfig(r, `${context}[${i}](${this.id})`), | ||||
|                 (r, i) => new PointRenderingConfig(r, `${context}[${i}](${this.id})`) | ||||
|             ) | ||||
|         } else { | ||||
|             this.mapRendering = [] | ||||
|  | @ -233,7 +233,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     r.location.has("centroid") || | ||||
|                     r.location.has("projected_centerpoint") || | ||||
|                     r.location.has("start") || | ||||
|                     r.location.has("end"), | ||||
|                     r.location.has("end") | ||||
|             ) | ||||
| 
 | ||||
|             if ( | ||||
|  | @ -255,7 +255,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 Constants.priviliged_layers.indexOf(<any>this.id) < 0 && | ||||
|                 this.source !== null /*library layer*/ && | ||||
|                 !this.source?.geojsonSource?.startsWith( | ||||
|                     "https://api.openstreetmap.org/api/0.6/notes.json", | ||||
|                     "https://api.openstreetmap.org/api/0.6/notes.json" | ||||
|                 ) | ||||
|             ) { | ||||
|                 throw ( | ||||
|  | @ -274,7 +274,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     typeof tr !== "string" && | ||||
|                     tr["builtin"] === undefined && | ||||
|                     tr["id"] === undefined && | ||||
|                     tr["rewrite"] === undefined, | ||||
|                     tr["rewrite"] === undefined | ||||
|             ) ?? [] | ||||
|         if (missingIds?.length > 0 && official) { | ||||
|             console.error("Some tagRenderings of", this.id, "are missing an id:", missingIds) | ||||
|  | @ -285,8 +285,8 @@ export default class LayerConfig extends WithContextLoader { | |||
|             (tr, i) => | ||||
|                 new TagRenderingConfig( | ||||
|                     <QuestionableTagRenderingConfigJson>tr, | ||||
|                     this.id + ".tagRenderings[" + i + "]", | ||||
|                 ), | ||||
|                     this.id + ".tagRenderings[" + i + "]" | ||||
|                 ) | ||||
|         ) | ||||
|         if (json.units !== undefined && !Array.isArray(json.units)) { | ||||
|             throw ( | ||||
|  | @ -296,7 +296,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|             ) | ||||
|         } | ||||
|         this.units = (json.units ?? []).flatMap((unitJson, i) => | ||||
|             Unit.fromJson(unitJson, this.tagRenderings, `${context}.unit[${i}]`), | ||||
|             Unit.fromJson(unitJson, this.tagRenderings, `${context}.unit[${i}]`) | ||||
|         ) | ||||
| 
 | ||||
|         if ( | ||||
|  | @ -358,11 +358,10 @@ export default class LayerConfig extends WithContextLoader { | |||
|         } | ||||
|         this.popupInFloatover = json.popupInFloatover ?? false | ||||
|         this.baseTags = TagUtils.changeAsProperties( | ||||
|             this.source?.osmTags?.asChange({ id: "node/-1" }) ?? [{ k: "id", v: "node/-1" }], | ||||
|             this.source?.osmTags?.asChange({ id: "node/-1" }) ?? [{ k: "id", v: "node/-1" }] | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     public hasDefaultIcon() { | ||||
|         if (this.mapRendering === undefined || this.mapRendering === null) { | ||||
|             return false | ||||
|  | @ -378,7 +377,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|             neededLayer: string | ||||
|         }[] = [], | ||||
|         addedByDefault = false, | ||||
|         canBeIncluded = true, | ||||
|         canBeIncluded = true | ||||
|     ): string { | ||||
|         const extraProps: string[] = [] | ||||
|         extraProps.push("This layer is shown at zoomlevel **" + this.minzoom + "** and higher") | ||||
|  | @ -386,32 +385,32 @@ export default class LayerConfig extends WithContextLoader { | |||
|         if (canBeIncluded) { | ||||
|             if (addedByDefault) { | ||||
|                 extraProps.push( | ||||
|                     "**This layer is included automatically in every theme. This layer might contain no points**", | ||||
|                     "**This layer is included automatically in every theme. This layer might contain no points**" | ||||
|                 ) | ||||
|             } | ||||
|             if (this.shownByDefault === false) { | ||||
|                 extraProps.push( | ||||
|                     "This layer is not visible by default and must be enabled in the filter by the user. ", | ||||
|                     "This layer is not visible by default and must be enabled in the filter by the user. " | ||||
|                 ) | ||||
|             } | ||||
|             if (this.title === undefined) { | ||||
|                 extraProps.push( | ||||
|                     "Elements don't have a title set and cannot be toggled nor will they show up in the dashboard. If you import this layer in your theme, override `title` to make this toggleable.", | ||||
|                     "Elements don't have a title set and cannot be toggled nor will they show up in the dashboard. If you import this layer in your theme, override `title` to make this toggleable." | ||||
|                 ) | ||||
|             } | ||||
|             if (this.name === undefined && this.shownByDefault === false) { | ||||
|                 extraProps.push( | ||||
|                     "This layer is not visible by default and the visibility cannot be toggled, effectively resulting in a fully hidden layer. This can be useful, e.g. to calculate some metatags. If you want to render this layer (e.g. for debugging), enable it by setting the URL-parameter layer-<id>=true", | ||||
|                     "This layer is not visible by default and the visibility cannot be toggled, effectively resulting in a fully hidden layer. This can be useful, e.g. to calculate some metatags. If you want to render this layer (e.g. for debugging), enable it by setting the URL-parameter layer-<id>=true" | ||||
|                 ) | ||||
|             } | ||||
|             if (this.name === undefined) { | ||||
|                 extraProps.push( | ||||
|                     "Not visible in the layer selection by default. If you want to make this layer toggable, override `name`", | ||||
|                     "Not visible in the layer selection by default. If you want to make this layer toggable, override `name`" | ||||
|                 ) | ||||
|             } | ||||
|             if (this.mapRendering.length === 0) { | ||||
|                 extraProps.push( | ||||
|                     "Not rendered on the map by default. If you want to rendering this on the map, override `mapRenderings`", | ||||
|                     "Not rendered on the map by default. If you want to rendering this on the map, override `mapRenderings`" | ||||
|                 ) | ||||
|             } | ||||
| 
 | ||||
|  | @ -421,12 +420,12 @@ export default class LayerConfig extends WithContextLoader { | |||
|                         "<img src='../warning.svg' height='1rem'/>", | ||||
|                         "This layer is loaded from an external source, namely ", | ||||
|                         "`" + this.source.geojsonSource + "`", | ||||
|                     ].join("\n\n"), | ||||
|                     ].join("\n\n") | ||||
|                 ) | ||||
|             } | ||||
|         } else { | ||||
|             extraProps.push( | ||||
|                 "This layer can **not** be included in a theme. It is solely used by [special renderings](SpecialRenderings.md) showing a minimap with custom data.", | ||||
|                 "This layer can **not** be included in a theme. It is solely used by [special renderings](SpecialRenderings.md) showing a minimap with custom data." | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -436,7 +435,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 usingLayer = [ | ||||
|                     "## Themes using this layer", | ||||
|                     MarkdownUtils.list( | ||||
|                         (usedInThemes ?? []).map((id) => `[${id}](https://mapcomplete.org/${id})`), | ||||
|                         (usedInThemes ?? []).map((id) => `[${id}](https://mapcomplete.org/${id})`) | ||||
|                     ), | ||||
|                 ] | ||||
|             } else if (this.source !== null) { | ||||
|  | @ -452,7 +451,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     " into the layout as it depends on it: ", | ||||
|                     dep.reason, | ||||
|                     "(" + dep.context + ")", | ||||
|                 ].join(" "), | ||||
|                 ].join(" ") | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -479,7 +478,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                             new And(preset.tags).asHumanString(true) + | ||||
|                             snaps | ||||
|                         ) | ||||
|                     }), | ||||
|                     }) | ||||
|                 ), | ||||
|             ] | ||||
|         } | ||||
|  | @ -487,8 +486,8 @@ export default class LayerConfig extends WithContextLoader { | |||
|         for (const revDep of Utils.Dedup(layerIsNeededBy?.get(this.id) ?? [])) { | ||||
|             extraProps.push( | ||||
|                 ["This layer is needed as dependency for layer", `[${revDep}](#${revDep})`].join( | ||||
|                     " ", | ||||
|                 ), | ||||
|                     " " | ||||
|                 ) | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|  | @ -499,10 +498,10 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 .filter((values) => values.key !== "id") | ||||
|                 .map((values) => { | ||||
|                     const embedded: string[] = values.values?.map((v) => | ||||
|                         Link.OsmWiki(values.key, v, true).SetClass("mr-2").AsMarkdown(), | ||||
|                         Link.OsmWiki(values.key, v, true).SetClass("mr-2").AsMarkdown() | ||||
|                     ) ?? ["_no preset options defined, or no values in them_"] | ||||
|                     const statistics = `https://taghistory.raifer.tech/?#***/${encodeURIComponent( | ||||
|                         values.key, | ||||
|                         values.key | ||||
|                     )}/` | ||||
|                     const tagInfo = `https://taginfo.openstreetmap.org/keys/${values.key}#values` | ||||
|                     return [ | ||||
|  | @ -517,7 +516,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                             : `[${values.type}](../SpecialInputElements.md#${values.type})`, | ||||
|                         embedded.join(" "), | ||||
|                     ] | ||||
|                 }), | ||||
|                 }) | ||||
|         ) | ||||
| 
 | ||||
|         let quickOverview: string[] = [] | ||||
|  | @ -527,7 +526,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 "this quick overview is incomplete", | ||||
|                 MarkdownUtils.table( | ||||
|                     ["attribute", "type", "values which are supported by this layer"], | ||||
|                     tableRows, | ||||
|                     tableRows | ||||
|                 ), | ||||
|             ] | ||||
|         } | ||||
|  | @ -561,19 +560,19 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 const parts = neededTags["and"] | ||||
|                 tagsDescription.push( | ||||
|                     "Elements must match **all** of the following expressions:", | ||||
|                     parts.map((p, i) => i + ". " + p.asHumanString(true, false, {})).join("\n"), | ||||
|                     parts.map((p, i) => i + ". " + p.asHumanString(true, false, {})).join("\n") | ||||
|                 ) | ||||
|             } else if (neededTags["or"]) { | ||||
|                 const parts = neededTags["or"] | ||||
|                 tagsDescription.push( | ||||
|                     "Elements must match **any** of the following expressions:", | ||||
|                     parts.map((p) => " - " + p.asHumanString(true, false, {})).join("\n"), | ||||
|                     parts.map((p) => " - " + p.asHumanString(true, false, {})).join("\n") | ||||
|                 ) | ||||
|             } else { | ||||
|                 tagsDescription.push( | ||||
|                     "Elements must match the expression **" + | ||||
|                     neededTags.asHumanString(true, false, {}) + | ||||
|                     "**", | ||||
|                         neededTags.asHumanString(true, false, {}) + | ||||
|                         "**" | ||||
|                 ) | ||||
|             } | ||||
| 
 | ||||
|  |  | |||
|  | @ -999,7 +999,7 @@ export class TagRenderingConfigUtils { | |||
|         tags: UIEventSource<Record<string, string>>, | ||||
|         feature?: Feature | ||||
|     ): Store<TagRenderingConfig> { | ||||
|         const isNSI = NameSuggestionIndex.supportedTypes.indexOf(<any> config.freeform?.key) >= 0 | ||||
|         const isNSI = NameSuggestionIndex.supportedTypes.indexOf(<any>config.freeform?.key) >= 0 | ||||
|         if (!isNSI) { | ||||
|             return new ImmutableStore(config) | ||||
|         } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue