@theseam/ui-common 0.3.0 → 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/breadcrumbs/_breadcrumbs-theme.scss +3 -0
- package/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +10 -0
- package/breadcrumbs/styles/_utilities.scss +3 -0
- package/breadcrumbs/styles/_variables.scss +1 -0
- package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +1 -1
- package/bundles/theseam-ui-common-breadcrumbs.umd.js +2 -1
- package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
- package/bundles/theseam-ui-common-dynamic.umd.js +1 -0
- package/bundles/theseam-ui-common-dynamic.umd.js.map +1 -1
- package/bundles/theseam-ui-common-form-field.umd.js +1 -1
- package/bundles/theseam-ui-common-form-field.umd.js.map +1 -1
- package/bundles/theseam-ui-common-framework.umd.js +18 -15
- package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
- package/bundles/theseam-ui-common-google-maps.umd.js +2202 -0
- package/bundles/theseam-ui-common-google-maps.umd.js.map +1 -0
- package/bundles/theseam-ui-common-menu.umd.js +1 -0
- package/bundles/theseam-ui-common-menu.umd.js.map +1 -1
- package/bundles/theseam-ui-common-modal.umd.js +21 -1
- package/bundles/theseam-ui-common-modal.umd.js.map +1 -1
- package/bundles/theseam-ui-common-utils.umd.js +610 -136
- package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
- package/bundles/theseam-ui-common-widget.umd.js +4 -2
- package/bundles/theseam-ui-common-widget.umd.js.map +1 -1
- package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +4 -3
- package/esm2015/dynamic/evaluators/jexl-evaluator/jexl-evaluator.js +2 -1
- package/esm2015/form-field/input.directive.js +2 -2
- package/esm2015/framework/base-layout/base-layout.component.js +3 -3
- package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +5 -5
- package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +4 -3
- package/esm2015/framework/top-bar/top-bar.component.js +10 -8
- package/esm2015/google-maps/google-maps/google-maps.component.js +261 -0
- package/esm2015/google-maps/google-maps-contextmenu.js +113 -0
- package/esm2015/google-maps/google-maps-controls.service.js +70 -0
- package/esm2015/google-maps/google-maps-feature-helpers.js +177 -0
- package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.js +195 -0
- package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.js +163 -0
- package/esm2015/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.js +57 -0
- package/esm2015/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.js +119 -0
- package/esm2015/google-maps/google-maps.module.js +45 -0
- package/esm2015/google-maps/google-maps.service.js +344 -0
- package/esm2015/google-maps/map-control.component.js +65 -0
- package/esm2015/google-maps/map-controls-service.js +4 -0
- package/esm2015/google-maps/map-file-drop/map-file-drop.component.js +135 -0
- package/esm2015/google-maps/map-value-manager.service.js +46 -0
- package/esm2015/google-maps/public-api.js +14 -0
- package/esm2015/google-maps/theseam-ui-common-google-maps.js +6 -0
- package/esm2015/menu/menu-toggle.directive.js +2 -1
- package/esm2015/modal/modal-ref.js +22 -2
- package/esm2015/utils/geo-json/coerce-feature-collection.js +44 -0
- package/esm2015/utils/geo-json/geo-json-to-area.js +11 -0
- package/esm2015/utils/geo-json/is-feature-collection.validator.js +21 -0
- package/esm2015/utils/geo-json/is-only-geometry-types.js +23 -0
- package/esm2015/utils/geo-json/is-only-geometry-types.validator.js +32 -0
- package/esm2015/utils/geo-json/merge-polygons.js +35 -0
- package/esm2015/utils/geo-json/no-inner-rings.validator.js +63 -0
- package/esm2015/utils/geo-json/no-kinks.validator.js +39 -0
- package/esm2015/utils/geo-json/read-geo-file.js +99 -0
- package/esm2015/utils/geo-json/split-multi-polygons.js +29 -0
- package/esm2015/utils/is-null-or-undefined.js +1 -1
- package/esm2015/utils/public-api.js +11 -1
- package/esm2015/widget/widget/widget.component.js +1 -1
- package/esm2015/widget/widget-content-components/widget-tile/widget-tile.component.js +4 -2
- package/fesm2015/theseam-ui-common-breadcrumbs.js +3 -2
- package/fesm2015/theseam-ui-common-breadcrumbs.js.map +1 -1
- package/fesm2015/theseam-ui-common-dynamic.js +1 -0
- package/fesm2015/theseam-ui-common-dynamic.js.map +1 -1
- package/fesm2015/theseam-ui-common-form-field.js +1 -1
- package/fesm2015/theseam-ui-common-form-field.js.map +1 -1
- package/fesm2015/theseam-ui-common-framework.js +15 -12
- package/fesm2015/theseam-ui-common-framework.js.map +1 -1
- package/fesm2015/theseam-ui-common-google-maps.js +1729 -0
- package/fesm2015/theseam-ui-common-google-maps.js.map +1 -0
- package/fesm2015/theseam-ui-common-menu.js +1 -0
- package/fesm2015/theseam-ui-common-menu.js.map +1 -1
- package/fesm2015/theseam-ui-common-modal.js +21 -1
- package/fesm2015/theseam-ui-common-modal.js.map +1 -1
- package/fesm2015/theseam-ui-common-utils.js +477 -94
- package/fesm2015/theseam-ui-common-utils.js.map +1 -1
- package/fesm2015/theseam-ui-common-widget.js +4 -2
- package/fesm2015/theseam-ui-common-widget.js.map +1 -1
- package/form-field/theseam-ui-common-form-field.metadata.json +1 -1
- package/framework/base-layout/base-layout.component.scss +14 -0
- package/framework/base-layout/styles/_variables.scss +14 -0
- package/framework/theseam-ui-common-framework.metadata.json +1 -1
- package/framework/top-bar/_top-bar-theme.scss +5 -0
- package/framework/top-bar/styles/_utilities.scss +3 -0
- package/framework/top-bar/styles/_variables.scss +18 -0
- package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +3 -1
- package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.scss +15 -0
- package/framework/top-bar/top-bar-title/top-bar-title.component.scss +6 -0
- package/framework/top-bar/top-bar.component.d.ts +3 -0
- package/framework/top-bar/top-bar.component.scss +39 -0
- package/google-maps/google-maps/google-maps.component.d.ts +89 -0
- package/google-maps/google-maps-contextmenu.d.ts +15 -0
- package/google-maps/google-maps-controls.service.d.ts +23 -0
- package/google-maps/google-maps-feature-helpers.d.ts +37 -0
- package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.d.ts +104 -0
- package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.d.ts +80 -0
- package/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.d.ts +21 -0
- package/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.d.ts +34 -0
- package/google-maps/google-maps.module.d.ts +2 -0
- package/google-maps/google-maps.service.d.ts +53 -0
- package/google-maps/map-control.component.d.ts +20 -0
- package/google-maps/map-controls-service.d.ts +13 -0
- package/google-maps/map-file-drop/map-file-drop.component.d.ts +34 -0
- package/google-maps/map-value-manager.service.d.ts +18 -0
- package/google-maps/package.json +11 -0
- package/google-maps/public-api.d.ts +13 -0
- package/google-maps/theseam-ui-common-google-maps.d.ts +5 -0
- package/google-maps/theseam-ui-common-google-maps.metadata.json +1 -0
- package/modal/modal-ref.d.ts +1 -0
- package/modal/theseam-ui-common-modal.metadata.json +1 -1
- package/package.json +17 -10
- package/utils/geo-json/coerce-feature-collection.d.ts +2 -0
- package/utils/geo-json/geo-json-to-area.d.ts +6 -0
- package/utils/geo-json/is-feature-collection.validator.d.ts +3 -0
- package/utils/geo-json/is-only-geometry-types.d.ts +5 -0
- package/utils/geo-json/is-only-geometry-types.validator.d.ts +4 -0
- package/utils/geo-json/merge-polygons.d.ts +9 -0
- package/utils/geo-json/no-inner-rings.validator.d.ts +10 -0
- package/utils/geo-json/no-kinks.validator.d.ts +3 -0
- package/utils/geo-json/read-geo-file.d.ts +7 -0
- package/utils/geo-json/split-multi-polygons.d.ts +8 -0
- package/utils/is-null-or-undefined.d.ts +1 -1
- package/utils/public-api.d.ts +10 -0
- package/utils/theseam-ui-common-utils.metadata.json +1 -1
- package/widget/styles/_variables.scss +3 -0
- package/widget/theseam-ui-common-widget.metadata.json +1 -1
- package/widget/widget/widget.component.scss +2 -0
- package/widget/widget-content-components/widget-tile/widget-tile.component.d.ts +2 -0
- package/widget/widget-content-components/widget-tile/widget-tile.component.scss +1 -1
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
3
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, } from '@angular/core';
|
|
5
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
6
|
+
import { fromEvent, Subject } from 'rxjs';
|
|
7
|
+
import { takeUntil, tap } from 'rxjs/operators';
|
|
8
|
+
import { AgmMap } from '@agm/core';
|
|
9
|
+
import { faCrosshairs, faFileImport } from '@fortawesome/free-solid-svg-icons';
|
|
10
|
+
import { InputBoolean, InputNumber, mixinDisabled } from '@theseam/ui-common/core';
|
|
11
|
+
import { MenuComponent } from '@theseam/ui-common/menu';
|
|
12
|
+
import { GoogleMapsControlsService } from '../google-maps-controls.service';
|
|
13
|
+
import { TheSeamGoogleMapsRecenterButtonControlComponent } from '../google-maps-recenter-button-control/google-maps-recenter-button-control.component';
|
|
14
|
+
import { TheSeamGoogleMapsUploadButtonControlComponent } from '../google-maps-upload-button-control/google-maps-upload-button-control.component';
|
|
15
|
+
import { GoogleMapsService } from '../google-maps.service';
|
|
16
|
+
import { MAP_CONTROLS_SERVICE } from '../map-controls-service';
|
|
17
|
+
import { MapValueManagerService, MapValueSource } from '../map-value-manager.service';
|
|
18
|
+
class TheSeamGoogleMapsComponentBase {
|
|
19
|
+
constructor(_elementRef) {
|
|
20
|
+
this._elementRef = _elementRef;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
const _TheSeamGoogleMapsMixinBase = mixinDisabled(TheSeamGoogleMapsComponentBase);
|
|
24
|
+
/**
|
|
25
|
+
* A wrapper for googlemap.
|
|
26
|
+
*/
|
|
27
|
+
export class TheSeamGoogleMapsComponent extends _TheSeamGoogleMapsMixinBase {
|
|
28
|
+
constructor(elementRef, _focusMonitor, _googleMaps, _mapValueManager) {
|
|
29
|
+
super(elementRef);
|
|
30
|
+
this._focusMonitor = _focusMonitor;
|
|
31
|
+
this._googleMaps = _googleMaps;
|
|
32
|
+
this._mapValueManager = _mapValueManager;
|
|
33
|
+
this._ngUnsubscribe = new Subject();
|
|
34
|
+
this._fileUploadControlDef = {
|
|
35
|
+
component: TheSeamGoogleMapsUploadButtonControlComponent,
|
|
36
|
+
data: { label: 'Import Geo File', icon: faFileImport },
|
|
37
|
+
position: 6 /* google.maps.ControlPosition.LEFT_BOTTOM */,
|
|
38
|
+
};
|
|
39
|
+
this._reCenterControlDef = {
|
|
40
|
+
component: TheSeamGoogleMapsRecenterButtonControlComponent,
|
|
41
|
+
data: { label: 'Center on Field', icon: faCrosshairs },
|
|
42
|
+
position: 9 /* google.maps.ControlPosition.RIGHT_BOTTOM */,
|
|
43
|
+
};
|
|
44
|
+
this._focusOrigin = null;
|
|
45
|
+
/**
|
|
46
|
+
* Set the tab index to `-1` to allow the root element of the
|
|
47
|
+
* component to receive `focus` event from javascript, but not get focused by
|
|
48
|
+
* keyboard navigation.
|
|
49
|
+
*/
|
|
50
|
+
this._tabIndex = -1;
|
|
51
|
+
this.fileDropEnabled = true;
|
|
52
|
+
this.fileUploadControlEnabled = false;
|
|
53
|
+
this.fullscreenControlEnabled = true;
|
|
54
|
+
this.reCenterControlEnabled = true;
|
|
55
|
+
this.mapTypeControlEnabled = true;
|
|
56
|
+
this.streetViewControlEnabled = false;
|
|
57
|
+
this.allowDrawingHoleInPolygon = false;
|
|
58
|
+
this.zoom = 14;
|
|
59
|
+
this.longitude = -98.570209;
|
|
60
|
+
this.latitude = 37.633814;
|
|
61
|
+
this.mapReady = new EventEmitter();
|
|
62
|
+
this._focusMonitor.monitor(this._elementRef, true).pipe(tap(origin => this._focusOrigin = origin), takeUntil(this._ngUnsubscribe)).subscribe();
|
|
63
|
+
this._mapValueManager.valueChanged.pipe(tap(change => {
|
|
64
|
+
if (this.onChange) {
|
|
65
|
+
this.onChange(change.value);
|
|
66
|
+
}
|
|
67
|
+
if (this.onTouched) {
|
|
68
|
+
this.onTouched();
|
|
69
|
+
}
|
|
70
|
+
}), tap(changed => {
|
|
71
|
+
if (this._googleMaps.mapReady && changed.source !== MapValueSource.FeatureChange) {
|
|
72
|
+
this._googleMaps.setData(changed.value);
|
|
73
|
+
}
|
|
74
|
+
}), takeUntil(this._ngUnsubscribe)).subscribe();
|
|
75
|
+
this._googleMaps.setBaseLatLng(this.latitude, this.longitude);
|
|
76
|
+
}
|
|
77
|
+
set value(value) {
|
|
78
|
+
this._mapValueManager.setValue(value, MapValueSource.Input);
|
|
79
|
+
}
|
|
80
|
+
get value() {
|
|
81
|
+
return this._mapValueManager.value;
|
|
82
|
+
}
|
|
83
|
+
set tabIndex(value) { this._tabIndex = coerceNumberProperty(value); }
|
|
84
|
+
get tabIndex() { return this._tabIndex; }
|
|
85
|
+
set fileImportHandler(value) {
|
|
86
|
+
this._googleMaps.setFileInputHandler(value);
|
|
87
|
+
}
|
|
88
|
+
get _attrDisabled() { return this.disabled || null; }
|
|
89
|
+
get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0); }
|
|
90
|
+
/** @ignore */
|
|
91
|
+
ngOnInit() {
|
|
92
|
+
this._googleMaps.setFeatureContextMenu(this.featureContextMenu);
|
|
93
|
+
fromEvent(window, 'keydown').pipe(tap((event) => {
|
|
94
|
+
switch (event.code) {
|
|
95
|
+
case 'Delete':
|
|
96
|
+
this._googleMaps.deleteSelection();
|
|
97
|
+
event.preventDefault();
|
|
98
|
+
event.stopPropagation();
|
|
99
|
+
break;
|
|
100
|
+
case 'Escape':
|
|
101
|
+
this._googleMaps.stopDrawing();
|
|
102
|
+
event.preventDefault();
|
|
103
|
+
event.stopPropagation();
|
|
104
|
+
break;
|
|
105
|
+
case 'ContextMenu':
|
|
106
|
+
this._googleMaps.openContextMenu();
|
|
107
|
+
event.preventDefault();
|
|
108
|
+
event.stopPropagation();
|
|
109
|
+
break;
|
|
110
|
+
}
|
|
111
|
+
}), takeUntil(this._ngUnsubscribe)).subscribe();
|
|
112
|
+
}
|
|
113
|
+
/** @ignore */
|
|
114
|
+
ngOnDestroy() {
|
|
115
|
+
this._focusMonitor.stopMonitoring(this._elementRef);
|
|
116
|
+
this._ngUnsubscribe.next();
|
|
117
|
+
this._ngUnsubscribe.complete();
|
|
118
|
+
}
|
|
119
|
+
/** @ignore */
|
|
120
|
+
ngAfterViewInit() { }
|
|
121
|
+
ngOnChanges(changes) {
|
|
122
|
+
let updateBase = false;
|
|
123
|
+
if (changes.hasOwnProperty('latitude')) {
|
|
124
|
+
this.latitude = changes['latitude'].currentValue;
|
|
125
|
+
updateBase = true;
|
|
126
|
+
}
|
|
127
|
+
if (changes.hasOwnProperty('longitude')) {
|
|
128
|
+
this.longitude = changes['longitude'].currentValue;
|
|
129
|
+
updateBase = true;
|
|
130
|
+
}
|
|
131
|
+
if (updateBase) {
|
|
132
|
+
this._googleMaps.setBaseLatLng(this.latitude, this.longitude);
|
|
133
|
+
}
|
|
134
|
+
if (changes.hasOwnProperty('allowDrawingHoleInPolygon')) {
|
|
135
|
+
this._googleMaps.allowDrawingHoleInPolygon(this.allowDrawingHoleInPolygon);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
writeValue(value) {
|
|
139
|
+
this.value = value;
|
|
140
|
+
}
|
|
141
|
+
registerOnChange(fn) {
|
|
142
|
+
this.onChange = fn;
|
|
143
|
+
}
|
|
144
|
+
registerOnTouched(fn) {
|
|
145
|
+
this.onTouched = fn;
|
|
146
|
+
}
|
|
147
|
+
setDisabledState(isDisabled) {
|
|
148
|
+
this.disabled = isDisabled;
|
|
149
|
+
}
|
|
150
|
+
fitBounds(bounds, padding) {
|
|
151
|
+
this._googleMaps.fitBounds(bounds, padding);
|
|
152
|
+
}
|
|
153
|
+
getGeoJson() {
|
|
154
|
+
return this._googleMaps.getGeoJson();
|
|
155
|
+
}
|
|
156
|
+
hasFocus() {
|
|
157
|
+
return this._focusOrigin !== null && this._focusOrigin !== undefined;
|
|
158
|
+
}
|
|
159
|
+
/** Focuses the button. */
|
|
160
|
+
focus() {
|
|
161
|
+
this._getHostElement().focus();
|
|
162
|
+
}
|
|
163
|
+
_getHostElement() {
|
|
164
|
+
return this._elementRef.nativeElement;
|
|
165
|
+
}
|
|
166
|
+
_onMapReady(theMap) {
|
|
167
|
+
var _a;
|
|
168
|
+
this._googleMaps.setMap(theMap);
|
|
169
|
+
this._googleMaps.setData(this._mapValueManager.value);
|
|
170
|
+
// NOTE: AgmMap has a race condition problem that causes the input latitude,
|
|
171
|
+
// longitude, and zoom to get ignored, before googlemaps emits
|
|
172
|
+
// 'center_changed'. This should avoid the issue, until we stop using AgmMap
|
|
173
|
+
// or upgrade to a more recent version that may not have the issue anymore.
|
|
174
|
+
this._googleMaps.reCenterOnFeatures();
|
|
175
|
+
(_a = this._googleMaps.googleMap) === null || _a === void 0 ? void 0 : _a.setZoom(this.zoom);
|
|
176
|
+
}
|
|
177
|
+
_onClickDeleteFeature() {
|
|
178
|
+
this._googleMaps.deleteSelection();
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
TheSeamGoogleMapsComponent.decorators = [
|
|
182
|
+
{ type: Component, args: [{
|
|
183
|
+
selector: 'seam-google-maps',
|
|
184
|
+
template: "<agm-map\n [latitude]=\"latitude\"\n [longitude]=\"longitude\"\n [zoom]=\"zoom\"\n [mapTypeControl]=\"true\"\n mapTypeId=\"hybrid\"\n [streetViewControl]=\"false\"\n (mapReady)=\"_onMapReady($event)\"\n [fullscreenControl]=\"$any(fullscreenControlEnabled)\">\n</agm-map>\n<seam-menu #featureContextMenu>\n <button seamMenuItem (click)=\"_onClickDeleteFeature()\">Delete</button>\n</seam-menu>\n<seam-map-file-drop *ngIf=\"fileDropEnabled\"></seam-map-file-drop>\n\n<seam-map-control *ngIf=\"fileUploadControlEnabled\" [def]=\"_fileUploadControlDef\"></seam-map-control>\n<seam-map-control *ngIf=\"reCenterControlEnabled\" [def]=\"_reCenterControlDef\"></seam-map-control>\n",
|
|
185
|
+
inputs: [
|
|
186
|
+
'disabled'
|
|
187
|
+
],
|
|
188
|
+
providers: [
|
|
189
|
+
MapValueManagerService,
|
|
190
|
+
GoogleMapsService,
|
|
191
|
+
{ provide: MAP_CONTROLS_SERVICE, useClass: GoogleMapsControlsService },
|
|
192
|
+
{
|
|
193
|
+
provide: NG_VALUE_ACCESSOR,
|
|
194
|
+
// tslint:disable-next-line: no-use-before-declare
|
|
195
|
+
useExisting: forwardRef(() => TheSeamGoogleMapsComponent),
|
|
196
|
+
multi: true
|
|
197
|
+
}
|
|
198
|
+
],
|
|
199
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
200
|
+
exportAs: 'seamGoogleMaps',
|
|
201
|
+
styles: [":host{display:block;position:relative;height:400px;width:100%}:host.show-focus-border.cdk-focused{outline:0;box-shadow:0 0 0 .2rem #357ebd40}:host.show-focus-border[disabled]{opacity:.65}agm-map{height:inherit;width:inherit}\n"]
|
|
202
|
+
},] }
|
|
203
|
+
];
|
|
204
|
+
TheSeamGoogleMapsComponent.ctorParameters = () => [
|
|
205
|
+
{ type: ElementRef },
|
|
206
|
+
{ type: FocusMonitor },
|
|
207
|
+
{ type: GoogleMapsService },
|
|
208
|
+
{ type: MapValueManagerService }
|
|
209
|
+
];
|
|
210
|
+
TheSeamGoogleMapsComponent.propDecorators = {
|
|
211
|
+
value: [{ type: Input }],
|
|
212
|
+
tabIndex: [{ type: Input }],
|
|
213
|
+
fileDropEnabled: [{ type: Input }],
|
|
214
|
+
fileUploadControlEnabled: [{ type: Input }],
|
|
215
|
+
fullscreenControlEnabled: [{ type: Input }],
|
|
216
|
+
reCenterControlEnabled: [{ type: Input }],
|
|
217
|
+
mapTypeControlEnabled: [{ type: Input }],
|
|
218
|
+
streetViewControlEnabled: [{ type: Input }],
|
|
219
|
+
allowDrawingHoleInPolygon: [{ type: Input }],
|
|
220
|
+
fileImportHandler: [{ type: Input }],
|
|
221
|
+
_attrDisabled: [{ type: HostBinding, args: ['attr.disabled',] }],
|
|
222
|
+
_attrTabIndex: [{ type: HostBinding, args: ['attr.tabindex',] }],
|
|
223
|
+
zoom: [{ type: Input }],
|
|
224
|
+
longitude: [{ type: Input }],
|
|
225
|
+
latitude: [{ type: Input }],
|
|
226
|
+
mapReady: [{ type: Output }],
|
|
227
|
+
agmMap: [{ type: ViewChild, args: [AgmMap, { static: true },] }],
|
|
228
|
+
featureContextMenu: [{ type: ViewChild, args: ['featureContextMenu', { static: true, read: MenuComponent },] }],
|
|
229
|
+
agmMapTpl: [{ type: ViewChild, args: [AgmMap, { static: true, read: ElementRef },] }]
|
|
230
|
+
};
|
|
231
|
+
__decorate([
|
|
232
|
+
InputBoolean()
|
|
233
|
+
], TheSeamGoogleMapsComponent.prototype, "fileDropEnabled", void 0);
|
|
234
|
+
__decorate([
|
|
235
|
+
InputBoolean()
|
|
236
|
+
], TheSeamGoogleMapsComponent.prototype, "fileUploadControlEnabled", void 0);
|
|
237
|
+
__decorate([
|
|
238
|
+
InputBoolean()
|
|
239
|
+
], TheSeamGoogleMapsComponent.prototype, "fullscreenControlEnabled", void 0);
|
|
240
|
+
__decorate([
|
|
241
|
+
InputBoolean()
|
|
242
|
+
], TheSeamGoogleMapsComponent.prototype, "reCenterControlEnabled", void 0);
|
|
243
|
+
__decorate([
|
|
244
|
+
InputBoolean()
|
|
245
|
+
], TheSeamGoogleMapsComponent.prototype, "mapTypeControlEnabled", void 0);
|
|
246
|
+
__decorate([
|
|
247
|
+
InputBoolean()
|
|
248
|
+
], TheSeamGoogleMapsComponent.prototype, "streetViewControlEnabled", void 0);
|
|
249
|
+
__decorate([
|
|
250
|
+
InputBoolean()
|
|
251
|
+
], TheSeamGoogleMapsComponent.prototype, "allowDrawingHoleInPolygon", void 0);
|
|
252
|
+
__decorate([
|
|
253
|
+
InputNumber()
|
|
254
|
+
], TheSeamGoogleMapsComponent.prototype, "zoom", void 0);
|
|
255
|
+
__decorate([
|
|
256
|
+
InputNumber()
|
|
257
|
+
], TheSeamGoogleMapsComponent.prototype, "longitude", void 0);
|
|
258
|
+
__decorate([
|
|
259
|
+
InputNumber()
|
|
260
|
+
], TheSeamGoogleMapsComponent.prototype, "latitude", void 0);
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-maps.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/google-maps/google-maps/google-maps.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { BooleanInput, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'\nimport { fromEvent, Subject } from 'rxjs'\nimport { takeUntil, tap } from 'rxjs/operators'\n\nimport { AgmMap } from '@agm/core'\nimport { faCrosshairs, faFileImport } from '@fortawesome/free-solid-svg-icons'\nimport { CanDisable, CanDisableCtor, InputBoolean, InputNumber, mixinDisabled } from '@theseam/ui-common/core'\nimport { MenuComponent } from '@theseam/ui-common/menu'\n\nimport { FeatureCollection } from 'geojson'\nimport { GoogleMapsControlsService } from '../google-maps-controls.service'\nimport { TheSeamGoogleMapsRecenterButtonControlComponent } from '../google-maps-recenter-button-control/google-maps-recenter-button-control.component'\nimport { TheSeamGoogleMapsUploadButtonControlComponent } from '../google-maps-upload-button-control/google-maps-upload-button-control.component'\nimport { GoogleMapsService } from '../google-maps.service'\nimport { MapControl, MAP_CONTROLS_SERVICE } from '../map-controls-service'\nimport { MapValue, MapValueManagerService, MapValueSource } from '../map-value-manager.service'\n\nclass TheSeamGoogleMapsComponentBase {\n  constructor(public _elementRef: ElementRef) {}\n}\n\nconst _TheSeamGoogleMapsMixinBase: CanDisableCtor &\n  typeof TheSeamGoogleMapsComponentBase =\n    mixinDisabled(TheSeamGoogleMapsComponentBase)\n\n/**\n * A wrapper for googlemap.\n */\n@Component({\n  selector: 'seam-google-maps',\n  templateUrl: './google-maps.component.html',\n  styleUrls: ['./google-maps.component.scss'],\n  inputs: [\n    'disabled'\n  ],\n  providers: [\n    MapValueManagerService,\n    GoogleMapsService,\n    { provide: MAP_CONTROLS_SERVICE, useClass: GoogleMapsControlsService },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      // tslint:disable-next-line: no-use-before-declare\n      useExisting: forwardRef(() => TheSeamGoogleMapsComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  exportAs: 'seamGoogleMaps'\n})\nexport class TheSeamGoogleMapsComponent extends _TheSeamGoogleMapsMixinBase\n  implements OnInit, AfterViewInit, OnDestroy, OnChanges, CanDisable, ControlValueAccessor {\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_zoom: NumberInput\n  static ngAcceptInputType_longitude: NumberInput\n  static ngAcceptInputType_latitude: NumberInput\n  static ngAcceptInputType_fileDropEnabled: BooleanInput\n  static ngAcceptInputType_fileUploadControlEnabled: BooleanInput\n  static ngAcceptInputType_fullscreenControlEnabled: BooleanInput\n  static ngAcceptInputType_reCenterControlEnabled: BooleanInput\n  static ngAcceptInputType_mapTypeControlEnabled: BooleanInput\n  static ngAcceptInputType_streetViewControlEnabled: BooleanInput\n  static ngAcceptInputType_allowDrawingHoleInPolygon: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  readonly _fileUploadControlDef: MapControl = {\n    component: TheSeamGoogleMapsUploadButtonControlComponent,\n    data: { label: 'Import Geo File', icon: faFileImport },\n    position: 6 /* google.maps.ControlPosition.LEFT_BOTTOM */,\n  }\n\n  readonly _reCenterControlDef: MapControl = {\n    component: TheSeamGoogleMapsRecenterButtonControlComponent,\n    data: { label: 'Center on Field', icon: faCrosshairs },\n    position: 9 /* google.maps.ControlPosition.RIGHT_BOTTOM */,\n  }\n\n  private _focusOrigin: FocusOrigin = null\n\n  @Input()\n  set value(value: MapValue) {\n    this._mapValueManager.setValue(value, MapValueSource.Input)\n  }\n  get value(): MapValue {\n    return this._mapValueManager.value\n  }\n\n  @Input()\n  set tabIndex(value: number) { this._tabIndex = coerceNumberProperty(value) }\n  get tabIndex(): number { return this._tabIndex }\n  /**\n   * Set the tab index to `-1` to allow the root element of the\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  private _tabIndex = -1\n\n  @Input() @InputBoolean() fileDropEnabled: boolean = true\n\n  @Input() @InputBoolean() fileUploadControlEnabled: boolean = false\n  @Input() @InputBoolean() fullscreenControlEnabled: boolean = true\n  @Input() @InputBoolean() reCenterControlEnabled: boolean = true\n  @Input() @InputBoolean() mapTypeControlEnabled: boolean = true\n  @Input() @InputBoolean() streetViewControlEnabled: boolean = false\n\n  @Input() @InputBoolean() allowDrawingHoleInPolygon: boolean = false\n\n  @Input()\n  set fileImportHandler(value: ((file: File) => void) | undefined | null) {\n    this._googleMaps.setFileInputHandler(value)\n  }\n\n  @HostBinding('attr.disabled')\n  get _attrDisabled() { return this.disabled || null }\n\n  @HostBinding('attr.tabindex')\n  get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0) }\n\n  onChange: any\n  onTouched: any\n\n  @Input() @InputNumber() zoom: number = 14\n  @Input() @InputNumber() longitude: number = -98.570209\n  @Input() @InputNumber() latitude: number = 37.633814\n\n  @Output() mapReady = new EventEmitter<void>()\n\n  @ViewChild(AgmMap, { static: true }) public agmMap!: AgmMap\n  @ViewChild('featureContextMenu', { static: true, read: MenuComponent }) public featureContextMenu!: MenuComponent\n\n  @ViewChild(AgmMap, { static: true, read: ElementRef }) public agmMapTpl!: ElementRef<HTMLElement>\n\n  constructor(\n    elementRef: ElementRef,\n    private readonly _focusMonitor: FocusMonitor,\n    private readonly _googleMaps: GoogleMapsService,\n    private readonly _mapValueManager: MapValueManagerService,\n  ) {\n    super(elementRef)\n\n    this._focusMonitor.monitor(this._elementRef, true).pipe(\n      tap(origin => this._focusOrigin = origin),\n      takeUntil(this._ngUnsubscribe),\n    ).subscribe()\n\n    this._mapValueManager.valueChanged.pipe(\n      tap(change => {\n        if (this.onChange) { this.onChange(change.value) }\n        if (this.onTouched) { this.onTouched() }\n      }),\n      tap(changed => {\n        if (this._googleMaps.mapReady && changed.source !== MapValueSource.FeatureChange) {\n          this._googleMaps.setData(changed.value)\n        }\n      }),\n      takeUntil(this._ngUnsubscribe),\n    ).subscribe()\n\n    this._googleMaps.setBaseLatLng(this.latitude, this.longitude)\n  }\n\n  /** @ignore */\n  ngOnInit() {\n    this._googleMaps.setFeatureContextMenu(this.featureContextMenu)\n\n    fromEvent<KeyboardEvent>(window, 'keydown').pipe(\n      tap((event: KeyboardEvent) => {\n        switch (event.code) {\n          case 'Delete': this._googleMaps.deleteSelection(); event.preventDefault(); event.stopPropagation(); break\n          case 'Escape': this._googleMaps.stopDrawing(); event.preventDefault(); event.stopPropagation();  break\n          case 'ContextMenu': this._googleMaps.openContextMenu(); event.preventDefault(); event.stopPropagation();  break\n        }\n      }),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n  }\n\n  /** @ignore */\n  ngOnDestroy() {\n    this._focusMonitor.stopMonitoring(this._elementRef)\n\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  /** @ignore */\n  ngAfterViewInit() { }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let updateBase = false\n    if (changes.hasOwnProperty('latitude')) {\n      this.latitude = changes['latitude'].currentValue\n      updateBase = true\n    }\n    if (changes.hasOwnProperty('longitude')) {\n      this.longitude = changes['longitude'].currentValue\n      updateBase = true\n    }\n    if (updateBase) {\n      this._googleMaps.setBaseLatLng(this.latitude, this.longitude)\n    }\n\n    if (changes.hasOwnProperty('allowDrawingHoleInPolygon')) {\n      this._googleMaps.allowDrawingHoleInPolygon(this.allowDrawingHoleInPolygon)\n    }\n  }\n\n  writeValue(value: MapValue): void {\n    this.value = value\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled\n  }\n\n  public fitBounds(bounds: google.maps.LatLngBounds | google.maps.LatLngBoundsLiteral, padding?: number | google.maps.Padding): void {\n    this._googleMaps.fitBounds(bounds, padding)\n  }\n\n  public getGeoJson(): Promise<object> {\n    return this._googleMaps.getGeoJson()\n  }\n\n  public hasFocus(): boolean {\n    return this._focusOrigin !== null && this._focusOrigin !== undefined\n  }\n\n  /** Focuses the button. */\n  public focus(): void {\n    this._getHostElement().focus()\n  }\n\n  private _getHostElement() {\n    return this._elementRef.nativeElement\n  }\n\n  _onMapReady(theMap: google.maps.Map) {\n    this._googleMaps.setMap(theMap)\n    this._googleMaps.setData(this._mapValueManager.value)\n    // NOTE: AgmMap has a race condition problem that causes the input latitude,\n    // longitude, and zoom to get ignored, before googlemaps emits\n    // 'center_changed'. This should avoid the issue, until we stop using AgmMap\n    // or upgrade to a more recent version that may not have the issue anymore.\n    this._googleMaps.reCenterOnFeatures()\n    this._googleMaps.googleMap?.setZoom(this.zoom)\n  }\n\n  _onClickDeleteFeature() {\n    this._googleMaps.deleteSelection()\n  }\n}\n"]}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { ESCAPE } from '@angular/cdk/keycodes';
|
|
2
|
+
import { fromEvent, Subject } from 'rxjs';
|
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { isFeatureSelected } from './google-maps-feature-helpers';
|
|
5
|
+
// TODO: Close on map losing focus.
|
|
6
|
+
export class GoogleMapsContextMenu {
|
|
7
|
+
constructor(_map, _menu, _position, _vcr, _ngZone, _data, _feature) {
|
|
8
|
+
this._map = _map;
|
|
9
|
+
this._menu = _menu;
|
|
10
|
+
this._vcr = _vcr;
|
|
11
|
+
this._ngZone = _ngZone;
|
|
12
|
+
this._data = _data;
|
|
13
|
+
this._feature = _feature;
|
|
14
|
+
const tplRef = this._menu.templateRef;
|
|
15
|
+
if (tplRef === undefined || tplRef === null) {
|
|
16
|
+
throw Error(`Menu template is not defined.`);
|
|
17
|
+
}
|
|
18
|
+
const ref = this._vcr.createEmbeddedView(tplRef);
|
|
19
|
+
ref.detectChanges();
|
|
20
|
+
const listeners = [];
|
|
21
|
+
const ngUnsubscribe = new Subject();
|
|
22
|
+
// TODO: Fix the initial focus. setTimeout avoids the wrong contextmenu
|
|
23
|
+
// getting triggered, but the first item flashes and looks off this way.
|
|
24
|
+
setTimeout(() => {
|
|
25
|
+
this._menu.focusFirstItem('program');
|
|
26
|
+
});
|
|
27
|
+
this._menu.closed.pipe(takeUntil(ngUnsubscribe)).subscribe(v => {
|
|
28
|
+
this.close();
|
|
29
|
+
});
|
|
30
|
+
fromEvent(document, 'keydown').pipe(takeUntil(ngUnsubscribe)).subscribe((event) => {
|
|
31
|
+
if (event.keyCode === ESCAPE) {
|
|
32
|
+
this.close();
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
const __cleanup = () => this._cleanupFn();
|
|
36
|
+
class GoogleMapsContextMenuOverlayView extends google.maps.OverlayView {
|
|
37
|
+
constructor(position, content) {
|
|
38
|
+
super();
|
|
39
|
+
this.position = position;
|
|
40
|
+
this.position = position;
|
|
41
|
+
this.containerDiv = document.createElement('div');
|
|
42
|
+
this.containerDiv.style.cursor = 'auto';
|
|
43
|
+
this.containerDiv.style.height = '0',
|
|
44
|
+
this.containerDiv.style.position = 'absolute';
|
|
45
|
+
this.containerDiv.appendChild(content);
|
|
46
|
+
// Optionally stop clicks, etc., from bubbling up to the map.
|
|
47
|
+
GoogleMapsContextMenuOverlayView.preventMapHitsAndGesturesFrom(this.containerDiv);
|
|
48
|
+
}
|
|
49
|
+
/** Called when the view is added to the map. */
|
|
50
|
+
onAdd() {
|
|
51
|
+
// tslint:disable-next-line: no-non-null-assertion
|
|
52
|
+
this.getPanes().floatPane.appendChild(this.containerDiv);
|
|
53
|
+
}
|
|
54
|
+
/** Called when the view is removed from the map. */
|
|
55
|
+
onRemove() {
|
|
56
|
+
if (this.containerDiv.parentElement) {
|
|
57
|
+
this.containerDiv.parentElement.removeChild(this.containerDiv);
|
|
58
|
+
}
|
|
59
|
+
__cleanup();
|
|
60
|
+
}
|
|
61
|
+
/** Called each frame when the view needs to draw itself. */
|
|
62
|
+
draw() {
|
|
63
|
+
// tslint:disable-next-line: no-non-null-assertion
|
|
64
|
+
const divPosition = this.getProjection().fromLatLngToDivPixel(this.position);
|
|
65
|
+
// Hide the popup when it is far out of view.
|
|
66
|
+
const display = Math.abs(divPosition.x) < 4000 && Math.abs(divPosition.y) < 4000
|
|
67
|
+
? 'block'
|
|
68
|
+
: 'none';
|
|
69
|
+
if (display === 'block') {
|
|
70
|
+
this.containerDiv.style.left = divPosition.x + 'px';
|
|
71
|
+
this.containerDiv.style.top = divPosition.y + 'px';
|
|
72
|
+
}
|
|
73
|
+
if (this.containerDiv.style.display !== display) {
|
|
74
|
+
this.containerDiv.style.display = display;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
this._overlayView = new GoogleMapsContextMenuOverlayView(_position, ref.rootNodes[0]);
|
|
79
|
+
this._overlayView.setMap(this._map);
|
|
80
|
+
this._ngZone.runOutsideAngular(() => {
|
|
81
|
+
listeners.push(this._data.addListener('removefeature', (event) => {
|
|
82
|
+
if (event.feature === this._feature) {
|
|
83
|
+
this._ngZone.run(() => { this.close(); });
|
|
84
|
+
}
|
|
85
|
+
}));
|
|
86
|
+
listeners.push(this._data.addListener('setproperty', (event) => {
|
|
87
|
+
if (event.feature === this._feature && !isFeatureSelected(this._feature)) {
|
|
88
|
+
this._ngZone.run(() => { this.close(); });
|
|
89
|
+
}
|
|
90
|
+
}));
|
|
91
|
+
listeners.push(this._data.addListener('removeproperty', (event) => {
|
|
92
|
+
if (event.feature === this._feature && !isFeatureSelected(this._feature)) {
|
|
93
|
+
this._ngZone.run(() => { this.close(); });
|
|
94
|
+
}
|
|
95
|
+
}));
|
|
96
|
+
listeners.push(this._map.addListener('click', (event) => {
|
|
97
|
+
this._ngZone.run(() => { this.close(); });
|
|
98
|
+
}));
|
|
99
|
+
listeners.push(this._data.addListener('click', (event) => {
|
|
100
|
+
this._ngZone.run(() => { this.close(); });
|
|
101
|
+
}));
|
|
102
|
+
});
|
|
103
|
+
this._cleanupFn = () => {
|
|
104
|
+
ngUnsubscribe.next();
|
|
105
|
+
ngUnsubscribe.complete();
|
|
106
|
+
listeners.forEach(google.maps.event.removeListener);
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
close() {
|
|
110
|
+
this._overlayView.setMap(null);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"google-maps-contextmenu.js","sourceRoot":"","sources":["../../../../projects/ui-common/google-maps/google-maps-contextmenu.ts"],"names":[],"mappings":"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","sourcesContent":["import { ESCAPE } from '@angular/cdk/keycodes'\nimport { NgZone, ViewContainerRef } from '@angular/core'\nimport { fromEvent, Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { MenuComponent } from '@theseam/ui-common/menu'\n\nimport { isFeatureSelected } from './google-maps-feature-helpers'\n\n// TODO: Close on map losing focus.\n\nexport class GoogleMapsContextMenu {\n\n  private readonly _overlayView: google.maps.OverlayView\n  private readonly _cleanupFn: () => void\n\n  constructor(\n    private readonly _map: google.maps.Map,\n    private readonly _menu: MenuComponent,\n    _position: google.maps.LatLng,\n    private readonly _vcr: ViewContainerRef,\n    private readonly _ngZone: NgZone,\n    private readonly _data: google.maps.Data,\n    private readonly _feature: google.maps.Data.Feature,\n  ) {\n    const tplRef = this._menu.templateRef\n    if (tplRef === undefined || tplRef === null) {\n      throw Error(`Menu template is not defined.`)\n    }\n\n    const ref = this._vcr.createEmbeddedView(tplRef)\n    ref.detectChanges()\n\n    const listeners: google.maps.MapsEventListener[] = []\n    const ngUnsubscribe = new Subject<void>()\n\n    // TODO: Fix the initial focus. setTimeout avoids the wrong contextmenu\n    // getting triggered, but the first item flashes and looks off this way.\n    setTimeout(() => {\n      this._menu.focusFirstItem('program')\n    })\n    this._menu.closed.pipe(\n      takeUntil(ngUnsubscribe)\n    ).subscribe(v => {\n      this.close()\n    })\n\n    fromEvent(document, 'keydown').pipe(\n      takeUntil(ngUnsubscribe)\n    ).subscribe((event: any) => {\n      if (event.keyCode === ESCAPE) {\n        this.close()\n      }\n    })\n\n    const __cleanup = () => this._cleanupFn()\n    class GoogleMapsContextMenuOverlayView extends google.maps.OverlayView {\n      public containerDiv: HTMLDivElement\n\n      constructor(\n        public position: google.maps.LatLng,\n        content: HTMLElement\n      ) {\n        super()\n        this.position = position\n\n        this.containerDiv = document.createElement('div')\n        this.containerDiv.style.cursor = 'auto'\n        this.containerDiv.style.height = '0',\n        this.containerDiv.style.position = 'absolute'\n        this.containerDiv.appendChild(content)\n\n        // Optionally stop clicks, etc., from bubbling up to the map.\n        GoogleMapsContextMenuOverlayView.preventMapHitsAndGesturesFrom(this.containerDiv)\n      }\n\n      /** Called when the view is added to the map. */\n      onAdd() {\n        // tslint:disable-next-line: no-non-null-assertion\n        this.getPanes()!.floatPane.appendChild(this.containerDiv)\n      }\n\n      /** Called when the view is removed from the map. */\n      onRemove() {\n        if (this.containerDiv.parentElement) {\n          this.containerDiv.parentElement.removeChild(this.containerDiv)\n        }\n        __cleanup()\n      }\n\n      /** Called each frame when the view needs to draw itself. */\n      draw() {\n        // tslint:disable-next-line: no-non-null-assertion\n        const divPosition = this.getProjection().fromLatLngToDivPixel(this.position)!\n\n        // Hide the popup when it is far out of view.\n        const display =\n          Math.abs(divPosition.x) < 4000 && Math.abs(divPosition.y) < 4000\n            ? 'block'\n            : 'none'\n\n        if (display === 'block') {\n          this.containerDiv.style.left = divPosition.x + 'px'\n          this.containerDiv.style.top = divPosition.y + 'px'\n        }\n\n        if (this.containerDiv.style.display !== display) {\n          this.containerDiv.style.display = display\n        }\n      }\n    }\n\n    this._overlayView = new GoogleMapsContextMenuOverlayView(_position, ref.rootNodes[0])\n    this._overlayView.setMap(this._map)\n\n    this._ngZone.runOutsideAngular(() => {\n      listeners.push(this._data.addListener('removefeature', (event: google.maps.Data.RemoveFeatureEvent) => {\n        if (event.feature === this._feature) {\n          this._ngZone.run(() => { this.close() })\n        }\n      }))\n\n      listeners.push(this._data.addListener('setproperty', (event: google.maps.Data.SetPropertyEvent) => {\n        if (event.feature === this._feature && !isFeatureSelected(this._feature)) {\n          this._ngZone.run(() => { this.close() })\n        }\n      }))\n\n      listeners.push(this._data.addListener('removeproperty', (event: google.maps.Data.RemovePropertyEvent) => {\n        if (event.feature === this._feature && !isFeatureSelected(this._feature)) {\n          this._ngZone.run(() => { this.close() })\n        }\n      }))\n\n      listeners.push(this._map.addListener('click', (event: google.maps.MapMouseEvent | google.maps.IconMouseEvent) => {\n        this._ngZone.run(() => { this.close() })\n      }))\n\n      listeners.push(this._data.addListener('click', (event: google.maps.Data.MouseEvent) => {\n        this._ngZone.run(() => { this.close() })\n      }))\n    })\n\n    this._cleanupFn = () => {\n      ngUnsubscribe.next()\n      ngUnsubscribe.complete()\n      listeners.forEach(google.maps.event.removeListener)\n    }\n  }\n\n  public close(): void {\n    this._overlayView.setMap(null)\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { ComponentFactoryResolver, Injectable, Injector } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import { GoogleMapsService } from './google-maps.service';
|
|
4
|
+
import { MAP_CONTROL_DATA } from './map-controls-service';
|
|
5
|
+
export class MapControlRef {
|
|
6
|
+
constructor(_googleMaps, _componentFactoryResolver, _injector, _controlDef) {
|
|
7
|
+
var _a;
|
|
8
|
+
this._googleMaps = _googleMaps;
|
|
9
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
|
10
|
+
this._injector = _injector;
|
|
11
|
+
this._controlDef = _controlDef;
|
|
12
|
+
this._destroyedSubject = new Subject();
|
|
13
|
+
this.destroyed = this._destroyedSubject.asObservable();
|
|
14
|
+
const component = this._controlDef.component;
|
|
15
|
+
const factory = this._componentFactoryResolver.resolveComponentFactory(component);
|
|
16
|
+
const providers = [];
|
|
17
|
+
if (this._controlDef.data) {
|
|
18
|
+
providers.push({
|
|
19
|
+
provide: MAP_CONTROL_DATA,
|
|
20
|
+
useValue: this._controlDef.data
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
const injector = Injector.create({
|
|
24
|
+
providers,
|
|
25
|
+
parent: this._injector,
|
|
26
|
+
});
|
|
27
|
+
this._componentRef = factory.create(injector);
|
|
28
|
+
this._componentRef.changeDetectorRef.detectChanges();
|
|
29
|
+
const position = (_a = this._controlDef.position) !== null && _a !== void 0 ? _a : google.maps.ControlPosition.LEFT_BOTTOM;
|
|
30
|
+
this._googleMaps.addControl(this._componentRef.location.nativeElement, position);
|
|
31
|
+
this._addedAtPosition = position;
|
|
32
|
+
}
|
|
33
|
+
destroy() {
|
|
34
|
+
const googleMaps = this._googleMaps.googleMap;
|
|
35
|
+
if (googleMaps !== undefined) {
|
|
36
|
+
let idx = -1;
|
|
37
|
+
googleMaps.controls[this._addedAtPosition].forEach((elem, index) => {
|
|
38
|
+
if (elem === this._componentRef.location.nativeElement) {
|
|
39
|
+
idx = index;
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
if (idx === -1) {
|
|
43
|
+
throw Error(`Unable to destroy control. Control not found.`);
|
|
44
|
+
}
|
|
45
|
+
googleMaps.controls[this._addedAtPosition].removeAt(idx);
|
|
46
|
+
}
|
|
47
|
+
this._componentRef.destroy();
|
|
48
|
+
this._destroyedSubject.next();
|
|
49
|
+
this._destroyedSubject.complete();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
export class GoogleMapsControlsService {
|
|
53
|
+
constructor(_googleMaps, _componentFactoryResolver, _injector) {
|
|
54
|
+
this._googleMaps = _googleMaps;
|
|
55
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
|
56
|
+
this._injector = _injector;
|
|
57
|
+
}
|
|
58
|
+
add(control) {
|
|
59
|
+
return new MapControlRef(this._googleMaps, this._componentFactoryResolver, this._injector, control);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
GoogleMapsControlsService.decorators = [
|
|
63
|
+
{ type: Injectable }
|
|
64
|
+
];
|
|
65
|
+
GoogleMapsControlsService.ctorParameters = () => [
|
|
66
|
+
{ type: GoogleMapsService },
|
|
67
|
+
{ type: ComponentFactoryResolver },
|
|
68
|
+
{ type: Injector }
|
|
69
|
+
];
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ29vZ2xlLW1hcHMtY29udHJvbHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9nb29nbGUtbWFwcy9nb29nbGUtbWFwcy1jb250cm9scy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBZ0IsVUFBVSxFQUFFLFFBQVEsRUFBa0IsTUFBTSxlQUFlLENBQUE7QUFDNUcsT0FBTyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQTtBQUUxQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUN6RCxPQUFPLEVBQWtDLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFFekYsTUFBTSxPQUFPLGFBQWE7SUFTeEIsWUFDbUIsV0FBOEIsRUFDOUIseUJBQW1ELEVBQ25ELFNBQW1CLEVBQ25CLFdBQXVCOztRQUh2QixnQkFBVyxHQUFYLFdBQVcsQ0FBbUI7UUFDOUIsOEJBQXlCLEdBQXpCLHlCQUF5QixDQUEwQjtRQUNuRCxjQUFTLEdBQVQsU0FBUyxDQUFVO1FBQ25CLGdCQUFXLEdBQVgsV0FBVyxDQUFZO1FBWHpCLHNCQUFpQixHQUFHLElBQUksT0FBTyxFQUFRLENBQUE7UUFhdEQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWSxFQUFFLENBQUE7UUFFdEQsTUFBTSxTQUFTLEdBQVEsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUE7UUFDakQsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDLHVCQUF1QixDQUFDLFNBQVMsQ0FBQyxDQUFBO1FBRWpGLE1BQU0sU0FBUyxHQUFxQixFQUFFLENBQUE7UUFDdEMsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRTtZQUN6QixTQUFTLENBQUMsSUFBSSxDQUFDO2dCQUNiLE9BQU8sRUFBRSxnQkFBZ0I7Z0JBQ3pCLFFBQVEsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUk7YUFDaEMsQ0FBQyxDQUFBO1NBQ0g7UUFDRCxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQy9CLFNBQVM7WUFDVCxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVM7U0FDdkIsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLGFBQWEsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQzdDLElBQUksQ0FBQyxhQUFhLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUE7UUFFcEQsTUFBTSxRQUFRLEdBQUcsTUFBQSxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsbUNBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFBO1FBRXJGLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUN6QixJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxhQUFhLEVBQ3pDLFFBQVEsQ0FDVCxDQUFBO1FBRUQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFFBQVEsQ0FBQTtJQUNsQyxDQUFDO0lBRU0sT0FBTztRQUNaLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFBO1FBQzdDLElBQUksVUFBVSxLQUFLLFNBQVMsRUFBRTtZQUM1QixJQUFJLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQTtZQUNaLFVBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFO2dCQUNqRSxJQUFJLElBQUksS0FBSyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxhQUFhLEVBQUU7b0JBQ3RELEdBQUcsR0FBRyxLQUFLLENBQUE7aUJBQ1o7WUFDSCxDQUFDLENBQUMsQ0FBQTtZQUNGLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxFQUFFO2dCQUNkLE1BQU0sS0FBSyxDQUFDLCtDQUErQyxDQUFDLENBQUE7YUFDN0Q7WUFDRCxVQUFVLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQTtTQUN6RDtRQUNELElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxFQUFFLENBQUE7UUFFNUIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxDQUFBO1FBQzdCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQTtJQUNuQyxDQUFDO0NBRUY7QUFHRCxNQUFNLE9BQU8seUJBQXlCO0lBRXBDLFlBQ21CLFdBQThCLEVBQzlCLHlCQUFtRCxFQUNuRCxTQUFtQjtRQUZuQixnQkFBVyxHQUFYLFdBQVcsQ0FBbUI7UUFDOUIsOEJBQXlCLEdBQXpCLHlCQUF5QixDQUEwQjtRQUNuRCxjQUFTLEdBQVQsU0FBUyxDQUFVO0lBQ2xDLENBQUM7SUFFRSxHQUFHLENBQUMsT0FBbUI7UUFDNUIsT0FBTyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyx5QkFBeUIsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFBO0lBQ3JHLENBQUM7OztZQVhGLFVBQVU7OztZQXRFRixpQkFBaUI7WUFIakIsd0JBQXdCO1lBQTRCLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsIENvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIFN0YXRpY1Byb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJ1xuXG5pbXBvcnQgeyBHb29nbGVNYXBzU2VydmljZSB9IGZyb20gJy4vZ29vZ2xlLW1hcHMuc2VydmljZSdcbmltcG9ydCB7IE1hcENvbnRyb2wsIE1hcENvbnRyb2xzU2VydmljZSwgTUFQX0NPTlRST0xfREFUQSB9IGZyb20gJy4vbWFwLWNvbnRyb2xzLXNlcnZpY2UnXG5cbmV4cG9ydCBjbGFzcyBNYXBDb250cm9sUmVmIHtcblxuICBwcml2YXRlIHJlYWRvbmx5IF9kZXN0cm95ZWRTdWJqZWN0ID0gbmV3IFN1YmplY3Q8dm9pZD4oKVxuXG4gIHByaXZhdGUgX2NvbXBvbmVudFJlZjogQ29tcG9uZW50UmVmPGFueT5cbiAgcHJpdmF0ZSBfYWRkZWRBdFBvc2l0aW9uOiBnb29nbGUubWFwcy5Db250cm9sUG9zaXRpb25cblxuICBwdWJsaWMgZGVzdHJveWVkOiBPYnNlcnZhYmxlPHZvaWQ+XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBfZ29vZ2xlTWFwczogR29vZ2xlTWFwc1NlcnZpY2UsXG4gICAgcHJpdmF0ZSByZWFkb25seSBfY29tcG9uZW50RmFjdG9yeVJlc29sdmVyOiBDb21wb25lbnRGYWN0b3J5UmVzb2x2ZXIsXG4gICAgcHJpdmF0ZSByZWFkb25seSBfaW5qZWN0b3I6IEluamVjdG9yLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2NvbnRyb2xEZWY6IE1hcENvbnRyb2xcbiAgKSB7XG4gICAgdGhpcy5kZXN0cm95ZWQgPSB0aGlzLl9kZXN0cm95ZWRTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpXG5cbiAgICBjb25zdCBjb21wb25lbnQ6IGFueSA9IHRoaXMuX2NvbnRyb2xEZWYuY29tcG9uZW50XG4gICAgY29uc3QgZmFjdG9yeSA9IHRoaXMuX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlci5yZXNvbHZlQ29tcG9uZW50RmFjdG9yeShjb21wb25lbnQpXG5cbiAgICBjb25zdCBwcm92aWRlcnM6IFN0YXRpY1Byb3ZpZGVyW10gPSBbXVxuICAgIGlmICh0aGlzLl9jb250cm9sRGVmLmRhdGEpIHtcbiAgICAgIHByb3ZpZGVycy5wdXNoKHtcbiAgICAgICAgcHJvdmlkZTogTUFQX0NPTlRST0xfREFUQSxcbiAgICAgICAgdXNlVmFsdWU6IHRoaXMuX2NvbnRyb2xEZWYuZGF0YVxuICAgICAgfSlcbiAgICB9XG4gICAgY29uc3QgaW5qZWN0b3IgPSBJbmplY3Rvci5jcmVhdGUoe1xuICAgICAgcHJvdmlkZXJzLFxuICAgICAgcGFyZW50OiB0aGlzLl9pbmplY3RvcixcbiAgICB9KVxuXG4gICAgdGhpcy5fY29tcG9uZW50UmVmID0gZmFjdG9yeS5jcmVhdGUoaW5qZWN0b3IpXG4gICAgdGhpcy5fY29tcG9uZW50UmVmLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKVxuXG4gICAgY29uc3QgcG9zaXRpb24gPSB0aGlzLl9jb250cm9sRGVmLnBvc2l0aW9uID8/IGdvb2dsZS5tYXBzLkNvbnRyb2xQb3NpdGlvbi5MRUZUX0JPVFRPTVxuXG4gICAgdGhpcy5fZ29vZ2xlTWFwcy5hZGRDb250cm9sKFxuICAgICAgdGhpcy5fY29tcG9uZW50UmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQsXG4gICAgICBwb3NpdGlvblxuICAgIClcblxuICAgIHRoaXMuX2FkZGVkQXRQb3NpdGlvbiA9IHBvc2l0aW9uXG4gIH1cblxuICBwdWJsaWMgZGVzdHJveSgpIHtcbiAgICBjb25zdCBnb29nbGVNYXBzID0gdGhpcy5fZ29vZ2xlTWFwcy5nb29nbGVNYXBcbiAgICBpZiAoZ29vZ2xlTWFwcyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBsZXQgaWR4ID0gLTFcbiAgICAgIGdvb2dsZU1hcHMuY29udHJvbHNbdGhpcy5fYWRkZWRBdFBvc2l0aW9uXS5mb3JFYWNoKChlbGVtLCBpbmRleCkgPT4ge1xuICAgICAgICBpZiAoZWxlbSA9PT0gdGhpcy5fY29tcG9uZW50UmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQpIHtcbiAgICAgICAgICBpZHggPSBpbmRleFxuICAgICAgICB9XG4gICAgICB9KVxuICAgICAgaWYgKGlkeCA9PT0gLTEpIHtcbiAgICAgICAgdGhyb3cgRXJyb3IoYFVuYWJsZSB0byBkZXN0cm95IGNvbnRyb2wuIENvbnRyb2wgbm90IGZvdW5kLmApXG4gICAgICB9XG4gICAgICBnb29nbGVNYXBzLmNvbnRyb2xzW3RoaXMuX2FkZGVkQXRQb3NpdGlvbl0ucmVtb3ZlQXQoaWR4KVxuICAgIH1cbiAgICB0aGlzLl9jb21wb25lbnRSZWYuZGVzdHJveSgpXG5cbiAgICB0aGlzLl9kZXN0cm95ZWRTdWJqZWN0Lm5leHQoKVxuICAgIHRoaXMuX2Rlc3Ryb3llZFN1YmplY3QuY29tcGxldGUoKVxuICB9XG5cbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEdvb2dsZU1hcHNDb250cm9sc1NlcnZpY2UgaW1wbGVtZW50cyBNYXBDb250cm9sc1NlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2dvb2dsZU1hcHM6IEdvb2dsZU1hcHNTZXJ2aWNlLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2luamVjdG9yOiBJbmplY3RvcixcbiAgKSB7IH1cblxuICBwdWJsaWMgYWRkKGNvbnRyb2w6IE1hcENvbnRyb2wpOiBNYXBDb250cm9sUmVmIHtcbiAgICByZXR1cm4gbmV3IE1hcENvbnRyb2xSZWYodGhpcy5fZ29vZ2xlTWFwcywgdGhpcy5fY29tcG9uZW50RmFjdG9yeVJlc29sdmVyLCB0aGlzLl9pbmplY3RvciwgY29udHJvbClcbiAgfVxufVxuIl19
|