@vcmap/ui 5.0.0-rc.9 → 5.0.1

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.
Files changed (724) hide show
  1. package/README.md +90 -106
  2. package/app.config.json +3 -0
  3. package/build/.eslintrc +3 -0
  4. package/build/build.js +302 -162
  5. package/build/buildCesium.js +39 -19
  6. package/build/buildHelpers.js +279 -87
  7. package/build/buildPreview.js +16 -6
  8. package/build/bundle.js +57 -0
  9. package/build/commonViteConfig.js +6 -15
  10. package/build/determineHost.js +17 -4
  11. package/build/generateOLLib.js +15 -18
  12. package/build/getPluginProxies.js +35 -3
  13. package/build/info/conf.json +21 -19
  14. package/build/info/publish.js +16 -5
  15. package/config/aerowest.config.json +47 -54
  16. package/config/base.config.json +607 -662
  17. package/config/codes.config.json +401 -0
  18. package/config/dev.config.json +460 -14
  19. package/config/graphFeatureInfo.config.json +141 -0
  20. package/config/projects.config.json +29 -0
  21. package/config/www.config.json +1843 -0
  22. package/dist/assets/@mdi/font/LICENSE +20 -0
  23. package/dist/assets/@mdi/font/css/materialdesignicons.css.map +16 -0
  24. package/dist/assets/@mdi/font/css/materialdesignicons.min.e3f476.css +3 -0
  25. package/dist/assets/@mdi/font/fonts/materialdesignicons-webfont.woff2 +0 -0
  26. package/dist/assets/cesium/ThirdParty/Workers/basis_transcoder.js +21 -0
  27. package/dist/assets/cesium/ThirdParty/Workers/package.json +1 -0
  28. package/dist/assets/cesium/ThirdParty/Workers/pako_deflate.min.js +2 -0
  29. package/dist/assets/cesium/ThirdParty/Workers/pako_inflate.min.js +2 -0
  30. package/dist/assets/cesium/ThirdParty/Workers/z-worker-pako.js +1 -0
  31. package/dist/assets/cesium/ThirdParty/basis_transcoder.wasm +0 -0
  32. package/dist/assets/cesium/ThirdParty/draco_decoder.wasm +0 -0
  33. package/dist/assets/cesium/ThirdParty/google-earth-dbroot-parser.js +8337 -0
  34. package/dist/assets/cesium/Workers/chunk-227AJNOA.js +59 -0
  35. package/dist/assets/cesium/Workers/chunk-2R5O53JW.js +157 -0
  36. package/dist/assets/cesium/Workers/chunk-34YUDLRP.js +781 -0
  37. package/dist/assets/cesium/Workers/chunk-3W63OHNJ.js +100 -0
  38. package/dist/assets/cesium/Workers/chunk-4MFFIWUA.js +163 -0
  39. package/dist/assets/cesium/Workers/chunk-66QLLS45.js +218 -0
  40. package/dist/assets/cesium/Workers/chunk-6BTKZDRG.js +77 -0
  41. package/dist/assets/cesium/Workers/chunk-A4JVFBQ3.js +101 -0
  42. package/dist/assets/cesium/Workers/chunk-ABADGKYE.js +58 -0
  43. package/dist/assets/cesium/Workers/chunk-AFFLIKOH.js +353 -0
  44. package/dist/assets/cesium/Workers/chunk-AHKEZ2OE.js +629 -0
  45. package/dist/assets/cesium/Workers/chunk-C3SXRKRW.js +476 -0
  46. package/dist/assets/cesium/Workers/chunk-CCFQRR6D.js +55 -0
  47. package/dist/assets/cesium/Workers/chunk-CHHNOC2C.js +1860 -0
  48. package/dist/assets/cesium/Workers/chunk-CTELOFLA.js +196 -0
  49. package/dist/assets/cesium/Workers/chunk-DUHWWBQQ.js +3273 -0
  50. package/dist/assets/cesium/Workers/chunk-EW2GWJYB.js +44 -0
  51. package/dist/assets/cesium/Workers/chunk-GLZBE3ML.js +421 -0
  52. package/dist/assets/cesium/Workers/chunk-HARLBUOL.js +236 -0
  53. package/dist/assets/cesium/Workers/chunk-HQF437NJ.js +117 -0
  54. package/dist/assets/cesium/Workers/chunk-IPA4EACJ.js +368 -0
  55. package/dist/assets/cesium/Workers/chunk-J3JY6I2C.js +1009 -0
  56. package/dist/assets/cesium/Workers/chunk-JB2LWGH4.js +390 -0
  57. package/dist/assets/cesium/Workers/chunk-JS3AW5BK.js +634 -0
  58. package/dist/assets/cesium/Workers/chunk-K36FEYS7.js +452 -0
  59. package/dist/assets/cesium/Workers/chunk-KD4Y7CZL.js +400 -0
  60. package/dist/assets/cesium/Workers/chunk-KTJSNCK4.js +842 -0
  61. package/dist/assets/cesium/Workers/chunk-LLUNNUJV.js +258 -0
  62. package/dist/assets/cesium/Workers/chunk-MPAZH4BF.js +37 -0
  63. package/dist/assets/cesium/Workers/chunk-MYZB7C4T.js +1258 -0
  64. package/dist/assets/cesium/Workers/chunk-N3JIFFX2.js +501 -0
  65. package/dist/assets/cesium/Workers/chunk-O5AMBQ36.js +430 -0
  66. package/dist/assets/cesium/Workers/chunk-OAVNIRB4.js +124 -0
  67. package/dist/assets/cesium/Workers/chunk-OYFCF4PL.js +171 -0
  68. package/dist/assets/cesium/Workers/chunk-OZJDGN5F.js +1477 -0
  69. package/dist/assets/cesium/Workers/chunk-PCJWUS4M.js +2041 -0
  70. package/dist/assets/cesium/Workers/chunk-PFQBCKBM.js +8644 -0
  71. package/dist/assets/cesium/Workers/chunk-QIKODV5G.js +305 -0
  72. package/dist/assets/cesium/Workers/chunk-QJ3DFBH3.js +73 -0
  73. package/dist/assets/cesium/Workers/chunk-QMEMZIJI.js +138 -0
  74. package/dist/assets/cesium/Workers/chunk-QT3MPEMI.js +102 -0
  75. package/dist/assets/cesium/Workers/chunk-RP2A7BR5.js +289 -0
  76. package/dist/assets/cesium/Workers/chunk-RW6LU2CJ.js +138 -0
  77. package/dist/assets/cesium/Workers/chunk-TFC6TZ3S.js +757 -0
  78. package/dist/assets/cesium/Workers/chunk-V3NGATMV.js +693 -0
  79. package/dist/assets/cesium/Workers/chunk-VLGOATD6.js +1075 -0
  80. package/dist/assets/cesium/Workers/chunk-WXTV4ATB.js +39 -0
  81. package/dist/assets/cesium/Workers/chunk-X4SU25DT.js +302 -0
  82. package/dist/assets/cesium/Workers/chunk-XTY7B2N6.js +2716 -0
  83. package/dist/assets/cesium/Workers/chunk-XY7MGBKC.js +513 -0
  84. package/dist/assets/cesium/Workers/chunk-Z24VKNDO.js +834 -0
  85. package/dist/assets/cesium/Workers/chunk-ZA25DG4Y.js +684 -0
  86. package/dist/assets/cesium/Workers/chunk-ZFOBYDGF.js +73 -0
  87. package/dist/assets/cesium/Workers/combineGeometry.js +67 -1
  88. package/dist/assets/cesium/Workers/createBoxGeometry.js +57 -1
  89. package/dist/assets/cesium/Workers/createBoxOutlineGeometry.js +234 -1
  90. package/dist/assets/cesium/Workers/createCircleGeometry.js +196 -1
  91. package/dist/assets/cesium/Workers/createCircleOutlineGeometry.js +146 -1
  92. package/dist/assets/cesium/Workers/createCoplanarPolygonGeometry.js +506 -1
  93. package/dist/assets/cesium/Workers/createCoplanarPolygonOutlineGeometry.js +224 -1
  94. package/dist/assets/cesium/Workers/createCorridorGeometry.js +1262 -1
  95. package/dist/assets/cesium/Workers/createCorridorOutlineGeometry.js +567 -1
  96. package/dist/assets/cesium/Workers/createCylinderGeometry.js +59 -1
  97. package/dist/assets/cesium/Workers/createCylinderOutlineGeometry.js +231 -1
  98. package/dist/assets/cesium/Workers/createEllipseGeometry.js +70 -1
  99. package/dist/assets/cesium/Workers/createEllipseOutlineGeometry.js +63 -1
  100. package/dist/assets/cesium/Workers/createEllipsoidGeometry.js +58 -1
  101. package/dist/assets/cesium/Workers/createEllipsoidOutlineGeometry.js +60 -1
  102. package/dist/assets/cesium/Workers/createFrustumGeometry.js +57 -1
  103. package/dist/assets/cesium/Workers/createFrustumOutlineGeometry.js +234 -1
  104. package/dist/assets/cesium/Workers/createGeometry.js +150 -1
  105. package/dist/assets/cesium/Workers/createGroundPolylineGeometry.js +1607 -1
  106. package/dist/assets/cesium/Workers/createPlaneGeometry.js +223 -1
  107. package/dist/assets/cesium/Workers/createPlaneOutlineGeometry.js +123 -1
  108. package/dist/assets/cesium/Workers/createPolygonGeometry.js +1134 -1
  109. package/dist/assets/cesium/Workers/createPolygonOutlineGeometry.js +542 -1
  110. package/dist/assets/cesium/Workers/createPolylineGeometry.js +495 -1
  111. package/dist/assets/cesium/Workers/createPolylineVolumeGeometry.js +379 -1
  112. package/dist/assets/cesium/Workers/createPolylineVolumeOutlineGeometry.js +277 -1
  113. package/dist/assets/cesium/Workers/createRectangleGeometry.js +1273 -1
  114. package/dist/assets/cesium/Workers/createRectangleOutlineGeometry.js +480 -1
  115. package/dist/assets/cesium/Workers/createSimplePolylineGeometry.js +399 -1
  116. package/dist/assets/cesium/Workers/createSphereGeometry.js +117 -1
  117. package/dist/assets/cesium/Workers/createSphereOutlineGeometry.js +117 -1
  118. package/dist/assets/cesium/Workers/createTaskProcessorWorker.js +32 -1
  119. package/dist/assets/cesium/Workers/createVectorTileClampedPolylines.js +492 -1
  120. package/dist/assets/cesium/Workers/createVectorTileGeometries.js +386 -1
  121. package/dist/assets/cesium/Workers/createVectorTilePoints.js +112 -1
  122. package/dist/assets/cesium/Workers/createVectorTilePolygons.js +384 -1
  123. package/dist/assets/cesium/Workers/createVectorTilePolylines.js +262 -1
  124. package/dist/assets/cesium/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +568 -1
  125. package/dist/assets/cesium/Workers/createVerticesFromHeightmap.js +2277 -3
  126. package/dist/assets/cesium/Workers/createVerticesFromQuantizedTerrainMesh.js +745 -1
  127. package/dist/assets/cesium/Workers/createWallGeometry.js +489 -1
  128. package/dist/assets/cesium/Workers/createWallOutlineGeometry.js +337 -1
  129. package/dist/assets/cesium/Workers/decodeDraco.js +369 -1
  130. package/dist/assets/cesium/Workers/decodeGoogleEarthEnterprisePacket.js +2650 -1
  131. package/dist/assets/cesium/Workers/decodeI3S.js +835 -0
  132. package/dist/assets/cesium/Workers/transcodeKTX2.js +3425 -1
  133. package/dist/assets/cesium/Workers/transferTypedArrayTest.js +41 -1
  134. package/dist/assets/cesium/Workers/upsampleQuantizedTerrainMesh.js +818 -1
  135. package/dist/assets/cesium.888ef7.js +164897 -0
  136. package/dist/assets/cesium.js +1 -1
  137. package/dist/assets/core.860907.js +19286 -0
  138. package/dist/assets/core.js +1 -1
  139. package/dist/assets/favicon-128.4c4ce5.png +0 -0
  140. package/dist/assets/favicon-180.5b99c0.png +0 -0
  141. package/dist/assets/favicon-192.0e205e.png +0 -0
  142. package/dist/assets/favicon-32.6b9add.png +0 -0
  143. package/dist/assets/favicon.d5ec97.svg +10 -0
  144. package/dist/assets/font/OFL.txt +93 -0
  145. package/dist/assets/font/TitilliumWeb-Regular.9ca076.woff2 +0 -0
  146. package/dist/assets/index-f265c560.js +1 -0
  147. package/dist/assets/ol.5e8a90.js +60117 -0
  148. package/dist/assets/ol.js +1 -1
  149. package/dist/assets/style/icon-marker-blue.534e37.png +0 -0
  150. package/dist/assets/style/icon-marker-green.0b6a92.png +0 -0
  151. package/dist/assets/style/icon-marker-o-blue.7b6d62.png +0 -0
  152. package/dist/assets/style/icon-marker-o-green.c863c0.png +0 -0
  153. package/dist/assets/style/icon-marker-o-red.93ff58.png +0 -0
  154. package/dist/assets/style/icon-marker-o.036477.png +0 -0
  155. package/dist/assets/style/icon-marker-red.313d03.png +0 -0
  156. package/dist/assets/style/icon-marker.70960f.png +0 -0
  157. package/dist/assets/style/icon-pin-blue.7be369.png +0 -0
  158. package/dist/assets/style/icon-pin-green.cbb935.png +0 -0
  159. package/dist/assets/style/icon-pin-red.3f25b2.png +0 -0
  160. package/dist/assets/style/icon-pin.b7ce77.png +0 -0
  161. package/dist/assets/ui.7758a8.css +5 -0
  162. package/dist/assets/ui.7758a8.js +16909 -0
  163. package/dist/assets/ui.js +1 -1
  164. package/dist/assets/vue.9771b3.js +4911 -0
  165. package/dist/assets/vue.js +5 -1
  166. package/dist/assets/vuetify.2818ff.css +5 -0
  167. package/dist/assets/vuetify.2818ff.js +21262 -0
  168. package/dist/assets/vuetify.js +5 -2
  169. package/dist/index.html +90 -8
  170. package/index.html +111 -0
  171. package/index.js +171 -24
  172. package/lib/cesium.js +1 -1
  173. package/lib/core.js +1 -1
  174. package/lib/olLib.js +861 -843
  175. package/lib/ui.js +1 -1
  176. package/lib/vue.js +2 -1
  177. package/lib/vuetify.js +2 -2
  178. package/package.json +56 -36
  179. package/plugins/.eslintrc +9 -0
  180. package/plugins/@vcmap-show-case/README.md +28 -0
  181. package/plugins/@vcmap-show-case/buttons-example/README.md +4 -0
  182. package/plugins/@vcmap-show-case/buttons-example/package.json +5 -0
  183. package/plugins/@vcmap-show-case/buttons-example/src/ButtonsExample.vue +282 -0
  184. package/plugins/@vcmap-show-case/buttons-example/src/index.js +51 -0
  185. package/plugins/@vcmap-show-case/category-tester/README.md +3 -0
  186. package/plugins/@vcmap-show-case/category-tester/package.json +5 -0
  187. package/plugins/@vcmap-show-case/category-tester/src/CategoriesExample.vue +135 -0
  188. package/plugins/@vcmap-show-case/category-tester/src/CollectionComponentOptions.vue +209 -0
  189. package/plugins/@vcmap-show-case/category-tester/src/index.js +73 -0
  190. package/plugins/@vcmap-show-case/collection-manager-example/README.md +3 -0
  191. package/plugins/@vcmap-show-case/collection-manager-example/package.json +5 -0
  192. package/plugins/@vcmap-show-case/collection-manager-example/src/CollectionManagerExample.vue +182 -0
  193. package/plugins/@vcmap-show-case/collection-manager-example/src/index.js +79 -0
  194. package/plugins/@vcmap-show-case/config-editor/README.md +3 -0
  195. package/plugins/@vcmap-show-case/config-editor/package.json +5 -0
  196. package/plugins/@vcmap-show-case/config-editor/src/ConfigEditor.vue +62 -0
  197. package/plugins/@vcmap-show-case/config-editor/src/index.js +49 -0
  198. package/plugins/@vcmap-show-case/context-menu-tester/README.md +3 -0
  199. package/plugins/@vcmap-show-case/context-menu-tester/package.json +5 -0
  200. package/plugins/@vcmap-show-case/context-menu-tester/src/index.js +41 -0
  201. package/plugins/@vcmap-show-case/form-inputs-example/README.md +4 -0
  202. package/plugins/@vcmap-show-case/form-inputs-example/config.json +5 -0
  203. package/plugins/@vcmap-show-case/form-inputs-example/package.json +5 -0
  204. package/plugins/@vcmap-show-case/form-inputs-example/src/FormInputsExample.vue +516 -0
  205. package/plugins/@vcmap-show-case/form-inputs-example/src/exampleActions.js +36 -0
  206. package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example/src}/index.js +119 -35
  207. package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example/src}/validation.js +14 -2
  208. package/plugins/@vcmap-show-case/hello-world/README.md +31 -0
  209. package/plugins/@vcmap-show-case/hello-world/package.json +6 -0
  210. package/plugins/@vcmap-show-case/hello-world/plugin-assets/vcs_logo.png +0 -0
  211. package/plugins/@vcmap-show-case/hello-world/src/defaultOptions.js +4 -0
  212. package/plugins/@vcmap-show-case/hello-world/src/helloWorld.vue +69 -0
  213. package/plugins/@vcmap-show-case/hello-world/src/index.js +142 -0
  214. package/plugins/@vcmap-show-case/hello-world/tests/helloWorld.spec.js +53 -0
  215. package/plugins/@vcmap-show-case/icons-example/README.md +5 -0
  216. package/plugins/@vcmap-show-case/icons-example/package.json +5 -0
  217. package/plugins/@vcmap-show-case/icons-example/src/AllIconsComponent.vue +51 -0
  218. package/plugins/@vcmap-show-case/icons-example/src/index.js +46 -0
  219. package/plugins/@vcmap-show-case/list-example/README.md +3 -0
  220. package/plugins/@vcmap-show-case/list-example/package.json +5 -0
  221. package/plugins/@vcmap-show-case/list-example/src/ListExample.vue +411 -0
  222. package/plugins/@vcmap-show-case/list-example/src/index.js +46 -0
  223. package/plugins/@vcmap-show-case/notifier-tester/README.md +3 -0
  224. package/plugins/@vcmap-show-case/notifier-tester/package.json +5 -0
  225. package/plugins/@vcmap-show-case/notifier-tester/src/NotifierTester.vue +82 -0
  226. package/plugins/@vcmap-show-case/notifier-tester/src/index.js +42 -0
  227. package/plugins/@vcmap-show-case/plugin-editors/README.md +4 -0
  228. package/plugins/@vcmap-show-case/plugin-editors/package.json +5 -0
  229. package/plugins/@vcmap-show-case/plugin-editors/src/PluginEditors.vue +119 -0
  230. package/plugins/@vcmap-show-case/plugin-editors/src/index.js +41 -0
  231. package/plugins/@vcmap-show-case/project-selector/README.md +25 -0
  232. package/plugins/@vcmap-show-case/project-selector/config.json +15 -0
  233. package/plugins/{@vcmap → @vcmap-show-case}/project-selector/package.json +3 -4
  234. package/plugins/{@vcmap/project-selector/ContextsListComponent.vue → @vcmap-show-case/project-selector/src/ModulesListComponent.vue} +22 -19
  235. package/plugins/@vcmap-show-case/project-selector/src/ProjectSelectorComponent.vue +102 -0
  236. package/plugins/@vcmap-show-case/project-selector/src/de.json +10 -0
  237. package/plugins/@vcmap-show-case/project-selector/src/en.json +10 -0
  238. package/plugins/@vcmap-show-case/project-selector/src/index.js +269 -0
  239. package/plugins/@vcmap-show-case/simple-graph/README.md +71 -0
  240. package/plugins/@vcmap-show-case/simple-graph/package.json +11 -0
  241. package/plugins/@vcmap-show-case/simple-graph/src/SimpleGraphComponent.vue +59 -0
  242. package/plugins/@vcmap-show-case/simple-graph/src/index.js +17 -0
  243. package/plugins/@vcmap-show-case/simple-graph/src/simpleGraphView.js +78 -0
  244. package/plugins/@vcmap-show-case/style-input-example/README.md +4 -0
  245. package/plugins/@vcmap-show-case/style-input-example/package.json +5 -0
  246. package/plugins/@vcmap-show-case/style-input-example/src/StyleExample.vue +190 -0
  247. package/plugins/@vcmap-show-case/style-input-example/src/index.js +42 -0
  248. package/plugins/@vcmap-show-case/switch-map-callback-example/README.md +21 -0
  249. package/plugins/@vcmap-show-case/switch-map-callback-example/config.json +3 -0
  250. package/plugins/@vcmap-show-case/switch-map-callback-example/package.json +5 -0
  251. package/plugins/@vcmap-show-case/switch-map-callback-example/src/index.js +34 -0
  252. package/plugins/@vcmap-show-case/switch-map-callback-example/src/switchMapCallback.js +47 -0
  253. package/plugins/@vcmap-show-case/table-example/README.md +3 -0
  254. package/plugins/@vcmap-show-case/table-example/package.json +5 -0
  255. package/plugins/@vcmap-show-case/table-example/src/DataTableExample.vue +187 -0
  256. package/plugins/@vcmap-show-case/table-example/src/index.js +49 -0
  257. package/plugins/@vcmap-show-case/textfields-example/README.md +3 -0
  258. package/plugins/@vcmap-show-case/textfields-example/package.json +5 -0
  259. package/plugins/{example/mySuperComponent.vue → @vcmap-show-case/textfields-example/src/TextfieldsExample.vue} +13 -31
  260. package/plugins/@vcmap-show-case/textfields-example/src/index.js +64 -0
  261. package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/README.md +5 -3
  262. package/plugins/@vcmap-show-case/theme-changer/config.json +69 -0
  263. package/plugins/@vcmap-show-case/theme-changer/package.json +11 -0
  264. package/plugins/{@vcmap/theme-changer → @vcmap-show-case/theme-changer/src}/ThemeChangerComponent.vue +36 -8
  265. package/plugins/{@vcmap/theme-changer → @vcmap-show-case/theme-changer/src}/index.js +14 -8
  266. package/plugins/@vcmap-show-case/vector-properties-example/package.json +5 -0
  267. package/plugins/@vcmap-show-case/vector-properties-example/src/VectorPropertiesExample.vue +128 -0
  268. package/plugins/@vcmap-show-case/vector-properties-example/src/index.js +40 -0
  269. package/plugins/@vcmap-show-case/window-tester/README.md +3 -0
  270. package/plugins/@vcmap-show-case/window-tester/package.json +5 -0
  271. package/plugins/@vcmap-show-case/window-tester/src/EmptyComponent.vue +18 -0
  272. package/plugins/@vcmap-show-case/window-tester/src/MyCustomHeader.vue +31 -0
  273. package/plugins/@vcmap-show-case/window-tester/src/WindowExample.vue +185 -0
  274. package/plugins/@vcmap-show-case/window-tester/src/WindowExampleContent.vue +18 -0
  275. package/plugins/@vcmap-show-case/window-tester/src/WindowExampleToggleChild.vue +45 -0
  276. package/plugins/@vcmap-show-case/window-tester/src/index.js +80 -0
  277. package/plugins/@vcmap-show-case/window-tester/src/toolboxData.js +288 -0
  278. package/plugins/@vcmap-show-case/wizard-example/README.md +3 -0
  279. package/plugins/@vcmap-show-case/wizard-example/package.json +5 -0
  280. package/plugins/@vcmap-show-case/wizard-example/src/WizardExample.vue +127 -0
  281. package/plugins/@vcmap-show-case/wizard-example/src/index.js +53 -0
  282. package/plugins/package.json +9 -2
  283. package/public/assets/@mdi/font/LICENSE +20 -0
  284. package/public/assets/@mdi/font/css/materialdesignicons.css.map +16 -0
  285. package/public/assets/@mdi/font/css/materialdesignicons.min.css +3 -0
  286. package/public/assets/@mdi/font/fonts/materialdesignicons-webfont.woff2 +0 -0
  287. package/public/assets/favicon-128.png +0 -0
  288. package/public/assets/favicon-180.png +0 -0
  289. package/public/assets/favicon-192.png +0 -0
  290. package/public/assets/favicon-32.png +0 -0
  291. package/public/assets/favicon.svg +10 -0
  292. package/public/assets/font/OFL.txt +93 -0
  293. package/public/assets/font/TitilliumWeb-Regular.woff2 +0 -0
  294. package/public/assets/style/icon-marker-blue.png +0 -0
  295. package/public/assets/style/icon-marker-green.png +0 -0
  296. package/public/assets/style/icon-marker-o-blue.png +0 -0
  297. package/public/assets/style/icon-marker-o-green.png +0 -0
  298. package/public/assets/style/icon-marker-o-red.png +0 -0
  299. package/public/assets/style/icon-marker-o.png +0 -0
  300. package/public/assets/style/icon-marker-red.png +0 -0
  301. package/public/assets/style/icon-marker.png +0 -0
  302. package/public/assets/style/icon-pin-blue.png +0 -0
  303. package/public/assets/style/icon-pin-green.png +0 -0
  304. package/public/assets/style/icon-pin-red.png +0 -0
  305. package/public/assets/style/icon-pin.png +0 -0
  306. package/src/actions/StyleSelector.vue +136 -0
  307. package/src/actions/actionHelper.js +203 -50
  308. package/src/actions/stateRefAction.js +2 -3
  309. package/src/application/VcsApp.vue +538 -98
  310. package/src/application/VcsAppWrapper.vue +32 -0
  311. package/src/application/VcsAttributions.vue +83 -0
  312. package/src/application/VcsAttributionsFooter.vue +83 -0
  313. package/src/application/VcsMap.vue +22 -5
  314. package/src/application/VcsNavbar.vue +217 -0
  315. package/src/application/VcsSettings.vue +98 -0
  316. package/src/application/attributionsHelper.js +162 -0
  317. package/src/callback/activateLayersCallback.js +54 -0
  318. package/src/callback/applyLayerStyleCallback.js +63 -0
  319. package/src/callback/deactivateLayersCallback.js +54 -0
  320. package/src/callback/goToViewpointCallback.js +54 -0
  321. package/src/callback/vcsCallback.js +66 -0
  322. package/src/components/ImageElementInjector.vue +24 -0
  323. package/src/components/buttons/VcsActionButtonList.vue +52 -22
  324. package/src/components/buttons/VcsButton.vue +60 -110
  325. package/src/components/buttons/VcsFormButton.vue +178 -0
  326. package/src/components/buttons/VcsToolButton.vue +161 -0
  327. package/src/components/form-inputs-controls/VcsCheckbox.vue +62 -20
  328. package/src/components/form-inputs-controls/VcsChipArrayInput.vue +290 -0
  329. package/src/components/form-inputs-controls/VcsDatePicker.vue +156 -0
  330. package/src/components/form-inputs-controls/VcsFormSection.vue +120 -16
  331. package/src/components/form-inputs-controls/VcsLabel.vue +29 -11
  332. package/src/components/form-inputs-controls/VcsRadio.vue +149 -0
  333. package/src/components/form-inputs-controls/VcsRadioGrid.vue +175 -0
  334. package/src/components/form-inputs-controls/VcsSelect.vue +164 -50
  335. package/src/components/form-inputs-controls/VcsSlider.vue +73 -0
  336. package/src/components/form-inputs-controls/VcsTextArea.vue +118 -68
  337. package/src/components/form-inputs-controls/VcsTextField.vue +238 -69
  338. package/src/components/form-inputs-controls/VcsWizard.vue +137 -0
  339. package/src/components/form-inputs-controls/VcsWizardStep.vue +161 -0
  340. package/src/components/form-inputs-controls/composables.js +31 -0
  341. package/src/components/form-output/VcsFormattedNumber.vue +28 -28
  342. package/src/{icons → components/icons}/+all.js +109 -5
  343. package/src/components/icons/2DAreaIcon.vue +58 -0
  344. package/src/components/icons/2DDistanceIcon.vue +24 -0
  345. package/src/components/icons/3DAreaIcon.vue +58 -0
  346. package/src/components/icons/3DDistanceIcon.vue +24 -0
  347. package/src/components/icons/3DHeightIcon.vue +24 -0
  348. package/src/components/icons/AngleIcon.vue +16 -0
  349. package/src/{icons → components/icons}/AssociationsIcon.vue +7 -4
  350. package/src/components/icons/AxisIcon.vue +35 -0
  351. package/src/components/icons/BoundingBoxIcon.vue +38 -0
  352. package/src/components/icons/CheckboxCheckedIcon.vue +12 -0
  353. package/src/components/icons/CheckboxIcon.vue +21 -0
  354. package/src/components/icons/CheckboxIndeterminateIcon.vue +10 -0
  355. package/src/components/icons/CircleIcon.vue +25 -0
  356. package/src/components/icons/ClippingHorizontalIcon.vue +18 -0
  357. package/src/components/icons/ClippingIcon.vue +17 -0
  358. package/src/components/icons/ClippingVerticalIcon.vue +18 -0
  359. package/src/components/icons/ColorPickerIcon.vue +17 -0
  360. package/src/{icons → components/icons}/ColorSwatchIcon.vue +6 -2
  361. package/src/{icons → components/icons}/CommentIcon.vue +6 -6
  362. package/src/components/icons/CompassIcon.vue +24 -0
  363. package/src/components/icons/ComponentsIcon.vue +18 -0
  364. package/src/components/icons/ConeIcon.vue +30 -0
  365. package/src/components/icons/DimensionsHouseIcon.vue +20 -0
  366. package/src/components/icons/EditIcon.vue +17 -0
  367. package/src/components/icons/EditVerticesIcon.vue +35 -0
  368. package/src/{icons → components/icons}/ElevationProfileIcon.vue +7 -14
  369. package/src/components/icons/ExportAreaIcon.vue +17 -0
  370. package/src/components/icons/ExportFlightIcon.vue +17 -0
  371. package/src/components/icons/ExportIcon.vue +24 -0
  372. package/src/components/icons/ExternalLinkIcon.vue +23 -0
  373. package/src/components/icons/EyeIcon.vue +17 -0
  374. package/src/components/icons/FastForwardIcon.vue +17 -0
  375. package/src/components/icons/FilterIcon.vue +18 -0
  376. package/src/components/icons/GlobalTerrainIcon.vue +19 -0
  377. package/src/components/icons/GlobeNatureIcon.vue +17 -0
  378. package/src/components/icons/GroundIcon.vue +27 -0
  379. package/src/{icons → components/icons}/HealthCareIndustriesIcon.vue +7 -12
  380. package/src/components/icons/HelpIcon.vue +17 -0
  381. package/src/components/icons/HideIcon.vue +25 -0
  382. package/src/components/icons/HomePointIcon.vue +17 -0
  383. package/src/{icons → components/icons}/HospitalsIcon.vue +7 -21
  384. package/src/components/icons/HouseIcon.vue +32 -0
  385. package/src/components/icons/ImportIcon.vue +18 -0
  386. package/src/components/icons/InfoIcon.vue +24 -0
  387. package/src/{icons → components/icons}/KebabIcon.vue +7 -5
  388. package/src/components/icons/LabelIcon.vue +23 -0
  389. package/src/{icons → components/icons}/LayersIcon.vue +7 -5
  390. package/src/components/icons/LegendIcon.vue +24 -0
  391. package/src/components/icons/LineIcon.vue +22 -0
  392. package/src/components/icons/LinkIcon.vue +17 -0
  393. package/src/components/icons/LogoutIcon.vue +17 -0
  394. package/src/components/icons/MapIcon.vue +18 -0
  395. package/src/{icons → components/icons}/MenuIcon.vue +7 -5
  396. package/src/components/icons/MinusIcon.vue +18 -0
  397. package/src/components/icons/ObjectAttributeIcon.vue +18 -0
  398. package/src/components/icons/ObjectSelectIcon.vue +18 -0
  399. package/src/components/icons/ObliqueViewIcon.vue +19 -0
  400. package/src/components/icons/PdfIcon.vue +19 -0
  401. package/src/components/icons/PedestrianIcon.vue +17 -0
  402. package/src/components/icons/PenIcon.vue +16 -0
  403. package/src/components/icons/PlayCircleIcon.vue +20 -0
  404. package/src/components/icons/PlusIcon.vue +18 -0
  405. package/src/components/icons/PoiIcon.vue +23 -0
  406. package/src/{icons/PolygonIcon.vue → components/icons/PointIcon.vue} +8 -6
  407. package/src/components/icons/PointSelectIcon.vue +18 -0
  408. package/src/components/icons/PresentationModeIcon.vue +17 -0
  409. package/src/{icons → components/icons}/ProgressIcon.vue +9 -7
  410. package/src/components/icons/QueryIcon.vue +39 -0
  411. package/src/components/icons/RectangleIcon.vue +24 -0
  412. package/src/components/icons/ReturnIcon.vue +17 -0
  413. package/src/components/icons/RewindIcon.vue +16 -0
  414. package/src/components/icons/RotateLeftIcon.vue +17 -0
  415. package/src/components/icons/RotateRightIcon.vue +17 -0
  416. package/src/components/icons/ScreenshotIcon.vue +53 -0
  417. package/src/components/icons/SearchIcon.vue +17 -0
  418. package/src/components/icons/ShadowIcon.vue +18 -0
  419. package/src/{icons → components/icons}/ShapesIcon.vue +13 -6
  420. package/src/components/icons/ShareIcon.vue +22 -0
  421. package/src/components/icons/SimpleCircleFilledIcon.vue +18 -0
  422. package/src/{icons → components/icons}/SimpleCircleHalfFilledIcon.vue +6 -2
  423. package/src/components/icons/SimpleCircleOutlinedIcon.vue +13 -0
  424. package/src/components/icons/SkipNextIcon.vue +18 -0
  425. package/src/components/icons/SkipPreviousIcon.vue +18 -0
  426. package/src/{icons → components/icons}/SplitViewIcon.vue +6 -6
  427. package/src/components/icons/TerrainBoxIcon.vue +19 -0
  428. package/src/components/icons/TextStyleIcon.vue +17 -0
  429. package/src/components/icons/ThreeDimensionsIcon.vue +17 -0
  430. package/src/components/icons/ToolsIcon.vue +16 -0
  431. package/src/components/icons/TouchIcon.vue +18 -0
  432. package/src/components/icons/TrashCanIcon.vue +18 -0
  433. package/src/components/icons/TriangleIcon.vue +16 -0
  434. package/src/components/icons/TwoDimensionsIcon.vue +18 -0
  435. package/src/components/icons/UploadIcon.vue +17 -0
  436. package/src/components/icons/UserProfileIcon.vue +17 -0
  437. package/src/components/icons/UserShareIcon.vue +16 -0
  438. package/src/components/icons/VideoRecorderIcon.vue +23 -0
  439. package/src/components/icons/ViewpointFlightIcon.vue +28 -0
  440. package/src/components/icons/ViewpointIcon.vue +28 -0
  441. package/src/components/icons/Viewshed360Icon.vue +18 -0
  442. package/src/components/icons/ViewshedConeIcon.vue +17 -0
  443. package/src/components/icons/ViewshedIcon.vue +18 -0
  444. package/src/components/icons/WalkingIcon.vue +17 -0
  445. package/src/components/icons/WallIcon.vue +22 -0
  446. package/src/components/icons/WandIcon.vue +123 -0
  447. package/src/components/lists/VcsActionList.vue +57 -25
  448. package/src/components/lists/VcsList.vue +593 -0
  449. package/src/components/lists/VcsTreeview.vue +45 -42
  450. package/src/components/lists/VcsTreeviewLeaf.vue +45 -69
  451. package/src/components/lists/VcsTreeviewSearchbar.vue +40 -48
  452. package/src/components/notification/VcsBadge.vue +6 -4
  453. package/src/components/notification/VcsHelp.vue +39 -0
  454. package/src/components/notification/VcsTooltip.vue +111 -105
  455. package/src/components/notification/validation.js +1 -1
  456. package/src/components/plugins/AbstractConfigEditor.vue +84 -0
  457. package/src/components/style/MenuWrapper.vue +140 -0
  458. package/src/components/style/VcsFillMenu.vue +61 -0
  459. package/src/components/style/VcsFillSelector.vue +45 -0
  460. package/src/components/style/VcsImageMenu.vue +83 -0
  461. package/src/components/style/VcsImageSelector.vue +986 -0
  462. package/src/components/style/VcsStrokeMenu.vue +73 -0
  463. package/src/components/style/VcsStrokeSelector.vue +88 -0
  464. package/src/components/style/VcsTextMenu.vue +81 -0
  465. package/src/components/style/VcsTextSelector.vue +269 -0
  466. package/src/components/style/VcsVectorStyleComponent.vue +114 -0
  467. package/src/components/style/composables.js +84 -0
  468. package/src/components/tables/VcsDataTable.vue +503 -0
  469. package/src/components/tables/VcsTable.vue +145 -0
  470. package/src/components/vector-properties/VcsVectorPropertiesComponent.vue +778 -0
  471. package/src/components/vector-properties/composables.js +93 -0
  472. package/src/contentTree/LayerTree.vue +18 -14
  473. package/src/contentTree/contentTreeCollection.js +109 -41
  474. package/src/contentTree/contentTreeItem.js +109 -43
  475. package/src/contentTree/groupContentTreeItem.js +46 -23
  476. package/src/contentTree/layerContentTreeItem.js +54 -23
  477. package/src/contentTree/layerGroupContentTreeItem.js +58 -26
  478. package/src/contentTree/nodeContentTreeItem.js +19 -8
  479. package/src/contentTree/obliqueCollectionContentTreeItem.js +51 -22
  480. package/src/contentTree/subContentTreeItem.js +14 -5
  481. package/src/contentTree/vcsObjectContentTreeItem.js +27 -16
  482. package/src/contentTree/viewpointContentTreeItem.js +121 -0
  483. package/src/downloadHelper.js +52 -0
  484. package/src/featureInfo/AddressBalloonComponent.vue +58 -0
  485. package/src/featureInfo/BalloonComponent.vue +193 -0
  486. package/src/featureInfo/abstractFeatureInfoView.js +346 -0
  487. package/src/featureInfo/addressBalloonFeatureInfoView.js +130 -0
  488. package/src/featureInfo/balloonFeatureInfoView.js +159 -0
  489. package/src/featureInfo/balloonHelper.js +172 -0
  490. package/src/featureInfo/featureInfo.js +525 -0
  491. package/src/featureInfo/featureInfoInteraction.js +48 -0
  492. package/src/featureInfo/iframeFeatureInfoView.js +97 -0
  493. package/src/featureInfo/tableFeatureInfoView.js +120 -0
  494. package/src/i18n/de.js +195 -0
  495. package/src/i18n/en.js +195 -0
  496. package/src/i18n/i18nCollection.js +137 -0
  497. package/src/init.js +121 -36
  498. package/src/legend/StyleLegendItem.vue +176 -0
  499. package/src/legend/VcsLegend.vue +140 -0
  500. package/src/legend/legendHelper.js +204 -0
  501. package/src/manager/buttonManager.js +35 -16
  502. package/src/manager/collectionManager/CollectionComponent.vue +140 -0
  503. package/src/manager/collectionManager/CollectionComponentList.vue +77 -0
  504. package/src/manager/collectionManager/CollectionComponentProvider.vue +39 -0
  505. package/src/manager/collectionManager/CollectionManager.vue +62 -0
  506. package/src/manager/collectionManager/categoryManager.js +83 -0
  507. package/src/manager/collectionManager/collectionComponent.js +470 -0
  508. package/src/manager/collectionManager/collectionManager.js +432 -0
  509. package/src/manager/contextMenu/ContextMenuComponent.vue +43 -0
  510. package/src/manager/contextMenu/contextMenuInteraction.js +47 -0
  511. package/src/manager/contextMenu/contextMenuManager.js +220 -0
  512. package/src/manager/navbarManager.js +47 -13
  513. package/src/manager/toolbox/GroupToolboxComponent.vue +128 -0
  514. package/src/manager/toolbox/SelectToolboxComponent.vue +144 -0
  515. package/src/manager/toolbox/ToolboxManager.vue +124 -102
  516. package/src/manager/toolbox/toolboxManager.js +257 -87
  517. package/src/manager/window/WindowComponent.vue +105 -85
  518. package/src/manager/window/WindowComponentHeader.vue +115 -24
  519. package/src/manager/window/WindowManager.vue +121 -55
  520. package/src/manager/window/windowHelper.js +465 -0
  521. package/src/manager/window/windowManager.js +298 -87
  522. package/src/navigation/{mapNavCompass.vue → MapNavCompass.vue} +31 -11
  523. package/src/navigation/MapNavigation.vue +276 -0
  524. package/src/navigation/ObliqueRotation.vue +69 -0
  525. package/src/navigation/{orientationToolsButton.vue → OrientationToolsButton.vue} +13 -12
  526. package/src/navigation/{tiltSlider.vue → TiltSlider.vue} +39 -16
  527. package/src/navigation/VcsCompass.vue +69 -0
  528. package/src/navigation/VcsZoomButton.vue +52 -0
  529. package/src/navigation/overviewMap.js +142 -104
  530. package/src/navigation/overviewMapClickedInteraction.js +6 -1
  531. package/src/notifier/NotifierComponent.vue +86 -0
  532. package/src/notifier/notifier.js +129 -0
  533. package/src/pluginHelper.js +148 -20
  534. package/src/search/ResultItem.vue +83 -0
  535. package/src/search/ResultsComponent.vue +103 -0
  536. package/src/search/SearchComponent.vue +116 -0
  537. package/src/search/search.js +342 -0
  538. package/src/setup.js +9 -10
  539. package/src/state.js +272 -0
  540. package/src/styles/_theming.scss +69 -21
  541. package/src/styles/_typography.scss +3 -6
  542. package/src/styles/main.scss +9 -0
  543. package/src/styles/shades.scss +4 -0
  544. package/src/styles/utils/_border.scss +1 -1
  545. package/src/styles/utils/_cursor.scss +4 -0
  546. package/src/styles/utils/_display.scss +1 -1
  547. package/src/styles/variables.scss +79 -11
  548. package/src/styles/vcsFont.scss +2 -5
  549. package/src/styles/vcsGrid.scss +9 -0
  550. package/src/uiConfig.js +83 -0
  551. package/src/vcsUiApp.js +508 -68
  552. package/src/vuePlugins/i18n.js +51 -13
  553. package/src/vuePlugins/vuetify.js +104 -43
  554. package/config/berlin.config.json +0 -529
  555. package/dist/assets/cesium/Workers/ArcType-fc72c06c.js +0 -1
  556. package/dist/assets/cesium/Workers/AttributeCompression-80665726.js +0 -1
  557. package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-a655a4bc.js +0 -1
  558. package/dist/assets/cesium/Workers/BoundingRectangle-c3b79029.js +0 -1
  559. package/dist/assets/cesium/Workers/BoxGeometry-f8f9c981.js +0 -1
  560. package/dist/assets/cesium/Workers/Color-de06a177.js +0 -1
  561. package/dist/assets/cesium/Workers/ComponentDatatype-a15c9a19.js +0 -1
  562. package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-48cdc26d.js +0 -1
  563. package/dist/assets/cesium/Workers/CorridorGeometryLibrary-ddc027d3.js +0 -1
  564. package/dist/assets/cesium/Workers/CylinderGeometry-82a8cbe6.js +0 -1
  565. package/dist/assets/cesium/Workers/CylinderGeometryLibrary-76cda53e.js +0 -1
  566. package/dist/assets/cesium/Workers/EllipseGeometry-32d55454.js +0 -1
  567. package/dist/assets/cesium/Workers/EllipseGeometryLibrary-b2ae188a.js +0 -1
  568. package/dist/assets/cesium/Workers/EllipseOutlineGeometry-f05a5a27.js +0 -1
  569. package/dist/assets/cesium/Workers/EllipsoidGeodesic-19e75e11.js +0 -1
  570. package/dist/assets/cesium/Workers/EllipsoidGeometry-7c99fc81.js +0 -1
  571. package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-21c243df.js +0 -1
  572. package/dist/assets/cesium/Workers/EllipsoidRhumbLine-6145377b.js +0 -1
  573. package/dist/assets/cesium/Workers/EllipsoidTangentPlane-a01286f6.js +0 -1
  574. package/dist/assets/cesium/Workers/EncodedCartesian3-d9f5c4a4.js +0 -1
  575. package/dist/assets/cesium/Workers/FrustumGeometry-17776af8.js +0 -1
  576. package/dist/assets/cesium/Workers/GeometryAttribute-89a520b9.js +0 -1
  577. package/dist/assets/cesium/Workers/GeometryAttributes-32b29525.js +0 -1
  578. package/dist/assets/cesium/Workers/GeometryInstance-4fbf16ba.js +0 -1
  579. package/dist/assets/cesium/Workers/GeometryOffsetAttribute-8c5e10db.js +0 -1
  580. package/dist/assets/cesium/Workers/GeometryPipeline-309fad76.js +0 -1
  581. package/dist/assets/cesium/Workers/IndexDatatype-f1dcdf35.js +0 -1
  582. package/dist/assets/cesium/Workers/IntersectionTests-58aa8f80.js +0 -1
  583. package/dist/assets/cesium/Workers/Matrix2-47e98d76.js +0 -1
  584. package/dist/assets/cesium/Workers/OrientedBoundingBox-fcb5b750.js +0 -1
  585. package/dist/assets/cesium/Workers/Plane-3f01019d.js +0 -1
  586. package/dist/assets/cesium/Workers/PolygonGeometryLibrary-0b29eb16.js +0 -1
  587. package/dist/assets/cesium/Workers/PolygonPipeline-a934c4dd.js +0 -1
  588. package/dist/assets/cesium/Workers/PolylinePipeline-8095c9bc.js +0 -1
  589. package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-67d12fff.js +0 -1
  590. package/dist/assets/cesium/Workers/PrimitivePipeline-980e44c5.js +0 -1
  591. package/dist/assets/cesium/Workers/RectangleGeometryLibrary-621c6de8.js +0 -1
  592. package/dist/assets/cesium/Workers/RuntimeError-8952249c.js +0 -1
  593. package/dist/assets/cesium/Workers/TerrainEncoding-f96552d5.js +0 -1
  594. package/dist/assets/cesium/Workers/Transforms-c8cb8f43.js +0 -39
  595. package/dist/assets/cesium/Workers/VertexFormat-a0b706b0.js +0 -1
  596. package/dist/assets/cesium/Workers/WallGeometryLibrary-c03d8479.js +0 -1
  597. package/dist/assets/cesium/Workers/WebGLConstants-508b9636.js +0 -1
  598. package/dist/assets/cesium/Workers/WebMercatorProjection-79b3214e.js +0 -1
  599. package/dist/assets/cesium/Workers/_commonjsHelpers-3aae1032-26891ab7.js +0 -1
  600. package/dist/assets/cesium/Workers/_rollup_plugin_ignore_empty_module_placeholder-57d574d0.js +0 -1
  601. package/dist/assets/cesium/Workers/arrayRemoveDuplicates-dc2f4046.js +0 -1
  602. package/dist/assets/cesium/Workers/cesiumWorkerBootstrapper.js +0 -6
  603. package/dist/assets/cesium/Workers/combine-3c023bda.js +0 -1
  604. package/dist/assets/cesium/Workers/defaultValue-81eec7ed.js +0 -1
  605. package/dist/assets/cesium.4e40f4.js +0 -9105
  606. package/dist/assets/core.edcf5e.js +0 -4
  607. package/dist/assets/index.60dea538.css +0 -1
  608. package/dist/assets/index.889d0f3a.js +0 -1
  609. package/dist/assets/ol.246fd4.js +0 -318
  610. package/dist/assets/ui.df4f6d.css +0 -1
  611. package/dist/assets/ui.df4f6d.js +0 -43
  612. package/dist/assets/vue-composition-api.a520f3.js +0 -14
  613. package/dist/assets/vue-composition-api.js +0 -2
  614. package/dist/assets/vue.2cee44.js +0 -9
  615. package/dist/assets/vuetify.cc817b.css +0 -5
  616. package/dist/assets/vuetify.cc817b.js +0 -48
  617. package/lib/vue-composition-api.js +0 -2
  618. package/map.config.json +0 -35
  619. package/plugins/@vcmap/pluginExample/config.json +0 -6
  620. package/plugins/@vcmap/pluginExample/package.json +0 -7
  621. package/plugins/@vcmap/pluginExample/pluginExampleComponent.vue +0 -374
  622. package/plugins/@vcmap/project-selector/ProjectSelectorComponent.vue +0 -81
  623. package/plugins/@vcmap/project-selector/README.md +0 -29
  624. package/plugins/@vcmap/project-selector/config.json +0 -15
  625. package/plugins/@vcmap/project-selector/index.js +0 -254
  626. package/plugins/@vcmap/theme-changer/config.json +0 -69
  627. package/plugins/@vcmap/theme-changer/package.json +0 -12
  628. package/plugins/buttonExamples/ButtonExamples.vue +0 -190
  629. package/plugins/buttonExamples/index.js +0 -41
  630. package/plugins/categoryTest/Categories.vue +0 -145
  631. package/plugins/categoryTest/Category.vue +0 -114
  632. package/plugins/categoryTest/ItemEditor.vue +0 -13
  633. package/plugins/categoryTest/index.js +0 -41
  634. package/plugins/example/index.js +0 -75
  635. package/plugins/test/allIconsComponent.vue +0 -34
  636. package/plugins/test/editor.vue +0 -63
  637. package/plugins/test/index.js +0 -116
  638. package/plugins/test/myCustomHeader.vue +0 -19
  639. package/plugins/test/toolbox-data.js +0 -129
  640. package/plugins/test/vcsContent.vue +0 -23
  641. package/plugins/test/windowManagerExample.vue +0 -143
  642. package/src/actions/styleSelector.vue +0 -90
  643. package/src/application/Navbar.vue +0 -130
  644. package/src/application/empty-cmp.vue +0 -6
  645. package/src/components/form-inputs-controls/VcsColorPicker.vue +0 -81
  646. package/src/contentTree/viewPointContentTreeItem.js +0 -107
  647. package/src/icons/2DAreaIcon.vue +0 -21
  648. package/src/icons/2DDistanceIcon.vue +0 -18
  649. package/src/icons/3DAreaIcon.vue +0 -21
  650. package/src/icons/3DDistanceIcon.vue +0 -18
  651. package/src/icons/3DHeightIcon.vue +0 -18
  652. package/src/icons/AngleIcon.vue +0 -8
  653. package/src/icons/AxisIcon.vue +0 -10
  654. package/src/icons/BoundingBoxIcon.vue +0 -15
  655. package/src/icons/CheckboxCheckedIcon.vue +0 -16
  656. package/src/icons/CheckboxIcon.vue +0 -23
  657. package/src/icons/CheckboxIndeterminateIcon.vue +0 -24
  658. package/src/icons/CircleIcon.vue +0 -10
  659. package/src/icons/CompassIcon.vue +0 -8
  660. package/src/icons/ComponentsIcon.vue +0 -7
  661. package/src/icons/ConeIcon.vue +0 -11
  662. package/src/icons/DimensionsHouseIcon.vue +0 -14
  663. package/src/icons/ExportAreaIcon.vue +0 -7
  664. package/src/icons/ExportFlightIcon.vue +0 -7
  665. package/src/icons/ExportIcon.vue +0 -8
  666. package/src/icons/ExternalLinkIcon.vue +0 -10
  667. package/src/icons/EyeIcon.vue +0 -7
  668. package/src/icons/FastForwardIcon.vue +0 -7
  669. package/src/icons/FilterIcon.vue +0 -8
  670. package/src/icons/GlobeNatureIcon.vue +0 -14
  671. package/src/icons/HelpIcon.vue +0 -7
  672. package/src/icons/HomePointIcon.vue +0 -8
  673. package/src/icons/HouseIcon.vue +0 -25
  674. package/src/icons/ImportIcon.vue +0 -8
  675. package/src/icons/InfoIcon.vue +0 -10
  676. package/src/icons/LabelIcon.vue +0 -7
  677. package/src/icons/LegendIcon.vue +0 -65
  678. package/src/icons/LineIcon.vue +0 -7
  679. package/src/icons/LinkIcon.vue +0 -7
  680. package/src/icons/MapIcon.vue +0 -8
  681. package/src/icons/MinusIcon.vue +0 -8
  682. package/src/icons/ObjectAttributeIcon.vue +0 -18
  683. package/src/icons/ObjectSelectIcon.vue +0 -8
  684. package/src/icons/ObliqueViewIcon.vue +0 -13
  685. package/src/icons/PdfIcon.vue +0 -10
  686. package/src/icons/PedestrianIcon.vue +0 -8
  687. package/src/icons/PenIcon.vue +0 -14
  688. package/src/icons/PlayCircleIcon.vue +0 -10
  689. package/src/icons/PlusIcon.vue +0 -9
  690. package/src/icons/PoiIcon.vue +0 -7
  691. package/src/icons/PointSelectIcon.vue +0 -7
  692. package/src/icons/PresentationModeIcon.vue +0 -7
  693. package/src/icons/QueryIcon.vue +0 -15
  694. package/src/icons/RectangleIcon.vue +0 -9
  695. package/src/icons/ReturnIcon.vue +0 -7
  696. package/src/icons/RewindIcon.vue +0 -6
  697. package/src/icons/SearchIcon.vue +0 -8
  698. package/src/icons/ShadowIcon.vue +0 -9
  699. package/src/icons/ShareIcon.vue +0 -22
  700. package/src/icons/SimpleCircleFilledIcon.vue +0 -15
  701. package/src/icons/SimpleCircleOutlinedIcon.vue +0 -15
  702. package/src/icons/SkipNextIcon.vue +0 -7
  703. package/src/icons/SkipPreviousIcon.vue +0 -9
  704. package/src/icons/TextStyleIcon.vue +0 -14
  705. package/src/icons/ThreeDimensionsIcon.vue +0 -7
  706. package/src/icons/ToolsIcon.vue +0 -35
  707. package/src/icons/TouchIcon.vue +0 -8
  708. package/src/icons/TrashCanIcon.vue +0 -7
  709. package/src/icons/TriangleIcon.vue +0 -15
  710. package/src/icons/TwoDimensionsIcon.vue +0 -8
  711. package/src/icons/UploadIcon.vue +0 -14
  712. package/src/icons/VideoRecorderIcon.vue +0 -14
  713. package/src/icons/WalkingIcon.vue +0 -7
  714. package/src/icons/WallIcon.vue +0 -14
  715. package/src/lang/de.js +0 -60
  716. package/src/lang/en.js +0 -53
  717. package/src/manager/toolbox/ToolboxGroupComponent.vue +0 -128
  718. package/src/navigation/mapNavigation.vue +0 -205
  719. package/src/navigation/obliqueRotation.vue +0 -48
  720. package/src/navigation/vcsCompass.vue +0 -144
  721. package/src/navigation/vcsZoomButton.vue +0 -27
  722. package/start.js +0 -3
  723. /package/src/{assets/logo-mobile.svg → logo-mobile.svg} +0 -0
  724. /package/src/{assets/logo.svg → logo.svg} +0 -0
