@vcmap/ui 5.0.0-rc.8 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +95 -64
- package/app.config.json +3 -0
- package/build/.eslintrc +3 -0
- package/build/build.js +302 -165
- package/build/buildCesium.js +39 -19
- package/build/buildHelpers.js +279 -88
- package/build/buildPreview.js +16 -6
- package/build/bundle.js +57 -0
- package/build/commonViteConfig.js +7 -16
- package/build/determineHost.js +17 -4
- package/build/generateOLLib.js +15 -18
- package/build/getPluginProxies.js +35 -3
- package/build/info/conf.json +21 -19
- package/build/info/publish.js +16 -5
- package/config/aerowest.config.json +47 -54
- package/config/base.config.json +597 -662
- package/config/codes.config.json +401 -0
- package/config/dev.config.json +460 -14
- package/config/graphFeatureInfo.config.json +141 -0
- package/config/projects.config.json +29 -0
- package/config/www.config.json +1801 -0
- package/dist/assets/@mdi/font/LICENSE +20 -0
- package/dist/assets/@mdi/font/css/materialdesignicons.css.map +16 -0
- package/dist/assets/@mdi/font/css/materialdesignicons.min.e3f476.css +3 -0
- package/dist/assets/@mdi/font/fonts/materialdesignicons-webfont.woff2 +0 -0
- package/dist/assets/cesium/ThirdParty/Workers/basis_transcoder.js +21 -0
- package/dist/assets/cesium/ThirdParty/Workers/package.json +1 -0
- package/dist/assets/cesium/ThirdParty/Workers/pako_deflate.min.js +2 -0
- package/dist/assets/cesium/ThirdParty/Workers/pako_inflate.min.js +2 -0
- package/dist/assets/cesium/ThirdParty/Workers/z-worker-pako.js +1 -0
- package/dist/assets/cesium/ThirdParty/basis_transcoder.wasm +0 -0
- package/dist/assets/cesium/ThirdParty/draco_decoder.wasm +0 -0
- package/dist/assets/cesium/ThirdParty/google-earth-dbroot-parser.js +8337 -0
- package/dist/assets/cesium/Workers/chunk-227AJNOA.js +59 -0
- package/dist/assets/cesium/Workers/chunk-2R5O53JW.js +157 -0
- package/dist/assets/cesium/Workers/chunk-34YUDLRP.js +781 -0
- package/dist/assets/cesium/Workers/chunk-3W63OHNJ.js +100 -0
- package/dist/assets/cesium/Workers/chunk-4MFFIWUA.js +163 -0
- package/dist/assets/cesium/Workers/chunk-66QLLS45.js +218 -0
- package/dist/assets/cesium/Workers/chunk-6BTKZDRG.js +77 -0
- package/dist/assets/cesium/Workers/chunk-A4JVFBQ3.js +101 -0
- package/dist/assets/cesium/Workers/chunk-ABADGKYE.js +58 -0
- package/dist/assets/cesium/Workers/chunk-AFFLIKOH.js +353 -0
- package/dist/assets/cesium/Workers/chunk-AHKEZ2OE.js +629 -0
- package/dist/assets/cesium/Workers/chunk-C3SXRKRW.js +476 -0
- package/dist/assets/cesium/Workers/chunk-CCFQRR6D.js +55 -0
- package/dist/assets/cesium/Workers/chunk-CHHNOC2C.js +1860 -0
- package/dist/assets/cesium/Workers/chunk-CTELOFLA.js +196 -0
- package/dist/assets/cesium/Workers/chunk-DUHWWBQQ.js +3273 -0
- package/dist/assets/cesium/Workers/chunk-EW2GWJYB.js +44 -0
- package/dist/assets/cesium/Workers/chunk-GLZBE3ML.js +421 -0
- package/dist/assets/cesium/Workers/chunk-HARLBUOL.js +236 -0
- package/dist/assets/cesium/Workers/chunk-HQF437NJ.js +117 -0
- package/dist/assets/cesium/Workers/chunk-IPA4EACJ.js +368 -0
- package/dist/assets/cesium/Workers/chunk-J3JY6I2C.js +1009 -0
- package/dist/assets/cesium/Workers/chunk-JB2LWGH4.js +390 -0
- package/dist/assets/cesium/Workers/chunk-JS3AW5BK.js +634 -0
- package/dist/assets/cesium/Workers/chunk-K36FEYS7.js +452 -0
- package/dist/assets/cesium/Workers/chunk-KD4Y7CZL.js +400 -0
- package/dist/assets/cesium/Workers/chunk-KTJSNCK4.js +842 -0
- package/dist/assets/cesium/Workers/chunk-LLUNNUJV.js +258 -0
- package/dist/assets/cesium/Workers/chunk-MPAZH4BF.js +37 -0
- package/dist/assets/cesium/Workers/chunk-MYZB7C4T.js +1258 -0
- package/dist/assets/cesium/Workers/chunk-N3JIFFX2.js +501 -0
- package/dist/assets/cesium/Workers/chunk-O5AMBQ36.js +430 -0
- package/dist/assets/cesium/Workers/chunk-OAVNIRB4.js +124 -0
- package/dist/assets/cesium/Workers/chunk-OYFCF4PL.js +171 -0
- package/dist/assets/cesium/Workers/chunk-OZJDGN5F.js +1477 -0
- package/dist/assets/cesium/Workers/chunk-PCJWUS4M.js +2041 -0
- package/dist/assets/cesium/Workers/chunk-PFQBCKBM.js +8644 -0
- package/dist/assets/cesium/Workers/chunk-QIKODV5G.js +305 -0
- package/dist/assets/cesium/Workers/chunk-QJ3DFBH3.js +73 -0
- package/dist/assets/cesium/Workers/chunk-QMEMZIJI.js +138 -0
- package/dist/assets/cesium/Workers/chunk-QT3MPEMI.js +102 -0
- package/dist/assets/cesium/Workers/chunk-RP2A7BR5.js +289 -0
- package/dist/assets/cesium/Workers/chunk-RW6LU2CJ.js +138 -0
- package/dist/assets/cesium/Workers/chunk-TFC6TZ3S.js +757 -0
- package/dist/assets/cesium/Workers/chunk-V3NGATMV.js +693 -0
- package/dist/assets/cesium/Workers/chunk-VLGOATD6.js +1075 -0
- package/dist/assets/cesium/Workers/chunk-WXTV4ATB.js +39 -0
- package/dist/assets/cesium/Workers/chunk-X4SU25DT.js +302 -0
- package/dist/assets/cesium/Workers/chunk-XTY7B2N6.js +2716 -0
- package/dist/assets/cesium/Workers/chunk-XY7MGBKC.js +513 -0
- package/dist/assets/cesium/Workers/chunk-Z24VKNDO.js +834 -0
- package/dist/assets/cesium/Workers/chunk-ZA25DG4Y.js +684 -0
- package/dist/assets/cesium/Workers/chunk-ZFOBYDGF.js +73 -0
- package/dist/assets/cesium/Workers/combineGeometry.js +67 -1
- package/dist/assets/cesium/Workers/createBoxGeometry.js +57 -1
- package/dist/assets/cesium/Workers/createBoxOutlineGeometry.js +234 -1
- package/dist/assets/cesium/Workers/createCircleGeometry.js +196 -1
- package/dist/assets/cesium/Workers/createCircleOutlineGeometry.js +146 -1
- package/dist/assets/cesium/Workers/createCoplanarPolygonGeometry.js +506 -1
- package/dist/assets/cesium/Workers/createCoplanarPolygonOutlineGeometry.js +224 -1
- package/dist/assets/cesium/Workers/createCorridorGeometry.js +1262 -1
- package/dist/assets/cesium/Workers/createCorridorOutlineGeometry.js +567 -1
- package/dist/assets/cesium/Workers/createCylinderGeometry.js +59 -1
- package/dist/assets/cesium/Workers/createCylinderOutlineGeometry.js +231 -1
- package/dist/assets/cesium/Workers/createEllipseGeometry.js +70 -1
- package/dist/assets/cesium/Workers/createEllipseOutlineGeometry.js +63 -1
- package/dist/assets/cesium/Workers/createEllipsoidGeometry.js +58 -1
- package/dist/assets/cesium/Workers/createEllipsoidOutlineGeometry.js +60 -1
- package/dist/assets/cesium/Workers/createFrustumGeometry.js +57 -1
- package/dist/assets/cesium/Workers/createFrustumOutlineGeometry.js +234 -1
- package/dist/assets/cesium/Workers/createGeometry.js +150 -1
- package/dist/assets/cesium/Workers/createGroundPolylineGeometry.js +1607 -1
- package/dist/assets/cesium/Workers/createPlaneGeometry.js +223 -1
- package/dist/assets/cesium/Workers/createPlaneOutlineGeometry.js +123 -1
- package/dist/assets/cesium/Workers/createPolygonGeometry.js +1134 -1
- package/dist/assets/cesium/Workers/createPolygonOutlineGeometry.js +542 -1
- package/dist/assets/cesium/Workers/createPolylineGeometry.js +495 -1
- package/dist/assets/cesium/Workers/createPolylineVolumeGeometry.js +379 -1
- package/dist/assets/cesium/Workers/createPolylineVolumeOutlineGeometry.js +277 -1
- package/dist/assets/cesium/Workers/createRectangleGeometry.js +1273 -1
- package/dist/assets/cesium/Workers/createRectangleOutlineGeometry.js +480 -1
- package/dist/assets/cesium/Workers/createSimplePolylineGeometry.js +399 -1
- package/dist/assets/cesium/Workers/createSphereGeometry.js +117 -1
- package/dist/assets/cesium/Workers/createSphereOutlineGeometry.js +117 -1
- package/dist/assets/cesium/Workers/createTaskProcessorWorker.js +32 -1
- package/dist/assets/cesium/Workers/createVectorTileClampedPolylines.js +492 -1
- package/dist/assets/cesium/Workers/createVectorTileGeometries.js +386 -1
- package/dist/assets/cesium/Workers/createVectorTilePoints.js +112 -1
- package/dist/assets/cesium/Workers/createVectorTilePolygons.js +384 -1
- package/dist/assets/cesium/Workers/createVectorTilePolylines.js +262 -1
- package/dist/assets/cesium/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +568 -1
- package/dist/assets/cesium/Workers/createVerticesFromHeightmap.js +2277 -3
- package/dist/assets/cesium/Workers/createVerticesFromQuantizedTerrainMesh.js +745 -1
- package/dist/assets/cesium/Workers/createWallGeometry.js +489 -1
- package/dist/assets/cesium/Workers/createWallOutlineGeometry.js +337 -1
- package/dist/assets/cesium/Workers/decodeDraco.js +369 -1
- package/dist/assets/cesium/Workers/decodeGoogleEarthEnterprisePacket.js +2650 -1
- package/dist/assets/cesium/Workers/decodeI3S.js +835 -0
- package/dist/assets/cesium/Workers/transcodeKTX2.js +3425 -1
- package/dist/assets/cesium/Workers/transferTypedArrayTest.js +41 -1
- package/dist/assets/cesium/Workers/upsampleQuantizedTerrainMesh.js +818 -1
- package/dist/assets/cesium.4137c8.js +164897 -0
- package/dist/assets/cesium.js +1 -1
- package/dist/assets/core.306872.js +19286 -0
- package/dist/assets/core.js +1 -1
- package/dist/assets/favicon-128.4c4ce5.png +0 -0
- package/dist/assets/favicon-180.5b99c0.png +0 -0
- package/dist/assets/favicon-192.0e205e.png +0 -0
- package/dist/assets/favicon-32.6b9add.png +0 -0
- package/dist/assets/favicon.d5ec97.svg +10 -0
- package/dist/assets/font/OFL.txt +93 -0
- package/dist/assets/font/TitilliumWeb-Regular.9ca076.woff2 +0 -0
- package/dist/assets/index-cfed33b1.js +1 -0
- package/dist/assets/ol.328bbf.js +60117 -0
- package/dist/assets/ol.js +1 -1
- package/dist/assets/style/icon-marker-blue.534e37.png +0 -0
- package/dist/assets/style/icon-marker-green.0b6a92.png +0 -0
- package/dist/assets/style/icon-marker-o-blue.7b6d62.png +0 -0
- package/dist/assets/style/icon-marker-o-green.c863c0.png +0 -0
- package/dist/assets/style/icon-marker-o-red.93ff58.png +0 -0
- package/dist/assets/style/icon-marker-o.036477.png +0 -0
- package/dist/assets/style/icon-marker-red.313d03.png +0 -0
- package/dist/assets/style/icon-marker.70960f.png +0 -0
- package/dist/assets/style/icon-pin-blue.7be369.png +0 -0
- package/dist/assets/style/icon-pin-green.cbb935.png +0 -0
- package/dist/assets/style/icon-pin-red.3f25b2.png +0 -0
- package/dist/assets/style/icon-pin.b7ce77.png +0 -0
- package/dist/assets/ui.e84ce9.css +5 -0
- package/dist/assets/ui.e84ce9.js +16488 -0
- package/dist/assets/ui.js +1 -1
- package/dist/assets/vue.1c8696.js +4911 -0
- package/dist/assets/vue.js +5 -1
- package/dist/assets/vuetify.008fac.css +5 -0
- package/dist/assets/vuetify.008fac.js +21262 -0
- package/dist/assets/vuetify.js +5 -2
- package/dist/index.html +90 -8
- package/index.html +111 -0
- package/index.js +203 -18
- package/lib/cesium.js +1 -1
- package/lib/core.js +1 -1
- package/lib/olLib.js +861 -843
- package/lib/ui.js +1 -1
- package/lib/vue.js +2 -1
- package/lib/vuetify.js +2 -2
- package/package.json +53 -34
- package/plugins/.eslintrc +9 -0
- package/plugins/@vcmap-show-case/README.md +28 -0
- package/plugins/@vcmap-show-case/buttons-example/README.md +4 -0
- package/plugins/@vcmap-show-case/buttons-example/package.json +5 -0
- package/plugins/@vcmap-show-case/buttons-example/src/ButtonsExample.vue +282 -0
- package/plugins/@vcmap-show-case/buttons-example/src/index.js +51 -0
- package/plugins/@vcmap-show-case/category-tester/README.md +3 -0
- package/plugins/@vcmap-show-case/category-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/category-tester/src/CategoriesExample.vue +135 -0
- package/plugins/@vcmap-show-case/category-tester/src/CollectionComponentOptions.vue +209 -0
- package/plugins/@vcmap-show-case/category-tester/src/index.js +73 -0
- package/plugins/@vcmap-show-case/collection-manager-example/README.md +3 -0
- package/plugins/@vcmap-show-case/collection-manager-example/package.json +5 -0
- package/plugins/@vcmap-show-case/collection-manager-example/src/CollectionManagerExample.vue +182 -0
- package/plugins/@vcmap-show-case/collection-manager-example/src/index.js +79 -0
- package/plugins/@vcmap-show-case/config-editor/README.md +3 -0
- package/plugins/@vcmap-show-case/config-editor/package.json +5 -0
- package/plugins/@vcmap-show-case/config-editor/src/ConfigEditor.vue +62 -0
- package/plugins/@vcmap-show-case/config-editor/src/index.js +49 -0
- package/plugins/@vcmap-show-case/context-menu-tester/README.md +3 -0
- package/plugins/@vcmap-show-case/context-menu-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/context-menu-tester/src/index.js +41 -0
- package/plugins/@vcmap-show-case/form-inputs-example/README.md +4 -0
- package/plugins/@vcmap-show-case/form-inputs-example/config.json +5 -0
- package/plugins/@vcmap-show-case/form-inputs-example/package.json +5 -0
- package/plugins/@vcmap-show-case/form-inputs-example/src/FormInputsExample.vue +516 -0
- package/plugins/@vcmap-show-case/form-inputs-example/src/exampleActions.js +36 -0
- package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example/src}/index.js +123 -39
- package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example/src}/validation.js +14 -2
- package/plugins/@vcmap-show-case/hello-world/README.md +31 -0
- package/plugins/@vcmap-show-case/hello-world/package.json +6 -0
- package/plugins/@vcmap-show-case/hello-world/plugin-assets/vcs_logo.png +0 -0
- package/plugins/@vcmap-show-case/hello-world/src/defaultOptions.js +4 -0
- package/plugins/@vcmap-show-case/hello-world/src/helloWorld.vue +69 -0
- package/plugins/@vcmap-show-case/hello-world/src/index.js +142 -0
- package/plugins/@vcmap-show-case/hello-world/tests/helloWorld.spec.js +53 -0
- package/plugins/@vcmap-show-case/icons-example/README.md +5 -0
- package/plugins/@vcmap-show-case/icons-example/package.json +5 -0
- package/plugins/@vcmap-show-case/icons-example/src/AllIconsComponent.vue +51 -0
- package/plugins/@vcmap-show-case/icons-example/src/index.js +46 -0
- package/plugins/@vcmap-show-case/list-example/README.md +3 -0
- package/plugins/@vcmap-show-case/list-example/package.json +5 -0
- package/plugins/@vcmap-show-case/list-example/src/ListExample.vue +411 -0
- package/plugins/@vcmap-show-case/list-example/src/index.js +46 -0
- package/plugins/@vcmap-show-case/notifier-tester/README.md +3 -0
- package/plugins/@vcmap-show-case/notifier-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/notifier-tester/src/NotifierTester.vue +82 -0
- package/plugins/@vcmap-show-case/notifier-tester/src/index.js +42 -0
- package/plugins/@vcmap-show-case/plugin-editors/README.md +4 -0
- package/plugins/@vcmap-show-case/plugin-editors/package.json +5 -0
- package/plugins/@vcmap-show-case/plugin-editors/src/PluginEditors.vue +119 -0
- package/plugins/@vcmap-show-case/plugin-editors/src/index.js +41 -0
- package/plugins/@vcmap-show-case/project-selector/README.md +25 -0
- package/plugins/@vcmap-show-case/project-selector/config.json +15 -0
- package/plugins/@vcmap-show-case/project-selector/package.json +13 -0
- package/plugins/@vcmap-show-case/project-selector/src/ModulesListComponent.vue +65 -0
- package/plugins/@vcmap-show-case/project-selector/src/ProjectSelectorComponent.vue +102 -0
- package/plugins/@vcmap-show-case/project-selector/src/de.json +10 -0
- package/plugins/@vcmap-show-case/project-selector/src/en.json +10 -0
- package/plugins/@vcmap-show-case/project-selector/src/index.js +269 -0
- package/plugins/@vcmap-show-case/simple-graph/README.md +71 -0
- package/plugins/@vcmap-show-case/simple-graph/package.json +11 -0
- package/plugins/@vcmap-show-case/simple-graph/src/SimpleGraphComponent.vue +59 -0
- package/plugins/@vcmap-show-case/simple-graph/src/index.js +17 -0
- package/plugins/@vcmap-show-case/simple-graph/src/simpleGraphView.js +78 -0
- package/plugins/@vcmap-show-case/style-input-example/README.md +4 -0
- package/plugins/@vcmap-show-case/style-input-example/package.json +5 -0
- package/plugins/@vcmap-show-case/style-input-example/src/StyleExample.vue +190 -0
- package/plugins/@vcmap-show-case/style-input-example/src/index.js +42 -0
- package/plugins/@vcmap-show-case/switch-map-callback-example/README.md +21 -0
- package/plugins/@vcmap-show-case/switch-map-callback-example/config.json +3 -0
- package/plugins/@vcmap-show-case/switch-map-callback-example/package.json +5 -0
- package/plugins/@vcmap-show-case/switch-map-callback-example/src/index.js +34 -0
- package/plugins/@vcmap-show-case/switch-map-callback-example/src/switchMapCallback.js +47 -0
- package/plugins/@vcmap-show-case/table-example/README.md +3 -0
- package/plugins/@vcmap-show-case/table-example/package.json +5 -0
- package/plugins/@vcmap-show-case/table-example/src/DataTableExample.vue +182 -0
- package/plugins/@vcmap-show-case/table-example/src/index.js +49 -0
- package/plugins/@vcmap-show-case/textfields-example/README.md +3 -0
- package/plugins/@vcmap-show-case/textfields-example/package.json +5 -0
- package/plugins/{example/mySuperComponent.vue → @vcmap-show-case/textfields-example/src/TextfieldsExample.vue} +13 -31
- package/plugins/@vcmap-show-case/textfields-example/src/index.js +64 -0
- package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/README.md +5 -3
- package/plugins/@vcmap-show-case/theme-changer/config.json +69 -0
- package/plugins/@vcmap-show-case/theme-changer/package.json +11 -0
- package/plugins/{@vcmap/theme-changer → @vcmap-show-case/theme-changer/src}/ThemeChangerComponent.vue +36 -8
- package/plugins/{@vcmap/theme-changer → @vcmap-show-case/theme-changer/src}/index.js +20 -14
- package/plugins/@vcmap-show-case/vector-properties-example/package.json +5 -0
- package/plugins/@vcmap-show-case/vector-properties-example/src/VectorPropertiesExample.vue +128 -0
- package/plugins/@vcmap-show-case/vector-properties-example/src/index.js +40 -0
- package/plugins/@vcmap-show-case/window-tester/README.md +3 -0
- package/plugins/@vcmap-show-case/window-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/window-tester/src/EmptyComponent.vue +18 -0
- package/plugins/@vcmap-show-case/window-tester/src/MyCustomHeader.vue +31 -0
- package/plugins/@vcmap-show-case/window-tester/src/WindowExample.vue +185 -0
- package/plugins/@vcmap-show-case/window-tester/src/WindowExampleContent.vue +18 -0
- package/plugins/@vcmap-show-case/window-tester/src/WindowExampleToggleChild.vue +45 -0
- package/plugins/@vcmap-show-case/window-tester/src/index.js +80 -0
- package/plugins/@vcmap-show-case/window-tester/src/toolboxData.js +288 -0
- package/plugins/@vcmap-show-case/wizard-example/README.md +3 -0
- package/plugins/@vcmap-show-case/wizard-example/package.json +5 -0
- package/plugins/@vcmap-show-case/wizard-example/src/WizardExample.vue +127 -0
- package/plugins/@vcmap-show-case/wizard-example/src/index.js +53 -0
- package/plugins/package.json +9 -2
- package/public/assets/@mdi/font/LICENSE +20 -0
- package/public/assets/@mdi/font/css/materialdesignicons.css.map +16 -0
- package/public/assets/@mdi/font/css/materialdesignicons.min.css +3 -0
- package/public/assets/@mdi/font/fonts/materialdesignicons-webfont.woff2 +0 -0
- package/public/assets/favicon-128.png +0 -0
- package/public/assets/favicon-180.png +0 -0
- package/public/assets/favicon-192.png +0 -0
- package/public/assets/favicon-32.png +0 -0
- package/public/assets/favicon.svg +10 -0
- package/public/assets/font/OFL.txt +93 -0
- package/public/assets/font/TitilliumWeb-Regular.woff2 +0 -0
- package/public/assets/style/icon-marker-blue.png +0 -0
- package/public/assets/style/icon-marker-green.png +0 -0
- package/public/assets/style/icon-marker-o-blue.png +0 -0
- package/public/assets/style/icon-marker-o-green.png +0 -0
- package/public/assets/style/icon-marker-o-red.png +0 -0
- package/public/assets/style/icon-marker-o.png +0 -0
- package/public/assets/style/icon-marker-red.png +0 -0
- package/public/assets/style/icon-marker.png +0 -0
- package/public/assets/style/icon-pin-blue.png +0 -0
- package/public/assets/style/icon-pin-green.png +0 -0
- package/public/assets/style/icon-pin-red.png +0 -0
- package/public/assets/style/icon-pin.png +0 -0
- package/src/actions/StyleSelector.vue +121 -0
- package/src/actions/actionHelper.js +186 -50
- package/src/actions/stateRefAction.js +2 -3
- package/src/application/VcsApp.vue +539 -93
- package/src/application/VcsAppWrapper.vue +32 -0
- package/src/application/VcsAttributions.vue +83 -0
- package/src/application/VcsAttributionsFooter.vue +83 -0
- package/src/application/VcsMap.vue +22 -5
- package/src/application/VcsNavbar.vue +217 -0
- package/src/application/VcsSettings.vue +98 -0
- package/src/application/attributionsHelper.js +162 -0
- package/src/callback/activateLayersCallback.js +54 -0
- package/src/callback/applyLayerStyleCallback.js +63 -0
- package/src/callback/deactivateLayersCallback.js +54 -0
- package/src/callback/goToViewpointCallback.js +54 -0
- package/src/callback/vcsCallback.js +66 -0
- package/src/components/ImageElementInjector.vue +24 -0
- package/src/components/buttons/VcsActionButtonList.vue +129 -0
- package/src/components/buttons/VcsButton.vue +151 -0
- package/src/components/buttons/VcsFormButton.vue +178 -0
- package/src/components/buttons/VcsToolButton.vue +161 -0
- package/src/components/form-inputs-controls/VcsCheckbox.vue +115 -0
- package/src/components/form-inputs-controls/VcsChipArrayInput.vue +290 -0
- package/src/components/form-inputs-controls/VcsDatePicker.vue +156 -0
- package/src/components/form-inputs-controls/VcsFormSection.vue +150 -0
- package/src/components/form-inputs-controls/VcsLabel.vue +56 -0
- package/src/components/form-inputs-controls/VcsRadio.vue +149 -0
- package/src/components/form-inputs-controls/VcsRadioGrid.vue +175 -0
- package/src/components/form-inputs-controls/VcsSelect.vue +211 -0
- package/src/components/form-inputs-controls/VcsSlider.vue +73 -0
- package/src/components/form-inputs-controls/VcsTextArea.vue +180 -0
- package/src/components/form-inputs-controls/VcsTextField.vue +298 -0
- package/src/components/form-inputs-controls/VcsWizard.vue +137 -0
- package/src/components/form-inputs-controls/VcsWizardStep.vue +161 -0
- package/src/components/form-inputs-controls/composables.js +31 -0
- package/src/components/form-output/VcsFormattedNumber.vue +103 -0
- package/src/components/icons/+all.js +463 -0
- package/src/components/icons/2DAreaIcon.vue +58 -0
- package/src/components/icons/2DDistanceIcon.vue +24 -0
- package/src/components/icons/3DAreaIcon.vue +58 -0
- package/src/components/icons/3DDistanceIcon.vue +24 -0
- package/src/components/icons/3DHeightIcon.vue +24 -0
- package/src/components/icons/AngleIcon.vue +16 -0
- package/src/components/icons/AssociationsIcon.vue +37 -0
- package/src/components/icons/AxisIcon.vue +35 -0
- package/src/components/icons/BoundingBoxIcon.vue +38 -0
- package/src/components/icons/CheckboxCheckedIcon.vue +12 -0
- package/src/components/icons/CheckboxIcon.vue +21 -0
- package/src/components/icons/CheckboxIndeterminateIcon.vue +10 -0
- package/src/components/icons/CircleIcon.vue +25 -0
- package/src/components/icons/ClippingHorizontalIcon.vue +18 -0
- package/src/components/icons/ClippingIcon.vue +17 -0
- package/src/components/icons/ClippingVerticalIcon.vue +18 -0
- package/src/components/icons/ColorPickerIcon.vue +17 -0
- package/src/components/icons/ColorSwatchIcon.vue +21 -0
- package/src/components/icons/CommentIcon.vue +19 -0
- package/src/components/icons/CompassIcon.vue +24 -0
- package/src/components/icons/ComponentsIcon.vue +18 -0
- package/src/components/icons/ConeIcon.vue +30 -0
- package/src/components/icons/DimensionsHouseIcon.vue +20 -0
- package/src/components/icons/EditIcon.vue +17 -0
- package/src/components/icons/EditVerticesIcon.vue +35 -0
- package/src/components/icons/ElevationProfileIcon.vue +104 -0
- package/src/components/icons/ExportAreaIcon.vue +17 -0
- package/src/components/icons/ExportFlightIcon.vue +17 -0
- package/src/components/icons/ExportIcon.vue +24 -0
- package/src/components/icons/ExternalLinkIcon.vue +23 -0
- package/src/components/icons/EyeIcon.vue +17 -0
- package/src/components/icons/FastForwardIcon.vue +17 -0
- package/src/components/icons/FilterIcon.vue +18 -0
- package/src/components/icons/GlobalTerrainIcon.vue +19 -0
- package/src/components/icons/GlobeNatureIcon.vue +17 -0
- package/src/components/icons/GroundIcon.vue +27 -0
- package/src/components/icons/HealthCareIndustriesIcon.vue +113 -0
- package/src/components/icons/HelpIcon.vue +17 -0
- package/src/components/icons/HideIcon.vue +25 -0
- package/src/components/icons/HomePointIcon.vue +17 -0
- package/src/components/icons/HospitalsIcon.vue +223 -0
- package/src/components/icons/HouseIcon.vue +32 -0
- package/src/components/icons/ImportIcon.vue +18 -0
- package/src/components/icons/InfoIcon.vue +24 -0
- package/src/components/icons/KebabIcon.vue +38 -0
- package/src/components/icons/LabelIcon.vue +23 -0
- package/src/components/icons/LayersIcon.vue +28 -0
- package/src/components/icons/LegendIcon.vue +24 -0
- package/src/components/icons/LineIcon.vue +22 -0
- package/src/components/icons/LinkIcon.vue +17 -0
- package/src/components/icons/LogoutIcon.vue +17 -0
- package/src/components/icons/MapIcon.vue +18 -0
- package/src/components/icons/MenuIcon.vue +36 -0
- package/src/components/icons/MinusIcon.vue +18 -0
- package/src/components/icons/ObjectAttributeIcon.vue +18 -0
- package/src/components/icons/ObjectSelectIcon.vue +18 -0
- package/src/components/icons/ObliqueViewIcon.vue +19 -0
- package/src/components/icons/PdfIcon.vue +19 -0
- package/src/components/icons/PedestrianIcon.vue +17 -0
- package/src/components/icons/PenIcon.vue +16 -0
- package/src/components/icons/PlayCircleIcon.vue +20 -0
- package/src/components/icons/PlusIcon.vue +18 -0
- package/src/components/icons/PoiIcon.vue +23 -0
- package/src/components/icons/PointIcon.vue +40 -0
- package/src/components/icons/PointSelectIcon.vue +18 -0
- package/src/components/icons/PresentationModeIcon.vue +17 -0
- package/src/components/icons/ProgressIcon.vue +26 -0
- package/src/components/icons/QueryIcon.vue +39 -0
- package/src/components/icons/RectangleIcon.vue +24 -0
- package/src/components/icons/ReturnIcon.vue +17 -0
- package/src/components/icons/RewindIcon.vue +16 -0
- package/src/components/icons/RotateLeftIcon.vue +17 -0
- package/src/components/icons/RotateRightIcon.vue +17 -0
- package/src/components/icons/ScreenshotIcon.vue +53 -0
- package/src/components/icons/SearchIcon.vue +17 -0
- package/src/components/icons/ShadowIcon.vue +18 -0
- package/src/components/icons/ShapesIcon.vue +35 -0
- package/src/components/icons/ShareIcon.vue +22 -0
- package/src/components/icons/SimpleCircleFilledIcon.vue +18 -0
- package/src/components/icons/SimpleCircleHalfFilledIcon.vue +16 -0
- package/src/components/icons/SimpleCircleOutlinedIcon.vue +13 -0
- package/src/components/icons/SkipNextIcon.vue +18 -0
- package/src/components/icons/SkipPreviousIcon.vue +18 -0
- package/src/components/icons/SplitViewIcon.vue +19 -0
- package/src/components/icons/TerrainBoxIcon.vue +19 -0
- package/src/components/icons/TextStyleIcon.vue +17 -0
- package/src/components/icons/ThreeDimensionsIcon.vue +17 -0
- package/src/components/icons/ToolsIcon.vue +16 -0
- package/src/components/icons/TouchIcon.vue +18 -0
- package/src/components/icons/TrashCanIcon.vue +18 -0
- package/src/components/icons/TriangleIcon.vue +16 -0
- package/src/components/icons/TwoDimensionsIcon.vue +18 -0
- package/src/components/icons/UploadIcon.vue +17 -0
- package/src/components/icons/UserProfileIcon.vue +17 -0
- package/src/components/icons/UserShareIcon.vue +16 -0
- package/src/components/icons/VideoRecorderIcon.vue +23 -0
- package/src/components/icons/ViewpointFlightIcon.vue +28 -0
- package/src/components/icons/ViewpointIcon.vue +28 -0
- package/src/components/icons/Viewshed360Icon.vue +18 -0
- package/src/components/icons/ViewshedConeIcon.vue +17 -0
- package/src/components/icons/ViewshedIcon.vue +18 -0
- package/src/components/icons/WalkingIcon.vue +17 -0
- package/src/components/icons/WallIcon.vue +22 -0
- package/src/components/icons/WandIcon.vue +123 -0
- package/src/components/lists/VcsActionList.vue +132 -0
- package/src/components/lists/VcsList.vue +590 -0
- package/src/components/lists/VcsTreeview.vue +112 -0
- package/src/components/lists/VcsTreeviewLeaf.vue +81 -0
- package/src/components/lists/VcsTreeviewSearchbar.vue +148 -0
- package/src/components/notification/VcsBadge.vue +29 -0
- package/src/components/notification/VcsHelp.vue +39 -0
- package/src/components/notification/VcsTooltip.vue +160 -0
- package/src/components/notification/validation.js +19 -0
- package/src/components/plugins/AbstractConfigEditor.vue +84 -0
- package/src/components/style/MenuWrapper.vue +140 -0
- package/src/components/style/VcsFillMenu.vue +61 -0
- package/src/components/style/VcsFillSelector.vue +45 -0
- package/src/components/style/VcsImageMenu.vue +83 -0
- package/src/components/style/VcsImageSelector.vue +577 -0
- package/src/components/style/VcsStrokeMenu.vue +73 -0
- package/src/components/style/VcsStrokeSelector.vue +88 -0
- package/src/components/style/VcsTextMenu.vue +81 -0
- package/src/components/style/VcsTextSelector.vue +269 -0
- package/src/components/style/VcsVectorStyleComponent.vue +114 -0
- package/src/components/style/composables.js +84 -0
- package/src/components/tables/VcsDataTable.vue +475 -0
- package/src/components/tables/VcsTable.vue +145 -0
- package/src/components/vector-properties/VcsVectorPropertiesComponent.vue +778 -0
- package/src/components/vector-properties/composables.js +93 -0
- package/src/contentTree/LayerTree.vue +19 -15
- package/src/contentTree/contentTreeCollection.js +114 -42
- package/src/contentTree/contentTreeItem.js +109 -43
- package/src/contentTree/groupContentTreeItem.js +46 -23
- package/src/contentTree/layerContentTreeItem.js +54 -23
- package/src/contentTree/layerGroupContentTreeItem.js +58 -26
- package/src/contentTree/nodeContentTreeItem.js +19 -8
- package/src/contentTree/obliqueCollectionContentTreeItem.js +51 -22
- package/src/contentTree/subContentTreeItem.js +14 -5
- package/src/contentTree/vcsObjectContentTreeItem.js +27 -16
- package/src/contentTree/viewpointContentTreeItem.js +121 -0
- package/src/downloadHelper.js +52 -0
- package/src/featureInfo/AddressBalloonComponent.vue +58 -0
- package/src/featureInfo/BalloonComponent.vue +193 -0
- package/src/featureInfo/abstractFeatureInfoView.js +346 -0
- package/src/featureInfo/addressBalloonFeatureInfoView.js +130 -0
- package/src/featureInfo/balloonFeatureInfoView.js +159 -0
- package/src/featureInfo/balloonHelper.js +172 -0
- package/src/featureInfo/featureInfo.js +525 -0
- package/src/featureInfo/featureInfoInteraction.js +48 -0
- package/src/featureInfo/iframeFeatureInfoView.js +97 -0
- package/src/featureInfo/tableFeatureInfoView.js +120 -0
- package/src/i18n/de.js +195 -0
- package/src/i18n/en.js +195 -0
- package/src/i18n/i18nCollection.js +137 -0
- package/src/init.js +121 -36
- package/src/legend/StyleLegendItem.vue +176 -0
- package/src/legend/VcsLegend.vue +140 -0
- package/src/legend/legendHelper.js +204 -0
- package/src/logo-mobile.svg +9 -0
- package/src/logo.svg +26 -0
- package/src/manager/buttonManager.js +30 -61
- package/src/manager/collectionManager/CollectionComponent.vue +140 -0
- package/src/manager/collectionManager/CollectionComponentList.vue +77 -0
- package/src/manager/collectionManager/CollectionComponentProvider.vue +39 -0
- package/src/manager/collectionManager/CollectionManager.vue +62 -0
- package/src/manager/collectionManager/categoryManager.js +83 -0
- package/src/manager/collectionManager/collectionComponent.js +470 -0
- package/src/manager/collectionManager/collectionManager.js +432 -0
- package/src/manager/contextMenu/ContextMenuComponent.vue +43 -0
- package/src/manager/contextMenu/contextMenuInteraction.js +47 -0
- package/src/manager/contextMenu/contextMenuManager.js +220 -0
- package/src/manager/navbarManager.js +115 -0
- package/src/manager/toolbox/GroupToolboxComponent.vue +128 -0
- package/src/manager/toolbox/SelectToolboxComponent.vue +144 -0
- package/src/manager/toolbox/ToolboxManager.vue +139 -74
- package/src/manager/toolbox/toolboxManager.js +371 -0
- package/src/manager/window/WindowComponent.vue +105 -85
- package/src/manager/window/WindowComponentHeader.vue +116 -25
- package/src/manager/window/WindowManager.vue +133 -50
- package/src/manager/window/windowHelper.js +465 -0
- package/src/manager/window/windowManager.js +297 -91
- package/src/navigation/{mapNavCompass.vue → MapNavCompass.vue} +31 -11
- package/src/navigation/MapNavigation.vue +291 -0
- package/src/navigation/ObliqueRotation.vue +69 -0
- package/src/navigation/{orientationToolsButton.vue → OrientationToolsButton.vue} +14 -13
- package/src/navigation/{tiltSlider.vue → TiltSlider.vue} +40 -17
- package/src/navigation/VcsCompass.vue +69 -0
- package/src/navigation/VcsZoomButton.vue +52 -0
- package/src/navigation/overviewMap.js +142 -104
- package/src/navigation/overviewMapClickedInteraction.js +6 -1
- package/src/notifier/NotifierComponent.vue +86 -0
- package/src/notifier/notifier.js +129 -0
- package/src/pluginHelper.js +148 -20
- package/src/search/ResultItem.vue +83 -0
- package/src/search/ResultsComponent.vue +103 -0
- package/src/search/SearchComponent.vue +116 -0
- package/src/search/search.js +342 -0
- package/src/setup.js +9 -10
- package/src/state.js +272 -0
- package/src/styles/_theming.scss +69 -11
- package/src/styles/_typography.scss +3 -6
- package/src/styles/main.scss +12 -0
- package/src/styles/shades.scss +4 -0
- package/src/styles/utils/_border.scss +1 -1
- package/src/styles/utils/_cursor.scss +4 -0
- package/src/styles/utils/_display.scss +1 -1
- package/src/styles/variables.scss +138 -0
- package/src/styles/vcsFont.scss +2 -0
- package/src/styles/vcsGrid.scss +13 -0
- package/src/uiConfig.js +83 -0
- package/src/vcsUiApp.js +510 -69
- package/src/vuePlugins/i18n.js +51 -13
- package/src/vuePlugins/vuetify.js +104 -43
- package/config/berlin.config.json +0 -529
- package/dist/assets/cesium/Workers/ArcType-fc72c06c.js +0 -1
- package/dist/assets/cesium/Workers/AttributeCompression-80665726.js +0 -1
- package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-a655a4bc.js +0 -1
- package/dist/assets/cesium/Workers/BoundingRectangle-c3b79029.js +0 -1
- package/dist/assets/cesium/Workers/BoxGeometry-f8f9c981.js +0 -1
- package/dist/assets/cesium/Workers/Color-de06a177.js +0 -1
- package/dist/assets/cesium/Workers/ComponentDatatype-a15c9a19.js +0 -1
- package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-48cdc26d.js +0 -1
- package/dist/assets/cesium/Workers/CorridorGeometryLibrary-ddc027d3.js +0 -1
- package/dist/assets/cesium/Workers/CylinderGeometry-82a8cbe6.js +0 -1
- package/dist/assets/cesium/Workers/CylinderGeometryLibrary-76cda53e.js +0 -1
- package/dist/assets/cesium/Workers/EllipseGeometry-32d55454.js +0 -1
- package/dist/assets/cesium/Workers/EllipseGeometryLibrary-b2ae188a.js +0 -1
- package/dist/assets/cesium/Workers/EllipseOutlineGeometry-f05a5a27.js +0 -1
- package/dist/assets/cesium/Workers/EllipsoidGeodesic-19e75e11.js +0 -1
- package/dist/assets/cesium/Workers/EllipsoidGeometry-7c99fc81.js +0 -1
- package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-21c243df.js +0 -1
- package/dist/assets/cesium/Workers/EllipsoidRhumbLine-6145377b.js +0 -1
- package/dist/assets/cesium/Workers/EllipsoidTangentPlane-a01286f6.js +0 -1
- package/dist/assets/cesium/Workers/EncodedCartesian3-d9f5c4a4.js +0 -1
- package/dist/assets/cesium/Workers/FrustumGeometry-17776af8.js +0 -1
- package/dist/assets/cesium/Workers/GeometryAttribute-89a520b9.js +0 -1
- package/dist/assets/cesium/Workers/GeometryAttributes-32b29525.js +0 -1
- package/dist/assets/cesium/Workers/GeometryInstance-4fbf16ba.js +0 -1
- package/dist/assets/cesium/Workers/GeometryOffsetAttribute-8c5e10db.js +0 -1
- package/dist/assets/cesium/Workers/GeometryPipeline-309fad76.js +0 -1
- package/dist/assets/cesium/Workers/IndexDatatype-f1dcdf35.js +0 -1
- package/dist/assets/cesium/Workers/IntersectionTests-58aa8f80.js +0 -1
- package/dist/assets/cesium/Workers/Matrix2-47e98d76.js +0 -1
- package/dist/assets/cesium/Workers/OrientedBoundingBox-fcb5b750.js +0 -1
- package/dist/assets/cesium/Workers/Plane-3f01019d.js +0 -1
- package/dist/assets/cesium/Workers/PolygonGeometryLibrary-0b29eb16.js +0 -1
- package/dist/assets/cesium/Workers/PolygonPipeline-a934c4dd.js +0 -1
- package/dist/assets/cesium/Workers/PolylinePipeline-8095c9bc.js +0 -1
- package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-67d12fff.js +0 -1
- package/dist/assets/cesium/Workers/PrimitivePipeline-980e44c5.js +0 -1
- package/dist/assets/cesium/Workers/RectangleGeometryLibrary-621c6de8.js +0 -1
- package/dist/assets/cesium/Workers/RuntimeError-8952249c.js +0 -1
- package/dist/assets/cesium/Workers/TerrainEncoding-f96552d5.js +0 -1
- package/dist/assets/cesium/Workers/Transforms-c8cb8f43.js +0 -39
- package/dist/assets/cesium/Workers/VertexFormat-a0b706b0.js +0 -1
- package/dist/assets/cesium/Workers/WallGeometryLibrary-c03d8479.js +0 -1
- package/dist/assets/cesium/Workers/WebGLConstants-508b9636.js +0 -1
- package/dist/assets/cesium/Workers/WebMercatorProjection-79b3214e.js +0 -1
- package/dist/assets/cesium/Workers/_commonjsHelpers-3aae1032-26891ab7.js +0 -1
- package/dist/assets/cesium/Workers/_rollup_plugin_ignore_empty_module_placeholder-57d574d0.js +0 -1
- package/dist/assets/cesium/Workers/arrayRemoveDuplicates-dc2f4046.js +0 -1
- package/dist/assets/cesium/Workers/cesiumWorkerBootstrapper.js +0 -6
- package/dist/assets/cesium/Workers/combine-3c023bda.js +0 -1
- package/dist/assets/cesium/Workers/defaultValue-81eec7ed.js +0 -1
- package/dist/assets/cesium.6b5bb6.js +0 -9105
- package/dist/assets/core.98f9bb.js +0 -4
- package/dist/assets/index.0be2842f.js +0 -1
- package/dist/assets/index.60dea538.css +0 -1
- package/dist/assets/ol.0561aa.js +0 -318
- package/dist/assets/ui.b7c1e3.css +0 -1
- package/dist/assets/ui.b7c1e3.js +0 -39
- package/dist/assets/uicomponents.682c5f.css +0 -1
- package/dist/assets/uicomponents.682c5f.js +0 -32
- package/dist/assets/uicomponents.js +0 -1
- package/dist/assets/vue-composition-api.f926fa.js +0 -14
- package/dist/assets/vue-composition-api.js +0 -2
- package/dist/assets/vue.ddcb6b.js +0 -9
- package/dist/assets/vuetify.d21163.css +0 -5
- package/dist/assets/vuetify.d21163.js +0 -48
- package/lib/uicomponents.js +0 -1
- package/lib/vue-composition-api.js +0 -2
- package/map.config.json +0 -35
- package/plugins/@vcmap/pluginExample/config.json +0 -6
- package/plugins/@vcmap/pluginExample/package.json +0 -7
- package/plugins/@vcmap/pluginExample/pluginExampleComponent.vue +0 -374
- package/plugins/@vcmap/project-selector/ContextsListComponent.vue +0 -62
- package/plugins/@vcmap/project-selector/ProjectSelectorComponent.vue +0 -81
- package/plugins/@vcmap/project-selector/README.md +0 -29
- package/plugins/@vcmap/project-selector/config.json +0 -15
- package/plugins/@vcmap/project-selector/index.js +0 -254
- package/plugins/@vcmap/project-selector/package.json +0 -15
- package/plugins/@vcmap/theme-changer/config.json +0 -69
- package/plugins/@vcmap/theme-changer/package.json +0 -12
- package/plugins/buttonExamples/ButtonExamples.vue +0 -190
- package/plugins/buttonExamples/index.js +0 -40
- package/plugins/categoryTest/Categories.vue +0 -145
- package/plugins/categoryTest/Category.vue +0 -114
- package/plugins/categoryTest/ItemEditor.vue +0 -13
- package/plugins/categoryTest/index.js +0 -41
- package/plugins/example/index.js +0 -56
- package/plugins/test/editor.vue +0 -63
- package/plugins/test/index.js +0 -93
- package/plugins/test/myCustomHeader.vue +0 -19
- package/plugins/test/toolbox-data.js +0 -49
- package/plugins/test/vcsContent.vue +0 -23
- package/plugins/test/windowManagerExample.vue +0 -144
- package/src/actions/styleSelector.vue +0 -90
- package/src/application/Navbar.vue +0 -118
- package/src/application/empty-cmp.vue +0 -6
- package/src/assets/logo.svg +0 -26
- package/src/contentTree/viewPointContentTreeItem.js +0 -107
- package/src/lang/de.js +0 -60
- package/src/lang/en.js +0 -53
- package/src/manager/toolbox/ToolboxMultiSelectButton.vue +0 -96
- package/src/manager/toolbox/ToolboxSingleSelectButton.vue +0 -98
- package/src/manager/toolbox/toolbox-manager.js +0 -203
- package/src/navigation/mapNavigation.vue +0 -201
- package/src/navigation/obliqueRotation.vue +0 -48
- package/src/navigation/vcsCompass.vue +0 -144
- package/src/navigation/vcsZoomButton.vue +0 -27
- package/start.js +0 -3
@@ -0,0 +1,52 @@
|
|
1
|
+
<template>
|
2
|
+
<div class="rounded vcs-navigation-zoom">
|
3
|
+
<div class="rounded inner">
|
4
|
+
<OrientationToolsButton
|
5
|
+
@click="$emit('zoom-in')"
|
6
|
+
icon="$vcsPlus"
|
7
|
+
tooltip="navigation.zoomInTooltip"
|
8
|
+
elevation="0"
|
9
|
+
/>
|
10
|
+
<OrientationToolsButton
|
11
|
+
@click="$emit('zoom-out')"
|
12
|
+
icon="$vcsMinus"
|
13
|
+
tooltip="navigation.zoomOutTooltip"
|
14
|
+
elevation="0"
|
15
|
+
/>
|
16
|
+
</div>
|
17
|
+
</div>
|
18
|
+
</template>
|
19
|
+
|
20
|
+
<script>
|
21
|
+
import OrientationToolsButton from './OrientationToolsButton.vue';
|
22
|
+
|
23
|
+
/**
|
24
|
+
* @description Zoom buttons rendered above each other.
|
25
|
+
* @vue-event {void} zoom-in - raised when zoom in is called
|
26
|
+
* @vue-event {void} zoom-out - raised when zoom out is called
|
27
|
+
*/
|
28
|
+
export default {
|
29
|
+
components: { OrientationToolsButton },
|
30
|
+
};
|
31
|
+
</script>
|
32
|
+
<style lang="scss" scoped>
|
33
|
+
.vcs-navigation-zoom {
|
34
|
+
box-shadow: rgba(0, 0, 0, 0.1) 0 2px 2px 0;
|
35
|
+
.inner {
|
36
|
+
box-shadow: rgba(0, 0, 0, 0.25) 0 0 10px 0 inset;
|
37
|
+
}
|
38
|
+
::v-deep {
|
39
|
+
.btn-orientation-tools {
|
40
|
+
&:first-child {
|
41
|
+
box-shadow: rgba(0, 0, 0, 0.25) -2px 2px 1px -2px,
|
42
|
+
rgba(0, 0, 0, 0.08) 1px 0 0 0, rgba(0, 0, 0, 0.05) -1px 1px 1px 1px !important;
|
43
|
+
}
|
44
|
+
&:last-child {
|
45
|
+
box-shadow: rgba(0, 0, 0, 0.25) -2px 3px 1px -2px,
|
46
|
+
rgba(0, 0, 0, 0.08) 1px 4px 2px 0,
|
47
|
+
rgba(0, 0, 0, 0.05) -1px 1px 1px 1px !important;
|
48
|
+
}
|
49
|
+
}
|
50
|
+
}
|
51
|
+
}
|
52
|
+
</style>
|
@@ -1,6 +1,5 @@
|
|
1
1
|
import {
|
2
2
|
OpenlayersMap,
|
3
|
-
CesiumMap,
|
4
3
|
ObliqueMap,
|
5
4
|
VectorLayer,
|
6
5
|
VectorStyleItem,
|
@@ -10,20 +9,26 @@ import {
|
|
10
9
|
DataState,
|
11
10
|
emptyStyle,
|
12
11
|
Extent,
|
13
|
-
|
12
|
+
Viewpoint,
|
14
13
|
deserializeLayer,
|
15
14
|
} from '@vcmap/core';
|
16
|
-
import Point from 'ol/geom/Point';
|
17
|
-
import Feature from 'ol/Feature';
|
18
|
-
import { Math as CesiumMath, Color } from '@vcmap/
|
15
|
+
import Point from 'ol/geom/Point.js';
|
16
|
+
import Feature from 'ol/Feature.js';
|
17
|
+
import { Math as CesiumMath, Color } from '@vcmap-cesium/engine';
|
19
18
|
import { unByKey } from 'ol/Observable.js';
|
20
19
|
import VectorSource from 'ol/source/Vector.js';
|
20
|
+
import { Icon } from 'ol/style.js';
|
21
21
|
import { WindowSlot } from '../manager/window/windowManager.js';
|
22
22
|
import OverviewMapClickedInteraction from './overviewMapClickedInteraction.js';
|
23
|
-
import {
|
23
|
+
import {
|
24
|
+
getDefaultPrimaryColor,
|
25
|
+
getColorByKey,
|
26
|
+
} from '../vuePlugins/vuetify.js';
|
24
27
|
import { vcsAppSymbol } from '../pluginHelper.js';
|
25
28
|
import VcsMap from '../application/VcsMap.vue';
|
26
29
|
|
30
|
+
export const overviewMapLayerSymbol = Symbol('overviewMapLayerSymbol');
|
31
|
+
|
27
32
|
/**
|
28
33
|
* @returns {WindowComponentOptions}
|
29
34
|
*/
|
@@ -35,16 +40,48 @@ export function getWindowComponentOptions() {
|
|
35
40
|
id: 'overview-map-container',
|
36
41
|
state: {
|
37
42
|
hideHeader: true,
|
43
|
+
classes: ['overview-map'],
|
38
44
|
},
|
39
45
|
position: {
|
40
46
|
right: '100px',
|
41
47
|
bottom: '25px',
|
42
|
-
width: '
|
43
|
-
height: '
|
48
|
+
width: '300px',
|
49
|
+
height: '240px',
|
44
50
|
},
|
45
51
|
};
|
46
52
|
}
|
47
53
|
|
54
|
+
/**
|
55
|
+
* @param {string} color
|
56
|
+
* @returns {import("ol/style/Icon").Options}
|
57
|
+
*/
|
58
|
+
function getCameraIcon(color) {
|
59
|
+
return {
|
60
|
+
src: `data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20xmlns%3Asvg%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22121.58616%22%20height%3D%2274.204994%22%20viewBox%3D%220%200%2032.169671%2019.633405%22%20version%3D%221.1%22%20id%3D%22svg216%22%3E%3Cdefs%20id%3D%22defs213%22%3E%3ClinearGradient%20id%3D%221-0%22%20x1%3D%2240.529999%22%20y1%3D%2248.970001%22%20x2%3D%2240.529999%22%20y2%3D%220.25%22%20gradientUnits%3D%22userSpaceOnUse%22%3E%3Cstop%20offset%3D%220%22%20stop-color%3D%22${encodeURIComponent(
|
61
|
+
color,
|
62
|
+
)}%22%20id%3D%22stop399%22%2F%3E%3Cstop%20offset%3D%22.46%22%20stop-color%3D%22${encodeURIComponent(
|
63
|
+
color,
|
64
|
+
)}%22%20stop-opacity%3D%22.60%22%20id%3D%22stop401%22%2F%3E%3Cstop%20offset%3D%22.65%22%20stop-color%3D%22${encodeURIComponent(
|
65
|
+
color,
|
66
|
+
)}%22%20stop-opacity%3D%22.40%22%20id%3D%22stop403%22%2F%3E%3Cstop%20offset%3D%22.83%22%20stop-color%3D%22${encodeURIComponent(
|
67
|
+
color,
|
68
|
+
)}%22%20stop-opacity%3D%22.20%22%20id%3D%22stop405%22%2F%3E%3Cstop%20offset%3D%22.89%22%20stop-color%3D%22${encodeURIComponent(
|
69
|
+
color,
|
70
|
+
)}%22%20stop-opacity%3D%22.15%22%20id%3D%22stop407%22%2F%3E%3Cstop%20offset%3D%221%22%20stop-color%3D%22transparent%22%20stop-opacity%3D%220%22%20id%3D%22stop409%22%2F%3E%3C%2FlinearGradient%3E%3ClinearGradient%20id%3D%222-9%22%20x1%3D%2240.529999%22%20y1%3D%2249.369999%22%20x2%3D%2240.529999%22%20y2%3D%220%22%20gradientUnits%3D%22userSpaceOnUse%22%3E%3Cstop%20offset%3D%22.24%22%20stop-color%3D%22${encodeURIComponent(
|
71
|
+
color,
|
72
|
+
)}%22%20id%3D%22stop412%22%2F%3E%3Cstop%20offset%3D%22.38%22%20stop-color%3D%22${encodeURIComponent(
|
73
|
+
color,
|
74
|
+
)}%22%20stop-opacity%3D%22.93%22%20id%3D%22stop414%22%2F%3E%3Cstop%20offset%3D%22.57%22%20stop-color%3D%22${encodeURIComponent(
|
75
|
+
color,
|
76
|
+
)}%22%20stop-opacity%3D%22.70%22%20id%3D%22stop416%22%2F%3E%3Cstop%20offset%3D%22.78%22%20stop-color%3D%22${encodeURIComponent(
|
77
|
+
color,
|
78
|
+
)}%22%20stop-opacity%3D%22.38%22%20id%3D%22stop418%22%2F%3E%3Cstop%20offset%3D%221%22%20stop-color%3D%22transparent%22%20stop-opacity%3D%220%22%20id%3D%22stop420%22%2F%3E%3C%2FlinearGradient%3E%3C%2Fdefs%3E%3Cg%20id%3D%22layer1%22%20transform%3D%22translate(5.3616118%2C3.2722342)%22%3E%3Cpolygon%20points%3D%220.53%2C0.25%2040.53%2C48.97%2080.53%2C0.25%20%22%20fill%3D%22url(%231)%22%20stroke%3D%22url(%232)%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%220.5px%22%20id%3D%22polygon425%22%20style%3D%22fill%3Aurl(%231-0)%3Bstroke%3Aurl(%232-9)%22%20transform%3D%22matrix(0.396875%2C0%2C0%2C0.396875%2C-5.3621201%2C-3.2722342)%22%2F%3E%3Ccircle%20cx%3D%2210.723224%22%20cy%3D%2213.781484%22%20r%3D%222.3812499%22%20fill%3D%22${encodeURIComponent(
|
79
|
+
color,
|
80
|
+
)}%22%20stroke%3D%22%23ffffff%22%20stroke-miterlimit%3D%2210%22%20id%3D%22circle427%22%20style%3D%22stroke-width%3A0.396874%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E`,
|
81
|
+
color,
|
82
|
+
};
|
83
|
+
}
|
84
|
+
|
48
85
|
/**
|
49
86
|
* A 2D OverviewMap for cesium, openlayers and oblique map.
|
50
87
|
* Baselayers are added to the OverviewMap using `showInOverviewMap` flag within the properties bag of a layer configuration.
|
@@ -77,9 +114,9 @@ class OverviewMap {
|
|
77
114
|
|
78
115
|
/**
|
79
116
|
* @private
|
80
|
-
* @type {import("@vcmap/core").
|
117
|
+
* @type {import("@vcmap/core").Viewpoint|null}
|
81
118
|
*/
|
82
|
-
this.
|
119
|
+
this._cachedViewpoint = null;
|
83
120
|
|
84
121
|
/**
|
85
122
|
* @type {import("@vcmap/core").VectorLayer}
|
@@ -99,21 +136,9 @@ class OverviewMap {
|
|
99
136
|
*/
|
100
137
|
this._obliqueSelectedImageLayer = null;
|
101
138
|
|
102
|
-
const
|
103
|
-
|
104
|
-
|
105
|
-
/**
|
106
|
-
* @type {VectorStyleItem}
|
107
|
-
*/
|
108
|
-
this.obliqueUnselectedStyle = new VectorStyleItem({
|
109
|
-
fill: {
|
110
|
-
color: fillColor.withAlpha(0.1).toCssColorString(),
|
111
|
-
},
|
112
|
-
stroke: {
|
113
|
-
color: primary,
|
114
|
-
width: 1,
|
115
|
-
},
|
116
|
-
});
|
139
|
+
const primary =
|
140
|
+
app.uiConfig.config.value.primaryColor ?? getDefaultPrimaryColor();
|
141
|
+
const fillColor = Color.fromCssColorString('#EDEDED');
|
117
142
|
|
118
143
|
/**
|
119
144
|
* @type {VectorStyleItem}
|
@@ -152,10 +177,7 @@ class OverviewMap {
|
|
152
177
|
* @type {import("@vcmap/core").VectorStyleItem}
|
153
178
|
*/
|
154
179
|
this.cameraIconStyle = new VectorStyleItem({
|
155
|
-
image:
|
156
|
-
src: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAA8CAYAAADxJz2MAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA4RpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTExIDc5LjE1ODMyNSwgMjAxNS8wOS8xMC0wMToxMDoyMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDphMzhlODgyYy00ZGYzLTZkNGMtYWZhYy1hYTkwOTI3MjRiYjEiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NEYxRkE1MDlENjRDMTFFNTlGRjhFMzM3RTA3MDJFMDciIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NEYxRkE1MDhENjRDMTFFNTlGRjhFMzM3RTA3MDJFMDciIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTUgKFdpbmRvd3MpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6OGJiODg5ODItZGM0Zi0xNjQyLWEyZDYtODJkZTcxMGNhNjkwIiBzdFJlZjpkb2N1bWVudElEPSJhZG9iZTpkb2NpZDpwaG90b3Nob3A6YzY5MTdhNjAtZDYzYy0xMWU1LThjNTgtYTMwNjE0MWQwNTkyIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+Fn8KKQAABwVJREFUeNrsW0toHVUYPufOvb2madNaa2NS3682BTcKiQqx4qO0i7gKpHFhoCBoG8SVC124ExcW02yCiFCQ4iLgIhWJCE2pYI1J1VitNFhTIz5STdI2D2tucsf/N9/YcTKvM+fMbYT54eu9nTvnzMx3/veZSNu2RSbJJZdRkBGYEZgRmBGYSUZgRmBGYEZgJslkTUZBoEjXpxcsxTz9U0OYIfxFsAi2a5DtOjnpxU09RNS9SEPXiXN8kbCWUCWhgZsIf+Am3WYdh0BpkFipeG3v2LhjdM4pgyPmbMI5aT1hHeECIV+BVVXRLJ17kR6LSnqOl8AbCZNsue4BWzAB/1B0TapLpEyJmDTcR9SCL4C8K4Tf+Jh3wK2EecIsoWDIFE1qSxoExvV9JcQLttAxfC7lPSdNgMQlqKpUuJht6MZ15gsao7OgElxw0NhAGMXvzJHtNzGzfBPILBj2dyY00ZT2qURdJmsr4TxcnCNW0CR1IPJ3RGk74YWTPITU0BTTGYLj92pB3E/e38MusAP5zsUQTayELxIKrkRX04SP39sEDfxGdRLWvPsIUyAyl1LkTMPkpAErYNKugyUOgUzlC20mbIfq5lN4gDiBREfTdYjka9cTRlBkJL7AnZjo54C6OY2bNz2n6mKUEDTOEX7Qzaf4wg+AvMkYzYc0nLkp7Y6zUCVY3gxMV5ggkIPITkw6j6aDCZMySYYJTV9CSVtF+Bi+P1TyEb/brlX5itCI77kKpy3SIKEyQlFY+47HIc+PQOnJ+dzH2ZGOI6iMeVIb1crBpCbqdleky+/dRvgyLGhEERj1nse3SCq3olIpKnYyZMqEJFkIJ1m+hfAL4YyCRVlJzJCDSAs6ErMuf5im9kmFVphqX3ARNS4r0/sgU8ZQpshKJCo/fAor5m46mCidTJmxVLBCrv17YbpOV76cxITjCl9omPAgCuxCism0aZ8oPfkem+4JPJP0IU6C1EWTBLJ8Dad7ByqVotDrLqdR74ZdawFFwhgyDG8skB5XYayD4hbeCniGcJkw55MfphkM4vq+oPZUDSznHfhz6dN1klGmbGLn7GaQ+CNuLFfhiJpEg3mhbye87WpRxQ0cxglkeYjwuLja6r4W3ZW448pwOx8STuo+eN4QgSeRG25Hsl1IITdUMeOg30og77SHPD/ti/R/JjXQWYwXQN6kYvsrKtE1USpyFN2CWv6gx7eFER9KoGXQzPmGfiU8BqdsY/4kyAHu716EjfOex89QTdhIeAtNESNi+UQdHbmI6qQZ3/OuPMrvwXIRsGIej1oMlnsJ7xG+03i+FRzlfXKfuBMFqfanhHsI9/s0HUxFXZXx7PfuJnxuImjoNhPiyhHcNKc4F3w0PY2A4pcLLuIe2CreNfBcdhIfmETYH35P2IXccAmLlcRs44zxmrLTr6xBo+B1wrSG2WoFEWW/ALkMP/gEPi2NQBDlD60A4jll6UGLqhBQ50ZJLsQyZVoa6AjnhLyvynsqU3gIGUKIqrYF/WYjaHxEOKrpnuw02lmqfvYN1M0TCZJ31Y4L+716dFdeEjFb8ybSGFOmLH384Rn0D8vi6iZ9TlMDpc8xgVyPF+tVwqWUePv3WS2DjtWvm+HIJfjBXfiuQlTOExjCxhYQdd8UAa9iGPb3tkkCo87hDeo65IeTrgohqZ+zfPwed1g+EMut+TRK1xX1cSV8oFs7eb+1C4FlIqB/aAv1Xb4y/N55wosJC4DUfWBUqSdjnMf+j3f2Wlz+0PLxa+7PMDh+rwaL83LCOjdxZWQp1MEyomOSi6k1F2HCj4rltroISEOEy8zd//cGEvZ71xMOieUXgVQty5mzrKOBJt4yUDGNczC5HWgvOWSUQQhr0w3ooFThmFNTL7mIZeEdwgGUj0nbYXZCLRWWpk/TiWCfEZ4Uy2+9z2G+WhBWPHDgwK6urq5txWJx8/Dw8ATGrANmMReP5a3VV0KsJKhZauSFJ1lhAr1j7kJQYb+1trW19ZG2traNp06dkvv37y/39vbKwcFBMT09faWurq6qvb3d3rNnzxHkeX+CzOfE8qt3sTaBTEvSPza0E46RPqbMOdv6lpaWnYcPH97Q2NgoSqWS6OvrkwMDA3J+fl6SFlZNTU2J5uZmMTMz87SLvIMgz5m/7NGu1LOMfIUWKuxBjhFaScNK1dXVcm5uTpw9e5axYszs7Kyora2VII1fvz1ucIGveSmnI8fIbB9uaGiob2pqWlMoFMTIyMh/COzo6LBZOzs7Ow8NDQ1xo+DZtOvc/5twRD5KBJ2wbXtkdHS03NPT8w/4Ox1boMDyCbor21bLTctVRmItkuGqffv2Lezdu/d5STI+Pj7V3d1NSjnC25GvieUud0ZgiHC93LR7927enBL9/f2seYOEL1bbjf4twAD8sqEzJ5yLRwAAAABJRU5ErkJggg==',
|
157
|
-
anchor: [0.5, 1],
|
158
|
-
},
|
180
|
+
image: getCameraIcon(getDefaultPrimaryColor()),
|
159
181
|
});
|
160
182
|
|
161
183
|
/**
|
@@ -199,7 +221,7 @@ class OverviewMap {
|
|
199
221
|
* @type {Array<function():void>}
|
200
222
|
* @private
|
201
223
|
*/
|
202
|
-
this.
|
224
|
+
this._collectionListeners = [
|
203
225
|
this._app.maps.layerCollection.added.addEventListener((layer) => {
|
204
226
|
if (layer.properties.showInOverviewMap) {
|
205
227
|
const clone = deserializeLayer(this._app, layer.toJSON());
|
@@ -219,6 +241,9 @@ class OverviewMap {
|
|
219
241
|
this._map.layerCollection.remove(clone);
|
220
242
|
}
|
221
243
|
}),
|
244
|
+
this._app.themeChanged.addEventListener(
|
245
|
+
this._updatePrimaryColor.bind(this),
|
246
|
+
),
|
222
247
|
];
|
223
248
|
}
|
224
249
|
|
@@ -254,6 +279,21 @@ class OverviewMap {
|
|
254
279
|
return this._mapClicked;
|
255
280
|
}
|
256
281
|
|
282
|
+
/**
|
283
|
+
* @private
|
284
|
+
*/
|
285
|
+
_updatePrimaryColor() {
|
286
|
+
const color = getColorByKey('primary');
|
287
|
+
this.obliqueSelectedStyle?.stroke?.setColor(color);
|
288
|
+
this._obliqueSelectedImageLayer?.forceRedraw?.();
|
289
|
+
const rotation = this.cameraIconStyle.image.getRotation();
|
290
|
+
this.cameraIconStyle.image = new Icon(getCameraIcon(color));
|
291
|
+
this.cameraIconStyle.image.setRotation(rotation);
|
292
|
+
this._cameraIconLayer
|
293
|
+
?.getFeatureById('cameraFeature')
|
294
|
+
?.setStyle(this.cameraIconStyle.style);
|
295
|
+
}
|
296
|
+
|
257
297
|
/**
|
258
298
|
* @private
|
259
299
|
*/
|
@@ -262,9 +302,10 @@ class OverviewMap {
|
|
262
302
|
const overviewMapClickedInteraction = new OverviewMapClickedInteraction();
|
263
303
|
this._mapClicked = overviewMapClickedInteraction.mapClicked;
|
264
304
|
this._eventHandler.addPersistentInteraction(overviewMapClickedInteraction);
|
265
|
-
this._mapPointerListener =
|
266
|
-
this.
|
267
|
-
|
305
|
+
this._mapPointerListener =
|
306
|
+
this._map.pointerInteractionEvent.addEventListener((e) => {
|
307
|
+
this._eventHandler.handleMapEvent(e);
|
308
|
+
});
|
268
309
|
}
|
269
310
|
|
270
311
|
/**
|
@@ -277,21 +318,23 @@ class OverviewMap {
|
|
277
318
|
this._setupMapInteraction();
|
278
319
|
}
|
279
320
|
await this._map.activate();
|
321
|
+
this._map.setTarget('overview-map-container');
|
322
|
+
this._map.target?.firstChild?.classList?.add('overviewMapElement');
|
280
323
|
if (!this._active) {
|
281
|
-
this._mapActivatedListener = this._app.maps.mapActivated.addEventListener(
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
324
|
+
this._mapActivatedListener = this._app.maps.mapActivated.addEventListener(
|
325
|
+
() => {
|
326
|
+
this._clearListeners();
|
327
|
+
this._cachedViewpoint = null;
|
328
|
+
this._activate();
|
329
|
+
},
|
330
|
+
);
|
286
331
|
}
|
287
332
|
this._active = true;
|
288
333
|
const { activeMap } = this._app.maps;
|
289
|
-
if (activeMap instanceof
|
290
|
-
await this._initializeForCesium(activeMap);
|
291
|
-
} else if (activeMap instanceof OpenlayersMap) {
|
292
|
-
await this._initializeForOpenlayers(activeMap);
|
293
|
-
} else if (activeMap instanceof ObliqueMap) {
|
334
|
+
if (activeMap instanceof ObliqueMap) {
|
294
335
|
await this._initializeForOblique(activeMap);
|
336
|
+
} else if (activeMap) {
|
337
|
+
await this._initializePostRenderHandler(activeMap);
|
295
338
|
}
|
296
339
|
}
|
297
340
|
|
@@ -304,7 +347,6 @@ class OverviewMap {
|
|
304
347
|
this._app.windowManager.add(getWindowComponentOptions(), vcsAppSymbol);
|
305
348
|
}
|
306
349
|
await this._activate();
|
307
|
-
this.map.setTarget('overview-map-container');
|
308
350
|
}
|
309
351
|
|
310
352
|
/**
|
@@ -321,45 +363,22 @@ class OverviewMap {
|
|
321
363
|
}
|
322
364
|
|
323
365
|
/**
|
324
|
-
* @param {import("@vcmap/core").
|
366
|
+
* @param {import("@vcmap/core").VcsMap} map
|
325
367
|
* @returns {Promise<void>}
|
326
368
|
* @private
|
327
369
|
*/
|
328
|
-
async
|
370
|
+
async _initializePostRenderHandler(map) {
|
329
371
|
if (!this._cameraIconLayer) {
|
330
372
|
this._setupCameraIconLayer();
|
373
|
+
this._syncCameraViewAndFeature();
|
331
374
|
}
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
const prRemover = cesiumScene.postRender.addEventListener(this._addCameraFeature, this);
|
337
|
-
const cleanupTasks = () => {
|
338
|
-
prRemover();
|
339
|
-
navRemover();
|
340
|
-
this._cameraIconLayer.deactivate();
|
341
|
-
};
|
342
|
-
this._listeners.push(cleanupTasks);
|
343
|
-
await this._cameraIconLayer.activate();
|
344
|
-
}
|
345
|
-
}
|
346
|
-
|
347
|
-
/**
|
348
|
-
* @param {import("@vcmap/core").OpenlayersMap} map
|
349
|
-
* @returns {Promise<void>}
|
350
|
-
* @private
|
351
|
-
*/
|
352
|
-
async _initializeForOpenlayers(map) {
|
353
|
-
if (!this._cameraIconLayer) {
|
354
|
-
this._setupCameraIconLayer();
|
355
|
-
}
|
356
|
-
const { olMap } = map;
|
357
|
-
const navListener = this._addNavigationListener(map);
|
358
|
-
const prUnKey = olMap.on('postrender', this._addCameraFeature.bind(this));
|
359
|
-
|
375
|
+
const navRemover = this._addNavigationListener(map);
|
376
|
+
const prRemover = map.postRender.addEventListener(
|
377
|
+
this._syncCameraViewAndFeature.bind(this),
|
378
|
+
);
|
360
379
|
const cleanupTasks = () => {
|
361
|
-
|
362
|
-
|
380
|
+
prRemover();
|
381
|
+
navRemover();
|
363
382
|
this._cameraIconLayer.deactivate();
|
364
383
|
};
|
365
384
|
this._listeners.push(cleanupTasks);
|
@@ -379,8 +398,10 @@ class OverviewMap {
|
|
379
398
|
if (e.feature) {
|
380
399
|
const id = e.feature.getId().toString();
|
381
400
|
if (this._obliqueTileLayer.getFeatureById(id)) {
|
382
|
-
const image = await obliqueMap.collection
|
383
|
-
|
401
|
+
const image = await obliqueMap.collection.loadImageForCoordinate(
|
402
|
+
e.positionOrPixel,
|
403
|
+
this._obliqueViewDirection,
|
404
|
+
);
|
384
405
|
if (image) {
|
385
406
|
await obliqueMap.setImageByName(image.name);
|
386
407
|
}
|
@@ -392,8 +413,12 @@ class OverviewMap {
|
|
392
413
|
|
393
414
|
const listeners = [
|
394
415
|
mapClickedListener,
|
395
|
-
obliqueMap.imageChanged.addEventListener(
|
396
|
-
|
416
|
+
obliqueMap.imageChanged.addEventListener(
|
417
|
+
this._obliqueImageChange.bind(this),
|
418
|
+
),
|
419
|
+
obliqueMap.collectionChanged.addEventListener(
|
420
|
+
this._obliqueCollectionChanged.bind(this),
|
421
|
+
),
|
397
422
|
];
|
398
423
|
|
399
424
|
const prUnKey = this._map.olMap.once('postrender', () => {
|
@@ -406,7 +431,9 @@ class OverviewMap {
|
|
406
431
|
this._obliqueImageLayer.deactivate();
|
407
432
|
this._obliqueSelectedImageLayer.deactivate();
|
408
433
|
unByKey(prUnKey);
|
409
|
-
listeners.forEach((l) => {
|
434
|
+
listeners.forEach((l) => {
|
435
|
+
l();
|
436
|
+
});
|
410
437
|
};
|
411
438
|
this._listeners.push(cleanupTasks);
|
412
439
|
await this._obliqueTileLayer.activate();
|
@@ -445,9 +472,9 @@ class OverviewMap {
|
|
445
472
|
projection: mercatorProjection.toJSON(),
|
446
473
|
});
|
447
474
|
|
448
|
-
const vp =
|
475
|
+
const vp = Viewpoint.createViewpointFromExtent(extent);
|
449
476
|
vp.distance /= this._obliqueResolutionFactor;
|
450
|
-
this._map.
|
477
|
+
this._map.gotoViewpoint(vp);
|
451
478
|
}
|
452
479
|
}
|
453
480
|
|
@@ -455,10 +482,13 @@ class OverviewMap {
|
|
455
482
|
* @private
|
456
483
|
*/
|
457
484
|
_setupObliqueLayers() {
|
485
|
+
const almostTransparentStyle = new VectorStyleItem({
|
486
|
+
fill: { color: 'rgba(0, 0, 0, 0.000001)' },
|
487
|
+
});
|
458
488
|
const obliqueTileStyle = new VectorStyleItem({});
|
459
489
|
obliqueTileStyle.style = (feature) => {
|
460
490
|
if (feature.get('state') === DataState.PENDING) {
|
461
|
-
return
|
491
|
+
return almostTransparentStyle.style;
|
462
492
|
}
|
463
493
|
return emptyStyle;
|
464
494
|
};
|
@@ -468,11 +498,12 @@ class OverviewMap {
|
|
468
498
|
style: obliqueTileStyle,
|
469
499
|
zIndex: 1,
|
470
500
|
});
|
501
|
+
this._obliqueTileLayer[overviewMapLayerSymbol] = true;
|
471
502
|
|
472
503
|
const obliqueImageStyle = new VectorStyleItem({});
|
473
504
|
obliqueImageStyle.style = (feature) => {
|
474
505
|
if (feature.get('viewDirection') === this._obliqueViewDirection) {
|
475
|
-
return
|
506
|
+
return almostTransparentStyle.style;
|
476
507
|
}
|
477
508
|
return emptyStyle;
|
478
509
|
};
|
@@ -481,10 +512,12 @@ class OverviewMap {
|
|
481
512
|
projection: mercatorProjection.toJSON(),
|
482
513
|
style: obliqueImageStyle,
|
483
514
|
});
|
515
|
+
this._obliqueImageLayer[overviewMapLayerSymbol] = true;
|
484
516
|
this._obliqueSelectedImageLayer = new VectorLayer({
|
485
517
|
projection: mercatorProjection.toJSON(),
|
486
518
|
style: this.obliqueSelectedStyle,
|
487
519
|
});
|
520
|
+
this._obliqueSelectedImageLayer[overviewMapLayerSymbol] = true;
|
488
521
|
this._map.layerCollection.add(this._obliqueImageLayer);
|
489
522
|
this._map.layerCollection.add(this._obliqueSelectedImageLayer);
|
490
523
|
this._map.layerCollection.add(this._obliqueTileLayer);
|
@@ -497,12 +530,12 @@ class OverviewMap {
|
|
497
530
|
*/
|
498
531
|
_addNavigationListener(activeMap) {
|
499
532
|
return this._mapClicked.addEventListener((e) => {
|
500
|
-
const vp = activeMap.
|
533
|
+
const vp = activeMap.getViewpointSync();
|
501
534
|
const height = vp.groundPosition[2] ? vp.groundPosition[2] : 0.0;
|
502
535
|
vp.groundPosition = Projection.mercatorToWgs84(e.positionOrPixel);
|
503
536
|
vp.groundPosition[2] = height;
|
504
537
|
vp.cameraPosition = null;
|
505
|
-
activeMap.
|
538
|
+
activeMap.gotoViewpoint(vp);
|
506
539
|
});
|
507
540
|
}
|
508
541
|
|
@@ -512,6 +545,7 @@ class OverviewMap {
|
|
512
545
|
projection: mercatorProjection.toJSON(),
|
513
546
|
zIndex: 50,
|
514
547
|
});
|
548
|
+
this._cameraIconLayer[overviewMapLayerSymbol] = true;
|
515
549
|
this._map.layerCollection.add(this._cameraIconLayer);
|
516
550
|
}
|
517
551
|
}
|
@@ -520,20 +554,22 @@ class OverviewMap {
|
|
520
554
|
* Adds and maintains the view and camera feature
|
521
555
|
* @private
|
522
556
|
*/
|
523
|
-
|
524
|
-
const viewpoint = this._app.maps.activeMap
|
525
|
-
if (
|
557
|
+
_syncCameraViewAndFeature() {
|
558
|
+
const viewpoint = this._app.maps.activeMap?.getViewpointSync();
|
559
|
+
if (
|
560
|
+
!viewpoint ||
|
561
|
+
!viewpoint.isValid() ||
|
562
|
+
viewpoint.equals(this._cachedViewpoint)
|
563
|
+
) {
|
526
564
|
return;
|
527
565
|
}
|
528
|
-
this.
|
566
|
+
this._cachedViewpoint = viewpoint.clone();
|
529
567
|
const gp = viewpoint.groundPosition;
|
530
568
|
const position = viewpoint.cameraPosition || gp;
|
531
569
|
const { heading } = viewpoint;
|
532
570
|
let { distance } = viewpoint;
|
533
571
|
if (position[2] && !(distance && distance < position[2] * 4)) {
|
534
572
|
distance = position[2] * 4;
|
535
|
-
} else if (position[2] == null) {
|
536
|
-
position[2] = distance;
|
537
573
|
}
|
538
574
|
|
539
575
|
distance = distance > this.minimumHeight ? distance : this.minimumHeight;
|
@@ -541,8 +577,9 @@ class OverviewMap {
|
|
541
577
|
return;
|
542
578
|
}
|
543
579
|
let cameraFeature = this._cameraIconLayer.getFeatureById('cameraFeature');
|
580
|
+
const coords = Projection.wgs84ToMercator(position);
|
544
581
|
if (!cameraFeature) {
|
545
|
-
const cameraGeometry = new Point(
|
582
|
+
const cameraGeometry = new Point(coords);
|
546
583
|
cameraFeature = new Feature({
|
547
584
|
geometry: cameraGeometry,
|
548
585
|
});
|
@@ -550,7 +587,7 @@ class OverviewMap {
|
|
550
587
|
cameraFeature.setStyle(this.cameraIconStyle.style);
|
551
588
|
this._cameraIconLayer.addFeatures([cameraFeature]);
|
552
589
|
}
|
553
|
-
cameraFeature.getGeometry().setCoordinates(
|
590
|
+
cameraFeature.getGeometry().setCoordinates(coords);
|
554
591
|
|
555
592
|
const rotationDegrees = viewpoint.heading;
|
556
593
|
const rotationRadians = CesiumMath.toRadians(rotationDegrees);
|
@@ -558,24 +595,26 @@ class OverviewMap {
|
|
558
595
|
this.cameraIconStyle.image.setRotation(rotationRadians);
|
559
596
|
|
560
597
|
viewpoint.heading = 0;
|
561
|
-
viewpoint.cameraPosition
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
|
598
|
+
if (viewpoint.cameraPosition) {
|
599
|
+
viewpoint.cameraPosition = position;
|
600
|
+
viewpoint.groundPosition = null;
|
601
|
+
viewpoint.distance = distance * 4;
|
602
|
+
}
|
603
|
+
this._map.gotoViewpoint(viewpoint);
|
566
604
|
}
|
567
605
|
|
568
606
|
/**
|
569
607
|
* @private
|
570
608
|
*/
|
571
609
|
_clearListeners() {
|
572
|
-
this._listeners.forEach(cb => cb());
|
610
|
+
this._listeners.forEach((cb) => cb());
|
573
611
|
this._listeners.splice(0);
|
574
612
|
}
|
575
613
|
|
576
614
|
destroy() {
|
577
615
|
this._clearListeners();
|
578
|
-
this.
|
616
|
+
this._collectionListeners.forEach((cb) => cb());
|
617
|
+
this._collectionListeners = [];
|
579
618
|
if (this._mapPointerListener) {
|
580
619
|
this._mapPointerListener();
|
581
620
|
this._mapPointerListener = null;
|
@@ -606,9 +645,8 @@ class OverviewMap {
|
|
606
645
|
this._eventHandler.destroy();
|
607
646
|
}
|
608
647
|
this.cameraIconStyle.destroy();
|
609
|
-
this.obliqueUnselectedStyle.destroy();
|
610
648
|
this.obliqueSelectedStyle.destroy();
|
611
|
-
this.
|
649
|
+
this._cachedViewpoint = null;
|
612
650
|
this._mapClicked = null;
|
613
651
|
}
|
614
652
|
}
|
@@ -0,0 +1,86 @@
|
|
1
|
+
<template>
|
2
|
+
<div>
|
3
|
+
<v-snackbar
|
4
|
+
dark
|
5
|
+
v-for="notification in notifications"
|
6
|
+
:key="notification.id"
|
7
|
+
v-model="notification.open"
|
8
|
+
:timeout="notification.timeout"
|
9
|
+
>
|
10
|
+
<v-icon :color="notification.type">
|
11
|
+
{{ icon[notification.type] }}
|
12
|
+
</v-icon>
|
13
|
+
<span class="snack-title">{{
|
14
|
+
$t(notification.title || defaultTitle[notification.type])
|
15
|
+
}}</span>
|
16
|
+
<template #action="{ attrs }">
|
17
|
+
<VcsButton
|
18
|
+
icon="mdi-close"
|
19
|
+
v-bind="attrs"
|
20
|
+
@click="notification.open = false"
|
21
|
+
/>
|
22
|
+
</template>
|
23
|
+
<span>{{ $t(notification.message) }}</span>
|
24
|
+
</v-snackbar>
|
25
|
+
</div>
|
26
|
+
</template>
|
27
|
+
|
28
|
+
<script>
|
29
|
+
import { VSnackbar, VIcon } from 'vuetify/lib';
|
30
|
+
import { inject } from 'vue';
|
31
|
+
import VcsButton from '../components/buttons/VcsButton.vue';
|
32
|
+
import { NotificationType } from './notifier.js';
|
33
|
+
|
34
|
+
/**
|
35
|
+
* @description Renders notifications of different types
|
36
|
+
*/
|
37
|
+
export default {
|
38
|
+
components: {
|
39
|
+
VSnackbar,
|
40
|
+
VcsButton,
|
41
|
+
VIcon,
|
42
|
+
},
|
43
|
+
name: 'NotifierComponent',
|
44
|
+
setup() {
|
45
|
+
const app = inject('vcsApp');
|
46
|
+
|
47
|
+
return {
|
48
|
+
notifications: app.notifier.notifications,
|
49
|
+
icon: {
|
50
|
+
[NotificationType.ERROR]: 'mdi-alert-box',
|
51
|
+
[NotificationType.WARNING]: 'mdi-alert',
|
52
|
+
[NotificationType.INFO]: 'mdi-information',
|
53
|
+
[NotificationType.SUCCESS]: 'mdi-check-circle',
|
54
|
+
},
|
55
|
+
defaultTitle: {
|
56
|
+
[NotificationType.ERROR]: 'notification.error',
|
57
|
+
[NotificationType.WARNING]: 'notification.warning',
|
58
|
+
[NotificationType.INFO]: 'notification.information',
|
59
|
+
[NotificationType.SUCCESS]: 'notification.success',
|
60
|
+
},
|
61
|
+
};
|
62
|
+
},
|
63
|
+
};
|
64
|
+
</script>
|
65
|
+
|
66
|
+
<style lang="scss" scoped>
|
67
|
+
.v-snack {
|
68
|
+
::v-deep {
|
69
|
+
.v-snack__content {
|
70
|
+
display: grid;
|
71
|
+
gap: 8px 4px;
|
72
|
+
grid-template-columns: 20px auto;
|
73
|
+
.v-icon {
|
74
|
+
grid-row-start: 1;
|
75
|
+
grid-row-end: 3;
|
76
|
+
align-self: start;
|
77
|
+
font-size: 17px;
|
78
|
+
}
|
79
|
+
}
|
80
|
+
.v-snack__action {
|
81
|
+
align-self: flex-start;
|
82
|
+
margin-top: 4px;
|
83
|
+
}
|
84
|
+
}
|
85
|
+
}
|
86
|
+
</style>
|