diff --git a/Customizations/Layout.ts b/Customizations/Layout.ts index 70bc7dc3a2..46252c6c06 100644 --- a/Customizations/Layout.ts +++ b/Customizations/Layout.ts @@ -18,6 +18,10 @@ export class Layout { public description: string | UIElement; public changesetMessage: string; public socialImage: string = ""; + /** + * Custom CSS link + */ + public customCss: string = undefined; public layers: (LayerDefinition | string)[]; public welcomeMessage: UIElement; diff --git a/Logic/MetaTagging.ts b/Logic/MetaTagging.ts index 4de819b6fd..5be7edbea9 100644 --- a/Logic/MetaTagging.ts +++ b/Logic/MetaTagging.ts @@ -5,12 +5,12 @@ import opening_hours from "opening_hours"; class SimpleMetaTagger { - private _f: (feature: any) => void; + private _f: (feature: any, index: number) => void; public readonly keys: string[]; public readonly doc: string; - constructor(keys: string[], doc: string, f: ((feature: any) => void)) { + constructor(keys: string[], doc: string, f: ((feature: any, index: number) => void)) { this.keys = keys; this.doc = doc; this._f = f; @@ -22,8 +22,9 @@ class SimpleMetaTagger { } addMetaTags(features: any[]) { - for (const feature of features) { - this._f(feature); + for (let i = 0; i < features.length; i++) { + let feature = features[i]; + this._f(feature, i); } } @@ -62,7 +63,7 @@ export default class MetaTagging { new SimpleMetaTagger( ["_country"], "The country code of the point", - (feature => { + ((feature, index) => { const centerPoint = GeoOperations.centerpoint(feature); const lat = centerPoint.geometry.coordinates[1]; const lon = centerPoint.geometry.coordinates[0] @@ -70,7 +71,11 @@ export default class MetaTagging { CodeGrid.getCode(lat, lon, (error, code) => { if (error === null) { feature.properties["_country"] = code; - State.state.allElements.addOrGetElement(feature).ping(); + + // There is a huge performance issue: if there are ~1000 features receiving a ping at the same time, + // The application hangs big time + // So we disable pinging all together + } else { console.warn("Could not determine country for", feature.properties.id, error); } @@ -85,6 +90,11 @@ export default class MetaTagging { if (tags["opening_hours"] !== undefined && tags["_country"] !== undefined) { + if (tags._isOpen !== undefined) { + // Already defined + return; + } + const oh = new opening_hours(tags["opening_hours"], { lat: tags._lat, lon: tags._lon, diff --git a/README.md b/README.md index e82fd198a0..ccdf8198d2 100644 --- a/README.md +++ b/README.md @@ -209,4 +209,7 @@ Forest icon via https://www.onlinewebfonts.com/icon/498112, CC BY Statistics icon via https://www.onlinewebfonts.com/icon/197818 Chronometer (on monitoring_station.svg): ANTU chronometer -https://commons.wikimedia.org/w/index.php?title=Antu_chronometer&action=edit&redlink=1 \ No newline at end of file +https://commons.wikimedia.org/w/index.php?title=Antu_chronometer + +Fries icon: +https://commons.wikimedia.org/wiki/File:French_fries_juliane_kr_r.svg \ No newline at end of file diff --git a/State.ts b/State.ts index 43a88e0fa8..f8e2909614 100644 --- a/State.ts +++ b/State.ts @@ -23,7 +23,7 @@ export default class State { // The singleton of the global state public static state: State; - public static vNumber = "0.1.0g"; + public static vNumber = "0.1.1"; // The user journey states thresholds when a new feature gets unlocked public static userJourney = { diff --git a/UI/Input/OpeningHours/PublicHolidayInput.ts b/UI/Input/OpeningHours/PublicHolidayInput.ts index c17baf960b..3676f1f5c0 100644 --- a/UI/Input/OpeningHours/PublicHolidayInput.ts +++ b/UI/Input/OpeningHours/PublicHolidayInput.ts @@ -30,7 +30,7 @@ export default class PublicHolidayInput extends InputElement { ); this._dropdown = dropdown.SetStyle("display:inline-block;"); this._mode = dropdown.GetValue(); - this.ListenTo(dropdown.GetValue()); + this.ListenTo(this._mode); const start = new TextField({ placeholder: "starthour", @@ -117,7 +117,7 @@ export default class PublicHolidayInput extends InputElement { if(str === "PH open"){ return { - mode: "open" + mode: " " } } diff --git a/assets/themes/fritures/fries.svg b/assets/themes/fritures/fries.svg new file mode 100644 index 0000000000..09550da5d8 --- /dev/null +++ b/assets/themes/fritures/fries.svg @@ -0,0 +1,156 @@ + + + + + + + French Fries + + + + food + + + + + Open Clip Art Library + + + + + Juliane Krug + + + + + Juliane Krug + + + + image/svg+xml + + + en + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/assets/themes/fritures/fritures.json b/assets/themes/fritures/fritures.json index d664a5575f..729974f9ea 100644 --- a/assets/themes/fritures/fritures.json +++ b/assets/themes/fritures/fritures.json @@ -12,7 +12,7 @@ "fr" ], "maintainer": "", - "icon": "https://upload.wikimedia.org/wikipedia/commons/5/55/French_fries_juliane_kr_r.svg", + "icon": "./assets/themes/fritures/fries.svg", "version": "0", "startLat": 0, "startLon": 0, @@ -69,17 +69,16 @@ }, { "render": { - "nl": "{phone}", - "fr": "{phone}" + "nl": "

Openingsuren

{opening_hours_table(opening_hours)}", + "fr": "

Horaires

{opening_hours_table(opening_hours)}" }, "question": { - "en": "What is the phone number?", - "nl": "Wat is het telefoonnummer van deze frituur?", - "fr": "Quel est le numéro de téléphone de cette friture?" + "nl": "Wat zijn de openinguren van deze frituur?", + "fr": "Quand est ce-que ce friture ouvert?" }, "freeform": { - "key": "phone", - "type": "phone" + "key": "opening_hours", + "type": "opening_hours" } }, { @@ -98,16 +97,17 @@ }, { "render": { - "nl": "

Openingsuren

{opening_hours_table(opening_hours)}", - "fr": "

Horaires

{opening_hours_table(opening_hours)}" + "nl": "{phone}", + "fr": "{phone}" }, "question": { - "nl": "Wat zijn de openinguren van deze frituur?", - "fr": "Quand est ce-que ce friture ouvert?" + "en": "What is the phone number?", + "nl": "Wat is het telefoonnummer van deze frituur?", + "fr": "Quel est le numéro de téléphone de cette friture?" }, "freeform": { - "key": "opening_hours", - "type": "opening_hours" + "key": "phone", + "type": "phone" } }, { @@ -224,7 +224,7 @@ } ], "icon": { - "render": "https://upload.wikimedia.org/wikipedia/commons/5/55/French_fries_juliane_kr_r.svg" + "render": "./assets/themes/fritures/fries.svg" }, "width": { "render": "8" diff --git a/createLayouts.ts b/createLayouts.ts index 603282742c..4bd7f59b0f 100644 --- a/createLayouts.ts +++ b/createLayouts.ts @@ -1,6 +1,7 @@ import {UIElement} from "./UI/UIElement"; // We HAVE to mark this while importing UIElement.runningFromConsole = true; + import {AllKnownLayouts} from "./Customizations/AllKnownLayouts"; import {Layout} from "./Customizations/Layout"; import {readFileSync, writeFile, writeFileSync} from "fs"; @@ -206,6 +207,11 @@ function createLandingPage(layout: Layout) { const ogDescr = Translations.W(layout.description ?? "Easily add and edit geodata with OpenStreetMap")?.InnerRender(); const ogImage = layout.socialImage; + let customCss = ""; + if (layout.customCss !== undefined && layout.customCss !== "") { + customCss = ` @@ -214,6 +220,9 @@ function createLandingPage(layout: Layout) { let output = template .replace(`./manifest.manifest`, `./${enc(layout.id)}.webmanifest`) .replace("", og) + .replace(/.+?<\/title>/, `<title>${ogTitle}`) + .replace("Loading MapComplete, hang on...", `Loading MapComplete theme ${ogTitle}...`) + .replace("", customCss) .replace(``, ``); diff --git a/index.html b/index.html index ec97707f4d..130f182b0b 100644 --- a/index.html +++ b/index.html @@ -12,6 +12,7 @@ +