@@ -1,79 +1,195 @@
1
- /* eslint-disable import/prefer-default-export */
2
1
  import { VcsEvent } from '@vcmap/core';
3
- import { reactive } from '@vue/composition-api';
4
2
  import { check, checkMaybe } from '@vcsuite/check';
5
3
  import { v4 as uuidv4 } from 'uuid';
6
- import { ButtonManager } from '../buttonManager.js';
4
+ import { reactive } from 'vue';
5
+ import { vcsAppSymbol } from '../../pluginHelper.js';
6
+ import ButtonManager from '../buttonManager.js';
7
+ import { ActionPattern } from '../../components/lists/VcsActionList.vue';
8
+ import { getActionFromOptions } from '../../actions/actionHelper.js';
7
9
 
8
10
  /**
9
- * @typedef ToolboxGroupComponentOptions
10
- * @property {string} [id] Optional ID, If not provided an uuid will be generated.
11
- * @property {string} [icon] Optional group icon, for dropdowns
12
- * @property {string} [title] Optional group title, for dropdowns
11
+ * Possible group types. Define behaviour of group:
12
+ * @property {number} SINGLE - SingleToolboxComponent with single toggle action rendered as VcsButton
13
+ * @property {number} SELECT - SelectToolboxComponent with one selected item of a list of items
14
+ * @property {number} GROUP - GroupToolboxComponent with multiple non-exclusive items rendered as VcsButton
15
+ * @enum {number}
13
16
  */
17
+ export const ToolboxType = {
18
+ SINGLE: 0,
19
+ SELECT: 1,
20
+ GROUP: 2,
21
+ };
14
22
 
15
23
  /**
16
- * @typedef ToolboxGroupComponent
24
+ * @typedef {Object} ToolboxComponentOptions
25
+ * @property {string} [id] - Optional ID, If not provided an uuid will be generated.
26
+ * @property {ToolboxType} type - Group type, defining the behaviour of the group
27
+ */
28
+
29
+ /**
30
+ * @typedef {ToolboxComponentOptions} SingleToolboxComponentOptions
31
+ * @property {VcsAction} action - An action of a single tool
32
+ */
33
+
34
+ /**
35
+ * @typedef {ToolboxComponentOptions} SelectToolboxComponentOptions
36
+ * @property {ToolboxSelectAction} action - An action determining the behaviour of the select group
37
+ */
38
+
39
+ /**
40
+ * @typedef {ToolboxComponentOptions} GroupToolboxComponentOptions
41
+ * @property {string} icon - Group icon
42
+ * @property {string} [title] - Optional group title, for dropdown
43
+ * @property {boolean} [disabled=false]
44
+ */
45
+
46
+ /**
47
+ * @typedef {Object} ToolboxComponent
17
48
  * @property {string} id
18
- * @property {string} title
49
+ * @property {ToolboxType} type - Group type, defining the behaviour of the group
50
+ * @property {string|vcsAppSymbol} owner
51
+ */
52
+
53
+ /**
54
+ * @typedef {ToolboxComponent} SingleToolboxComponent
55
+ * @property {VcsAction} action
56
+ */
57
+
58
+ /**
59
+ * @typedef {ToolboxComponent} GroupToolboxComponent
60
+ * @property {string|undefined} icon
61
+ * @property {string|undefined} title
19
62
  * @property {ButtonManager} buttonManager
63
+ * @property {boolean} [disabled=false]
64
+ */
65
+
66
+ /**
67
+ * @typedef {ToolboxComponent} SelectToolboxComponent
68
+ * @property {ToolboxSelectAction} action
69
+ */
70
+
71
+ /**
72
+ * @typedef {VcsAction} ToolboxSelectAction
73
+ * @property {function(index:number):void} selected - A callback determining the select behavior of the group. Should set the currentIndex.
74
+ * @property {Array<ToolboxSelectItem>} tools - A list of exclusive tools belonging to the group
75
+ * @property {number} currentIndex - Index of the current item
76
+ */
77
+
78
+ /**
79
+ * @typedef {Object} ToolboxSelectItem
80
+ * @property {string} name
81
+ * @property {string} [title]
82
+ * @property {string} icon
83
+ * @property {boolean} [disabled=false]
20
84
  */
