import WithContextLoader from "./WithContextLoader"; import TagRenderingConfig from "./TagRenderingConfig"; import {Utils} from "../../Utils"; import LineRenderingConfigJson from "./Json/LineRenderingConfigJson"; export default class LineRenderingConfig extends WithContextLoader { public readonly color: TagRenderingConfig; public readonly width: TagRenderingConfig; public readonly dashArray: TagRenderingConfig; public readonly lineCap: TagRenderingConfig; public readonly offset: TagRenderingConfig; public readonly fill: TagRenderingConfig; public readonly fillColor: TagRenderingConfig; public readonly leftRightSensitive: boolean constructor(json: LineRenderingConfigJson, context: string) { super(json, context) this.color = this.tr("color", "#0000ff"); this.width = this.tr("width", "7"); this.dashArray = this.tr("dashArray", ""); this.lineCap = this.tr("lineCap", "round"); this.fill = this.tr("fill", "round"); this.fillColor = this.tr("fillColor", "round"); this.leftRightSensitive = json.offset !== undefined && json.offset !== 0 && json.offset !== "0" this.offset = this.tr("offset", "0"); } public GenerateLeafletStyle(tags: {}): { fillColor: string; color: string; lineCap: string; offset: number; weight: number; dashArray: string; fill: string } { function rendernum(tr: TagRenderingConfig, deflt: number) { const str = Number(render(tr, "" + deflt)); const n = Number(str); if (isNaN(n)) { return deflt; } return n; } function render(tr: TagRenderingConfig, deflt?: string) { if (tags === undefined) { return deflt } const str = tr?.GetRenderValue(tags)?.txt ?? deflt; return Utils.SubstituteKeys(str, tags)?.replace(/{.*}/g, ""); } const dashArray = render(this.dashArray); let color = render(this.color, "#00f"); if (color.startsWith("--")) { color = getComputedStyle(document.body).getPropertyValue( "--catch-detail-color" ); } return { color, dashArray, weight: rendernum(this.width, 5), lineCap: render(this.lineCap), offset: rendernum(this.offset, 0), fill: render(this.fill), fillColor: render(this.fillColor) } } }