@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.
Files changed (131) hide show
  1. package/breadcrumbs/_breadcrumbs-theme.scss +3 -0
  2. package/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +10 -0
  3. package/breadcrumbs/styles/_utilities.scss +3 -0
  4. package/breadcrumbs/styles/_variables.scss +1 -0
  5. package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +1 -1
  6. package/bundles/theseam-ui-common-breadcrumbs.umd.js +2 -1
  7. package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
  8. package/bundles/theseam-ui-common-dynamic.umd.js +1 -0
  9. package/bundles/theseam-ui-common-dynamic.umd.js.map +1 -1
  10. package/bundles/theseam-ui-common-form-field.umd.js +1 -1
  11. package/bundles/theseam-ui-common-form-field.umd.js.map +1 -1
  12. package/bundles/theseam-ui-common-framework.umd.js +18 -15
  13. package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
  14. package/bundles/theseam-ui-common-google-maps.umd.js +2202 -0
  15. package/bundles/theseam-ui-common-google-maps.umd.js.map +1 -0
  16. package/bundles/theseam-ui-common-menu.umd.js +1 -0
  17. package/bundles/theseam-ui-common-menu.umd.js.map +1 -1
  18. package/bundles/theseam-ui-common-modal.umd.js +21 -1
  19. package/bundles/theseam-ui-common-modal.umd.js.map +1 -1
  20. package/bundles/theseam-ui-common-utils.umd.js +610 -136
  21. package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
  22. package/bundles/theseam-ui-common-widget.umd.js +4 -2
  23. package/bundles/theseam-ui-common-widget.umd.js.map +1 -1
  24. package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +4 -3
  25. package/esm2015/dynamic/evaluators/jexl-evaluator/jexl-evaluator.js +2 -1
  26. package/esm2015/form-field/input.directive.js +2 -2
  27. package/esm2015/framework/base-layout/base-layout.component.js +3 -3
  28. package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +5 -5
  29. package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +4 -3
  30. package/esm2015/framework/top-bar/top-bar.component.js +10 -8
  31. package/esm2015/google-maps/google-maps/google-maps.component.js +261 -0
  32. package/esm2015/google-maps/google-maps-contextmenu.js +113 -0
  33. package/esm2015/google-maps/google-maps-controls.service.js +70 -0
  34. package/esm2015/google-maps/google-maps-feature-helpers.js +177 -0
  35. package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.js +195 -0
  36. package/esm2015/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.js +163 -0
  37. package/esm2015/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.js +57 -0
  38. package/esm2015/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.js +119 -0
  39. package/esm2015/google-maps/google-maps.module.js +45 -0
  40. package/esm2015/google-maps/google-maps.service.js +344 -0
  41. package/esm2015/google-maps/map-control.component.js +65 -0
  42. package/esm2015/google-maps/map-controls-service.js +4 -0
  43. package/esm2015/google-maps/map-file-drop/map-file-drop.component.js +135 -0
  44. package/esm2015/google-maps/map-value-manager.service.js +46 -0
  45. package/esm2015/google-maps/public-api.js +14 -0
  46. package/esm2015/google-maps/theseam-ui-common-google-maps.js +6 -0
  47. package/esm2015/menu/menu-toggle.directive.js +2 -1
  48. package/esm2015/modal/modal-ref.js +22 -2
  49. package/esm2015/utils/geo-json/coerce-feature-collection.js +44 -0
  50. package/esm2015/utils/geo-json/geo-json-to-area.js +11 -0
  51. package/esm2015/utils/geo-json/is-feature-collection.validator.js +21 -0
  52. package/esm2015/utils/geo-json/is-only-geometry-types.js +23 -0
  53. package/esm2015/utils/geo-json/is-only-geometry-types.validator.js +32 -0
  54. package/esm2015/utils/geo-json/merge-polygons.js +35 -0
  55. package/esm2015/utils/geo-json/no-inner-rings.validator.js +63 -0
  56. package/esm2015/utils/geo-json/no-kinks.validator.js +39 -0
  57. package/esm2015/utils/geo-json/read-geo-file.js +99 -0
  58. package/esm2015/utils/geo-json/split-multi-polygons.js +29 -0
  59. package/esm2015/utils/is-null-or-undefined.js +1 -1
  60. package/esm2015/utils/public-api.js +11 -1
  61. package/esm2015/widget/widget/widget.component.js +1 -1
  62. package/esm2015/widget/widget-content-components/widget-tile/widget-tile.component.js +4 -2
  63. package/fesm2015/theseam-ui-common-breadcrumbs.js +3 -2
  64. package/fesm2015/theseam-ui-common-breadcrumbs.js.map +1 -1
  65. package/fesm2015/theseam-ui-common-dynamic.js +1 -0
  66. package/fesm2015/theseam-ui-common-dynamic.js.map +1 -1
  67. package/fesm2015/theseam-ui-common-form-field.js +1 -1
  68. package/fesm2015/theseam-ui-common-form-field.js.map +1 -1
  69. package/fesm2015/theseam-ui-common-framework.js +15 -12
  70. package/fesm2015/theseam-ui-common-framework.js.map +1 -1
  71. package/fesm2015/theseam-ui-common-google-maps.js +1729 -0
  72. package/fesm2015/theseam-ui-common-google-maps.js.map +1 -0
  73. package/fesm2015/theseam-ui-common-menu.js +1 -0
  74. package/fesm2015/theseam-ui-common-menu.js.map +1 -1
  75. package/fesm2015/theseam-ui-common-modal.js +21 -1
  76. package/fesm2015/theseam-ui-common-modal.js.map +1 -1
  77. package/fesm2015/theseam-ui-common-utils.js +477 -94
  78. package/fesm2015/theseam-ui-common-utils.js.map +1 -1
  79. package/fesm2015/theseam-ui-common-widget.js +4 -2
  80. package/fesm2015/theseam-ui-common-widget.js.map +1 -1
  81. package/form-field/theseam-ui-common-form-field.metadata.json +1 -1
  82. package/framework/base-layout/base-layout.component.scss +14 -0
  83. package/framework/base-layout/styles/_variables.scss +14 -0
  84. package/framework/theseam-ui-common-framework.metadata.json +1 -1
  85. package/framework/top-bar/_top-bar-theme.scss +5 -0
  86. package/framework/top-bar/styles/_utilities.scss +3 -0
  87. package/framework/top-bar/styles/_variables.scss +18 -0
  88. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +3 -1
  89. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.scss +15 -0
  90. package/framework/top-bar/top-bar-title/top-bar-title.component.scss +6 -0
  91. package/framework/top-bar/top-bar.component.d.ts +3 -0
  92. package/framework/top-bar/top-bar.component.scss +39 -0
  93. package/google-maps/google-maps/google-maps.component.d.ts +89 -0
  94. package/google-maps/google-maps-contextmenu.d.ts +15 -0
  95. package/google-maps/google-maps-controls.service.d.ts +23 -0
  96. package/google-maps/google-maps-feature-helpers.d.ts +37 -0
  97. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.component.d.ts +104 -0
  98. package/google-maps/google-maps-places-autocomplete/google-maps-places-autocomplete.directive.d.ts +80 -0
  99. package/google-maps/google-maps-recenter-button-control/google-maps-recenter-button-control.component.d.ts +21 -0
  100. package/google-maps/google-maps-upload-button-control/google-maps-upload-button-control.component.d.ts +34 -0
  101. package/google-maps/google-maps.module.d.ts +2 -0
  102. package/google-maps/google-maps.service.d.ts +53 -0
  103. package/google-maps/map-control.component.d.ts +20 -0
  104. package/google-maps/map-controls-service.d.ts +13 -0
  105. package/google-maps/map-file-drop/map-file-drop.component.d.ts +34 -0
  106. package/google-maps/map-value-manager.service.d.ts +18 -0
  107. package/google-maps/package.json +11 -0
  108. package/google-maps/public-api.d.ts +13 -0
  109. package/google-maps/theseam-ui-common-google-maps.d.ts +5 -0
  110. package/google-maps/theseam-ui-common-google-maps.metadata.json +1 -0
  111. package/modal/modal-ref.d.ts +1 -0
  112. package/modal/theseam-ui-common-modal.metadata.json +1 -1
  113. package/package.json +17 -10
  114. package/utils/geo-json/coerce-feature-collection.d.ts +2 -0
  115. package/utils/geo-json/geo-json-to-area.d.ts +6 -0
  116. package/utils/geo-json/is-feature-collection.validator.d.ts +3 -0
  117. package/utils/geo-json/is-only-geometry-types.d.ts +5 -0
  118. package/utils/geo-json/is-only-geometry-types.validator.d.ts +4 -0
  119. package/utils/geo-json/merge-polygons.d.ts +9 -0
  120. package/utils/geo-json/no-inner-rings.validator.d.ts +10 -0
  121. package/utils/geo-json/no-kinks.validator.d.ts +3 -0
  122. package/utils/geo-json/read-geo-file.d.ts +7 -0
  123. package/utils/geo-json/split-multi-polygons.d.ts +8 -0
  124. package/utils/is-null-or-undefined.d.ts +1 -1
  125. package/utils/public-api.d.ts +10 -0
  126. package/utils/theseam-ui-common-utils.metadata.json +1 -1
  127. package/widget/styles/_variables.scss +3 -0
  128. package/widget/theseam-ui-common-widget.metadata.json +1 -1
  129. package/widget/widget/widget.component.scss +2 -0
  130. package/widget/widget-content-components/widget-tile/widget-tile.component.d.ts +2 -0
  131. 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