21
85
 
22
86
  /**
23
87
  * Default groups predefining icon and title of the group
24
- * @type {Array<ToolboxGroupComponentOptions>}
88
+ * @type {Array<ToolboxComponentOptions>}
25
89
  */
26
90
  const defaultGroups = [
27
- {
28
- id: 'select',
29
- icon: '$vcsPen',
30
- title: 'select',
31
- },
32
- {
33
- id: 'measurement',
34
- icon: '$vcsDimensionsHouse',
35
- title: 'measurement',
36
- },
37
91
  {
38
92
  id: 'flight',
93
+ type: ToolboxType.GROUP,
39
94
  icon: '$vcsVideoRecorder',
40
- title: 'flight',
95
+ title: 'toolbox.flight',
96
+ },
97
+ {
98
+ id: 'miscellaneous',
99
+ type: ToolboxType.GROUP,
100
+ icon: 'mdi-dots-grid',
101
+ title: 'toolbox.miscellaneous',
41
102
  },
42
103
  ];
43
104
 
44
105
  /**
45
- * Requests default groups for a toolboxManager.
106
+ * Default order of toolboxComponents shown in the toolbox
107
+ * @type {string[]}
108
+ */
109
+ const defaultOrder = ['featureInfo', 'flight'];
110
+
111
+ /**
112
+ * sorts by owner and optionally plugin order
113
+ * If both components are owned by vcsApp, defaultOrder is used to compare
114
+ * @param {ToolboxComponent|ButtonComponent} compA
115
+ * @param {ToolboxComponent|ButtonComponent} compB
116
+ * @param {string[]} [order] order of owners to sort by
117
+ * @returns {number}
118
+ */
119
+ export function sortByOwner(compA, compB, order = []) {
120
+ const sorted = [vcsAppSymbol, ...order];
121
+ let indexA = sorted.indexOf(compA.owner);
122
+ let indexB = sorted.indexOf(compB.owner);
123
+
124
+ if (compA.owner === vcsAppSymbol && compB.owner === vcsAppSymbol) {
125
+ indexA = defaultOrder.indexOf(compA.id);
126
+ indexB = defaultOrder.indexOf(compB.id);
127
+ }
128
+
129
+ if (indexA === indexB) {
130
+ return 0;
131
+ }
132
+
133
+ if (indexA === -1) {
134
+ return 1;
135
+ }
136
+
137
+ if (indexB === -1) {
138
+ return -1;
139
+ }
140
+ return indexA - indexB;
141
+ }
142
+
143
+ /**
144
+ * returns ToolboxComponents sorted by owner (or other sort function)
145
+ * @param {Array<ToolboxComponent|ButtonComponent>} components
146
+ * @param {string[]} [order] optional order to sort by (plugin names)
147
+ * @param {function(ownerA:string, ownerB:string, order: string[]):number} [compareFn=sortByOwner] Per default components are sorted by owner: app first, then plugins
148
+ * @returns {Array<ToolboxComponent|ButtonComponent>}
149
+ */
150
+ export function getComponentsByOrder(
151
+ components,
152
+ order = [],
153
+ compareFn = sortByOwner,
154
+ ) {
155
+ return [...components].sort((a, b) => compareFn(a, b, order));
156
+ }
157
+
158
+ /**
159
+ * Adds default groups for a toolboxManager.
46
160
  * Once requested, group id, icon and title are defined and cannot be changed or overwritten.
47
161
  * @param {ToolboxManager} toolboxManager
48
- * @param {Array<ToolboxGroupComponentOptions>} groups
162
+ * @param {Array<ToolboxComponentOptions>} groups
49
163
  */
