forked from MapComplete/MapComplete
		
	chore: automated housekeeping...
This commit is contained in:
		
							parent
							
								
									14b2799f08
								
							
						
					
					
						commit
						4add2d1aff
					
				
					 151 changed files with 4561 additions and 3315 deletions
				
			
		|  | @ -41,7 +41,7 @@ export abstract class Conversion<TIn, TOut> { | |||
|             fixed = this.convert(json, context) | ||||
|         } catch (e) { | ||||
|             console.error(e) | ||||
|             context.err("ERROR WHILE RUNNING STEP " + this.name+": "+e) | ||||
|             context.err("ERROR WHILE RUNNING STEP " + this.name + ": " + e) | ||||
|             fixed = undefined | ||||
|         } | ||||
|         for (const msg of context.messages) { | ||||
|  | @ -54,12 +54,11 @@ export abstract class Conversion<TIn, TOut> { | |||
|             throw new Error( | ||||
|                 [ | ||||
|                     "Detected one or more errors, stopping now:", | ||||
|                     context.getAll("error").map((e) => e.context.path.join(".") + ": " + e.message) | ||||
|                     context.getAll("error").map((e) => e.context.path.join(".") + ": " + e.message), | ||||
|                 ].join("\n\t") | ||||
|             ) | ||||
|         } | ||||
|         return fixed | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
|     public andThenF<X>(f: (tout: TOut) => X): Conversion<TIn, X> { | ||||
|  | @ -69,8 +68,7 @@ export abstract class Conversion<TIn, TOut> { | |||
|     public abstract convert(json: TIn, context: ConversionContext): TOut | ||||
| } | ||||
| 
 | ||||
| export abstract class DesugaringStep<T> extends Conversion<T, T> { | ||||
| } | ||||
| export abstract class DesugaringStep<T> extends Conversion<T, T> {} | ||||
| 
 | ||||
| export class Pipe<TIn, TInter, TOut> extends Conversion<TIn, TOut> { | ||||
|     private readonly _step0: Conversion<TIn, TInter> | ||||
|  | @ -257,7 +255,7 @@ export class Cached<TIn, TOut> extends Conversion<TIn, TOut> { | |||
|         const converted = this._step.convert(json, context) | ||||
|         Object.defineProperty(json, this.key, { | ||||
|             value: converted, | ||||
|             enumerable: false | ||||
|             enumerable: false, | ||||
|         }) | ||||
|         return converted | ||||
|     } | ||||
|  | @ -270,8 +268,8 @@ export class Fuse<T> extends DesugaringStep<T> { | |||
|     constructor(doc: string, ...steps: DesugaringStep<T>[]) { | ||||
|         super( | ||||
|             (doc ?? "") + | ||||
|             "This fused pipeline of the following steps: " + | ||||
|             steps.map((s) => s.name).join(", "), | ||||
|                 "This fused pipeline of the following steps: " + | ||||
|                 steps.map((s) => s.name).join(", "), | ||||
|             Utils.Dedup([].concat(...steps.map((step) => step.modifiedAttributes))), | ||||
|             "Fuse(" + steps.map((s) => s.name).join(", ") + ")" | ||||
|         ) | ||||
|  |  | |||
|  | @ -55,13 +55,12 @@ export class ExtractImages extends Conversion< | |||
|     } | ||||
| 
 | ||||
|     static isImageType(metapath: any): boolean { | ||||
|         if (metapath.hints.typehint === "icon" || | ||||
|             metapath.hints.typehint === "image") { | ||||
|         if (metapath.hints.typehint === "icon" || metapath.hints.typehint === "image") { | ||||
|             return true | ||||
|         } | ||||
| 
 | ||||
|         const types = metapath.hints.types?.split(";").map(x => x.trim()) | ||||
|         if (types?.some(t => t === "icon" || t === "image")) { | ||||
|         const types = metapath.hints.types?.split(";").map((x) => x.trim()) | ||||
|         if (types?.some((t) => t === "icon" || t === "image")) { | ||||
|             return true | ||||
|         } | ||||
| 
 | ||||
|  | @ -120,7 +119,7 @@ export class ExtractImages extends Conversion< | |||
|             const allRenderedValuesAreImages = ExtractImages.isImageType(metapath) | ||||
| 
 | ||||
|             const found = Utils.CollectPath(metapath.path, json) | ||||
|             if(found.length === 0){ | ||||
|             if (found.length === 0) { | ||||
|                 continue | ||||
|             } | ||||
| 
 | ||||
|  | @ -177,7 +176,7 @@ export class ExtractImages extends Conversion< | |||
|                                     } else { | ||||
|                                         allFoundImages.push({ | ||||
|                                             path: img.leaf, | ||||
|                                             context: context + "." + path | ||||
|                                             context: context + "." + path, | ||||
|                                         }) | ||||
|                                     } | ||||
|                                 } | ||||
|  | @ -191,7 +190,7 @@ export class ExtractImages extends Conversion< | |||
|                                             .ExtractImages(false) | ||||
|                                             .map((path) => ({ | ||||
|                                                 path, | ||||
|                                                 context: context + "." + path | ||||
|                                                 context: context + "." + path, | ||||
|                                             })) | ||||
|                                     ) | ||||
|                                 } | ||||
|  | @ -211,7 +210,7 @@ export class ExtractImages extends Conversion< | |||
|                     } | ||||
|                     allFoundImages.push({ | ||||
|                         context: context.path.join(".") + "." + foundElement.path.join("."), | ||||
|                         path: foundElement.leaf | ||||
|                         path: foundElement.leaf, | ||||
|                     }) | ||||
|                 } | ||||
|             } | ||||
|  |  | |||
|  | @ -7,10 +7,13 @@ import { | |||
|     FirstOf, | ||||
|     Fuse, | ||||
|     On, | ||||
|     SetDefault | ||||
|     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" | ||||
|  | @ -63,24 +66,27 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|         const newFilters: FilterConfigJson[] = [] | ||||
|         const filters = <(FilterConfigJson | string)[]>json.filter | ||||
| 
 | ||||
|         for (let i = 0; i < json.tagRenderings?.length; i++){ | ||||
|             const tagRendering = <TagRenderingConfigJson> json.tagRenderings[i] | ||||
|             if(!tagRendering?.filter){ | ||||
|         for (let i = 0; i < json.tagRenderings?.length; i++) { | ||||
|             const tagRendering = <TagRenderingConfigJson>json.tagRenderings[i] | ||||
|             if (!tagRendering?.filter) { | ||||
|                 continue | ||||
|             } | ||||
|             for (const filterName of tagRendering.filter ?? []) { | ||||
|                 if(typeof filterName !== "string"){ | ||||
|                     context.enters("tagRenderings",i,"filter").err("Not a string: "+ filterName) | ||||
|                 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)) | ||||
|                 const exists = filters.some((existing) => { | ||||
|                     const id: string = existing["id"] ?? existing | ||||
|                     return ( | ||||
|                         filterName === id || | ||||
|                         (filterName.startsWith("filters.") && filterName.endsWith("." + id)) | ||||
|                     ) | ||||
|                 }) | ||||
|                 if(exists){ | ||||
|                 if (exists) { | ||||
|                     continue | ||||
|                 } | ||||
|                 if(!filterName){ | ||||
|                     context.err("Got undefined as filter expansion in "+tagRendering["id"]) | ||||
|                 if (!filterName) { | ||||
|                     context.err("Got undefined as filter expansion in " + tagRendering["id"]) | ||||
|                     continue | ||||
|                 } | ||||
|                 filters.push(filterName) | ||||
|  | @ -89,7 +95,7 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
| 
 | ||||
|         for (let i = 0; i < filters.length; i++) { | ||||
|             const filter = filters[i] | ||||
|             if(filter === undefined){ | ||||
|             if (filter === undefined) { | ||||
|                 continue | ||||
|             } | ||||
|             if (typeof filter !== "string") { | ||||
|  | @ -141,9 +147,9 @@ class ExpandFilter extends DesugaringStep<LayerConfigJson> { | |||
|                     const expandedFilter = (<(FilterConfigJson | string)[]>layer.filter).find( | ||||
|                         (f) => typeof f !== "string" && f.id === expectedId | ||||
|                     ) | ||||
|                     if(expandedFilter === undefined){ | ||||
|                         context.err("Did not find filter with name "+filter) | ||||
|                     }else{ | ||||
|                     if (expandedFilter === undefined) { | ||||
|                         context.err("Did not find filter with name " + filter) | ||||
|                     } else { | ||||
|                         newFilters.push(<FilterConfigJson>expandedFilter) | ||||
|                     } | ||||
|                 } else { | ||||
|  | @ -644,7 +650,6 @@ export class AddQuestionBox extends DesugaringStep<LayerConfigJson> { | |||
| } | ||||
| 
 | ||||
| export class AddEditingElements extends DesugaringStep<LayerConfigJson> { | ||||
| 
 | ||||
|     private readonly _desugaring: DesugaringContext | ||||
|     private readonly _addedByDefaultAtTop: QuestionableTagRenderingConfigJson[] | ||||
|     private readonly _addedByDefault: QuestionableTagRenderingConfigJson[] | ||||
|  | @ -669,7 +674,6 @@ export class AddEditingElements extends DesugaringStep<LayerConfigJson> { | |||
|         return Utils.NoNull(idsInOrder.map((id) => this._desugaring.tagRenderings.get(id))) | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     convert(json: LayerConfigJson, _: ConversionContext): LayerConfigJson { | ||||
|         if (this._desugaring.tagRenderings === null) { | ||||
|             return json | ||||
|  | @ -734,7 +738,7 @@ export class AddEditingElements extends DesugaringStep<LayerConfigJson> { | |||
|             const trc: QuestionableTagRenderingConfigJson = { | ||||
|                 id: "all-tags", | ||||
|                 render: { "*": "{all_tags()}" }, | ||||
|                 labels:["ignore_docs"], | ||||
|                 labels: ["ignore_docs"], | ||||
|                 metacondition: { | ||||
|                     or: [ | ||||
|                         "__featureSwitchIsDebugging=true", | ||||
|  |  | |||
|  | @ -71,8 +71,8 @@ class SubstituteLayer extends Conversion<string | LayerConfigJson, LayerConfigJs | |||
| 
 | ||||
|         for (const name of names) { | ||||
|             const found = Utils.Clone(state.sharedLayers.get(name)) | ||||
|             if(found === undefined){ | ||||
|                 context.err("Layer with name "+name+" not found") | ||||
|             if (found === undefined) { | ||||
|                 context.err("Layer with name " + name + " not found") | ||||
|                 continue | ||||
|             } | ||||
|             found["_basedOn"] = name | ||||
|  | @ -393,7 +393,6 @@ class AddDependencyLayersToTheme extends DesugaringStep<LayoutConfigJson> { | |||
|             }[] = [] | ||||
| 
 | ||||
|             for (const layerConfig of alreadyLoaded) { | ||||
| 
 | ||||
|                 try { | ||||
|                     const layerDeps = DependencyCalculator.getLayerDependencies( | ||||
|                         new LayerConfig(layerConfig, themeId + "(dependencies)") | ||||
|  | @ -402,7 +401,10 @@ class AddDependencyLayersToTheme extends DesugaringStep<LayoutConfigJson> { | |||
|                 } catch (e) { | ||||
|                     console.error(e) | ||||
|                     throw ( | ||||
|                         "Detecting layer dependencies for " + layerConfig?.id + " failed due to " + e | ||||
|                         "Detecting layer dependencies for " + | ||||
|                         layerConfig?.id + | ||||
|                         " failed due to " + | ||||
|                         e | ||||
|                     ) | ||||
|                 } | ||||
|             } | ||||
|  |  | |||
|  | @ -1761,7 +1761,7 @@ export class ValidateFilter extends DesugaringStep<FilterConfigJson> { | |||
|             // Calling another filter, we skip
 | ||||
|             return filter | ||||
|         } | ||||
|         if(filter === undefined){ | ||||
|         if (filter === undefined) { | ||||
|             context.err("Trying to validate a filter, but this filter is undefined") | ||||
|             return undefined | ||||
|         } | ||||
|  | @ -1990,7 +1990,7 @@ export class ValidateThemeEnsemble extends Conversion< | |||
|         >() | ||||
| 
 | ||||
|         for (const theme of json) { | ||||
|             if(theme.id === "personal"){ | ||||
|             if (theme.id === "personal") { | ||||
|                 continue | ||||
|             } | ||||
|             for (const layer of theme.layers) { | ||||
|  |  | |||
|  | @ -25,11 +25,13 @@ export default class FilterConfig { | |||
|     public readonly defaultSelection?: number | ||||
| 
 | ||||
|     constructor(json: FilterConfigJson, context: string) { | ||||
|         if(typeof json === "string"){ | ||||
|             throw "Got a non-expanded filter, just a string: "+json | ||||
|         if (typeof json === "string") { | ||||
|             throw "Got a non-expanded filter, just a string: " + json | ||||
|         } | ||||
|         if (json.options === undefined) { | ||||
|             throw `A filter without options was given at ${context}. The ID is ${JSON.stringify(json)}` | ||||
|             throw `A filter without options was given at ${context}. The ID is ${JSON.stringify( | ||||
|                 json | ||||
|             )}` | ||||
|         } | ||||
|         if (json.id === undefined) { | ||||
|             throw `A filter without id was found at ${context}` | ||||
|  | @ -209,16 +211,16 @@ export default class FilterConfig { | |||
|             Utils.NoNull(["id", "question", "osmTags", hasField ? "fields" : undefined]), | ||||
|             this.options.map((opt, i) => { | ||||
|                 const isDefault = this.options.length > 1 && (this.defaultSelection ?? 0) == i | ||||
|                 return <string[]> Utils.NoNull([ | ||||
|                     this.id + "." + i, | ||||
|                     isDefault | ||||
|                         ? `*${opt.question.txt}* (default)` | ||||
|                         : opt.question, | ||||
|                     opt.osmTags?.asHumanString() ?? "", | ||||
|                     opt.fields?.length > 0 | ||||
|                         ? (opt.fields.map((f) => f.name + " (" + f.type + ")")).join(" ") | ||||
|                         : undefined, | ||||
|                 ]) | ||||
|                 return <string[]>( | ||||
|                     Utils.NoNull([ | ||||
|                         this.id + "." + i, | ||||
|                         isDefault ? `*${opt.question.txt}* (default)` : opt.question, | ||||
|                         opt.osmTags?.asHumanString() ?? "", | ||||
|                         opt.fields?.length > 0 | ||||
|                             ? opt.fields.map((f) => f.name + " (" + f.type + ")").join(" ") | ||||
|                             : undefined, | ||||
|                     ]) | ||||
|                 ) | ||||
|             }) | ||||
|         ) | ||||
|     } | ||||
|  |  | |||
|  | @ -93,7 +93,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     overpassScript: json.source["overpassScript"], | ||||
|                     isOsmCache: json.source["isOsmCache"], | ||||
|                     mercatorCrs: json.source["mercatorCrs"], | ||||
|                     idKey: json.source["idKey"] | ||||
|                     idKey: json.source["idKey"], | ||||
|                 }, | ||||
|                 json.id | ||||
|             ) | ||||
|  | @ -162,7 +162,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|             let preciseInput: PreciseInput = { | ||||
|                 preferredBackground: ["photo"], | ||||
|                 snapToLayers: undefined, | ||||
|                 maxSnapDistance: undefined | ||||
|                 maxSnapDistance: undefined, | ||||
|             } | ||||
|             if (pr["preciseInput"] !== undefined) { | ||||
|                 throw ( | ||||
|  | @ -175,7 +175,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                 let snapToLayers = pr.snapToLayer | ||||
|                 preciseInput = { | ||||
|                     snapToLayers, | ||||
|                     maxSnapDistance: pr.maxSnapDistance ?? 10 | ||||
|                     maxSnapDistance: pr.maxSnapDistance ?? 10, | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|  | @ -187,7 +187,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     `${translationContext}.presets.${i}.description` | ||||
|                 ), | ||||
|                 preciseInput: preciseInput, | ||||
|                 exampleImages: pr.exampleImages | ||||
|                 exampleImages: pr.exampleImages, | ||||
|             } | ||||
|             return config | ||||
|         }) | ||||
|  | @ -293,10 +293,10 @@ export default class LayerConfig extends WithContextLoader { | |||
|             this.filters = [] | ||||
|         } else { | ||||
|             this.filters = (<FilterConfigJson[]>json.filter ?? []) | ||||
|                 .filter(f => typeof f !== "string") | ||||
|                 .filter((f) => typeof f !== "string") | ||||
|                 .map((option, i) => { | ||||
|                 return new FilterConfig(option, `layers:${this.id}.filter.${i}`) | ||||
|             }) | ||||
|                     return new FilterConfig(option, `layers:${this.id}.filter.${i}`) | ||||
|                 }) | ||||
|         } | ||||
| 
 | ||||
|         { | ||||
|  | @ -311,7 +311,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|         } | ||||
| 
 | ||||
|         this.titleIcons = this.ParseTagRenderings(<TagRenderingConfigJson[]>json.titleIcons ?? [], { | ||||
|             readOnlyMode: true | ||||
|             readOnlyMode: true, | ||||
|         }) | ||||
| 
 | ||||
|         this.title = this.tr("title", undefined, translationContext) | ||||
|  | @ -412,7 +412,7 @@ export default class LayerConfig extends WithContextLoader { | |||
|                     [ | ||||
|                         "<img src='../warning.svg' height='1rem'/>", | ||||
|                         "This layer is loaded from an external source, namely ", | ||||
|                         "`" + this.source.geojsonSource + "`" | ||||
|                         "`" + this.source.geojsonSource + "`", | ||||
|                     ].join("\n\n") | ||||
|                 ) | ||||
|             } | ||||
|  | @ -428,10 +428,8 @@ 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) { | ||||
|                 usingLayer = ["No themes use this layer"] | ||||
|  | @ -442,45 +440,46 @@ export default class LayerConfig extends WithContextLoader { | |||
|             extraProps.push( | ||||
|                 [ | ||||
|                     "This layer will automatically load ", | ||||
|                     (`[${dep.neededLayer}](./${dep.neededLayer}.md)`), | ||||
|                     `[${dep.neededLayer}](./${dep.neededLayer}.md)`, | ||||
|                     " into the layout as it depends on it: ", | ||||
|                     dep.reason, | ||||
|                     "(" + dep.context + ")" | ||||
|                     "(" + dep.context + ")", | ||||
|                 ].join(" ") | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|         for (const revDep of Utils.Dedup(layerIsNeededBy?.get(this.id) ?? [])) { | ||||
|             extraProps.push( | ||||
|                 [ | ||||
|                     "This layer is needed as dependency for layer", | ||||
|                     (`[${revDep}](#${revDep})`) | ||||
|                 ].join(" ") | ||||
|                 ["This layer is needed as dependency for layer", `[${revDep}](#${revDep})`].join( | ||||
|                     " " | ||||
|                 ) | ||||
|             ) | ||||
|         } | ||||
| 
 | ||||
|         const tableRows: string[][] = Utils.NoNull( | ||||
|             this.tagRenderings | ||||
|                 .map((tr) => tr.FreeformValues()) | ||||
|                 .filter(values => values !== undefined) | ||||
|                 .filter(values => values.key !== "id") | ||||
|                 .filter((values) => values !== undefined) | ||||
|                 .filter((values) => values.key !== "id") | ||||
|                 .map((values) => { | ||||
|                     const embedded: (string)[] = values.values?.map((v) => | ||||
|                     const embedded: string[] = values.values?.map((v) => | ||||
|                         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)}/` | ||||
|                     const statistics = `https://taghistory.raifer.tech/?#***/${encodeURIComponent( | ||||
|                         values.key | ||||
|                     )}/` | ||||
|                     const tagInfo = `https://taginfo.openstreetmap.org/keys/${values.key}#values` | ||||
|                     return [ | ||||
|                         [ | ||||
|                             `<a target="_blank" href='${tagInfo}'><img src='https://mapcomplete.org/assets/svg/search.svg' height='18px'></a>`, | ||||
|                             `<a target="_blank" href='${statistics}'><img src='https://mapcomplete.org/assets/svg/statistics.svg' height='18px'></a>`, | ||||
| 
 | ||||
|                             Link.OsmWiki(values.key).AsMarkdown() | ||||
|                             Link.OsmWiki(values.key).AsMarkdown(), | ||||
|                         ].join(" "), | ||||
|                         values.type === undefined | ||||
|                             ? "Multiple choice" | ||||
|                             : `[${values.type}](../SpecialInputElements.md#${values.type})`, | ||||
|                         embedded.join(" ") | ||||
|                         embedded.join(" "), | ||||
|                     ] | ||||
|                 }) | ||||
|         ) | ||||
|  | @ -488,31 +487,30 @@ export default class LayerConfig extends WithContextLoader { | |||
|         let quickOverview: string[] = [] | ||||
|         if (tableRows.length > 0) { | ||||
|             quickOverview = [ | ||||
|                 ("**Warning:**"), | ||||
|                 "**Warning:**", | ||||
|                 "this quick overview is incomplete", | ||||
|                 MarkdownUtils.table( | ||||
|                     ["attribute", "type", "values which are supported by this layer"], | ||||
|                     tableRows | ||||
|                 ) | ||||
|                 ), | ||||
|             ] | ||||
|         } | ||||
| 
 | ||||
|         let overpassLink: string = undefined | ||||
|         if (this.source !== undefined) { | ||||
|             try { | ||||
|                 overpassLink = ( | ||||
|                 overpassLink = | ||||
|                     "[Execute on overpass](" + | ||||
|                     Overpass.AsOverpassTurboLink(<TagsFilter>this.source.osmTags.optimize()) | ||||
|                         .replaceAll("(", "%28") | ||||
|                         .replaceAll(")", "%29") | ||||
|                     + ")" | ||||
|                 ) | ||||
|                         .replaceAll(")", "%29") + | ||||
|                     ")" | ||||
|             } catch (e) { | ||||
|                 console.error("Could not generate overpasslink for " + this.id) | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         const filterDocs: (string)[] = [] | ||||
|         const filterDocs: string[] = [] | ||||
|         if (this.filters.length > 0) { | ||||
|             filterDocs.push("## Filters") | ||||
|             filterDocs.push(...this.filters.map((filter) => filter.GenerateDocs())) | ||||
|  | @ -538,8 +536,8 @@ export default class LayerConfig extends WithContextLoader { | |||
|             } else { | ||||
|                 tagsDescription.push( | ||||
|                     "Elements must match the expression **" + | ||||
|                     neededTags.asHumanString(true, false, {}) + | ||||
|                     "**" | ||||
|                         neededTags.asHumanString(true, false, {}) + | ||||
|                         "**" | ||||
|                 ) | ||||
|             } | ||||
| 
 | ||||
|  | @ -551,17 +549,21 @@ export default class LayerConfig extends WithContextLoader { | |||
|         return [ | ||||
|             [ | ||||
|                 "# " + this.id + "\n", | ||||
|                 this._basedOn ? `This layer is based on [${this._basedOn}](../Layers/${this._basedOn}.md)` : "", | ||||
|                 this.description, "\n"].join("\n\n"), | ||||
|                 this._basedOn | ||||
|                     ? `This layer is based on [${this._basedOn}](../Layers/${this._basedOn}.md)` | ||||
|                     : "", | ||||
|                 this.description, | ||||
|                 "\n", | ||||
|             ].join("\n\n"), | ||||
|             MarkdownUtils.list(extraProps), | ||||
|             ...usingLayer, | ||||
|             ...tagsDescription, | ||||
|             "## Supported attributes", | ||||
|             quickOverview, | ||||
|             ...this.tagRenderings | ||||
|                 .filter(tr => tr.labels.indexOf("ignore_docs") < 0) | ||||
|                 .filter((tr) => tr.labels.indexOf("ignore_docs") < 0) | ||||
|                 .map((tr) => tr.GenerateDocumentation()), | ||||
|             ...filterDocs | ||||
|             ...filterDocs, | ||||
|         ].join("\n\n") | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ import { Tag } from "../../Logic/Tags/Tag" | |||
| import Link from "../../UI/Base/Link" | ||||
| import { | ||||
|     MappingConfigJson, | ||||
|     QuestionableTagRenderingConfigJson | ||||
|     QuestionableTagRenderingConfigJson, | ||||
| } from "./Json/QuestionableTagRenderingConfigJson" | ||||
| import Validators, { ValidatorType } from "../../UI/InputElement/Validators" | ||||
| import { TagRenderingConfigJson } from "./Json/TagRenderingConfigJson" | ||||
|  | @ -204,7 +204,7 @@ export default class TagRenderingConfig { | |||
|                 inline: json.freeform.inline ?? false, | ||||
|                 default: json.freeform.default, | ||||
|                 postfixDistinguished: json.freeform.postfixDistinguished?.trim(), | ||||
|                 args: json.freeform.helperArgs | ||||
|                 args: json.freeform.helperArgs, | ||||
|             } | ||||
|             if (json.freeform["extraTags"] !== undefined) { | ||||
|                 throw `Freeform.extraTags is defined. This should probably be 'freeform.addExtraTag' (at ${context})` | ||||
|  | @ -416,7 +416,7 @@ export default class TagRenderingConfig { | |||
|             iconClass, | ||||
|             addExtraTags, | ||||
|             searchTerms: mapping.searchTerms, | ||||
|             priorityIf: prioritySearch | ||||
|             priorityIf: prioritySearch, | ||||
|         } | ||||
|         if (isQuestionable) { | ||||
|             if (hideInAnswer !== true && mp.if !== undefined && !mp.if.isUsableAsAnswer()) { | ||||
|  | @ -517,7 +517,7 @@ export default class TagRenderingConfig { | |||
|                     then: new TypedTranslation<object>( | ||||
|                         this.render.replace("{" + this.freeform.key + "}", leftover).translations, | ||||
|                         this.render.context | ||||
|                     ) | ||||
|                     ), | ||||
|                 }) | ||||
|             } | ||||
|         } | ||||
|  | @ -567,7 +567,7 @@ export default class TagRenderingConfig { | |||
|                         return { | ||||
|                             then: this.render.PartialSubs({ [this.freeform.key]: v.trim() }), | ||||
|                             icon: this.renderIcon, | ||||
|                             iconClass: this.renderIconClass | ||||
|                             iconClass: this.renderIconClass, | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|  | @ -622,7 +622,7 @@ export default class TagRenderingConfig { | |||
|                     key: commonKey, | ||||
|                     values: Utils.NoNull( | ||||
|                         values.map((arr) => arr.filter((item) => item.k === commonKey)[0]?.v) | ||||
|                     ) | ||||
|                     ), | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|  | @ -637,7 +637,7 @@ export default class TagRenderingConfig { | |||
|             return { | ||||
|                 key, | ||||
|                 type: this.freeform.type, | ||||
|                 values | ||||
|                 values, | ||||
|             } | ||||
|         } catch (e) { | ||||
|             console.error("Could not create FreeformValues for tagrendering", this.id) | ||||
|  | @ -743,7 +743,7 @@ export default class TagRenderingConfig { | |||
|             // Either no mappings, or this is a radio-button selected freeform value
 | ||||
|             const tag = new And([ | ||||
|                 new Tag(this.freeform.key, freeformValue), | ||||
|                 ...(this.freeform.addExtraTags ?? []) | ||||
|                 ...(this.freeform.addExtraTags ?? []), | ||||
|             ]) | ||||
|             const newProperties = tag.applyOn(currentProperties) | ||||
|             if (this.invalidValues?.matchesProperties(newProperties)) { | ||||
|  | @ -767,7 +767,7 @@ export default class TagRenderingConfig { | |||
|                 selectedMappings.push( | ||||
|                     new And([ | ||||
|                         new Tag(this.freeform.key, freeformValue), | ||||
|                         ...(this.freeform.addExtraTags ?? []) | ||||
|                         ...(this.freeform.addExtraTags ?? []), | ||||
|                     ]) | ||||
|                 ) | ||||
|             } | ||||
|  | @ -795,12 +795,12 @@ export default class TagRenderingConfig { | |||
|         if (useFreeform) { | ||||
|             return new And([ | ||||
|                 new Tag(this.freeform.key, freeformValue), | ||||
|                 ...(this.freeform.addExtraTags ?? []) | ||||
|                 ...(this.freeform.addExtraTags ?? []), | ||||
|             ]) | ||||
|         } else if (singleSelectedMapping !== undefined) { | ||||
|             return new And([ | ||||
|                 this.mappings[singleSelectedMapping].if, | ||||
|                 ...(this.mappings[singleSelectedMapping].addExtraTags ?? []) | ||||
|                 ...(this.mappings[singleSelectedMapping].addExtraTags ?? []), | ||||
|             ]) | ||||
|         } else { | ||||
|             console.error("TagRenderingConfig.ConstructSpecification has a weird fallback for", { | ||||
|  | @ -808,7 +808,7 @@ export default class TagRenderingConfig { | |||
|                 singleSelectedMapping, | ||||
|                 multiSelectedMapping, | ||||
|                 currentProperties, | ||||
|                 useFreeform | ||||
|                 useFreeform, | ||||
|             }) | ||||
| 
 | ||||
|             return undefined | ||||
|  | @ -838,11 +838,11 @@ export default class TagRenderingConfig { | |||
|                     } | ||||
|                     const msgs: string[] = [ | ||||
|                         icon + | ||||
|                         " " + | ||||
|                         "*" + | ||||
|                         m.then.textFor(lang) + | ||||
|                         "* is shown if with " + | ||||
|                         m.if.asHumanString(true, false, {}) | ||||
|                             " " + | ||||
|                             "*" + | ||||
|                             m.then.textFor(lang) + | ||||
|                             "* is shown if with " + | ||||
|                             m.if.asHumanString(true, false, {}), | ||||
|                     ] | ||||
| 
 | ||||
|                     if (m.hideInAnswer === true) { | ||||
|  | @ -851,7 +851,7 @@ export default class TagRenderingConfig { | |||
|                     if (m.ifnot !== undefined) { | ||||
|                         msgs.push( | ||||
|                             "Unselecting this answer will add " + | ||||
|                             m.ifnot.asHumanString(true, false, {}) | ||||
|                                 m.ifnot.asHumanString(true, false, {}) | ||||
|                         ) | ||||
|                     } | ||||
|                     return msgs.join(". ") | ||||
|  | @ -875,7 +875,7 @@ export default class TagRenderingConfig { | |||
|         if (this.labels?.length > 0) { | ||||
|             labels = [ | ||||
|                 "This tagrendering has labels ", | ||||
|                 ...this.labels.map((label) => "`" + label + "`") | ||||
|                 ...this.labels.map((label) => "`" + label + "`"), | ||||
|             ].join("\n") | ||||
|         } | ||||
| 
 | ||||
|  | @ -888,15 +888,13 @@ export default class TagRenderingConfig { | |||
|             freeform, | ||||
|             mappings, | ||||
|             condition, | ||||
|             labels | ||||
|             labels, | ||||
|         ].join("\n") | ||||
|     } | ||||
| 
 | ||||
|     public | ||||
| 
 | ||||
|     usedTags() | ||||
|         : | ||||
|         TagsFilter[] { | ||||
|     usedTags(): TagsFilter[] { | ||||
|         const tags: TagsFilter[] = [] | ||||
|         tags.push( | ||||
|             this.metacondition, | ||||
|  | @ -924,9 +922,7 @@ export default class TagRenderingConfig { | |||
|      */ | ||||
|     public | ||||
| 
 | ||||
|     settableKeys() | ||||
|         : | ||||
|         string[] | undefined { | ||||
|     settableKeys(): string[] | undefined { | ||||
|         const toDelete = new Set<string>() | ||||
|         if (this.freeform) { | ||||
|             toDelete.add(this.freeform.key) | ||||
|  | @ -975,7 +971,7 @@ export class TagRenderingConfigUtils { | |||
|             const oldMappingsCloned = | ||||
|                 clone.mappings?.map((m) => ({ | ||||
|                     ...m, | ||||
|                     priorityIf: m.priorityIf ?? TagUtils.Tag("id~*") | ||||
|                     priorityIf: m.priorityIf ?? TagUtils.Tag("id~*"), | ||||
|                 })) ?? [] | ||||
|             clone.mappings = [...oldMappingsCloned, ...extraMappings] | ||||
|             return clone | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue