diff --git a/src/app/cesium-map/csmap.component.ts b/src/app/cesium-map/csmap.component.ts index 5ee64719..98808ad9 100644 --- a/src/app/cesium-map/csmap.component.ts +++ b/src/app/cesium-map/csmap.component.ts @@ -16,6 +16,7 @@ import { KMLQuerierHandler } from './custom-querier-handler/kml-querier-handler. import { AdvancedComponentService } from 'app/services/ui/advanced-component.service'; import { UserStateService } from 'app/services/user/user-state.service'; import { VMFQuerierHandler } from './custom-querier-handler/vmf-querier-handler.service'; +import { GeoJsonQuerierHandler } from './custom-querier-handler/geojson-querier-handler.service' import { Observable, forkJoin, throwError } from 'rxjs'; import { catchError, finalize, tap, timeout } from 'rxjs/operators'; import { ToolbarComponent } from 'app/menupanel/toolbar/toolbar.component'; @@ -174,6 +175,7 @@ export class CsMapComponent implements AfterViewInit { return this.viewer; } + ngAfterViewInit() { this.csMapService.init(); @@ -332,6 +334,10 @@ export class CsMapComponent implements AfterViewInit { this.displayModal(mapClickInfo.clickCoord); const handler = new VMFQuerierHandler(entity); this.setModalHTML(handler.getHTML(), layer.name + ": " + handler.getFeatureName(), entity, this.bsModalRef); + } else if (layer.cswRecords.find(c => c.onlineResources.find(o => o.type === ResourceType.GEOJSON))) { + this.displayModal(mapClickInfo.clickCoord); + const handler = new GeoJsonQuerierHandler(entity); + this.setModalHTML(handler.getHTML(), layer.name + ": " + handler.getFeatureName(), entity, this.bsModalRef); } } // TODO: Remove commented code, kept for yet to be re-implemented entity types diff --git a/src/app/cesium-map/custom-querier-handler/geojson-querier-handler.service.ts b/src/app/cesium-map/custom-querier-handler/geojson-querier-handler.service.ts new file mode 100644 index 00000000..e53e6a6e --- /dev/null +++ b/src/app/cesium-map/custom-querier-handler/geojson-querier-handler.service.ts @@ -0,0 +1,33 @@ +import { UtilitiesService, LayerModel } from "@auscope/portal-core-ui"; + +export class GeoJsonQuerierHandler { + + constructor(private entity: any) {} + + /** + * Creates an HTML string using a feature's GeoJsonFeatureData + * + * @returns HTML string + */ + public getHTML(): string { + let html = '