280 lines
No EOL
33 KiB
JavaScript
Executable file
280 lines
No EOL
33 KiB
JavaScript
Executable file
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265
|
|
/// <reference types="google.maps" preserve="true" />
|
|
import { Directive, EventEmitter, Input, NgZone, Output, inject, } from '@angular/core';
|
|
import { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';
|
|
import { map, take, takeUntil } from 'rxjs/operators';
|
|
import { GoogleMap } from '../google-map/google-map';
|
|
import { MapEventManager } from '../map-event-manager';
|
|
import * as i0 from "@angular/core";
|
|
import * as i1 from "../google-map/google-map";
|
|
/**
|
|
* Angular component that renders a Google Maps Circle via the Google Maps JavaScript API.
|
|
* @see developers.google.com/maps/documentation/javascript/reference/polygon#Circle
|
|
*/
|
|
export class MapCircle {
|
|
set options(options) {
|
|
this._options.next(options || {});
|
|
}
|
|
set center(center) {
|
|
this._center.next(center);
|
|
}
|
|
set radius(radius) {
|
|
this._radius.next(radius);
|
|
}
|
|
constructor(_map, _ngZone) {
|
|
this._map = _map;
|
|
this._ngZone = _ngZone;
|
|
this._eventManager = new MapEventManager(inject(NgZone));
|
|
this._options = new BehaviorSubject({});
|
|
this._center = new BehaviorSubject(undefined);
|
|
this._radius = new BehaviorSubject(undefined);
|
|
this._destroyed = new Subject();
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.center_changed
|
|
*/
|
|
this.centerChanged = this._eventManager.getLazyEmitter('center_changed');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.click
|
|
*/
|
|
this.circleClick = this._eventManager.getLazyEmitter('click');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dblclick
|
|
*/
|
|
this.circleDblclick = this._eventManager.getLazyEmitter('dblclick');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.drag
|
|
*/
|
|
this.circleDrag = this._eventManager.getLazyEmitter('drag');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dragend
|
|
*/
|
|
this.circleDragend = this._eventManager.getLazyEmitter('dragend');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dragstart
|
|
*/
|
|
this.circleDragstart = this._eventManager.getLazyEmitter('dragstart');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mousedown
|
|
*/
|
|
this.circleMousedown = this._eventManager.getLazyEmitter('mousedown');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mousemove
|
|
*/
|
|
this.circleMousemove = this._eventManager.getLazyEmitter('mousemove');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseout
|
|
*/
|
|
this.circleMouseout = this._eventManager.getLazyEmitter('mouseout');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseover
|
|
*/
|
|
this.circleMouseover = this._eventManager.getLazyEmitter('mouseover');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseup
|
|
*/
|
|
this.circleMouseup = this._eventManager.getLazyEmitter('mouseup');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.radius_changed
|
|
*/
|
|
this.radiusChanged = this._eventManager.getLazyEmitter('radius_changed');
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.rightclick
|
|
*/
|
|
this.circleRightclick = this._eventManager.getLazyEmitter('rightclick');
|
|
/** Event emitted when the circle is initialized. */
|
|
this.circleInitialized = new EventEmitter();
|
|
}
|
|
ngOnInit() {
|
|
if (!this._map._isBrowser) {
|
|
return;
|
|
}
|
|
this._combineOptions()
|
|
.pipe(take(1))
|
|
.subscribe(options => {
|
|
if (google.maps.Circle && this._map.googleMap) {
|
|
this._initialize(this._map.googleMap, google.maps.Circle, options);
|
|
}
|
|
else {
|
|
this._ngZone.runOutsideAngular(() => {
|
|
Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(([map, lib]) => {
|
|
this._initialize(map, lib.Circle, options);
|
|
});
|
|
});
|
|
}
|
|
});
|
|
}
|
|
_initialize(map, circleConstructor, options) {
|
|
// Create the object outside the zone so its events don't trigger change detection.
|
|
// We'll bring it back in inside the `MapEventManager` only for the events that the
|
|
// user has subscribed to.
|
|
this._ngZone.runOutsideAngular(() => {
|
|
this.circle = new circleConstructor(options);
|
|
this._assertInitialized();
|
|
this.circle.setMap(map);
|
|
this._eventManager.setTarget(this.circle);
|
|
this.circleInitialized.emit(this.circle);
|
|
this._watchForOptionsChanges();
|
|
this._watchForCenterChanges();
|
|
this._watchForRadiusChanges();
|
|
});
|
|
}
|
|
ngOnDestroy() {
|
|
this._eventManager.destroy();
|
|
this._destroyed.next();
|
|
this._destroyed.complete();
|
|
this.circle?.setMap(null);
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getBounds
|
|
*/
|
|
getBounds() {
|
|
this._assertInitialized();
|
|
return this.circle.getBounds();
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getCenter
|
|
*/
|
|
getCenter() {
|
|
this._assertInitialized();
|
|
return this.circle.getCenter();
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getDraggable
|
|
*/
|
|
getDraggable() {
|
|
this._assertInitialized();
|
|
return this.circle.getDraggable();
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getEditable
|
|
*/
|
|
getEditable() {
|
|
this._assertInitialized();
|
|
return this.circle.getEditable();
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getRadius
|
|
*/
|
|
getRadius() {
|
|
this._assertInitialized();
|
|
return this.circle.getRadius();
|
|
}
|
|
/**
|
|
* @see
|
|
* developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getVisible
|
|
*/
|
|
getVisible() {
|
|
this._assertInitialized();
|
|
return this.circle.getVisible();
|
|
}
|
|
_combineOptions() {
|
|
return combineLatest([this._options, this._center, this._radius]).pipe(map(([options, center, radius]) => {
|
|
const combinedOptions = {
|
|
...options,
|
|
center: center || options.center,
|
|
radius: radius !== undefined ? radius : options.radius,
|
|
};
|
|
return combinedOptions;
|
|
}));
|
|
}
|
|
_watchForOptionsChanges() {
|
|
this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {
|
|
this._assertInitialized();
|
|
this.circle.setOptions(options);
|
|
});
|
|
}
|
|
_watchForCenterChanges() {
|
|
this._center.pipe(takeUntil(this._destroyed)).subscribe(center => {
|
|
if (center) {
|
|
this._assertInitialized();
|
|
this.circle.setCenter(center);
|
|
}
|
|
});
|
|
}
|
|
_watchForRadiusChanges() {
|
|
this._radius.pipe(takeUntil(this._destroyed)).subscribe(radius => {
|
|
if (radius !== undefined) {
|
|
this._assertInitialized();
|
|
this.circle.setRadius(radius);
|
|
}
|
|
});
|
|
}
|
|
_assertInitialized() {
|
|
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
if (!this.circle) {
|
|
throw Error('Cannot interact with a Google Map Circle before it has been ' +
|
|
'initialized. Please wait for the Circle to load before trying to interact with it.');
|
|
}
|
|
}
|
|
}
|
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapCircle, deps: [{ token: i1.GoogleMap }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.0-next.2", type: MapCircle, isStandalone: true, selector: "map-circle", inputs: { options: "options", center: "center", radius: "radius" }, outputs: { centerChanged: "centerChanged", circleClick: "circleClick", circleDblclick: "circleDblclick", circleDrag: "circleDrag", circleDragend: "circleDragend", circleDragstart: "circleDragstart", circleMousedown: "circleMousedown", circleMousemove: "circleMousemove", circleMouseout: "circleMouseout", circleMouseover: "circleMouseover", circleMouseup: "circleMouseup", radiusChanged: "radiusChanged", circleRightclick: "circleRightclick", circleInitialized: "circleInitialized" }, exportAs: ["mapCircle"], ngImport: i0 }); }
|
|
}
|
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0-next.2", ngImport: i0, type: MapCircle, decorators: [{
|
|
type: Directive,
|
|
args: [{
|
|
selector: 'map-circle',
|
|
exportAs: 'mapCircle',
|
|
standalone: true,
|
|
}]
|
|
}], ctorParameters: () => [{ type: i1.GoogleMap }, { type: i0.NgZone }], propDecorators: { options: [{
|
|
type: Input
|
|
}], center: [{
|
|
type: Input
|
|
}], radius: [{
|
|
type: Input
|
|
}], centerChanged: [{
|
|
type: Output
|
|
}], circleClick: [{
|
|
type: Output
|
|
}], circleDblclick: [{
|
|
type: Output
|
|
}], circleDrag: [{
|
|
type: Output
|
|
}], circleDragend: [{
|
|
type: Output
|
|
}], circleDragstart: [{
|
|
type: Output
|
|
}], circleMousedown: [{
|
|
type: Output
|
|
}], circleMousemove: [{
|
|
type: Output
|
|
}], circleMouseout: [{
|
|
type: Output
|
|
}], circleMouseover: [{
|
|
type: Output
|
|
}], circleMouseup: [{
|
|
type: Output
|
|
}], radiusChanged: [{
|
|
type: Output
|
|
}], circleRightclick: [{
|
|
type: Output
|
|
}], circleInitialized: [{
|
|
type: Output
|
|
}] } });
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-circle.js","sourceRoot":"","sources":["../../../../../../src/google-maps/map-circle/map-circle.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// Workaround for: https://github.com/bazelbuild/rules_nodejs/issues/1265\n/// <reference types=\"google.maps\" preserve=\"true\" />\n\nimport {\n  Directive,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  inject,\n} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, take, takeUntil} from 'rxjs/operators';\n\nimport {GoogleMap} from '../google-map/google-map';\nimport {MapEventManager} from '../map-event-manager';\n\n/**\n * Angular component that renders a Google Maps Circle via the Google Maps JavaScript API.\n * @see developers.google.com/maps/documentation/javascript/reference/polygon#Circle\n */\n@Directive({\n  selector: 'map-circle',\n  exportAs: 'mapCircle',\n  standalone: true,\n})\nexport class MapCircle implements OnInit, OnDestroy {\n  private _eventManager = new MapEventManager(inject(NgZone));\n  private readonly _options = new BehaviorSubject<google.maps.CircleOptions>({});\n  private readonly _center = new BehaviorSubject<\n    google.maps.LatLng | google.maps.LatLngLiteral | undefined\n  >(undefined);\n  private readonly _radius = new BehaviorSubject<number | undefined>(undefined);\n\n  private readonly _destroyed = new Subject<void>();\n\n  /**\n   * Underlying google.maps.Circle object.\n   *\n   * @see developers.google.com/maps/documentation/javascript/reference/polygon#Circle\n   */\n  circle?: google.maps.Circle; // initialized in ngOnInit\n\n  @Input()\n  set options(options: google.maps.CircleOptions) {\n    this._options.next(options || {});\n  }\n\n  @Input()\n  set center(center: google.maps.LatLng | google.maps.LatLngLiteral) {\n    this._center.next(center);\n  }\n\n  @Input()\n  set radius(radius: number) {\n    this._radius.next(radius);\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.center_changed\n   */\n  @Output() readonly centerChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('center_changed');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.click\n   */\n  @Output() readonly circleClick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('click');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dblclick\n   */\n  @Output() readonly circleDblclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dblclick');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.drag\n   */\n  @Output() readonly circleDrag: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('drag');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dragend\n   */\n  @Output() readonly circleDragend: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragend');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.dragstart\n   */\n  @Output() readonly circleDragstart: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('dragstart');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mousedown\n   */\n  @Output() readonly circleMousedown: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousedown');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mousemove\n   */\n  @Output() readonly circleMousemove: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mousemove');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseout\n   */\n  @Output() readonly circleMouseout: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseout');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseover\n   */\n  @Output() readonly circleMouseover: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseover');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.mouseup\n   */\n  @Output() readonly circleMouseup: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('mouseup');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.radius_changed\n   */\n  @Output() readonly radiusChanged: Observable<void> =\n    this._eventManager.getLazyEmitter<void>('radius_changed');\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.rightclick\n   */\n  @Output() readonly circleRightclick: Observable<google.maps.MapMouseEvent> =\n    this._eventManager.getLazyEmitter<google.maps.MapMouseEvent>('rightclick');\n\n  /** Event emitted when the circle is initialized. */\n  @Output() readonly circleInitialized: EventEmitter<google.maps.Circle> =\n    new EventEmitter<google.maps.Circle>();\n\n  constructor(\n    private readonly _map: GoogleMap,\n    private readonly _ngZone: NgZone,\n  ) {}\n\n  ngOnInit() {\n    if (!this._map._isBrowser) {\n      return;\n    }\n\n    this._combineOptions()\n      .pipe(take(1))\n      .subscribe(options => {\n        if (google.maps.Circle && this._map.googleMap) {\n          this._initialize(this._map.googleMap, google.maps.Circle, options);\n        } else {\n          this._ngZone.runOutsideAngular(() => {\n            Promise.all([this._map._resolveMap(), google.maps.importLibrary('maps')]).then(\n              ([map, lib]) => {\n                this._initialize(map, (lib as google.maps.MapsLibrary).Circle, options);\n              },\n            );\n          });\n        }\n      });\n  }\n\n  private _initialize(\n    map: google.maps.Map,\n    circleConstructor: typeof google.maps.Circle,\n    options: google.maps.CircleOptions,\n  ) {\n    // Create the object outside the zone so its events don't trigger change detection.\n    // We'll bring it back in inside the `MapEventManager` only for the events that the\n    // user has subscribed to.\n    this._ngZone.runOutsideAngular(() => {\n      this.circle = new circleConstructor(options);\n      this._assertInitialized();\n      this.circle.setMap(map);\n      this._eventManager.setTarget(this.circle);\n      this.circleInitialized.emit(this.circle);\n      this._watchForOptionsChanges();\n      this._watchForCenterChanges();\n      this._watchForRadiusChanges();\n    });\n  }\n\n  ngOnDestroy() {\n    this._eventManager.destroy();\n    this._destroyed.next();\n    this._destroyed.complete();\n    this.circle?.setMap(null);\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getBounds\n   */\n  getBounds(): google.maps.LatLngBounds | null {\n    this._assertInitialized();\n    return this.circle.getBounds();\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getCenter\n   */\n  getCenter(): google.maps.LatLng | null {\n    this._assertInitialized();\n    return this.circle.getCenter();\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getDraggable\n   */\n  getDraggable(): boolean {\n    this._assertInitialized();\n    return this.circle.getDraggable();\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getEditable\n   */\n  getEditable(): boolean {\n    this._assertInitialized();\n    return this.circle.getEditable();\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getRadius\n   */\n  getRadius(): number {\n    this._assertInitialized();\n    return this.circle.getRadius();\n  }\n\n  /**\n   * @see\n   * developers.google.com/maps/documentation/javascript/reference/polygon#Circle.getVisible\n   */\n  getVisible(): boolean {\n    this._assertInitialized();\n    return this.circle.getVisible();\n  }\n\n  private _combineOptions(): Observable<google.maps.CircleOptions> {\n    return combineLatest([this._options, this._center, this._radius]).pipe(\n      map(([options, center, radius]) => {\n        const combinedOptions: google.maps.CircleOptions = {\n          ...options,\n          center: center || options.center,\n          radius: radius !== undefined ? radius : options.radius,\n        };\n        return combinedOptions;\n      }),\n    );\n  }\n\n  private _watchForOptionsChanges() {\n    this._options.pipe(takeUntil(this._destroyed)).subscribe(options => {\n      this._assertInitialized();\n      this.circle.setOptions(options);\n    });\n  }\n\n  private _watchForCenterChanges() {\n    this._center.pipe(takeUntil(this._destroyed)).subscribe(center => {\n      if (center) {\n        this._assertInitialized();\n        this.circle.setCenter(center);\n      }\n    });\n  }\n\n  private _watchForRadiusChanges() {\n    this._radius.pipe(takeUntil(this._destroyed)).subscribe(radius => {\n      if (radius !== undefined) {\n        this._assertInitialized();\n        this.circle.setRadius(radius);\n      }\n    });\n  }\n\n  private _assertInitialized(): asserts this is {circle: google.maps.Circle} {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!this.circle) {\n        throw Error(\n          'Cannot interact with a Google Map Circle before it has been ' +\n            'initialized. Please wait for the Circle to load before trying to interact with it.',\n        );\n      }\n    }\n  }\n}\n"]}
|