UNPKG

angular-cesium-ivy

Version:
121 lines (120 loc) 13.6 kB
import { ChangeDetectionStrategy, Component, Input, Output, EventEmitter } from '@angular/core'; import { fromEvent as observableFromEvent } from 'rxjs'; import { switchMap, takeUntil, tap } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "../../../../angular-cesium/services/cesium/cesium.service"; import * as i2 from "@angular/common"; import * as i3 from "../ac-toolbar-button/ac-toolbar-button.component"; import * as i4 from "./drag-icon.component"; function AcToolbarComponent_div_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div"); i0.ɵɵelementStart(1, "ac-toolbar-button"); i0.ɵɵelement(2, "ac-drag-icon"); i0.ɵɵelementEnd(); i0.ɵɵelementEnd(); } } const _c0 = ["*"]; /** * Toolbar widget, act as a container for ac-toolbar-button components * allowing drag configuration and passing `toolbarClass` as attributes * * Usage: * ``` * <ac-toolbar [allowDrag]="true" (onDrag)="handleDrag($event)"> <ac-toolbar-button [iconUrl]="'assets/home-icon.svg'" (onClick)="goHome()"> </ac-toolbar-button> <ac-toolbar-button [iconUrl]="'assets/explore-icon.svg'" (onClick)="rangeAndBearing()"> </ac-toolbar-button> </ac-toolbar> * ``` * */ export class AcToolbarComponent { constructor(element, cesiumService) { this.element = element; this.cesiumService = cesiumService; this.allowDrag = true; this.onDrag = new EventEmitter(); this.dragStyle = { 'height.px': 20, 'width.px': 20, }; } ngOnInit() { this.cesiumService.getMap().getMapContainer().appendChild(this.element.nativeElement); if (this.allowDrag) { this.listenForDragging(); } } ngOnChanges(changes) { if (changes.allowDrag && changes.allowDrag.currentValue && !changes.allowDrag.previousValue) { this.listenForDragging(); } if (changes.allowDrag && !changes.allowDrag.currentValue && changes.allowDrag.previousValue) { this.dragSubscription.unsubscribe(); } } ngOnDestroy() { if (this.dragSubscription) { this.dragSubscription.unsubscribe(); } } listenForDragging() { this.mouseDown$ = this.mouseDown$ || observableFromEvent(this.element.nativeElement, 'mousedown'); this.mouseMove$ = this.mouseMove$ || observableFromEvent(document, 'mousemove'); this.mouseUp$ = this.mouseUp$ || observableFromEvent(document, 'mouseup'); this.drag$ = this.drag$ || this.mouseDown$.pipe(switchMap(() => this.mouseMove$.pipe(tap(this.onDrag.emit), takeUntil(this.mouseUp$)))); this.dragSubscription = this.drag$.subscribe((event) => { this.element.nativeElement.style.left = `${event.x}px`; this.element.nativeElement.style.top = `${event.y}px`; }); } } AcToolbarComponent.ɵfac = function AcToolbarComponent_Factory(t) { return new (t || AcToolbarComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.CesiumService)); }; AcToolbarComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AcToolbarComponent, selectors: [["ac-toolbar"]], inputs: { toolbarClass: "toolbarClass", allowDrag: "allowDrag" }, outputs: { onDrag: "onDrag" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c0, decls: 3, vars: 4, consts: [[4, "ngIf"]], template: function AcToolbarComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵprojectionDef(); i0.ɵɵelementStart(0, "div"); i0.ɵɵtemplate(1, AcToolbarComponent_div_1_Template, 3, 0, "div", 0); i0.ɵɵprojection(2); i0.ɵɵelementEnd(); } if (rf & 2) { i0.ɵɵclassMap(ctx.toolbarClass); i0.ɵɵadvance(1); i0.ɵɵproperty("ngIf", ctx.allowDrag); } }, directives: [i2.NgIf, i3.AcToolbarButtonComponent, i4.DragIconComponent], styles: ["[_nghost-%COMP%] {\n position: absolute;\n top: 20px;\n left: 20px;\n width: 20px;\n height: 20px;\n z-index: 999;\n -webkit-user-drag: none;\n }"], changeDetection: 0 }); (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AcToolbarComponent, [{ type: Component, args: [{ selector: 'ac-toolbar', template: ` <div class="{{toolbarClass}}"> <div *ngIf="allowDrag"> <ac-toolbar-button> <ac-drag-icon></ac-drag-icon> </ac-toolbar-button> </div> <ng-content></ng-content> </div> `, styles: [` :host { position: absolute; top: 20px; left: 20px; width: 20px; height: 20px; z-index: 999; -webkit-user-drag: none; } `], changeDetection: ChangeDetectionStrategy.OnPush, }] }], function () { return [{ type: i0.ElementRef }, { type: i1.CesiumService }]; }, { toolbarClass: [{ type: Input }], allowDrag: [{ type: Input }], onDrag: [{ type: Output }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ac-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/angular-cesium/src/lib/angular-cesium-widgets/components/toolbar/ac-toolbar/ac-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  Output,\n  EventEmitter\n} from '@angular/core';\nimport { fromEvent as observableFromEvent, Subscription, Observable } from 'rxjs';\nimport { switchMap, takeUntil, tap } from 'rxjs/operators';\nimport { CesiumService } from '../../../../angular-cesium/services/cesium/cesium.service';\n\n\n/**\n * Toolbar widget, act as a container for ac-toolbar-button components\n * allowing drag configuration and passing `toolbarClass` as attributes\n *\n * Usage:\n * ```\n * <ac-toolbar [allowDrag]=\"true\" (onDrag)=\"handleDrag($event)\">\n <ac-toolbar-button [iconUrl]=\"'assets/home-icon.svg'\" (onClick)=\"goHome()\">\n </ac-toolbar-button>\n <ac-toolbar-button [iconUrl]=\"'assets/explore-icon.svg'\" (onClick)=\"rangeAndBearing()\">\n </ac-toolbar-button>\n </ac-toolbar>\n * ```\n *\n */\n@Component(\n  {\n    selector: 'ac-toolbar',\n    template: `\n        <div class=\"{{toolbarClass}}\">\n            <div *ngIf=\"allowDrag\">\n                <ac-toolbar-button>\n                    <ac-drag-icon></ac-drag-icon>\n                </ac-toolbar-button>\n            </div>\n\n            <ng-content></ng-content>\n        </div>\n    `,\n    styles: [`\n        :host {\n            position: absolute;\n            top: 20px;\n            left: 20px;\n            width: 20px;\n            height: 20px;\n            z-index: 999;\n            -webkit-user-drag: none;\n        }\n    `],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n  }\n)\nexport class AcToolbarComponent implements OnInit, OnChanges, OnDestroy {\n  @Input()\n  toolbarClass: string;\n  @Input()\n  allowDrag = true;\n  @Output()\n  onDrag = new EventEmitter<MouseEvent>();\n\n  dragStyle = {\n    'height.px': 20,\n    'width.px': 20,\n  };\n\n  private mouseDown$: Observable<MouseEvent>;\n  private mouseMove$: Observable<MouseEvent>;\n  private mouseUp$: Observable<MouseEvent>;\n  private drag$: Observable<MouseEvent>;\n  private dragSubscription: Subscription;\n\n  constructor(private element: ElementRef, private cesiumService: CesiumService) {}\n\n  ngOnInit() {\n    this.cesiumService.getMap().getMapContainer().appendChild(this.element.nativeElement);\n    if (this.allowDrag) {\n      this.listenForDragging();\n    }\n  }\n\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.allowDrag && changes.allowDrag.currentValue && !changes.allowDrag.previousValue) {\n      this.listenForDragging();\n    }\n\n    if (changes.allowDrag && !changes.allowDrag.currentValue && changes.allowDrag.previousValue) {\n      this.dragSubscription.unsubscribe();\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.dragSubscription) {\n      this.dragSubscription.unsubscribe();\n    }\n  }\n\n  private listenForDragging() {\n    this.mouseDown$ = this.mouseDown$ || observableFromEvent(this.element.nativeElement, 'mousedown');\n    this.mouseMove$ = this.mouseMove$ || observableFromEvent(document, 'mousemove') as Observable<MouseEvent>;\n    this.mouseUp$ = this.mouseUp$ || observableFromEvent(document, 'mouseup') as Observable<MouseEvent>;\n\n    this.drag$ = this.drag$ ||\n                 this.mouseDown$.pipe(\n                    switchMap(() => this.mouseMove$.pipe(\n                      tap(this.onDrag.emit),\n                      takeUntil(this.mouseUp$)\n                    ))\n                 );\n\n    this.dragSubscription = this.drag$.subscribe((event: MouseEvent) => {\n      this.element.nativeElement.style.left = `${event.x}px`;\n      this.element.nativeElement.style.top = `${event.y}px`;\n    });\n  }\n}\n"]}