Fix performance, add 'isClosed' badge to shops
This commit is contained in:
parent
efd7631837
commit
a9dfce72a6
18 changed files with 334 additions and 124 deletions
|
@ -13,6 +13,7 @@ import {Utils} from "../../Utils";
|
||||||
import Combine from "../../UI/Base/Combine";
|
import Combine from "../../UI/Base/Combine";
|
||||||
import {VariableUiElement} from "../../UI/Base/VariableUIElement";
|
import {VariableUiElement} from "../../UI/Base/VariableUIElement";
|
||||||
import {UIEventSource} from "../../Logic/UIEventSource";
|
import {UIEventSource} from "../../Logic/UIEventSource";
|
||||||
|
import {FixedUiElement} from "../../UI/Base/FixedUiElement";
|
||||||
import {UIElement} from "../../UI/UIElement";
|
import {UIElement} from "../../UI/UIElement";
|
||||||
|
|
||||||
export default class LayerConfig {
|
export default class LayerConfig {
|
||||||
|
@ -35,7 +36,7 @@ export default class LayerConfig {
|
||||||
titleIcons: TagRenderingConfig[];
|
titleIcons: TagRenderingConfig[];
|
||||||
|
|
||||||
icon: TagRenderingConfig;
|
icon: TagRenderingConfig;
|
||||||
iconOverlays: { if: TagsFilter, then: string, badge: boolean }[]
|
iconOverlays: { if: TagsFilter, then: TagRenderingConfig, badge: boolean }[]
|
||||||
iconSize: TagRenderingConfig;
|
iconSize: TagRenderingConfig;
|
||||||
rotation: TagRenderingConfig;
|
rotation: TagRenderingConfig;
|
||||||
color: TagRenderingConfig;
|
color: TagRenderingConfig;
|
||||||
|
@ -140,9 +141,13 @@ export default class LayerConfig {
|
||||||
this.title = tr("title", undefined);
|
this.title = tr("title", undefined);
|
||||||
this.icon = tr("icon", Img.AsData(Svg.bug));
|
this.icon = tr("icon", Img.AsData(Svg.bug));
|
||||||
this.iconOverlays = (json.iconOverlays ?? []).map(overlay => {
|
this.iconOverlays = (json.iconOverlays ?? []).map(overlay => {
|
||||||
|
let tr = new TagRenderingConfig(overlay.then);
|
||||||
|
if (typeof overlay.then === "string" && SharedTagRenderings.SharedIcons[overlay.then] !== undefined) {
|
||||||
|
tr = SharedTagRenderings.SharedIcons[overlay.then];
|
||||||
|
}
|
||||||
return {
|
return {
|
||||||
if: FromJSON.Tag(overlay.if),
|
if: FromJSON.Tag(overlay.if),
|
||||||
then: overlay.then,
|
then: tr,
|
||||||
badge: overlay.badge ?? false
|
badge: overlay.badge ?? false
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -172,7 +177,7 @@ export default class LayerConfig {
|
||||||
popupAnchor: [number, number];
|
popupAnchor: [number, number];
|
||||||
iconAnchor: [number, number];
|
iconAnchor: [number, number];
|
||||||
iconSize: [number, number];
|
iconSize: [number, number];
|
||||||
html: string;
|
html: UIElement;
|
||||||
className?: string;
|
className?: string;
|
||||||
};
|
};
|
||||||
weight: number; dashArray: number[]
|
weight: number; dashArray: number[]
|
||||||
|
@ -232,32 +237,31 @@ export default class LayerConfig {
|
||||||
|
|
||||||
const iconUrlStatic = render(this.icon);
|
const iconUrlStatic = render(this.icon);
|
||||||
const self = this;
|
const self = this;
|
||||||
var mappedHtml = tags.map(tags => {
|
var mappedHtml = tags.map(tgs => {
|
||||||
// What do you mean, 'tags' is never read?
|
// What do you mean, 'tgs' is never read?
|
||||||
// It is read implicitly in the 'render' method
|
// It is read implicitly in the 'render' method
|
||||||
const iconUrl = render(self.icon);
|
const iconUrl = render(self.icon);
|
||||||
const rotation = render(self.rotation, "0deg");
|
const rotation = render(self.rotation, "0deg");
|
||||||
|
|
||||||
let htmlParts = [];
|
let htmlParts: UIElement[] = [];
|
||||||
let sourceParts = iconUrl.split(";");
|
let sourceParts = iconUrl.split(";");
|
||||||
|
|
||||||
function genHtmlFromString(sourcePart: string): string {
|
function genHtmlFromString(sourcePart: string): UIElement {
|
||||||
const style = `width:100%;height:100%;rotate:${rotation};display:block;position: absolute; top: 0, left: 0`;
|
const style = `width:100%;height:100%;rotate:${rotation};display:block;position: absolute; top: 0, left: 0`;
|
||||||
let html = `<img src="${sourcePart}" style="${style}" />`;
|
let html: UIElement = new FixedUiElement(`<img src="${sourcePart}" style="${style}" />`);
|
||||||
const match = sourcePart.match(/([a-zA-Z0-9_]*):#([0-9a-fA-F]{3,6})/)
|
const match = sourcePart.match(/([a-zA-Z0-9_]*):#([0-9a-fA-F]{3,6})/)
|
||||||
if (match !== null && Svg.All[match[1] + ".svg"] !== undefined) {
|
if (match !== null && Svg.All[match[1] + ".svg"] !== undefined) {
|
||||||
html = new Combine([
|
html = new Combine([
|
||||||
(Svg.All[match[1] + ".svg"] as string)
|
(Svg.All[match[1] + ".svg"] as string)
|
||||||
.replace(/#000000/g, "#" + match[2])
|
.replace(/#000000/g, "#" + match[2])
|
||||||
]).SetStyle(style).Render();
|
]).SetStyle(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sourcePart.startsWith(Utils.assets_path)) {
|
if (sourcePart.startsWith(Utils.assets_path)) {
|
||||||
const key = sourcePart.substr(Utils.assets_path.length);
|
const key = sourcePart.substr(Utils.assets_path.length);
|
||||||
html = new Combine([
|
html = new Combine([
|
||||||
(Svg.All[key] as string).replace(/stop-color:#000000/g, 'stop-color:' + color)
|
(Svg.All[key] as string).replace(/stop-color:#000000/g, 'stop-color:' + color)
|
||||||
]).SetStyle(style)
|
]).SetStyle(style);
|
||||||
.Render();
|
|
||||||
}
|
}
|
||||||
return html;
|
return html;
|
||||||
}
|
}
|
||||||
|
@ -270,12 +274,12 @@ export default class LayerConfig {
|
||||||
|
|
||||||
let badges = [];
|
let badges = [];
|
||||||
for (const iconOverlay of self.iconOverlays) {
|
for (const iconOverlay of self.iconOverlays) {
|
||||||
if (!iconOverlay.if.matchesProperties(tags)) {
|
if (!iconOverlay.if.matchesProperties(tgs)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (iconOverlay.badge) {
|
if (iconOverlay.badge) {
|
||||||
const badgeParts: string[] = [];
|
const badgeParts: UIElement[] = [];
|
||||||
const partDefs = iconOverlay.then.split(";");
|
const partDefs = iconOverlay.then.GetRenderValue(tgs).txt.split(";");
|
||||||
|
|
||||||
for (const badgePartStr of partDefs) {
|
for (const badgePartStr of partDefs) {
|
||||||
badgeParts.push(genHtmlFromString(badgePartStr))
|
badgeParts.push(genHtmlFromString(badgePartStr))
|
||||||
|
@ -287,25 +291,24 @@ export default class LayerConfig {
|
||||||
badges.push(badgeCompound)
|
badges.push(badgeCompound)
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
htmlParts.push(genHtmlFromString(iconOverlay.then));
|
htmlParts.push(genHtmlFromString(
|
||||||
|
iconOverlay.then.GetRenderValue(tgs).txt));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (badges.length > 0) {
|
if (badges.length > 0) {
|
||||||
const badgesComponent = new Combine(badges)
|
const badgesComponent = new Combine(badges)
|
||||||
.SetStyle("display:flex;height:50%;width:100%;position:absolute;top:50%;left:50%;")
|
.SetStyle("display:flex;height:50%;width:100%;position:absolute;top:50%;left:50%;");
|
||||||
.Render()
|
|
||||||
|
|
||||||
htmlParts.push(badgesComponent)
|
htmlParts.push(badgesComponent)
|
||||||
}
|
}
|
||||||
return htmlParts.join("");
|
return new Combine(htmlParts).Render();
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
icon:
|
icon:
|
||||||
{
|
{
|
||||||
html: new VariableUiElement(mappedHtml).Render(),
|
html: new VariableUiElement(mappedHtml),
|
||||||
iconSize: [iconW, iconH],
|
iconSize: [iconW, iconH],
|
||||||
iconAnchor: [anchorW, anchorH],
|
iconAnchor: [anchorW, anchorH],
|
||||||
popupAnchor: [0, 3 - anchorH],
|
popupAnchor: [0, 3 - anchorH],
|
||||||
|
|
|
@ -74,7 +74,7 @@ export interface LayerConfigJson {
|
||||||
*
|
*
|
||||||
* Note: strings are interpreted as icons, so layering and substituting is supported
|
* Note: strings are interpreted as icons, so layering and substituting is supported
|
||||||
*/
|
*/
|
||||||
iconOverlays?: {if: string | AndOrTagConfigJson, then: string, badge?: boolean}[]
|
iconOverlays?: {if: string | AndOrTagConfigJson, then: string | TagRenderingConfigJson, badge?: boolean}[]
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A string containing "width,height" or "width,height,anchorpoint" where anchorpoint is any of 'center', 'top', 'bottom', 'left', 'right', 'bottomleft','topright', ...
|
* A string containing "width,height" or "width,height,anchorpoint" where anchorpoint is any of 'center', 'top', 'bottom', 'left', 'right', 'bottomleft','topright', ...
|
||||||
|
|
|
@ -5,12 +5,13 @@ import * as icons from "../assets/tagRenderings/icons.json";
|
||||||
export default class SharedTagRenderings {
|
export default class SharedTagRenderings {
|
||||||
|
|
||||||
public static SharedTagRendering = SharedTagRenderings.generatedSharedFields();
|
public static SharedTagRendering = SharedTagRenderings.generatedSharedFields();
|
||||||
|
public static SharedIcons = SharedTagRenderings.generatedSharedFields(true);
|
||||||
|
|
||||||
private static generatedSharedFields() {
|
private static generatedSharedFields(iconsOnly = false) {
|
||||||
const dict = {}
|
const dict = {}
|
||||||
|
|
||||||
|
|
||||||
function add(key, store){
|
function add(key, store) {
|
||||||
try {
|
try {
|
||||||
dict[key] = new TagRenderingConfig(store[key])
|
dict[key] = new TagRenderingConfig(store[key])
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -18,9 +19,10 @@ export default class SharedTagRenderings {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!iconsOnly) {
|
||||||
for (const key in questions) {
|
for (const key in questions) {
|
||||||
add(key, questions);
|
add(key, questions);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
for (const key in icons) {
|
for (const key in icons) {
|
||||||
add(key, icons);
|
add(key, icons);
|
||||||
|
|
|
@ -152,8 +152,16 @@ export class FilteredLayer {
|
||||||
color: style.color
|
color: style.color
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
style.icon.html.ListenTo(self.isDisplayed)
|
||||||
marker = L.marker(latLng, {
|
marker = L.marker(latLng, {
|
||||||
icon: L.divIcon(style.icon)
|
icon: L.divIcon({
|
||||||
|
html: style.icon.html.Render(),
|
||||||
|
className: style.icon.className,
|
||||||
|
iconAnchor: style.icon.iconAnchor,
|
||||||
|
iconUrl: style.icon.iconUrl,
|
||||||
|
popupAnchor: style.icon.popupAnchor,
|
||||||
|
iconSize: style.icon.iconSize
|
||||||
|
})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return marker;
|
return marker;
|
||||||
|
|
|
@ -67,11 +67,15 @@ export default class MetaTagging {
|
||||||
|
|
||||||
let centerPoint: any = GeoOperations.centerpoint(feature);
|
let centerPoint: any = GeoOperations.centerpoint(feature);
|
||||||
const lat = centerPoint.geometry.coordinates[1];
|
const lat = centerPoint.geometry.coordinates[1];
|
||||||
const lon = centerPoint.geometry.coordinates[0]
|
const lon = centerPoint.geometry.coordinates[0];
|
||||||
coder.GetCountryCodeFor(lon, lat, (countries) => {
|
coder.GetCountryCodeFor(lon, lat, (countries) => {
|
||||||
feature.properties["_country"] = countries[0].trim().toLowerCase();
|
try {
|
||||||
const tagsSource = State.state.allElements.getEventSourceFor(feature);
|
feature.properties["_country"] = countries[0].trim().toLowerCase();
|
||||||
tagsSource.ping();
|
const tagsSource = State.state.allElements.getEventSourceFor(feature);
|
||||||
|
tagsSource.ping();
|
||||||
|
} catch (e) {
|
||||||
|
console.error(e)
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
@ -85,6 +89,8 @@ export default class MetaTagging {
|
||||||
if (tags.opening_hours === undefined || tags._country === undefined) {
|
if (tags.opening_hours === undefined || tags._country === undefined) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
try{
|
||||||
|
|
||||||
const oh = new opening_hours(tags["opening_hours"], {
|
const oh = new opening_hours(tags["opening_hours"], {
|
||||||
lat: tags._lat,
|
lat: tags._lat,
|
||||||
lon: tags._lon,
|
lon: tags._lon,
|
||||||
|
@ -105,7 +111,7 @@ export default class MetaTagging {
|
||||||
tagsSource.ping();
|
tagsSource.ping();
|
||||||
}
|
}
|
||||||
|
|
||||||
const nextChange = oh.getNextChange() as Date;
|
const nextChange = oh.getNextChange();
|
||||||
if (nextChange !== undefined) {
|
if (nextChange !== undefined) {
|
||||||
window.setTimeout(
|
window.setTimeout(
|
||||||
updateTags,
|
updateTags,
|
||||||
|
@ -114,6 +120,10 @@ export default class MetaTagging {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
updateTags();
|
updateTags();
|
||||||
|
}catch(e){
|
||||||
|
console.error(e);
|
||||||
|
tags["_isOpen"] = "parse_error";
|
||||||
|
}
|
||||||
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
2
State.ts
2
State.ts
|
@ -23,7 +23,7 @@ export default class State {
|
||||||
// The singleton of the global state
|
// The singleton of the global state
|
||||||
public static state: State;
|
public static state: State;
|
||||||
|
|
||||||
public static vNumber = "0.2.3d";
|
public static vNumber = "0.2.4";
|
||||||
|
|
||||||
// The user journey states thresholds when a new feature gets unlocked
|
// The user journey states thresholds when a new feature gets unlocked
|
||||||
public static userJourney = {
|
public static userJourney = {
|
||||||
|
|
14
Svg.ts
14
Svg.ts
File diff suppressed because one or more lines are too long
|
@ -19,9 +19,9 @@ export class LayerSelection extends UIElement {
|
||||||
const leafletStyle = layer.layerDef.GenerateLeafletStyle(new UIEventSource<any>({id: "node/-1"}), true)
|
const leafletStyle = layer.layerDef.GenerateLeafletStyle(new UIEventSource<any>({id: "node/-1"}), true)
|
||||||
const leafletHtml = leafletStyle.icon.html;
|
const leafletHtml = leafletStyle.icon.html;
|
||||||
const icon =
|
const icon =
|
||||||
new FixedUiElement(leafletHtml)
|
new FixedUiElement(leafletHtml.Render())
|
||||||
.SetClass("single-layer-selection-toggle")
|
.SetClass("single-layer-selection-toggle")
|
||||||
let iconUnselected: UIElement = new FixedUiElement(leafletHtml)
|
let iconUnselected: UIElement = new FixedUiElement(leafletHtml.Render())
|
||||||
.SetClass("single-layer-selection-toggle")
|
.SetClass("single-layer-selection-toggle")
|
||||||
.SetStyle("opacity:0.2;");
|
.SetStyle("opacity:0.2;");
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ export class SimpleAddUI extends UIElement {
|
||||||
const presets = layer.layerDef.presets;
|
const presets = layer.layerDef.presets;
|
||||||
for (const preset of presets) {
|
for (const preset of presets) {
|
||||||
const tags = TagUtils.KVtoProperties(preset.tags ?? []);
|
const tags = TagUtils.KVtoProperties(preset.tags ?? []);
|
||||||
let icon: UIElement = new FixedUiElement(layer.layerDef.GenerateLeafletStyle(new UIEventSource<any>(tags), false).icon.html).SetClass("simple-add-ui-icon");
|
let icon: UIElement = new FixedUiElement(layer.layerDef.GenerateLeafletStyle(new UIEventSource<any>(tags), false).icon.html.Render()).SetClass("simple-add-ui-icon");
|
||||||
|
|
||||||
const csCount = State.state.osmConnection.userDetails.data.csCount;
|
const csCount = State.state.osmConnection.userDetails.data.csCount;
|
||||||
let tagInfo = "";
|
let tagInfo = "";
|
||||||
|
|
148
assets/layers/bike_repair_station/bike_pump.svg
Normal file
148
assets/layers/bike_repair_station/bike_pump.svg
Normal file
|
@ -0,0 +1,148 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
width="98"
|
||||||
|
height="98"
|
||||||
|
viewBox="0 0 98 98"
|
||||||
|
version="1.1"
|
||||||
|
id="svg42"
|
||||||
|
sodipodi:docname="logo.svg"
|
||||||
|
style="fill:none"
|
||||||
|
inkscape:version="0.92.4 (5da689c313, 2019-01-14)">
|
||||||
|
<metadata
|
||||||
|
id="metadata46">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1920"
|
||||||
|
inkscape:window-height="1001"
|
||||||
|
id="namedview44"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="4"
|
||||||
|
inkscape:cx="-2.2900136"
|
||||||
|
inkscape:cy="62.988337"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="0"
|
||||||
|
inkscape:window-maximized="1"
|
||||||
|
inkscape:current-layer="layer4" />
|
||||||
|
<defs
|
||||||
|
id="defs40">
|
||||||
|
<filter
|
||||||
|
id="filter0_d"
|
||||||
|
x="-3"
|
||||||
|
y="2"
|
||||||
|
width="102.479"
|
||||||
|
height="102.479"
|
||||||
|
filterUnits="userSpaceOnUse"
|
||||||
|
style="color-interpolation-filters:sRGB">
|
||||||
|
<feFlood
|
||||||
|
flood-opacity="0"
|
||||||
|
result="BackgroundImageFix"
|
||||||
|
id="feFlood22" />
|
||||||
|
<feColorMatrix
|
||||||
|
in="SourceAlpha"
|
||||||
|
type="matrix"
|
||||||
|
values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"
|
||||||
|
id="feColorMatrix24" />
|
||||||
|
<feOffset
|
||||||
|
dy="4"
|
||||||
|
id="feOffset26" />
|
||||||
|
<feGaussianBlur
|
||||||
|
stdDeviation="2"
|
||||||
|
id="feGaussianBlur28" />
|
||||||
|
<feColorMatrix
|
||||||
|
type="matrix"
|
||||||
|
values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0"
|
||||||
|
id="feColorMatrix30" />
|
||||||
|
<feBlend
|
||||||
|
mode="normal"
|
||||||
|
in2="BackgroundImageFix"
|
||||||
|
result="effect1_dropShadow"
|
||||||
|
id="feBlend32" />
|
||||||
|
<feBlend
|
||||||
|
mode="normal"
|
||||||
|
in="SourceGraphic"
|
||||||
|
in2="effect1_dropShadow"
|
||||||
|
result="shape"
|
||||||
|
id="feBlend34" />
|
||||||
|
</filter>
|
||||||
|
<clipPath
|
||||||
|
id="clip0">
|
||||||
|
<rect
|
||||||
|
width="66.806396"
|
||||||
|
height="66.806396"
|
||||||
|
transform="rotate(-45,59.937093,23.412543)"
|
||||||
|
id="rect37"
|
||||||
|
x="0"
|
||||||
|
y="0"
|
||||||
|
style="fill:#ffffff" />
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
<g
|
||||||
|
inkscape:groupmode="layer"
|
||||||
|
id="layer1"
|
||||||
|
inkscape:label="re"
|
||||||
|
style="display:inline"
|
||||||
|
transform="translate(-12.466103,-2.0847473)">
|
||||||
|
<rect
|
||||||
|
style="fill:#fffcff;fill-opacity:1;stroke:#ffffff;stroke-width:3.50900006;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||||
|
id="rect834"
|
||||||
|
width="23.963444"
|
||||||
|
height="3.9908068"
|
||||||
|
x="47.66375"
|
||||||
|
y="21.641689" />
|
||||||
|
<rect
|
||||||
|
style="fill:#ffffff;fill-opacity:1;stroke:#ffffff;stroke-width:0;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||||
|
id="rect839"
|
||||||
|
width="6.5160999"
|
||||||
|
height="8.9842997"
|
||||||
|
x="56.447304"
|
||||||
|
y="27.271845" />
|
||||||
|
<path
|
||||||
|
style="fill:none;stroke:#ffffff;stroke-width:7.93900013;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||||
|
d="m 47.842047,77.142657 23.821625,0.209511"
|
||||||
|
id="path842"
|
||||||
|
inkscape:connector-curvature="0" />
|
||||||
|
<rect
|
||||||
|
style="display:inline;fill:#ffffff;fill-opacity:1;stroke:#ffffff;stroke-width:2.87199998;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1"
|
||||||
|
id="rect863"
|
||||||
|
width="7.4682202"
|
||||||
|
height="36.044868"
|
||||||
|
x="55.90678"
|
||||||
|
y="37.580132" />
|
||||||
|
<path
|
||||||
|
style="display:inline;fill:none;stroke:#ffffff;stroke-width:2.5999999;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||||
|
d="m 64.040577,70.321209 c 0,0 6.250256,1.104191 6.250256,-4.19911 0,-5.303301 0,-31.201087 0,-31.201087 0,0 0.176777,-3.623922 4.154253,-3.623922 3.977475,0 4.065864,3.447145 4.065864,3.447145 l 0.08839,29.875262"
|
||||||
|
id="path868"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
sodipodi:nodetypes="cscscc" />
|
||||||
|
<path
|
||||||
|
style="display:inline;fill:#fffeff;fill-opacity:1;stroke:#fffeff;stroke-width:2;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:0.97014926"
|
||||||
|
d="m 76.543734,62.21875 4.018766,-0.03125 0.125,4.640625 3,-0.0625 0.104018,4.221891 -3.783471,-0.02589 c -2.730516,-0.27045 -3.676466,-1.207877 -3.48639,-3.569907 z"
|
||||||
|
id="path871"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
sodipodi:nodetypes="cccccccc" />
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 5.1 KiB |
|
@ -577,6 +577,18 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"iconOverlays": [
|
||||||
|
{
|
||||||
|
"if": "opening_hours~*",
|
||||||
|
"then": "isOpen",
|
||||||
|
"badge": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:pump=yes",
|
||||||
|
"then": "circle:#e2783d;./assets/layers/bike_repair_station/pump.svg",
|
||||||
|
"badge": true
|
||||||
|
}
|
||||||
|
],
|
||||||
"width": {
|
"width": {
|
||||||
"render": "1"
|
"render": "1"
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,22 +1,36 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
<svg
|
<svg
|
||||||
width="100"
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
height="100"
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
viewBox="0 0 100 100"
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
id="svg5"
|
||||||
|
style="fill:none"
|
||||||
version="1.1"
|
version="1.1"
|
||||||
style="fill:none">
|
viewBox="0 0 100 100"
|
||||||
<circle
|
height="100"
|
||||||
cx="50"
|
width="100">
|
||||||
cy="50"
|
<metadata
|
||||||
r="45.0"
|
id="metadata11">
|
||||||
id="circle4"
|
<rdf:RDF>
|
||||||
style="fill:none;fill-opacity:1;stroke:#000000;stroke-width:10;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs9" />
|
||||||
<path
|
<path
|
||||||
id="path823"
|
style="fill:none;stroke:#000000;stroke-width:9;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||||
d="M 46,55.932203 H 66.550847"
|
d="M 46,55.932203 H 66.550847"
|
||||||
style="fill:none;stroke:#000000;stroke-width:9;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
id="path823" />
|
||||||
<path
|
<path
|
||||||
id="path825"
|
style="fill:none;stroke:#000000;stroke-width:9;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||||
d="m 46,55.533898 v -27.805085 0"
|
d="m 46,55.533898 v -27.805085 0"
|
||||||
style="fill:none;stroke:#000000;stroke-width:9;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
id="path825" />
|
||||||
</svg>
|
</svg>
|
||||||
|
|
Before Width: | Height: | Size: 805 B After Width: | Height: | Size: 1.1 KiB |
|
@ -1,42 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
id="svg3"
|
|
||||||
width="100"
|
|
||||||
height="100"
|
|
||||||
viewBox="0 0 100 100"
|
|
||||||
version="1.1"
|
|
||||||
style="fill:none">
|
|
||||||
<metadata
|
|
||||||
id="metadata9">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title></dc:title>
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<defs
|
|
||||||
id="defs7" />
|
|
||||||
<circle
|
|
||||||
cx="50"
|
|
||||||
cy="50"
|
|
||||||
r="45.408772"
|
|
||||||
id="circle4"
|
|
||||||
style="fill:none;fill-opacity:1;stroke:#180000;stroke-width:7.5;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
|
||||||
<path
|
|
||||||
id="path823"
|
|
||||||
d="M 46,55.932203 H 66.550847"
|
|
||||||
style="fill:none;stroke:#180000;stroke-width:7;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
|
||||||
<path
|
|
||||||
id="path825"
|
|
||||||
d="m 46,55.533898 v -27.805085 0"
|
|
||||||
style="fill:none;stroke:#180000;stroke-width:7.38227367;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 1.3 KiB |
34
assets/svg/ring.svg
Normal file
34
assets/svg/ring.svg
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
id="svg5"
|
||||||
|
style="fill:none"
|
||||||
|
version="1.1"
|
||||||
|
viewBox="0 0 100 100"
|
||||||
|
height="100"
|
||||||
|
width="100">
|
||||||
|
<metadata
|
||||||
|
id="metadata11">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
<dc:title></dc:title>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs9" />
|
||||||
|
<circle
|
||||||
|
style="fill:none;fill-opacity:1;stroke:#000000;stroke-width:10;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
|
||||||
|
id="circle4"
|
||||||
|
r="45.0"
|
||||||
|
cy="50"
|
||||||
|
cx="50" />
|
||||||
|
</svg>
|
After Width: | Height: | Size: 924 B |
|
@ -14,6 +14,39 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"isOpen": {
|
||||||
|
"#": "Shows a coloured clock if opening hours are parsed. Uses the metatagging, suitable to use as a (badged) overlay",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "_isOpen=yes",
|
||||||
|
"then": "clock:#0f0;ring:#0f0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "_isOpen=no",
|
||||||
|
"then": "circle:#f00;clock:#fff"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"#": "Still loading the country",
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"_isOpen=",
|
||||||
|
"opening_hours~*"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "clock:#ff0;ring:#ff0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"#": "Still loading the country",
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"_isOpen=parse_error",
|
||||||
|
"opening_hours~*"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "circle:#f0f;clock:#fff"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
"phonelink": {
|
"phonelink": {
|
||||||
"render": "<a href='tel:{phone}'><img src='./assets/svg/phone.svg'/></a>",
|
"render": "<a href='tel:{phone}'><img src='./assets/svg/phone.svg'/></a>",
|
||||||
"condition": "phone~*"
|
"condition": "phone~*"
|
||||||
|
|
|
@ -67,6 +67,9 @@
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"titleIcons": [
|
||||||
|
"isOpen"
|
||||||
|
],
|
||||||
"description": {
|
"description": {
|
||||||
"en": "A shop",
|
"en": "A shop",
|
||||||
"fr": "Un magasin"
|
"fr": "Un magasin"
|
||||||
|
@ -238,23 +241,8 @@
|
||||||
},
|
},
|
||||||
"iconOverlays": [
|
"iconOverlays": [
|
||||||
{
|
{
|
||||||
"if": "_isOpen=yes",
|
"if": "opening_hours~*",
|
||||||
"then": "clock:#0f0",
|
"then": "isOpen",
|
||||||
"badge": true
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"if": "_isOpen=no",
|
|
||||||
"then": "circle:#f00;clock:#fff",
|
|
||||||
"badge": true
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"if": {
|
|
||||||
"and": [
|
|
||||||
"_isOpen=",
|
|
||||||
"opening_hours~*"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"then": "clock:#ff0",
|
|
||||||
"badge": true
|
"badge": true
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
|
6
package-lock.json
generated
6
package-lock.json
generated
|
@ -6917,9 +6917,9 @@
|
||||||
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="
|
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="
|
||||||
},
|
},
|
||||||
"latlon2country": {
|
"latlon2country": {
|
||||||
"version": "1.0.7",
|
"version": "1.0.8",
|
||||||
"resolved": "https://registry.npmjs.org/latlon2country/-/latlon2country-1.0.7.tgz",
|
"resolved": "https://registry.npmjs.org/latlon2country/-/latlon2country-1.0.8.tgz",
|
||||||
"integrity": "sha512-47ZiSbCR7O7is1gNtd4T+1RyRHKoiunBvvZWET+oi+Y4+PgS2x/RsKqcBwhsyTXIDdNmMfrZB1sjFNMYEXqg4w==",
|
"integrity": "sha512-V0Zz9Zq/fAtuAoZWc+eaqpsNpCeGw2O0gu2XIA1KuWA5ePp3sK4o8ndz2dP9k68KtMx3Y//IoOgOb+NzFGgebQ==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"@turf/boolean-point-in-polygon": "^6.0.1",
|
"@turf/boolean-point-in-polygon": "^6.0.1",
|
||||||
"@turf/turf": "^5.1.6",
|
"@turf/turf": "^5.1.6",
|
||||||
|
|
|
@ -40,7 +40,7 @@
|
||||||
"escape-html": "^1.0.3",
|
"escape-html": "^1.0.3",
|
||||||
"i18next-client": "^1.11.4",
|
"i18next-client": "^1.11.4",
|
||||||
"jquery": "latest",
|
"jquery": "latest",
|
||||||
"latlon2country": "^1.0.7",
|
"latlon2country": "^1.0.8",
|
||||||
"leaflet": "^1.7.1",
|
"leaflet": "^1.7.1",
|
||||||
"leaflet-providers": "^1.10.2",
|
"leaflet-providers": "^1.10.2",
|
||||||
"libphonenumber": "0.0.10",
|
"libphonenumber": "0.0.10",
|
||||||
|
|
Loading…
Reference in a new issue