UNPKG

angular-cesium-ivy

Version:
187 lines 22.8 kB
import { ChangeDetectionStrategy, Component, ContentChildren, Input, ViewChild } from '@angular/core'; import { Subject } from 'rxjs'; import * as _get from 'lodash.get'; import { BasicDesc } from '../../services/basic-desc/basic-desc.service'; import * as i0 from "@angular/core"; import * as i1 from "../../services/layer-service/layer-service.service"; import * as i2 from "../ac-layer/ac-layer.component"; const _c0 = ["layer"]; const _c1 = ["*"]; /** * This is component represents an array under `ac-layer`. * The element must be a child of ac-layer element. * + acFor `{string}` - get the tracked array and entityName (see the example). * + idGetter `{Function}` - a function that gets the id for a given element in the array -should be defined for maximum performance. * + show `{boolean}` - show/hide array's entities. * * __Usage :__ * ``` *<ac-layer acFor="let track of tracks$" [show]="show" [context]="this" [store]="true"> * <ac-array-desc acFor="let arrayItem of track.array" [idGetter]="trackArrayIdGetter"> * <ac-array-desc acFor="let innerArrayItem of arrayItem.innerArray" [idGetter]="trackArrayIdGetter"> * <ac-point-desc props="{ * position: innerArrayItem.pos, * pixelSize: 10, * color: getTrackColor(track), * outlineColor: Cesium.Color.BLUE, * outlineWidth: 1 * }"> * </ac-point-desc> * </ac-array-desc> * </ac-array-desc> *</ac-layer> * ``` */ export class AcArrayDescComponent { constructor(layerService, cd) { this.layerService = layerService; this.cd = cd; this.show = true; this.entitiesMap = new Map(); this.id = 0; this.acForRgx = /^let\s+.+\s+of\s+.+$/; this.arrayObservable$ = new Subject(); } ngOnChanges(changes) { if (changes['acFor'].firstChange) { const acForString = changes['acFor'].currentValue; if (!this.acForRgx.test(acForString)) { throw new Error(`ac-layer: Invalid [acFor] syntax. Expected: [acFor]="let item of observable" .Instead received: ${acForString}`); } const acForArr = changes['acFor'].currentValue.split(' '); this.arrayPath = acForArr[3]; this.entityName = acForArr[1]; } } ngOnInit() { if (this.layer) { this.layer.getLayerService().cache = false; } this.layerServiceSubscription = this.layerService.layerUpdates().subscribe(() => { this.cd.detectChanges(); }); } ngAfterContentInit() { this.layerService.context['arrayObservable$'] = this.arrayObservable$; this.layerService.registerDescription(this); this.basicDescs._results.forEach((component) => { component.setLayerService(this.layer.getLayerService()); }); this.arrayDescs._results.splice(0, 1); this.arrayDescs._results.forEach((component) => { this.layerService.unregisterDescription(component); this.layer.getLayerService().registerDescription(component); component.layerService = this.layer.getLayerService(); component.setLayerService(this.layer.getLayerService()); }); } ngOnDestroy() { if (this.layerServiceSubscription) { this.layerServiceSubscription.unsubscribe(); } } setLayerService(layerService) { this.layerService = layerService; } draw(context, id, contextEntity) { const get = _get; const entitiesArray = get(context, this.arrayPath); if (!entitiesArray) { return; } const previousEntitiesIdArray = this.entitiesMap.get(id); const entitiesIdArray = []; this.entitiesMap.set(id, entitiesIdArray); entitiesArray.forEach((item, index) => { this.layerService.context[this.entityName] = item; const arrayItemId = this.generateCombinedId(id, item, index); entitiesIdArray.push(arrayItemId); this.layer.update(contextEntity, arrayItemId); }); if (previousEntitiesIdArray) { const entitiesToRemove = this.idGetter ? previousEntitiesIdArray.filter((entityId) => entitiesIdArray.indexOf(entityId) < 0) : previousEntitiesIdArray; if (entitiesToRemove) { entitiesToRemove.forEach((entityId) => this.layer.remove(entityId)); } } } remove(id) { const entitiesIdArray = this.entitiesMap.get(id); if (entitiesIdArray) { entitiesIdArray.forEach((entityId) => this.layer.remove(entityId)); } this.entitiesMap.delete(id); } removeAll() { this.layer.removeAll(); this.entitiesMap.clear(); } getAcForString() { return `let ${this.entityName + '___temp'} of arrayObservable$`; } generateCombinedId(entityId, arrayItem, index) { let arrayItemId; if (this.idGetter) { arrayItemId = this.idGetter(arrayItem, index); } else { arrayItemId = (this.id++) % Number.MAX_SAFE_INTEGER; } return entityId + arrayItemId; } } AcArrayDescComponent.ɵfac = function AcArrayDescComponent_Factory(t) { return new (t || AcArrayDescComponent)(i0.ɵɵdirectiveInject(i1.LayerService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; AcArrayDescComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AcArrayDescComponent, selectors: [["ac-array-desc"]], contentQueries: function AcArrayDescComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) { i0.ɵɵcontentQuery(dirIndex, BasicDesc, 4); i0.ɵɵcontentQuery(dirIndex, AcArrayDescComponent, 4); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.basicDescs = _t); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.arrayDescs = _t); } }, viewQuery: function AcArrayDescComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 7); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.layer = _t.first); } }, inputs: { acFor: "acFor", idGetter: "idGetter", show: "show" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c1, decls: 3, vars: 5, consts: [[3, "acFor", "context", "options", "show", "zIndex"], ["layer", ""]], template: function AcArrayDescComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵprojectionDef(); i0.ɵɵelementStart(0, "ac-layer", 0, 1); i0.ɵɵprojection(2, 0, ["#content", ""]); i0.ɵɵelementEnd(); } if (rf & 2) { i0.ɵɵproperty("acFor", ctx.getAcForString())("context", ctx.layerService.context)("options", ctx.layerService.options)("show", ctx.layerService.show && ctx.show)("zIndex", ctx.layerService.zIndex); } }, directives: [i2.AcLayerComponent], encapsulation: 2, changeDetection: 0 }); (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AcArrayDescComponent, [{ type: Component, args: [{ selector: 'ac-array-desc', template: ` <ac-layer #layer [acFor]="getAcForString()" [context]="layerService.context" [options]="layerService.options" [show]="layerService.show && show" [zIndex]="layerService.zIndex"> <ng-content #content></ng-content> </ac-layer> `, changeDetection: ChangeDetectionStrategy.OnPush, }] }], function () { return [{ type: i1.LayerService }, { type: i0.ChangeDetectorRef }]; }, { acFor: [{ type: Input }], idGetter: [{ type: Input }], show: [{ type: Input }], layer: [{ type: ViewChild, args: ['layer', { static: true }] }], basicDescs: [{ type: ContentChildren, args: [BasicDesc, { descendants: false }] }], arrayDescs: [{ type: ContentChildren, args: [AcArrayDescComponent, { descendants: false }] }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ac-array-desc.component.js","sourceRoot":"","sources":["../../../../../../../projects/angular-cesium/src/lib/angular-cesium/components/ac-array-desc/ac-array-desc.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { AcNotification } from '../../models/ac-notification';\nimport { Subject, Subscription } from 'rxjs';\nimport { IDescription } from '../../models/description';\nimport * as _get from 'lodash.get';\nimport { AcLayerComponent } from '../ac-layer/ac-layer.component';\nimport { LayerService } from '../../services/layer-service/layer-service.service';\nimport { BasicDesc } from '../../services/basic-desc/basic-desc.service';\n\n/**\n *  This is component represents an array under `ac-layer`.\n *  The element must be a child of ac-layer element.\n *  + acFor `{string}` - get the tracked array and entityName (see the example).\n *  + idGetter `{Function}` - a function that gets the id for a given element in the array -should be defined for maximum performance.\n *  + show `{boolean}` - show/hide array's entities.\n *\n *  __Usage :__\n *  ```\n *<ac-layer acFor=\"let track of tracks$\" [show]=\"show\" [context]=\"this\" [store]=\"true\">\n *  <ac-array-desc acFor=\"let arrayItem of track.array\" [idGetter]=\"trackArrayIdGetter\">\n *    <ac-array-desc acFor=\"let innerArrayItem of arrayItem.innerArray\" [idGetter]=\"trackArrayIdGetter\">\n *      <ac-point-desc props=\"{\n *        position: innerArrayItem.pos,\n *        pixelSize: 10,\n *        color: getTrackColor(track),\n *        outlineColor: Cesium.Color.BLUE,\n *        outlineWidth: 1\n *      }\">\n *      </ac-point-desc>\n *    </ac-array-desc>\n *  </ac-array-desc>\n *</ac-layer>\n *  ```\n */\n\n@Component({\n  selector: 'ac-array-desc',\n  template: `\n    <ac-layer #layer [acFor]=\"getAcForString()\"\n              [context]=\"layerService.context\"\n              [options]=\"layerService.options\"\n              [show]=\"layerService.show && show\"\n              [zIndex]=\"layerService.zIndex\">\n      <ng-content #content></ng-content>\n    </ac-layer>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AcArrayDescComponent implements OnChanges, OnInit, AfterContentInit, OnDestroy, IDescription {\n\n  @Input() acFor: string;\n\n  @Input() idGetter: (item: any, index: number) => string;\n\n  @Input() show = true;\n  @ViewChild('layer', {static: true}) private layer: AcLayerComponent;\n  @ContentChildren(BasicDesc, {descendants: false}) private basicDescs: any;\n  @ContentChildren(AcArrayDescComponent, {descendants: false}) private arrayDescs: any;\n  private entitiesMap = new Map<string, string[]>();\n  private layerServiceSubscription: Subscription;\n  private id = 0;\n  private readonly acForRgx = /^let\\s+.+\\s+of\\s+.+$/;\n  entityName: string;\n  arrayPath: string;\n  arrayObservable$ = new Subject<AcNotification>();\n\n  constructor(public layerService: LayerService, private cd: ChangeDetectorRef) {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['acFor'].firstChange) {\n      const acForString = changes['acFor'].currentValue;\n      if (!this.acForRgx.test(acForString)) {\n        throw new Error(`ac-layer: Invalid [acFor] syntax. Expected: [acFor]=\"let item of observable\" .Instead received: ${acForString}`);\n      }\n      const acForArr = changes['acFor'].currentValue.split(' ');\n      this.arrayPath = acForArr[3];\n      this.entityName = acForArr[1];\n    }\n  }\n\n  ngOnInit(): void {\n    if (this.layer) {\n      this.layer.getLayerService().cache = false;\n    }\n\n    this.layerServiceSubscription = this.layerService.layerUpdates().subscribe(() => {\n      this.cd.detectChanges();\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.layerService.context['arrayObservable$'] = this.arrayObservable$;\n    this.layerService.registerDescription(this);\n    this.basicDescs._results.forEach((component: BasicDesc) => {\n      component.setLayerService(this.layer.getLayerService());\n    });\n    this.arrayDescs._results.splice(0, 1);\n    this.arrayDescs._results.forEach((component: AcArrayDescComponent) => {\n      this.layerService.unregisterDescription(component);\n      this.layer.getLayerService().registerDescription(component);\n      component.layerService = this.layer.getLayerService();\n      component.setLayerService(this.layer.getLayerService());\n    });\n  }\n\n  ngOnDestroy(): void {\n    if (this.layerServiceSubscription) {\n      this.layerServiceSubscription.unsubscribe();\n    }\n  }\n\n  setLayerService(layerService: LayerService) {\n    this.layerService = layerService;\n  }\n\n  draw(context: any, id: string, contextEntity: any) {\n    const get = _get;\n    const entitiesArray: any[] = get(context, this.arrayPath);\n    if (!entitiesArray) {\n      return;\n    }\n    const previousEntitiesIdArray = this.entitiesMap.get(id);\n    const entitiesIdArray: any[] = [];\n    this.entitiesMap.set(id, entitiesIdArray);\n\n    entitiesArray.forEach((item, index) => {\n      this.layerService.context[this.entityName] = item;\n      const arrayItemId = this.generateCombinedId(id, item, index);\n      entitiesIdArray.push(arrayItemId);\n      this.layer.update(contextEntity, arrayItemId);\n    });\n\n    if (previousEntitiesIdArray) {\n      const entitiesToRemove = this.idGetter ?\n        previousEntitiesIdArray.filter((entityId) => entitiesIdArray.indexOf(entityId) < 0) :\n        previousEntitiesIdArray;\n      if (entitiesToRemove) {\n        entitiesToRemove.forEach((entityId) => this.layer.remove(entityId));\n      }\n    }\n  }\n\n  remove(id: string) {\n    const entitiesIdArray = this.entitiesMap.get(id);\n    if (entitiesIdArray) {\n      entitiesIdArray.forEach((entityId) => this.layer.remove(entityId));\n    }\n    this.entitiesMap.delete(id);\n  }\n\n  removeAll() {\n    this.layer.removeAll();\n    this.entitiesMap.clear();\n  }\n\n  getAcForString() {\n    return `let ${this.entityName + '___temp'} of arrayObservable$`;\n  }\n\n  private generateCombinedId(entityId: string, arrayItem: any, index: number): string {\n    let arrayItemId;\n    if (this.idGetter) {\n      arrayItemId = this.idGetter(arrayItem, index);\n    } else {\n      arrayItemId = (this.id++) % Number.MAX_SAFE_INTEGER;\n    }\n    return entityId + arrayItemId;\n  }\n}\n"]}