UNPKG

@ng-maps/core

Version:

**@ng-maps/core** is a simple, modular and tree-shakable library for displaying google-maps inside an angular application

258 lines 28.7 kB
import { Directive, EventEmitter, Input, Output, } from '@angular/core'; import { Subscription } from 'rxjs'; import { CircleManager } from '../services/managers/circle-manager'; import * as i0 from "@angular/core"; import * as i1 from "../services/managers/circle-manager"; export class NgMapsCircleDirective { constructor(_manager) { this._manager = _manager; /** * Indicates whether this Circle handles mouse events. Defaults to true. */ this.clickable = true; /** * If set to true, the user can drag this circle over the map. Defaults to false. */ this.draggable = false; /** * If set to true, the user can edit this circle by dragging the control points shown at * the center and around the circumference of the circle. Defaults to false. */ this.editable = false; /** * The radius in meters on the Earth's surface. */ this.radius = 0; /** * The stroke position. Defaults to CENTER. * This property is not supported on Internet Explorer 8 and earlier. * * @fixme */ // @Input() strokePosition: google.maps.StrokePosition = // google.maps.StrokePosition.CENTER; /** * The stroke width in pixels. */ this.strokeWeight = 0; /** * Whether this circle is visible on the map. Defaults to true. */ this.visible = true; /** * This event is fired when the circle's center is changed. */ this.centerChange = new EventEmitter(); /** * This event emitter gets emitted when the user clicks on the circle. */ this.circleClick = new EventEmitter(); /** * This event emitter gets emitted when the user clicks on the circle. */ this.circleDblClick = new EventEmitter(); /** * This event is repeatedly fired while the user drags the circle. */ this.drag = new EventEmitter(); /** * This event is fired when the user stops dragging the circle. */ this.dragEnd = new EventEmitter(); /** * This event is fired when the user starts dragging the circle. */ this.dragStart = new EventEmitter(); /** * This event is fired when the DOM mousedown event is fired on the circle. */ this.mouseDown = new EventEmitter(); /** * This event is fired when the DOM mousemove event is fired on the circle. */ this.mouseMove = new EventEmitter(); /** * This event is fired on circle mouseout. */ this.mouseOut = new EventEmitter(); /** * This event is fired on circle mouseover. */ this.mouseOver = new EventEmitter(); /** * This event is fired when the DOM mouseup event is fired on the circle. */ this.mouseUp = new EventEmitter(); /** * This event is fired when the circle's radius is changed. */ this.radiusChange = new EventEmitter(); /** * This event is fired when the circle is right-clicked on. */ this.rightClick = new EventEmitter(); this._circleAddedToManager = false; this.subscription = new Subscription(); } static { this._mapOptions = [ 'fillColor', 'fillOpacity', 'strokeColor', 'strokeOpacity', 'strokePosition', 'strokeWeight', 'visible', 'zIndex', 'clickable', ]; } /** @internal */ ngOnInit() { this._manager.addCircle(this); this._circleAddedToManager = true; this._registerEventListeners(); } /** @internal */ ngOnChanges(changes) { if (!this._circleAddedToManager) { return; } if (changes.latitude || changes.longitude) { this._manager.setCenter(this); } if (changes.editable) { this._manager.setEditable(this); } if (changes.draggable) { this._manager.setDraggable(this); } if (changes.visible) { this._manager.setVisible(this); } if (changes.radius) { this._manager.setRadius(this); } this._updateCircleOptionsChanges(changes); } _updateCircleOptionsChanges(changes) { const options = {}; const optionKeys = Object.keys(changes).filter((k) => NgMapsCircleDirective._mapOptions.indexOf(k) !== -1); optionKeys.forEach((k) => { options[k] = changes[k].currentValue; }); if (optionKeys.length > 0) { this._manager.setOptions(this, options); } } _registerEventListeners() { const events = new Map(); events.set('center_changed', this.centerChange); events.set('click', this.circleClick); events.set('dblclick', this.circleDblClick); events.set('drag', this.drag); events.set('dragend', this.dragEnd); events.set('dragstart', this.dragStart); events.set('mousedown', this.mouseDown); events.set('mousemove', this.mouseMove); events.set('mouseout', this.mouseOut); events.set('mouseover', this.mouseOver); events.set('mouseup', this.mouseUp); events.set('radius_changed', this.radiusChange); events.set('rightclick', this.rightClick); events.forEach((eventEmitter, eventName) => { this.subscription.add(this._manager .createEventObservable(eventName, this) .subscribe((value) => { switch (eventName) { case 'radius_changed': this._manager .getRadius(this) .then((radius) => eventEmitter.emit(radius)); break; case 'center_changed': this._manager.getCenter(this).then((center) => eventEmitter.emit({ ...center, })); break; default: eventEmitter.emit(value); } })); }); } /** @internal */ ngOnDestroy() { this.subscription.unsubscribe(); this._manager.removeCircle(this); } /** * Gets the LatLngBounds of this Circle. */ async getBounds() { return this._manager.getBounds(this); } async getCenter() { return this._manager.getCenter(this); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: NgMapsCircleDirective, deps: [{ token: i1.CircleManager }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: NgMapsCircleDirective, selector: "map-circle", inputs: { latitude: "latitude", longitude: "longitude", clickable: "clickable", draggable: "draggable", editable: "editable", fillColor: "fillColor", fillOpacity: "fillOpacity", radius: "radius", strokeColor: "strokeColor", strokeOpacity: "strokeOpacity", strokeWeight: "strokeWeight", visible: "visible", zIndex: "zIndex" }, outputs: { centerChange: "centerChange", circleClick: "circleClick", circleDblClick: "circleDblClick", drag: "drag", dragEnd: "dragEnd", dragStart: "dragStart", mouseDown: "mouseDown", mouseMove: "mouseMove", mouseOut: "mouseOut", mouseOver: "mouseOver", mouseUp: "mouseUp", radiusChange: "radiusChange", rightClick: "rightClick" }, usesOnChanges: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: NgMapsCircleDirective, decorators: [{ type: Directive, args: [{ // eslint-disable-next-line @angular-eslint/directive-selector selector: 'map-circle', }] }], ctorParameters: () => [{ type: i1.CircleManager }], propDecorators: { latitude: [{ type: Input }], longitude: [{ type: Input }], clickable: [{ type: Input }], draggable: [{ type: Input }], editable: [{ type: Input }], fillColor: [{ type: Input }], fillOpacity: [{ type: Input }], radius: [{ type: Input }], strokeColor: [{ type: Input }], strokeOpacity: [{ type: Input }], strokeWeight: [{ type: Input }], visible: [{ type: Input }], zIndex: [{ type: Input }], centerChange: [{ type: Output }], circleClick: [{ type: Output }], circleDblClick: [{ type: Output }], drag: [{ type: Output }], dragEnd: [{ type: Output }], dragStart: [{ type: Output }], mouseDown: [{ type: Output }], mouseMove: [{ type: Output }], mouseOut: [{ type: Output }], mouseOver: [{ type: Output }], mouseUp: [{ type: Output }], radiusChange: [{ type: Output }], rightClick: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"circle.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/directives/circle.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChange,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { BoundsLiteral } from '../interface/bounds';\nimport { CircleOptions } from '../interface/circle-options';\nimport { GeoPoint } from '../interface/geo-point';\nimport { CircleManager } from '../services/managers/circle-manager';\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: 'map-circle',\n})\nexport class NgMapsCircleDirective\n  implements OnInit, OnChanges, OnDestroy, CircleOptions\n{\n  constructor(private _manager: CircleManager) {}\n\n  private static _mapOptions: Array<string> = [\n    'fillColor',\n    'fillOpacity',\n    'strokeColor',\n    'strokeOpacity',\n    'strokePosition',\n    'strokeWeight',\n    'visible',\n    'zIndex',\n    'clickable',\n  ];\n  /**\n   * The latitude position of the circle (required).\n   */\n  @Input() public latitude?: number;\n\n  /**\n   * The clickable position of the circle (required).\n   */\n  @Input() public longitude?: number;\n\n  /**\n   * Indicates whether this Circle handles mouse events. Defaults to true.\n   */\n  @Input() public clickable: boolean = true;\n\n  /**\n   * If set to true, the user can drag this circle over the map. Defaults to false.\n   */\n  @Input() public draggable: boolean = false;\n\n  /**\n   * If set to true, the user can edit this circle by dragging the control points shown at\n   * the center and around the circumference of the circle. Defaults to false.\n   */\n  @Input() public editable: boolean = false;\n\n  /**\n   * The fill color. All CSS3 colors are supported except for extended named colors.\n   */\n  @Input() public fillColor?: string;\n\n  /**\n   * The fill opacity between 0.0 and 1.0.\n   */\n  @Input() public fillOpacity?: number;\n\n  /**\n   * The radius in meters on the Earth's surface.\n   */\n  @Input() public radius: number = 0;\n\n  /**\n   * The stroke color. All CSS3 colors are supported except for extended named colors.\n   */\n  @Input() public strokeColor?: string;\n\n  /**\n   * The stroke opacity between 0.0 and 1.0\n   */\n  @Input() public strokeOpacity?: number;\n\n  /**\n   * The stroke position. Defaults to CENTER.\n   * This property is not supported on Internet Explorer 8 and earlier.\n   *\n   * @fixme\n   */\n  // @Input() strokePosition: google.maps.StrokePosition =\n  //   google.maps.StrokePosition.CENTER;\n\n  /**\n   * The stroke width in pixels.\n   */\n  @Input() public strokeWeight: number = 0;\n\n  /**\n   * Whether this circle is visible on the map. Defaults to true.\n   */\n  @Input() public visible: boolean = true;\n\n  /**\n   * The zIndex compared to other polys.\n   */\n  @Input() public zIndex?: number;\n\n  /**\n   * This event is fired when the circle's center is changed.\n   */\n  @Output()\n  public centerChange: EventEmitter<GeoPoint> = new EventEmitter<GeoPoint>();\n\n  /**\n   * This event emitter gets emitted when the user clicks on the circle.\n   */\n  @Output()\n  public circleClick: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event emitter gets emitted when the user clicks on the circle.\n   */\n  @Output()\n  public circleDblClick: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is repeatedly fired while the user drags the circle.\n   */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public drag: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the user stops dragging the circle.\n   */\n  @Output()\n  public dragEnd: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the user starts dragging the circle.\n   */\n  @Output()\n  public dragStart: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the DOM mousedown event is fired on the circle.\n   */\n  @Output()\n  public mouseDown: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the DOM mousemove event is fired on the circle.\n   */\n  @Output()\n  public mouseMove: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired on circle mouseout.\n   */\n  @Output()\n  public mouseOut: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired on circle mouseover.\n   */\n  @Output()\n  public mouseOver: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the DOM mouseup event is fired on the circle.\n   */\n  @Output()\n  public mouseUp: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  /**\n   * This event is fired when the circle's radius is changed.\n   */\n  @Output()\n  public radiusChange: EventEmitter<number> = new EventEmitter<number>();\n\n  /**\n   * This event is fired when the circle is right-clicked on.\n   */\n  @Output()\n  public rightClick: EventEmitter<google.maps.MapMouseEvent> =\n    new EventEmitter<google.maps.MapMouseEvent>();\n\n  private _circleAddedToManager: boolean = false;\n\n  private subscription: Subscription = new Subscription();\n\n  /** @internal */\n  public ngOnInit() {\n    this._manager.addCircle(this);\n    this._circleAddedToManager = true;\n    this._registerEventListeners();\n  }\n\n  /** @internal */\n  public ngOnChanges(changes: { [key: string]: SimpleChange }) {\n    if (!this._circleAddedToManager) {\n      return;\n    }\n    if (changes.latitude || changes.longitude) {\n      this._manager.setCenter(this);\n    }\n    if (changes.editable) {\n      this._manager.setEditable(this);\n    }\n    if (changes.draggable) {\n      this._manager.setDraggable(this);\n    }\n    if (changes.visible) {\n      this._manager.setVisible(this);\n    }\n    if (changes.radius) {\n      this._manager.setRadius(this);\n    }\n    this._updateCircleOptionsChanges(changes);\n  }\n\n  private _updateCircleOptionsChanges(changes: {\n    [propName: string]: SimpleChange;\n  }) {\n    const options: { [propName: string]: any } = {};\n    const optionKeys = Object.keys(changes).filter(\n      (k) => NgMapsCircleDirective._mapOptions.indexOf(k) !== -1,\n    );\n    optionKeys.forEach((k) => {\n      options[k] = changes[k].currentValue;\n    });\n    if (optionKeys.length > 0) {\n      this._manager.setOptions(this, options);\n    }\n  }\n\n  private _registerEventListeners() {\n    const events: Map<string, EventEmitter<any>> = new Map<\n      string,\n      EventEmitter<any>\n    >();\n    events.set('center_changed', this.centerChange);\n    events.set('click', this.circleClick);\n    events.set('dblclick', this.circleDblClick);\n    events.set('drag', this.drag);\n    events.set('dragend', this.dragEnd);\n    events.set('dragstart', this.dragStart);\n    events.set('mousedown', this.mouseDown);\n    events.set('mousemove', this.mouseMove);\n    events.set('mouseout', this.mouseOut);\n    events.set('mouseover', this.mouseOver);\n    events.set('mouseup', this.mouseUp);\n    events.set('radius_changed', this.radiusChange);\n    events.set('rightclick', this.rightClick);\n\n    events.forEach((eventEmitter, eventName) => {\n      this.subscription.add(\n        this._manager\n          .createEventObservable<google.maps.MapMouseEvent>(eventName, this)\n          .subscribe((value) => {\n            switch (eventName) {\n              case 'radius_changed':\n                this._manager\n                  .getRadius(this)\n                  .then((radius) => eventEmitter.emit(radius));\n                break;\n              case 'center_changed':\n                this._manager.getCenter(this).then((center) =>\n                  eventEmitter.emit({\n                    ...center,\n                  }),\n                );\n                break;\n              default:\n                eventEmitter.emit(value);\n            }\n          }),\n      );\n    });\n  }\n\n  /** @internal */\n  public ngOnDestroy() {\n    this.subscription.unsubscribe();\n    this._manager.removeCircle(this);\n  }\n\n  /**\n   * Gets the LatLngBounds of this Circle.\n   */\n  public async getBounds(): Promise<BoundsLiteral | null> {\n    return this._manager.getBounds(this);\n  }\n\n  public async getCenter(): Promise<GeoPoint | null> {\n    return this._manager.getCenter(this);\n  }\n}\n"]}