50
164
  export function setupDefaultGroups(toolboxManager, groups = defaultGroups) {
51
- groups.forEach(({ id, icon, title }) => toolboxManager.requestGroup(id, icon, title));
165
+ groups.forEach((toolboxComponentOptions) =>
166
+ toolboxManager.add(toolboxComponentOptions, vcsAppSymbol),
167
+ );
52
168
  }
53
169
 
54
170
  /**
55
171
  * @class ToolboxManager
56
- * @description Manages a set of Toolbox Groups
57
- * @implements VcsComponentManager<ToolboxGroupComponent,ToolboxGroupComponentOptions>
172
+ * @description Manages a set of Toolbox Components
173
+ * @implements VcsComponentManager<ToolboxComponent,ToolboxComponentOptions>
58
174
  */
59
- export class ToolboxManager {
175
+ class ToolboxManager {
60
176
  constructor() {
61
177
  /**
62
- * @type {import("@vcmap/core").VcsEvent<ToolboxGroupComponent>}
178
+ * @type {import("@vcmap/core").VcsEvent<ToolboxComponent>}
63
179
  */
64
180
  this.added = new VcsEvent();
65
181
  /**
66
- * @type {import("@vcmap/core").VcsEvent<ToolboxGroupComponent>}
182
+ * @type {import("@vcmap/core").VcsEvent<ToolboxComponent>}
67
183
  */
68
184
  this.removed = new VcsEvent();
69
185
  /**
70
186
  * reactive ordered array of ids,
71
187
  * @type {Array<string>}
72
188
  */
73
- this.componentIds = reactive([]);
189
+ this.componentIds = [];
74
190
 
75
191
  /**
76
- * @type {Map<string, ToolboxGroupComponent>}
192
+ * @type {Map<string, ToolboxComponent>}
77
193
  * @private
78
194
  */
79
195
  this._toolboxGroups = new Map();
@@ -81,7 +197,7 @@ export class ToolboxManager {
81
197
 
82
198
  /**
83
199
  * @param {string} id
84
- * @returns {ToolboxGroupComponent}
200
+ * @returns {ToolboxComponent}
85
201
  */
86
202
  get(id) {
87
203
  return this._toolboxGroups.get(id);
@@ -96,103 +212,155 @@ export class ToolboxManager {
96
212
  }
97
213
 
98
214
  /**
99
- * Toolbox groups should be static. Removing them can lead to undefined behavior.
215
+ * removes a ToolboxComponent, Component will not be rendered anymore and will be destroyed.
216
+ * Add ToolboxComponent again to show the component again
100
217
  * @param {string} id
101
218
  */
102
219
  remove(id) {
103
220
  check(id, String);
104
- const toolboxGroupComponent = this._toolboxGroups.get(id);
105
- if (toolboxGroupComponent) {
221
+ const toolboxComponent = this._toolboxGroups.get(id);
222
+ if (toolboxComponent) {
106
223
  const index = this.componentIds.indexOf(id);
107
224
  this.componentIds.splice(index, 1);
108
225
  this._toolboxGroups.delete(id);
109
- this.removed.raiseEvent(toolboxGroupComponent);
110
- toolboxGroupComponent.buttonManager.destroy();
226
+ this.removed.raiseEvent(toolboxComponent);
227
+ if (toolboxComponent.buttonManager) {
228
+ toolboxComponent.buttonManager.destroy();
229
+ }
111
230
  }
112
231
  }
113
232
 
114
233
  /**
115
- * Do not call add directly. Use requestGroup for adding toolbox groups.
116
- * @param {ToolboxGroupComponentOptions} toolboxGroupComponentOptions
117
- * @throws {Error} if a buttonComponent with the same ID has already been added
118
- * @returns {ToolboxGroupComponent}
234
+ * adds a ToolboxComponent
235
+ * @param {SingleToolboxComponentOptions|SelectToolboxComponentOptions|GroupToolboxComponentOptions} toolboxComponentOptions
236
+ * @param {string|symbol} owner pluginName or vcsAppSymbol
237
+ * @throws {Error} if a toolboxComponent with the same ID has already been added
238
+ * @returns {SingleToolboxComponent|SelectToolboxComponent|GroupToolboxComponent}
119
239
  */
120
- add(toolboxGroupComponentOptions) {
121
- checkMaybe(toolboxGroupComponentOptions.id, String);
122
- checkMaybe(toolboxGroupComponentOptions.icon, String);
123
- checkMaybe(toolboxGroupComponentOptions.title, String);
240
+ add(toolboxComponentOptions, owner) {
241
+ checkMaybe(toolboxComponentOptions.id, String);
242
+ check(toolboxComponentOptions.type, Object.values(ToolboxType));
243
+ check(owner, [String, vcsAppSymbol]);
124
244
 
125
- if (toolboxGroupComponentOptions.id && this.has(toolboxGroupComponentOptions.id)) {
126
- throw new Error(`A toolGroup with id ${toolboxGroupComponentOptions.id} has already been registered.`);
245
+ if (toolboxComponentOptions.id && this.has(toolboxComponentOptions.id)) {
246
+ throw new Error(
247
+ `A toolGroup with id ${toolboxComponentOptions.id} has already been registered.`,
248
+ );
127
249
  }
128
- const id = toolboxGroupComponentOptions.id || uuidv4();
129
- const icon = toolboxGroupComponentOptions.icon || undefined;
130
- const title = toolboxGroupComponentOptions.title || undefined;
131
- const buttonManager = new ButtonManager();
250
+ const id = toolboxComponentOptions.id || uuidv4();
251
+ const { type } = toolboxComponentOptions;
132
252
 
133
253
  /**
134
- * @type {ToolboxGroupComponent}
254
+ * @type {ToolboxComponent}
135
255
  */
136
- const toolboxGroupComponent = {
256
+ let toolboxComponent = {
137
257
  get id() {
138
258
  return id;
139
259
  },
140
- get icon() {
141
- return icon;
260
+ get type() {
261
+ return type;
142
262
  },
143
- get title() {
144
- return title;
145
- },
146
- get buttonManager() {
147
- return buttonManager;
263
+ get owner() {
264
+ return owner;
148
265
  },
149
266
  };
150
267
 
151
- this._toolboxGroups.set(id, toolboxGroupComponent);
152
- this.componentIds.push(id);
153
- this.added.raiseEvent(toolboxGroupComponent);
154
- return toolboxGroupComponent;
155
- }
156
-
157
- /**
158
- * Returns an existing group or creates a new group. Add toolbox groups with this API.
159
- * @param {string} id
160
- * @param {string} [icon='mdi-select-group']
161
- * @param {string} [title='defaultGroup']
162
- * @returns {ToolboxGroupComponent}
163
- */
164
- requestGroup(id, icon = 'mdi-select-group', title = 'defaultGroup') {
165
- check(id, String);
166
- checkMaybe(icon, String);
167
- checkMaybe(title, String);
168
-
169
- if (this.has(id)) {
170
- return this.get(id);
268
+ if (type === ToolboxType.SINGLE) {
269
+ check(toolboxComponentOptions.action, ActionPattern);
270
+ const action = getActionFromOptions(toolboxComponentOptions.action);
271
+ /**
272
+ * @type {SingleToolboxComponent}
273
+ */
274
+ toolboxComponent = {
275
+ ...toolboxComponent,
276
+ get action() {
277
+ return reactive(action);
278
+ },
279
+ };
280
+ } else if (type === ToolboxType.SELECT) {
281
+ check(toolboxComponentOptions.action, {
282
+ ...ActionPattern,
283
+ selected: Function,
284
+ currentIndex: Number,
285
+ disabled: [undefined, Boolean],
286
+ tools: [
287
+ {
288
+ name: String,
289
+ title: [undefined, String],
290
+ icon: String,
291
+ disabled: [undefined, Boolean],
292
+ },
293
+ ],
294
+ });
295
+ const action = getActionFromOptions(toolboxComponentOptions.action);
296
+ /**
297
+ * @type {SelectToolboxComponent}
298
+ */
299
+ toolboxComponent = {
300
+ ...toolboxComponent,
301
+ get action() {
302
+ return reactive(action);
303
+ },
304
+ };
171
305
  } else {
172
- return this.add({ id, icon, title });
306
+ check(toolboxComponentOptions.icon, String);
307
+ checkMaybe(toolboxComponentOptions.title, String);
308
+ checkMaybe(toolboxComponentOptions.disabled, Boolean);
309
+ const { icon, title = undefined, disabled } = toolboxComponentOptions;
310
+ const buttonManager = new ButtonManager();
311
+ /**
312
+ * @type {GroupToolboxComponent}
313
+ */
314
+ toolboxComponent = {
315
+ ...toolboxComponent,
316
+ disabled,
317
+ get icon() {
318
+ return icon;
319
+ },
320
+ get title() {
321
+ return title;
322
+ },
323
+ get buttonManager() {
324
+ return buttonManager;
325
+ },
326
+ };
173
327
  }
328
+
329
+ this._toolboxGroups.set(toolboxComponent.id, toolboxComponent);
330
+ this.componentIds.push(toolboxComponent.id);
331
+ this.added.raiseEvent(toolboxComponent);
332
+ return toolboxComponent;
174
333
  }
175
334
 
176
335
  /**
177
- * removes all {@link ButtonComponent}s of a specific owner and fires removed Events
336
+ * removes all {@link ToolboxComponent}s of a specific owner and fires removed Events
178
337
  * @param {string|vcsAppSymbol} owner
179
338
  */
180
339
  removeOwner(owner) {
181
- this.componentIds.forEach((id) => {
182
- this.get(id).buttonManager.removeOwner(owner);
340
+ const componentIds = [...this.componentIds];
341
+ componentIds.forEach((id) => {
342
+ const toolboxComponent = this.get(id);
343
+ if (toolboxComponent.buttonManager) {
344
+ toolboxComponent.buttonManager.removeOwner(owner);
345
+ }
346
+ if (owner === toolboxComponent.owner) {
347
+ this.remove(id);
348
+ }
183
349
  });
184
350
  }
185
351
 
186
352
  /**
187
- * removes all buttonComponents and fires removed Events
353
+ * removes all toolboxComponents and fires removed Events
188
354
  */
189
355
  clear() {
190
356
  const componentIds = [...this.componentIds];
191
- componentIds.forEach((id) => { this.remove(id); });
357
+ componentIds.forEach((id) => {
358
+ this.remove(id);
359
+ });
192
360
  }
193
361
 
194
362
  /**
195
- * destroys the ButtonManager;
363
+ * destroys the ToolboxManager;
196
364
  */
197
365
  destroy() {
198
366
  this.added.destroy();
@@ -202,3 +370,5 @@ export class ToolboxManager {
202
370
  this._toolboxGroups.clear();
203
371
  }
204
372
  }
373
+
374
+ export default ToolboxManager;
@@ -2,28 +2,35 @@
2
2
  <v-sheet
3
3
  :id="`window-component--${windowState.id}`"
4
4
  class="elevation-3 position-absolute d-flex flex-column"
5
- ref="windowComponentRef"
6
- @click="clicked"
5
+ v-on="{ ...$listeners }"
6
+ @dragstart="dragStart"
7
+ @dragend="dragEnd"
8
+ :draggable="isDraggable"
7
9
  :class="{
8
- 'rounded': !isDocked,
9
- 'marginToTop': isDocked
10
+ rounded: !isDocked,
11
+ marginToTop: isDocked || !isChild,
12
+ 'rounded-br': isDynamicLeft,
13
+ 'rounded-bl': isDynamicRight,
10
14
  }"
11
15
  >
12
16
  <div
13
17
  v-if="!windowState.hideHeader"
14
- ref="draggableHeaderRef"
18
+ @mousedown="mousedown"
19
+ @mouseup="isDraggable = false"
15
20
  class="pa-2"
16
21
  :class="{
17
22
  'cursor-grab': isDynamic,
18
- 'grey--text': !isOnTop,
23
+ child: isChild,
19
24
  }"
20
- :draggable="isDynamic"
21
25
  >
22
- <slot name="headerComponent" />
26
+ <slot name="headerComponent" :props="$attrs" />
23
27
  </div>
24
- <v-divider />
28
+ <v-divider v-if="!windowState.hideHeader" />
25
29
  <div
26
- class="overflow-x-hidden"
30
+ class="overflow-x-hidden mb-1"
31
+ :class="{
32
+ rounded: !isDocked,
33
+ }"
27
34
  >
28
35
  <slot />
29
36
  </div>
@@ -31,22 +38,33 @@
31
38
  </template>
32
39
 
33
40
  <style scoped>
34
-
35
- .marginToTop {
36
- margin-top: 2px;
37
- }
38
-
41
+ .marginToTop {
42
+ margin-top: 2px;
43
+ }
39
44
  </style>
40
45
 
41
46
  <script>
42
- import {
43
- onMounted, onUnmounted, computed, ref, nextTick,
44
- } from '@vue/composition-api';
45
- import { fromEvent } from 'rxjs';
46
- import { switchMap, take, map, tap } from 'rxjs/operators';
47
+ import { computed, inject, provide, ref } from 'vue';
48
+ import { VDivider, VSheet } from 'vuetify/lib';
47
49
  import { WindowSlot } from './windowManager.js';
48
50
 
51
+ /**
52
+ * @description WindowComponent defining the structure and style of VC Map windows
53
+ * @vue-prop {WindowState} windowState
54
+ * @vue-prop {boolean} isOnTop - Whether the component is focused
55
+ * @vue-prop {Object} slotWindow - slot ref of the window
56
+ * @vue-event {PointerEvent} click - raised when the component is clicked
57
+ * @vue-event {MouseEvent} mousedown - raised when the component is mousedown
58
+ * @vue-event {{dx: number, dy: number}} move - raised when the component is moved (dragged)
59
+ * @vue-data {slot} [#default] - slot with the window content
60
+ * @vue-data {slot} [#headerComponent] - slot to override the default header
61
+ */
49
62
  export default {
63
+ name: 'WindowComponent',
64
+ components: {
65
+ VSheet,
66
+ VDivider,
67
+ },
50
68
  props: {
51
69
  windowState: {
52
70
  type: Object,
@@ -62,79 +80,81 @@
62
80
  required: true,
63
81
  },
64
82
  },
65
- setup({ windowState, slotWindow }, { emit }) {
66
- const draggableHeaderRef = ref(null);
67
- const windowComponentRef = ref(null);
68
- const isDynamic = computed(() => slotWindow.value !== WindowSlot.STATIC);
69
- const isDocked = computed(() => slotWindow.value !== WindowSlot.DETACHED);
70
- const clicked = (e) => {
71
- emit('click', e);
72
- };
73
-
74
- let dragOverSub;
75
- let dropSub;
76
- onMounted(() => {
77
- if (!windowState.hideHeader && slotWindow.value !== WindowSlot.STATIC) {
78
- nextTick(() => {
79
- const dragStart = fromEvent(draggableHeaderRef.value, 'dragstart');
80
- const dragOver = fromEvent(document.body, 'dragover');
81
- const drop = fromEvent(document.body, 'drop');
82
- const dragThenDrop = dragStart.pipe(
83
- tap(() => {
84
- dragOverSub = dragOver.subscribe((e) => {
85
- // make it accepting drop events
86
- // TODO check if setting the position here works.
87
- e.preventDefault();
88
- });
89
- }),
90
- switchMap((startEvent) => {
91
- // To get to the Root Element of a Custom Component .$el is used here.
92
- const style = window.getComputedStyle(windowComponentRef.value.$el, null);
93
- const windowPosition = {
94
- top: parseInt(style.getPropertyValue('top'), 10),
95
- left: parseInt(style.getPropertyValue('left'), 10),
96
- width: parseInt(style.getPropertyValue('width'), 10),
97
- height: parseInt(style.getPropertyValue('height'), 10),
98
- };
99
- // set dataTransfer for Firefox
100
- startEvent.dataTransfer.setData('text/html', null);
101
-
102
- return drop.pipe(
103
- take(1),
104
- map((dropEvent) => {
105
- windowPosition.dx = startEvent.clientX - dropEvent.clientX;
106
- windowPosition.dy = startEvent.clientY - dropEvent.clientY;
107
- return windowPosition;
108
- }),
109
- tap(() => {
110
- dragOverSub.unsubscribe();
111
- }),
112
- );
113
- }),
114
- );
115
- dropSub = dragThenDrop.subscribe((pos) => {
116
- emit('dropped', pos);
117
- });
118
- });
119
- }
83
+ setup(props, { emit }) {
84
+ const app = inject('vcsApp');
85
+ const { provides } = app.windowManager.get(props.windowState.id);
86
+ Object.entries(provides).forEach(([key, value]) => {
87
+ provide(key, value);
120
88
  });
121
89
 
122
- onUnmounted(() => {
123
- if (dragOverSub) {
124
- dragOverSub.unsubscribe();
90
+ const isChild = computed(() => !!props.windowState.parentId);
91
+ const isDynamic = computed(() => props.slotWindow !== WindowSlot.STATIC);
92
+ const isDocked = computed(() => props.slotWindow !== WindowSlot.DETACHED);
93
+ const isDockedLeft = computed(() => {
94
+ return (
95
+ props.slotWindow === WindowSlot.STATIC ||
96
+ props.slotWindow === WindowSlot.DYNAMIC_LEFT ||
97
+ props.slotWindow === WindowSlot.DYNAMIC_CHILD
98
+ );
99
+ });
100
+ const isDockedRight = computed(
101
+ () => props.slotWindow === WindowSlot.DYNAMIC_RIGHT,
102
+ );
103
+ const isDraggable = ref(false);
104
+ /**
105
+ * Sets window as draggable on mousedown on header.
106
+ * Stops bubbling of header action buttons.
107
+ * @param {MouseEvent} e
108
+ */
109
+ const mousedown = (e) => {
110
+ emit('mousedown', e);
111
+ if (e.target.closest('button')) {
112
+ return;
125
113
  }
126
- if (dropSub) {
127
- dropSub.unsubscribe();
114
+ isDraggable.value = isDynamic.value;
115
+ };
116
+ /**
117
+ * @type {DragEvent}
118
+ */
119
+ let startEvent;
120
+ /**
121
+ * @param {DragEvent} e
122
+ */
123
+ const dragStart = (e) => {
124
+ if (!isDraggable.value) {
125
+ e.preventDefault();
126
+ e.stopPropagation();
128
127
  }
129
- });
128
+ startEvent = e;
129
+ // set mouse cursor to move
130
+ e.dataTransfer.effectAllowed = 'move';
131
+ };
132
+ /**
133
+ * @param {DragEvent} endEvent
134
+ */
135
+ const dragEnd = (endEvent) => {
136
+ const movement = {
137
+ dx: endEvent.clientX - startEvent.clientX,
138
+ dy: endEvent.clientY - startEvent.clientY,
139
+ };
140
+ emit('moved', movement);
141
+ startEvent = null;
142
+ isDraggable.value = false;
143
+ endEvent.target.parentElement.ondragover = null;
144
+ app.maps.target.ondragover = null;
145
+ };
146
+
130
147
  return {
131
148
  isDynamic,
149
+ isChild,
132
150
  isDocked,
133
- draggableHeaderRef,
134
- windowComponentRef,
135
- clicked,
151
+ isDynamicLeft: isDockedLeft,
152
+ isDynamicRight: isDockedRight,
153
+ isDraggable,
154
+ dragStart,
155
+ dragEnd,
156
+ mousedown,
136
157
  };
137
158
  },
138
159
  };
139
160
  </script>
140
-