diff --git a/package-lock.json b/package-lock.json
index 0fe4439..c1e2c6b 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -510,7 +510,6 @@
"resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz",
"integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==",
"dev": true,
- "optional": true,
"requires": {
"delegates": "^1.0.0",
"readable-stream": "^2.0.6"
@@ -1887,8 +1886,7 @@
"version": "1.1.0",
"resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
"integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=",
- "dev": true,
- "optional": true
+ "dev": true
},
"constants-browserify": {
"version": "1.0.0",
@@ -2424,8 +2422,7 @@
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
"integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=",
- "dev": true,
- "optional": true
+ "dev": true
},
"depd": {
"version": "1.1.2",
@@ -4280,7 +4277,6 @@
"resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz",
"integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=",
"dev": true,
- "optional": true,
"requires": {
"graceful-fs": "^4.1.2",
"inherits": "~2.0.0",
@@ -4310,7 +4306,6 @@
"resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz",
"integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=",
"dev": true,
- "optional": true,
"requires": {
"aproba": "^1.0.3",
"console-control-strings": "^1.0.0",
@@ -4957,8 +4952,7 @@
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
"integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=",
- "dev": true,
- "optional": true
+ "dev": true
},
"has-value": {
"version": "1.0.0",
@@ -7377,7 +7371,6 @@
"resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz",
"integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==",
"dev": true,
- "optional": true,
"requires": {
"are-we-there-yet": "~1.1.2",
"console-control-strings": "~1.1.0",
@@ -11170,7 +11163,6 @@
"resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz",
"integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==",
"dev": true,
- "optional": true,
"requires": {
"string-width": "^1.0.2 || 2"
}
diff --git a/src/GoogleMaps.xml b/src/GoogleMaps.xml
index c619af4..c3cd835 100644
--- a/src/GoogleMaps.xml
+++ b/src/GoogleMaps.xml
@@ -62,7 +62,7 @@ WARNING: Address lookups are Google APIs calls which are limited in the free tri
-
+
Locations entity
Database / Microflow
@@ -234,6 +234,22 @@ WARNING: Address lookups are Google APIs calls which are limited in the free tri
+
+ Marker label (Context)
+ Markers
+ For 'Datasource' 'Context'; Add a single character label inside the default marker to identify markers.
+
+
+
+
+
+ Marker label (Database / Microflow)
+ Markers
+ For 'Datasource' 'Database' or 'Microflow'; Add a single character label inside the default marker to identify markers.
+
+
+
+
Map styles
diff --git a/src/GoogleMapsContext.xml b/src/GoogleMapsContext.xml
index b80fdaf..70f23f1 100644
--- a/src/GoogleMapsContext.xml
+++ b/src/GoogleMapsContext.xml
@@ -173,6 +173,14 @@
+
+ Marker label
+ Markers
+ When using default markers, Google allows you to add a label to each marker. This can be used e.g. to number markers and make them easily recognizable.
+
+
+
+
Styles
diff --git a/src/components/GoogleMapContainer.ts b/src/components/GoogleMapContainer.ts
index ffdfebe..dc3c621 100644
--- a/src/components/GoogleMapContainer.ts
+++ b/src/components/GoogleMapContainer.ts
@@ -34,10 +34,12 @@ interface GoogleMapContainerProps extends WrapperProps {
latitudeAttribute: string;
longitudeAttribute: string;
markerImageAttribute: string;
+ markerLabelAttribute: string;
addressAttributeContext: string;
latitudeAttributeContext: string;
longitudeAttributeContext: string;
markerImageAttributeContext: string;
+ markerLabelAttributeContext: string;
staticLocations: StaticLocation[];
markerImages: Array<{ enumKey: string, enumImage: string}>;
width: number;
@@ -124,10 +126,12 @@ class GoogleMapContainer extends Component this.subscriptionHandles.push(window.mx.data.subscribe({
attr,
callback: () => this.fetchData(contextObject), guid: contextObject.getGuid()
@@ -198,17 +202,20 @@ class GoogleMapContainer extends Component {
if (this.state.isLoaded && this.state.locations && this.state.locations.length) {
this.state.locations.map((locationObject, index) => {
- const { latitude, longitude, url } = locationObject;
+ const { latitude, longitude, url, label } = locationObject;
if (this.validLocation(locationObject)) {
markerElements.push(createElement(Marker, {
key: index,
lat: latitude as number,
lng: longitude as number,
- url
+ url,
+ label
}));
}
});
diff --git a/src/components/Marker.ts b/src/components/Marker.ts
index 787a8fe..4606b83 100644
--- a/src/components/Marker.ts
+++ b/src/components/Marker.ts
@@ -4,6 +4,7 @@ export interface MarkerProps {
lat: number;
lng: number;
url?: string;
+ label?: string;
}
export const Marker: StatelessComponent = (props) => {
@@ -14,6 +15,9 @@ export const Marker: StatelessComponent = (props) => {
className: "widget-google-maps-marker-url",
style
});
+ } else if (props.label) {
+ return createElement("div", { className: "widget-google-maps-marker" },
+ createElement("div", { className: "widget-google-maps-marker-label" }, props.label.substring(0, 1)));
}
return createElement("div", { className: "widget-google-maps-marker" });
diff --git a/src/ui/GoogleMaps.css b/src/ui/GoogleMaps.css
index 934f3f4..9fa9f05 100644
--- a/src/ui/GoogleMaps.css
+++ b/src/ui/GoogleMaps.css
@@ -1,30 +1,46 @@
.widget-google-maps-wrapper {
- position: relative;
+ position: relative;
}
.widget-google-maps-wrapper > div {
- position: absolute;
- top: 0; bottom: 0; left: 0; right: 0;
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
}
-.widget-google-maps-marker{
- background-image: url();
- cursor: pointer;
- width: 50px;
- height: 50px;
- padding: 0;
- left: -25px;
- top: -50px;
- position: absolute;
+.widget-google-maps-marker {
+ background-image: url();
+ cursor: pointer;
+ width: 50px;
+ height: 50px;
+ padding: 0;
+ left: -25px;
+ top: -50px;
+ position: absolute;
}
.widget-google-maps-marker-url {
- background-repeat: no-repeat;
- cursor: pointer;
- width: 50px;
- height: 50px;
- padding: 0;
- left: -25px;
- top: -50px;
- position: absolute;
+ background-repeat: no-repeat;
+ cursor: pointer;
+ width: 50px;
+ height: 50px;
+ padding: 0;
+ left: -25px;
+ top: -50px;
+ position: absolute;
}
+
+.widget-google-maps-marker-label {
+ background: #c0392b;
+ border-radius: 10px;
+ width: 18px;
+ text-align: center;
+ font-size: 16px;
+ left: 16px;
+ top: 7px;
+ position: absolute;
+ font-weight: bold;
+ color: #fff;
+}
\ No newline at end of file
diff --git a/src/utils/ContainerUtils.ts b/src/utils/ContainerUtils.ts
index 1fc1c16..5d6b644 100644
--- a/src/utils/ContainerUtils.ts
+++ b/src/utils/ContainerUtils.ts
@@ -6,6 +6,7 @@ export interface Location {
latitude?: number;
longitude?: number;
url?: string;
+ label?: string;
}
export interface StaticLocation {