| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import PointRenderingConfigJson from "./Json/PointRenderingConfigJson" | 
					
						
							|  |  |  | import TagRenderingConfig from "./TagRenderingConfig" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { TagsFilter } from "../../Logic/Tags/TagsFilter" | 
					
						
							|  |  |  | import { TagUtils } from "../../Logic/Tags/TagUtils" | 
					
						
							|  |  |  | import { Utils } from "../../Utils" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import WithContextLoader from "./WithContextLoader" | 
					
						
							| 
									
										
										
										
											2023-10-07 03:07:32 +02:00
										 |  |  | import { ImmutableStore, Store } from "../../Logic/UIEventSource" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import BaseUIElement from "../../UI/BaseUIElement" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { FixedUiElement } from "../../UI/Base/FixedUiElement" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import Combine from "../../UI/Base/Combine" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { VariableUiElement } from "../../UI/Base/VariableUIElement" | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  | import { TagRenderingConfigJson } from "./Json/TagRenderingConfigJson" | 
					
						
							|  |  |  | import SvelteUIElement from "../../UI/Base/SvelteUIElement" | 
					
						
							| 
									
										
										
										
											2023-10-11 04:16:52 +02:00
										 |  |  | import DynamicMarker from "../../UI/Map/DynamicMarker.svelte" | 
					
						
							| 
									
										
										
										
											2024-04-28 01:08:28 +02:00
										 |  |  | import { UIElement } from "../../UI/UIElement" | 
					
						
							|  |  |  | import Img from "../../UI/Base/Img" | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class IconConfig extends WithContextLoader { | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |     public static readonly defaultIcon = new IconConfig({ icon: "pin", color: "#ff9939" }) | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  |     public readonly icon: TagRenderingConfig | 
					
						
							|  |  |  |     public readonly color: TagRenderingConfig | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor( | 
					
						
							|  |  |  |         config: { | 
					
						
							|  |  |  |             icon: string | TagRenderingConfigJson | 
					
						
							|  |  |  |             color?: string | TagRenderingConfigJson | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         context?: string | 
					
						
							|  |  |  |     ) { | 
					
						
							|  |  |  |         super(config, context) | 
					
						
							|  |  |  |         this.icon = this.tr("icon") | 
					
						
							|  |  |  |         this.color = this.tr("color") | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-06-04 18:10:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  | export default class PointRenderingConfig extends WithContextLoader { | 
					
						
							| 
									
										
										
										
											2023-04-27 02:24:38 +02:00
										 |  |  |     static readonly allowed_location_codes: ReadonlySet<string> = new Set<string>([ | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         "point", | 
					
						
							|  |  |  |         "centroid", | 
					
						
							|  |  |  |         "start", | 
					
						
							|  |  |  |         "end", | 
					
						
							|  |  |  |         "projected_centerpoint", | 
					
						
							| 
									
										
										
										
											2024-02-20 13:33:38 +01:00
										 |  |  |         "polygon_centroid", | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     ]) | 
					
						
							|  |  |  |     public readonly location: Set< | 
					
						
							| 
									
										
										
										
											2024-02-20 13:33:38 +01:00
										 |  |  |         | "point" | 
					
						
							|  |  |  |         | "centroid" | 
					
						
							|  |  |  |         | "start" | 
					
						
							|  |  |  |         | "end" | 
					
						
							|  |  |  |         | "projected_centerpoint" | 
					
						
							|  |  |  |         | "polygon_centroid" | 
					
						
							|  |  |  |         | string | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     > | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-11 04:16:52 +02:00
										 |  |  |     public readonly marker: IconConfig[] | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     public readonly iconBadges: { if: TagsFilter; then: TagRenderingConfig }[] | 
					
						
							|  |  |  |     public readonly iconSize: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2023-06-20 02:02:45 +02:00
										 |  |  |     public readonly anchor: TagRenderingConfig | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     public readonly label: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |     public readonly labelCss: TagRenderingConfig | 
					
						
							|  |  |  |     public readonly labelCssClasses: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     public readonly rotation: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2022-12-09 13:58:41 +01:00
										 |  |  |     public readonly cssDef: TagRenderingConfig | 
					
						
							|  |  |  |     public readonly cssClasses?: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2023-03-25 02:48:24 +01:00
										 |  |  |     public readonly pitchAlignment?: TagRenderingConfig | 
					
						
							|  |  |  |     public readonly rotationAlignment?: TagRenderingConfig | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     constructor(json: PointRenderingConfigJson, context: string) { | 
					
						
							|  |  |  |         super(json, context) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 14:09:28 +01:00
										 |  |  |         if (json === undefined || json === null) { | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  |             throw `At ${context}: Invalid PointRenderingConfig: undefined or null` | 
					
						
							| 
									
										
										
										
											2023-02-02 14:09:28 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |         if (typeof json.location === "string") { | 
					
						
							| 
									
										
										
										
											2021-10-28 03:15:36 +02:00
										 |  |  |             json.location = [json.location] | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-22 01:07:32 +02:00
										 |  |  |         this.location = new Set(json.location) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         this.location.forEach((l) => { | 
					
						
							| 
									
										
										
										
											2021-10-28 03:15:36 +02:00
										 |  |  |             const allowed = PointRenderingConfig.allowed_location_codes | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |             if (!allowed.has(l)) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 throw `A point rendering has an invalid location: '${l}' is not one of ${Array.from( | 
					
						
							|  |  |  |                     allowed | 
					
						
							|  |  |  |                 ).join(", ")} (at ${context}.location)`
 | 
					
						
							| 
									
										
										
										
											2021-10-28 03:15:36 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-07 03:07:32 +02:00
										 |  |  |         this.marker = (json.marker ?? []).map((m) => new IconConfig(<any>m)) | 
					
						
							| 
									
										
										
										
											2022-12-16 13:45:07 +01:00
										 |  |  |         if (json.css !== undefined) { | 
					
						
							| 
									
										
										
										
											2022-12-09 13:58:41 +01:00
										 |  |  |             this.cssDef = this.tr("css", undefined) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         this.cssClasses = this.tr("cssClasses", undefined) | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |         this.labelCss = this.tr("labelCss", undefined) | 
					
						
							|  |  |  |         this.labelCssClasses = this.tr("labelCssClasses", undefined) | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  |         this.iconBadges = (json.iconBadges ?? []).map((overlay, i) => { | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |             return { | 
					
						
							|  |  |  |                 if: TagUtils.Tag(overlay.if), | 
					
						
							| 
									
										
										
										
											2023-02-03 03:57:30 +01:00
										 |  |  |                 then: new TagRenderingConfig(overlay.then, `iconBadges.${i}`), | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-20 02:47:20 +02:00
										 |  |  |         if (typeof json.iconSize === "string") { | 
					
						
							|  |  |  |             const s = json.iconSize | 
					
						
							|  |  |  |             if (["bottom", "top", "center"].some((e) => s.endsWith(e))) { | 
					
						
							|  |  |  |                 throw ( | 
					
						
							|  |  |  |                     "At " + | 
					
						
							|  |  |  |                     context + | 
					
						
							|  |  |  |                     " in : iconSize uses legacy ,bottom, center or top postfix. Use the field `anchor` instead." | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-10-02 01:23:43 +02:00
										 |  |  |         this.iconSize = this.tr("iconSize", "40,40", context + ".iconsize") | 
					
						
							|  |  |  |         this.anchor = this.tr("anchor", "center", context + ".anchor") | 
					
						
							|  |  |  |         this.label = this.tr("label", undefined, context + ".label") | 
					
						
							|  |  |  |         this.rotation = this.tr("rotation", "0", context + ".rotation") | 
					
						
							|  |  |  |         this.pitchAlignment = this.tr("pitchAlignment", "canvas", context + ".pitchAlignment") | 
					
						
							| 
									
										
										
										
											2023-03-25 02:48:24 +01:00
										 |  |  |         this.rotationAlignment = this.tr( | 
					
						
							|  |  |  |             "rotationAlignment", | 
					
						
							| 
									
										
										
										
											2023-10-02 01:23:43 +02:00
										 |  |  |             json.pitchAlignment === "map" ? "map" : "canvas", | 
					
						
							|  |  |  |             context + ".rotationAlignment" | 
					
						
							| 
									
										
										
										
											2023-03-25 02:48:24 +01:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-06-16 16:06:26 +02:00
										 |  |  |     private static FromHtmlMulti( | 
					
						
							|  |  |  |         multiSpec: string, | 
					
						
							|  |  |  |         tags: Store<Record<string, string>> | 
					
						
							|  |  |  |     ): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |         const icons: IconConfig[] = [] | 
					
						
							| 
									
										
										
										
											2024-04-28 01:08:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |         for (const subspec of multiSpec.split(";")) { | 
					
						
							| 
									
										
										
										
											2024-06-16 16:06:26 +02:00
										 |  |  |             if (subspec.startsWith("http://") || subspec.startsWith("https://")) { | 
					
						
							|  |  |  |                 icons.push(new IconConfig({ icon: subspec })) | 
					
						
							| 
									
										
										
										
											2024-04-28 01:08:28 +02:00
										 |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |             const [icon, color] = subspec.split(":") | 
					
						
							|  |  |  |             icons.push(new IconConfig({ icon, color })) | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |         return new SvelteUIElement(DynamicMarker, { marker: icons, tags }).SetClass( | 
					
						
							|  |  |  |             "w-full h-full block absolute top-0 left-0" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  |     public GetBaseIcon(tags?: Record<string, string>): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |         return new SvelteUIElement(DynamicMarker, { | 
					
						
							|  |  |  |             marker: this.marker, | 
					
						
							|  |  |  |             rotation: this.rotation, | 
					
						
							|  |  |  |             tags: new ImmutableStore(tags), | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-24 19:21:15 +01:00
										 |  |  |     public RenderIcon( | 
					
						
							| 
									
										
										
										
											2023-03-28 05:13:48 +02:00
										 |  |  |         tags: Store<Record<string, string>>, | 
					
						
							| 
									
										
										
										
											2021-10-30 02:34:16 +02:00
										 |  |  |         options?: { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             noSize?: false | boolean | 
					
						
							| 
									
										
										
										
											2022-02-01 04:14:54 +01:00
										 |  |  |             includeBadges?: true | boolean | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |             metatags?: Store<Record<string, string>> | 
					
						
							| 
									
										
										
										
											2021-10-30 02:34:16 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     ): { | 
					
						
							|  |  |  |         html: BaseUIElement | 
					
						
							|  |  |  |         iconAnchor: [number, number] | 
					
						
							|  |  |  |     } { | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         function num(str, deflt = 40) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             const n = Number(str) | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |             if (isNaN(n)) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 return deflt | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             return n | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-06 23:56:50 +02:00
										 |  |  |         function render(tr: TagRenderingConfig, deflt?: string): string { | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |             if (tags === undefined) { | 
					
						
							|  |  |  |                 return deflt | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             const str = tr?.GetRenderValue(tags.data)?.txt ?? deflt | 
					
						
							|  |  |  |             return Utils.SubstituteKeys(str, tags.data).replace(/{.*}/g, "") | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-23 00:58:21 +01:00
										 |  |  |         // in MapLibre, the offset is relative to the _center_ of the object, with left = [-x, 0] and up = [0,-y]
 | 
					
						
							|  |  |  |         let anchorW = 0 | 
					
						
							| 
									
										
										
										
											2023-03-24 19:21:15 +01:00
										 |  |  |         let anchorH = 0 | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |         const anchor = render(this.anchor, "center") | 
					
						
							|  |  |  |         const mode = anchor?.trim()?.toLowerCase() ?? "center" | 
					
						
							|  |  |  |         const size = this.iconSize.GetRenderValue(tags.data).Subs(tags).txt ?? "[40,40]" | 
					
						
							|  |  |  |         const [iconW, iconH] = size.split(",").map((x) => num(x)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         if (mode === "left") { | 
					
						
							| 
									
										
										
										
											2023-03-23 00:58:21 +01:00
										 |  |  |             anchorW = -iconW / 2 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (mode === "right") { | 
					
						
							| 
									
										
										
										
											2023-03-23 00:58:21 +01:00
										 |  |  |             anchorW = iconW / 2 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (mode === "top") { | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |             anchorH = iconH / 2 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (mode === "bottom") { | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |             anchorH = -iconH / 2 | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |         const icon = | 
					
						
							|  |  |  |             this.marker?.length > 0 | 
					
						
							|  |  |  |                 ? new SvelteUIElement(DynamicMarker, { | 
					
						
							|  |  |  |                       marker: this.marker, | 
					
						
							|  |  |  |                       rotation: this.rotation, | 
					
						
							|  |  |  |                       tags, | 
					
						
							| 
									
										
										
										
											2024-06-20 04:21:29 +02:00
										 |  |  |                       emojiHeight: iconH, | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |                   }).SetClass("w-full h-full") | 
					
						
							|  |  |  |                 : undefined | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         let badges = undefined | 
					
						
							| 
									
										
										
										
											2022-02-11 02:03:33 +01:00
										 |  |  |         if (options?.includeBadges ?? true) { | 
					
						
							| 
									
										
										
										
											2023-11-17 18:26:59 +01:00
										 |  |  |             badges = this.GetBadges(tags, options?.metatags) | 
					
						
							| 
									
										
										
										
											2022-01-27 01:23:04 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const iconAndBadges = new Combine([icon, badges]).SetClass("block relative") | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |         if (options?.noSize) { | 
					
						
							| 
									
										
										
										
											2021-10-30 02:34:16 +02:00
										 |  |  |             iconAndBadges.SetClass("w-full h-full") | 
					
						
							| 
									
										
										
										
											2024-02-02 13:55:05 +01:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             tags.map((tags) => this.iconSize.GetRenderValue(tags).Subs(tags).txt ?? "[40,40]").map( | 
					
						
							|  |  |  |                 (size) => { | 
					
						
							|  |  |  |                     const [iconW, iconH] = size.split(",").map((x) => num(x)) | 
					
						
							|  |  |  |                     iconAndBadges.SetStyle(`width: ${iconW}px; height: ${iconH}px`) | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2021-10-30 02:34:16 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |         const css = this.cssDef?.GetRenderValue(tags.data)?.txt | 
					
						
							|  |  |  |         const cssClasses = this.cssClasses?.GetRenderValue(tags.data)?.txt | 
					
						
							| 
									
										
										
										
											2022-12-09 13:58:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |         let label = this.GetLabel(tags, icon === undefined) | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         let htmlEl: BaseUIElement | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  |         if (icon === undefined && label === undefined) { | 
					
						
							| 
									
										
										
										
											2021-11-22 00:50:29 +01:00
										 |  |  |             htmlEl = undefined | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  |         } else if (icon === undefined) { | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |             htmlEl = label | 
					
						
							| 
									
										
										
										
											2022-01-26 21:40:38 +01:00
										 |  |  |         } else if (label === undefined) { | 
					
						
							|  |  |  |             htmlEl = new Combine([iconAndBadges]) | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2021-11-22 00:50:29 +01:00
										 |  |  |             htmlEl = new Combine([iconAndBadges, label]).SetStyle("flex flex-col") | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-16 13:45:07 +01:00
										 |  |  |         if (css !== undefined) { | 
					
						
							| 
									
										
										
										
											2022-12-09 13:58:41 +01:00
										 |  |  |             htmlEl?.SetStyle(css) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-16 13:45:07 +01:00
										 |  |  |         if (cssClasses !== undefined) { | 
					
						
							| 
									
										
										
										
											2022-12-09 13:58:41 +01:00
										 |  |  |             htmlEl?.SetClass(cssClasses) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |         return { | 
					
						
							| 
									
										
										
										
											2021-11-22 00:50:29 +01:00
										 |  |  |             html: htmlEl, | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  |             iconAnchor: [anchorW, anchorH], | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-10-19 02:31:32 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-10-21 21:41:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |     private GetBadges( | 
					
						
							|  |  |  |         tags: Store<Record<string, string>>, | 
					
						
							|  |  |  |         metaTags?: Store<Record<string, string>> | 
					
						
							|  |  |  |     ): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |         if (this.iconBadges.length === 0) { | 
					
						
							|  |  |  |             return undefined | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return new VariableUiElement( | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |             tags.map( | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |                 (tagsData) => { | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                     const badgeElements = this.iconBadges.map((badge) => { | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |                         if (!badge.if.matchesProperties(tagsData)) { | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                             // Doesn't match...
 | 
					
						
							|  |  |  |                             return undefined | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         const metaCondition = badge.then.metacondition | 
					
						
							|  |  |  |                         if ( | 
					
						
							|  |  |  |                             metaCondition && | 
					
						
							|  |  |  |                             metaTags && | 
					
						
							|  |  |  |                             !metaCondition.matchesProperties(metaTags.data) | 
					
						
							|  |  |  |                         ) { | 
					
						
							|  |  |  |                             // Doesn't match
 | 
					
						
							|  |  |  |                             return undefined | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         const htmlDefs = Utils.SubstituteKeys( | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |                             badge.then.GetRenderValue(tagsData)?.txt, | 
					
						
							|  |  |  |                             tagsData | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                         ) | 
					
						
							|  |  |  |                         if (htmlDefs.startsWith("<") && htmlDefs.endsWith(">")) { | 
					
						
							|  |  |  |                             // This is probably an HTML-element
 | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |                             return new FixedUiElement(Utils.SubstituteKeys(htmlDefs, tagsData)) | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                                 .SetStyle("width: 1.5rem") | 
					
						
							|  |  |  |                                 .SetClass("block") | 
					
						
							|  |  |  |                         } | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                         if (!htmlDefs) { | 
					
						
							|  |  |  |                             return undefined | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                         const badgeElement = PointRenderingConfig.FromHtmlMulti( | 
					
						
							|  |  |  |                             htmlDefs, | 
					
						
							| 
									
										
										
										
											2023-11-19 04:38:34 +01:00
										 |  |  |                             tags | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                         )?.SetClass("block relative") | 
					
						
							|  |  |  |                         if (badgeElement === undefined) { | 
					
						
							|  |  |  |                             return undefined | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         return new Combine([badgeElement]) | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |                             .SetStyle("width: 1.5rem") | 
					
						
							|  |  |  |                             .SetClass("block") | 
					
						
							| 
									
										
										
										
											2023-11-14 17:35:12 +01:00
										 |  |  |                     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     return new Combine(badgeElements).SetClass("inline-flex h-full") | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 [metaTags] | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ).SetClass("absolute bottom-0 right-1/3 h-1/2 w-0") | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |     private GetLabel(tags: Store<Record<string, string>>, labelOnly: boolean): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |         if (this.label === undefined) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             return undefined | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |         const cssLabel = this.labelCss?.GetRenderValue(tags.data)?.txt | 
					
						
							|  |  |  |         const cssClassesLabel = this.labelCssClasses?.GetRenderValue(tags.data)?.txt | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const self = this | 
					
						
							|  |  |  |         return new VariableUiElement( | 
					
						
							|  |  |  |             tags.map((tags) => { | 
					
						
							|  |  |  |                 const label = self.label | 
					
						
							|  |  |  |                     ?.GetRenderValue(tags) | 
					
						
							|  |  |  |                     ?.Subs(tags) | 
					
						
							| 
									
										
										
										
											2024-02-15 17:39:59 +01:00
										 |  |  |                     ?.SetClass("flex items-center justify-center absolute marker-label") | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |                     ?.SetClass(cssClassesLabel) | 
					
						
							|  |  |  |                 if (cssLabel) { | 
					
						
							|  |  |  |                     label.SetStyle(cssLabel) | 
					
						
							| 
									
										
										
										
											2023-12-05 03:27:17 +01:00
										 |  |  |                 } else if (labelOnly) { | 
					
						
							| 
									
										
										
										
											2024-02-07 20:29:05 +01:00
										 |  |  |                     return label?.SetStyle("transform: translate(-50%, -50%);") | 
					
						
							| 
									
										
										
										
											2023-04-02 02:59:20 +02:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 return new Combine([label]).SetClass("flex flex-col items-center") | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             }) | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-11-07 16:34:51 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | } |