From f8196fc099fd35947d3903051ad543aa3cefccbb Mon Sep 17 00:00:00 2001 From: Aijana Schumann Date: Fri, 9 Oct 2020 21:08:54 +0200 Subject: Networkmap bugfix Fix icons don't show up after reload Issue-ID: CCSDK-2879 Signed-off-by: Aijana Schumann Change-Id: Ic752d969acb0985e4ae97cec101ac2bbe0895716 --- .../networkMapApp/src/services/mapImagesService.ts | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 sdnr/wt/odlux/apps/networkMapApp/src/services/mapImagesService.ts (limited to 'sdnr/wt/odlux/apps/networkMapApp/src/services') diff --git a/sdnr/wt/odlux/apps/networkMapApp/src/services/mapImagesService.ts b/sdnr/wt/odlux/apps/networkMapApp/src/services/mapImagesService.ts new file mode 100644 index 000000000..c414b15c9 --- /dev/null +++ b/sdnr/wt/odlux/apps/networkMapApp/src/services/mapImagesService.ts @@ -0,0 +1,54 @@ +/** + * ============LICENSE_START======================================================================== + * ONAP : ccsdk feature sdnr wt odlux + * ================================================================================================= + * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property. All rights reserved. + * ================================================================================================= + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License + * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express + * or implied. See the License for the specific language governing permissions and limitations under + * the License. + * ============LICENSE_END========================================================================== + */ + +import * as mapboxgl from 'mapbox-gl'; +import apartment from '../../icons/apartment.png'; +import datacenter from '../../icons/datacenter.png'; +import factory from '../../icons/factory.png'; +import lamp from '../../icons/lamp.png'; + +type ImagesLoaded = (allImagesLoaded: boolean) => void; +type MapImages = {name: string, url: string} + +export const Images : MapImages[] = [{name: 'data-center', url: datacenter}, {name: 'house', url: apartment}, {name: 'factory', url: factory},{name: 'lamp', url: lamp}] ; + +export const addImages = (map: mapboxgl.Map, callback?: ImagesLoaded) =>{ + + Images.forEach(image => { + + map.loadImage( + image.url, + function (error: any, img: any) { + if (error) throw error; + map.addImage(image.name, img); + allImagesLoaded(map, callback); + }); + }); +} + +const allImagesLoaded = (map: mapboxgl.Map, callback?: ImagesLoaded) =>{ + + const loadedImages = Images.map(image =>{ + return map.hasImage(image.name); + }); + + const allImagesLoaded = loadedImages.filter(el => !el); + if(allImagesLoaded.length===0){ + callback && callback(true); + } +} \ No newline at end of file -- cgit 1.2.3-korg