@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.
Files changed (663) hide show
  1. package/README.md +95 -64
  2. package/app.config.json +3 -0
  3. package/build/.eslintrc +3 -0
  4. package/build/build.js +302 -165
  5. package/build/buildCesium.js +39 -19
  6. package/build/buildHelpers.js +279 -88
  7. package/build/buildPreview.js +16 -6
  8. package/build/bundle.js +57 -0
  9. package/build/commonViteConfig.js +7 -16
  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 +597 -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 +1801 -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.4137c8.js +164897 -0
  136. package/dist/assets/cesium.js +1 -1
  137. package/dist/assets/core.306872.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-cfed33b1.js +1 -0
  147. package/dist/assets/ol.328bbf.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.e84ce9.css +5 -0
  162. package/dist/assets/ui.e84ce9.js +16488 -0
  163. package/dist/assets/ui.js +1 -1
  164. package/dist/assets/vue.1c8696.js +4911 -0
  165. package/dist/assets/vue.js +5 -1
  166. package/dist/assets/vuetify.008fac.css +5 -0
  167. package/dist/assets/vuetify.008fac.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 +203 -18
  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 +53 -34
  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 +123 -39
  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-show-case/project-selector/package.json +13 -0
  234. package/plugins/@vcmap-show-case/project-selector/src/ModulesListComponent.vue +65 -0
  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 +182 -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 +20 -14
  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 +121 -0
  307. package/src/actions/actionHelper.js +186 -50
  308. package/src/actions/stateRefAction.js +2 -3
  309. package/src/application/VcsApp.vue +539 -93
  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 +129 -0
  324. package/src/components/buttons/VcsButton.vue +151 -0
  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 +115 -0
  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 +150 -0
  331. package/src/components/form-inputs-controls/VcsLabel.vue +56 -0
  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 +211 -0
  335. package/src/components/form-inputs-controls/VcsSlider.vue +73 -0
  336. package/src/components/form-inputs-controls/VcsTextArea.vue +180 -0
  337. package/src/components/form-inputs-controls/VcsTextField.vue +298 -0
  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 +103 -0
  342. package/src/components/icons/+all.js +463 -0
  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/components/icons/AssociationsIcon.vue +37 -0
  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/components/icons/ColorSwatchIcon.vue +21 -0
  361. package/src/components/icons/CommentIcon.vue +19 -0
  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/components/icons/ElevationProfileIcon.vue +104 -0
  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/components/icons/HealthCareIndustriesIcon.vue +113 -0
  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/components/icons/HospitalsIcon.vue +223 -0
  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/components/icons/KebabIcon.vue +38 -0
  388. package/src/components/icons/LabelIcon.vue +23 -0
  389. package/src/components/icons/LayersIcon.vue +28 -0
  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/components/icons/MenuIcon.vue +36 -0
  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/components/icons/PointIcon.vue +40 -0
  407. package/src/components/icons/PointSelectIcon.vue +18 -0
  408. package/src/components/icons/PresentationModeIcon.vue +17 -0
  409. package/src/components/icons/ProgressIcon.vue +26 -0
  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/components/icons/ShapesIcon.vue +35 -0
  420. package/src/components/icons/ShareIcon.vue +22 -0
  421. package/src/components/icons/SimpleCircleFilledIcon.vue +18 -0
  422. package/src/components/icons/SimpleCircleHalfFilledIcon.vue +16 -0
  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/components/icons/SplitViewIcon.vue +19 -0
  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 +132 -0
  448. package/src/components/lists/VcsList.vue +590 -0
  449. package/src/components/lists/VcsTreeview.vue +112 -0
  450. package/src/components/lists/VcsTreeviewLeaf.vue +81 -0
  451. package/src/components/lists/VcsTreeviewSearchbar.vue +148 -0
  452. package/src/components/notification/VcsBadge.vue +29 -0
  453. package/src/components/notification/VcsHelp.vue +39 -0
  454. package/src/components/notification/VcsTooltip.vue +160 -0
  455. package/src/components/notification/validation.js +19 -0
  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 +577 -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 +475 -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 +19 -15
  473. package/src/contentTree/contentTreeCollection.js +114 -42
  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/logo-mobile.svg +9 -0
  502. package/src/logo.svg +26 -0
  503. package/src/manager/buttonManager.js +30 -61
  504. package/src/manager/collectionManager/CollectionComponent.vue +140 -0
  505. package/src/manager/collectionManager/CollectionComponentList.vue +77 -0
  506. package/src/manager/collectionManager/CollectionComponentProvider.vue +39 -0
  507. package/src/manager/collectionManager/CollectionManager.vue +62 -0
  508. package/src/manager/collectionManager/categoryManager.js +83 -0
  509. package/src/manager/collectionManager/collectionComponent.js +470 -0
  510. package/src/manager/collectionManager/collectionManager.js +432 -0
  511. package/src/manager/contextMenu/ContextMenuComponent.vue +43 -0
  512. package/src/manager/contextMenu/contextMenuInteraction.js +47 -0
  513. package/src/manager/contextMenu/contextMenuManager.js +220 -0
  514. package/src/manager/navbarManager.js +115 -0
  515. package/src/manager/toolbox/GroupToolboxComponent.vue +128 -0
  516. package/src/manager/toolbox/SelectToolboxComponent.vue +144 -0
  517. package/src/manager/toolbox/ToolboxManager.vue +139 -74
  518. package/src/manager/toolbox/toolboxManager.js +371 -0
  519. package/src/manager/window/WindowComponent.vue +105 -85
  520. package/src/manager/window/WindowComponentHeader.vue +116 -25
  521. package/src/manager/window/WindowManager.vue +133 -50
  522. package/src/manager/window/windowHelper.js +465 -0
  523. package/src/manager/window/windowManager.js +297 -91
  524. package/src/navigation/{mapNavCompass.vue → MapNavCompass.vue} +31 -11
  525. package/src/navigation/MapNavigation.vue +291 -0
  526. package/src/navigation/ObliqueRotation.vue +69 -0
  527. package/src/navigation/{orientationToolsButton.vue → OrientationToolsButton.vue} +14 -13
  528. package/src/navigation/{tiltSlider.vue → TiltSlider.vue} +40 -17
  529. package/src/navigation/VcsCompass.vue +69 -0
  530. package/src/navigation/VcsZoomButton.vue +52 -0
  531. package/src/navigation/overviewMap.js +142 -104
  532. package/src/navigation/overviewMapClickedInteraction.js +6 -1
  533. package/src/notifier/NotifierComponent.vue +86 -0
  534. package/src/notifier/notifier.js +129 -0
  535. package/src/pluginHelper.js +148 -20
  536. package/src/search/ResultItem.vue +83 -0
  537. package/src/search/ResultsComponent.vue +103 -0
  538. package/src/search/SearchComponent.vue +116 -0
  539. package/src/search/search.js +342 -0
  540. package/src/setup.js +9 -10
  541. package/src/state.js +272 -0
  542. package/src/styles/_theming.scss +69 -11
  543. package/src/styles/_typography.scss +3 -6
  544. package/src/styles/main.scss +12 -0
  545. package/src/styles/shades.scss +4 -0
  546. package/src/styles/utils/_border.scss +1 -1
  547. package/src/styles/utils/_cursor.scss +4 -0
  548. package/src/styles/utils/_display.scss +1 -1
  549. package/src/styles/variables.scss +138 -0
  550. package/src/styles/vcsFont.scss +2 -0
  551. package/src/styles/vcsGrid.scss +13 -0
  552. package/src/uiConfig.js +83 -0
  553. package/src/vcsUiApp.js +510 -69
  554. package/src/vuePlugins/i18n.js +51 -13
  555. package/src/vuePlugins/vuetify.js +104 -43
  556. package/config/berlin.config.json +0 -529
  557. package/dist/assets/cesium/Workers/ArcType-fc72c06c.js +0 -1
  558. package/dist/assets/cesium/Workers/AttributeCompression-80665726.js +0 -1
  559. package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-a655a4bc.js +0 -1
  560. package/dist/assets/cesium/Workers/BoundingRectangle-c3b79029.js +0 -1
  561. package/dist/assets/cesium/Workers/BoxGeometry-f8f9c981.js +0 -1
  562. package/dist/assets/cesium/Workers/Color-de06a177.js +0 -1
  563. package/dist/assets/cesium/Workers/ComponentDatatype-a15c9a19.js +0 -1
  564. package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-48cdc26d.js +0 -1
  565. package/dist/assets/cesium/Workers/CorridorGeometryLibrary-ddc027d3.js +0 -1
  566. package/dist/assets/cesium/Workers/CylinderGeometry-82a8cbe6.js +0 -1
  567. package/dist/assets/cesium/Workers/CylinderGeometryLibrary-76cda53e.js +0 -1
  568. package/dist/assets/cesium/Workers/EllipseGeometry-32d55454.js +0 -1
  569. package/dist/assets/cesium/Workers/EllipseGeometryLibrary-b2ae188a.js +0 -1
  570. package/dist/assets/cesium/Workers/EllipseOutlineGeometry-f05a5a27.js +0 -1
  571. package/dist/assets/cesium/Workers/EllipsoidGeodesic-19e75e11.js +0 -1
  572. package/dist/assets/cesium/Workers/EllipsoidGeometry-7c99fc81.js +0 -1
  573. package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-21c243df.js +0 -1
  574. package/dist/assets/cesium/Workers/EllipsoidRhumbLine-6145377b.js +0 -1
  575. package/dist/assets/cesium/Workers/EllipsoidTangentPlane-a01286f6.js +0 -1
  576. package/dist/assets/cesium/Workers/EncodedCartesian3-d9f5c4a4.js +0 -1
  577. package/dist/assets/cesium/Workers/FrustumGeometry-17776af8.js +0 -1
  578. package/dist/assets/cesium/Workers/GeometryAttribute-89a520b9.js +0 -1
  579. package/dist/assets/cesium/Workers/GeometryAttributes-32b29525.js +0 -1
  580. package/dist/assets/cesium/Workers/GeometryInstance-4fbf16ba.js +0 -1
  581. package/dist/assets/cesium/Workers/GeometryOffsetAttribute-8c5e10db.js +0 -1
  582. package/dist/assets/cesium/Workers/GeometryPipeline-309fad76.js +0 -1
  583. package/dist/assets/cesium/Workers/IndexDatatype-f1dcdf35.js +0 -1
  584. package/dist/assets/cesium/Workers/IntersectionTests-58aa8f80.js +0 -1
  585. package/dist/assets/cesium/Workers/Matrix2-47e98d76.js +0 -1
  586. package/dist/assets/cesium/Workers/OrientedBoundingBox-fcb5b750.js +0 -1
  587. package/dist/assets/cesium/Workers/Plane-3f01019d.js +0 -1
  588. package/dist/assets/cesium/Workers/PolygonGeometryLibrary-0b29eb16.js +0 -1
  589. package/dist/assets/cesium/Workers/PolygonPipeline-a934c4dd.js +0 -1
  590. package/dist/assets/cesium/Workers/PolylinePipeline-8095c9bc.js +0 -1
  591. package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-67d12fff.js +0 -1
  592. package/dist/assets/cesium/Workers/PrimitivePipeline-980e44c5.js +0 -1
  593. package/dist/assets/cesium/Workers/RectangleGeometryLibrary-621c6de8.js +0 -1
  594. package/dist/assets/cesium/Workers/RuntimeError-8952249c.js +0 -1
  595. package/dist/assets/cesium/Workers/TerrainEncoding-f96552d5.js +0 -1
  596. package/dist/assets/cesium/Workers/Transforms-c8cb8f43.js +0 -39
  597. package/dist/assets/cesium/Workers/VertexFormat-a0b706b0.js +0 -1
  598. package/dist/assets/cesium/Workers/WallGeometryLibrary-c03d8479.js +0 -1
  599. package/dist/assets/cesium/Workers/WebGLConstants-508b9636.js +0 -1
  600. package/dist/assets/cesium/Workers/WebMercatorProjection-79b3214e.js +0 -1
  601. package/dist/assets/cesium/Workers/_commonjsHelpers-3aae1032-26891ab7.js +0 -1
  602. package/dist/assets/cesium/Workers/_rollup_plugin_ignore_empty_module_placeholder-57d574d0.js +0 -1
  603. package/dist/assets/cesium/Workers/arrayRemoveDuplicates-dc2f4046.js +0 -1
  604. package/dist/assets/cesium/Workers/cesiumWorkerBootstrapper.js +0 -6
  605. package/dist/assets/cesium/Workers/combine-3c023bda.js +0 -1
  606. package/dist/assets/cesium/Workers/defaultValue-81eec7ed.js +0 -1
  607. package/dist/assets/cesium.6b5bb6.js +0 -9105
  608. package/dist/assets/core.98f9bb.js +0 -4
  609. package/dist/assets/index.0be2842f.js +0 -1
  610. package/dist/assets/index.60dea538.css +0 -1
  611. package/dist/assets/ol.0561aa.js +0 -318
  612. package/dist/assets/ui.b7c1e3.css +0 -1
  613. package/dist/assets/ui.b7c1e3.js +0 -39
  614. package/dist/assets/uicomponents.682c5f.css +0 -1
  615. package/dist/assets/uicomponents.682c5f.js +0 -32
  616. package/dist/assets/uicomponents.js +0 -1
  617. package/dist/assets/vue-composition-api.f926fa.js +0 -14
  618. package/dist/assets/vue-composition-api.js +0 -2
  619. package/dist/assets/vue.ddcb6b.js +0 -9
  620. package/dist/assets/vuetify.d21163.css +0 -5
  621. package/dist/assets/vuetify.d21163.js +0 -48
  622. package/lib/uicomponents.js +0 -1
  623. package/lib/vue-composition-api.js +0 -2
  624. package/map.config.json +0 -35
  625. package/plugins/@vcmap/pluginExample/config.json +0 -6
  626. package/plugins/@vcmap/pluginExample/package.json +0 -7
  627. package/plugins/@vcmap/pluginExample/pluginExampleComponent.vue +0 -374
  628. package/plugins/@vcmap/project-selector/ContextsListComponent.vue +0 -62
  629. package/plugins/@vcmap/project-selector/ProjectSelectorComponent.vue +0 -81
  630. package/plugins/@vcmap/project-selector/README.md +0 -29
  631. package/plugins/@vcmap/project-selector/config.json +0 -15
  632. package/plugins/@vcmap/project-selector/index.js +0 -254
  633. package/plugins/@vcmap/project-selector/package.json +0 -15
  634. package/plugins/@vcmap/theme-changer/config.json +0 -69
  635. package/plugins/@vcmap/theme-changer/package.json +0 -12
  636. package/plugins/buttonExamples/ButtonExamples.vue +0 -190
  637. package/plugins/buttonExamples/index.js +0 -40
  638. package/plugins/categoryTest/Categories.vue +0 -145
  639. package/plugins/categoryTest/Category.vue +0 -114
  640. package/plugins/categoryTest/ItemEditor.vue +0 -13
  641. package/plugins/categoryTest/index.js +0 -41
  642. package/plugins/example/index.js +0 -56
  643. package/plugins/test/editor.vue +0 -63
  644. package/plugins/test/index.js +0 -93
  645. package/plugins/test/myCustomHeader.vue +0 -19
  646. package/plugins/test/toolbox-data.js +0 -49
  647. package/plugins/test/vcsContent.vue +0 -23
  648. package/plugins/test/windowManagerExample.vue +0 -144
  649. package/src/actions/styleSelector.vue +0 -90
  650. package/src/application/Navbar.vue +0 -118
  651. package/src/application/empty-cmp.vue +0 -6
  652. package/src/assets/logo.svg +0 -26
  653. package/src/contentTree/viewPointContentTreeItem.js +0 -107
  654. package/src/lang/de.js +0 -60
  655. package/src/lang/en.js +0 -53
  656. package/src/manager/toolbox/ToolboxMultiSelectButton.vue +0 -96
  657. package/src/manager/toolbox/ToolboxSingleSelectButton.vue +0 -98
  658. package/src/manager/toolbox/toolbox-manager.js +0 -203
  659. package/src/navigation/mapNavigation.vue +0 -201
  660. package/src/navigation/obliqueRotation.vue +0 -48
  661. package/src/navigation/vcsCompass.vue +0 -144
  662. package/src/navigation/vcsZoomButton.vue +0 -27
  663. package/start.js +0 -3
@@ -0,0 +1,590 @@
1
+ <template>
2
+ <div class="d-contents">
3
+ <vcs-treeview-searchbar
4
+ v-if="searchable"
5
+ :placeholder="searchbarPlaceholder"
6
+ v-model="query"
7
+ />
8
+ <v-list dense>
9
+ <v-list-item v-if="showTitle" class="font-weight-bold">
10
+ <v-list-item-action v-if="selectable">
11
+ <v-spacer v-if="singleSelect" />
12
+ <v-icon
13
+ v-else-if="selected.length === renderingItems.length"
14
+ @click="clear"
15
+ >
16
+ mdi-check-circle
17
+ </v-icon>
18
+ <v-icon
19
+ v-else-if="
20
+ selected.length > 0 && selected.length < renderingItems.length
21
+ "
22
+ @click="selectAll()"
23
+ >
24
+ mdi-minus-circle
25
+ </v-icon>
26
+ <v-icon v-else @click="selectAll()"> mdi-circle-outline </v-icon>
27
+ </v-list-item-action>
28
+ <v-list-item-content>
29
+ <v-icon v-if="icon">
30
+ {{ icon }}
31
+ </v-icon>
32
+ <VcsTooltip :tooltip="$t(listHeaderTooltip)">
33
+ <template #activator="{ on, attrs }">
34
+ <v-list-item-title v-bind="attrs" v-on="on" ref="listHeader">
35
+ {{ $t(title) }}
36
+ </v-list-item-title>
37
+ </template>
38
+ </VcsTooltip>
39
+ <vcs-action-button-list
40
+ v-if="actions?.length > 0"
41
+ :actions="actions"
42
+ :block-overflow="true"
43
+ :overflow-count="actionButtonListOverflowCount"
44
+ />
45
+ </v-list-item-content>
46
+ </v-list-item>
47
+ <v-list-item
48
+ v-for="(item, index) in renderingItems"
49
+ :key="`item-${index}`"
50
+ :input-value="selected.includes(item)"
51
+ :disabled="item.disabled"
52
+ @mousedown.shift="$event.preventDefault()"
53
+ @mouseover="hovering = index"
54
+ @mouseout="hovering = undefined"
55
+ :draggable="isDraggable"
56
+ @dragstart="drag($event, item, index)"
57
+ @mouseup="drop($event, index)"
58
+ :class="{
59
+ 'v-list-item__lighten_even': lightenEven,
60
+ 'v-list-item__lighten_odd': !lightenEven,
61
+ 'vcs-draggable-item': isDraggable,
62
+ 'v-list-item__dragged': dragging === index,
63
+ 'border-bottom': borderBottom(index),
64
+ 'border-top': borderTop(index),
65
+ }"
66
+ >
67
+ <v-list-item-action v-if="selectable">
68
+ <v-icon v-if="selected.includes(item)" @click="remove(item)">
69
+ mdi-check-circle
70
+ </v-icon>
71
+ <v-icon
72
+ v-else
73
+ @click="singleSelect ? select(item, $event) : add(item)"
74
+ >
75
+ mdi-circle-outline
76
+ </v-icon>
77
+ </v-list-item-action>
78
+ <v-list-item-content
79
+ :class="[selectable && !isDraggable ? 'cursor-pointer' : '']"
80
+ @click="select(item, $event)"
81
+ >
82
+ <v-icon v-if="item.icon">
83
+ {{ item.icon }}
84
+ </v-icon>
85
+ <VcsTooltip
86
+ :tooltip="
87
+ dragging !== undefined
88
+ ? undefined
89
+ : $t(item.tooltip || overflowTitle(index, item.title))
90
+ "
91
+ >
92
+ <template #activator="{ on, attrs }">
93
+ <v-list-item-title v-bind="attrs" v-on="on" ref="titles">
94
+ {{ $t(item.title) }}
95
+ </v-list-item-title>
96
+ </template>
97
+ </VcsTooltip>
98
+ </v-list-item-content>
99
+ <VcsBadge v-if="item.hasUpdate" :color="'warning'" />
100
+ <v-list-item-action>
101
+ <vcs-action-button-list
102
+ v-if="item.actions?.length > 0"
103
+ :actions="item.actions"
104
+ :block-overflow="true"
105
+ :overflow-count="actionButtonListOverflowCount"
106
+ />
107
+ </v-list-item-action>
108
+ </v-list-item>
109
+ </v-list>
110
+ </div>
111
+ </template>
112
+
113
+ <script>
114
+ import { computed, getCurrentInstance, inject, ref, watch } from 'vue';
115
+ import {
116
+ VList,
117
+ VListItem,
118
+ VListItemContent,
119
+ VListItemAction,
120
+ VIcon,
121
+ VListItemTitle,
122
+ VSpacer,
123
+ } from 'vuetify/lib';
124
+ import VcsActionButtonList from '../buttons/VcsActionButtonList.vue';
125
+ import VcsTooltip from '../notification/VcsTooltip.vue';
126
+ import VcsTreeviewSearchbar from './VcsTreeviewSearchbar.vue';
127
+ import VcsBadge from '../notification/VcsBadge.vue';
128
+
129
+ /**
130
+ * @typedef {Object} VcsListItem
131
+ * @property {string} name
132
+ * @property {boolean} [visible] - Whether to display this item or not.
133
+ * @property {boolean} [disabled] - Whether this item should be displayed as disabled.
134
+ * @property {string} title - The title to be displayed
135
+ * @property {string} [tooltip]
136
+ * @property {string|HTMLCanvasElement|HTMLImageElement|undefined} [icon] - An optional icon to display with this item. Can be a URL or HTMLElement.
137
+ * @property {boolean} [hasUpdate] - Shows badge, if item has an update.
138
+ * @property {Array<VcsAction>} [actions]
139
+ * @property {function(boolean):void} [selectionChanged] - A callback called if the selection changes with the current selection status. called before value update
140
+ */
141
+
142
+ /**
143
+ * @typedef {Object} ItemMovedEvent
144
+ * @property {VcsListItem} item
145
+ * @property {number} targetIndex
146
+ */
147
+
148
+ /**
149
+ * @description
150
+ * The VCS list is intended to render items. Items can be selectable (by default, more than one) or only a single item can
151
+ * be selected. If items are disabled they cannot be selected. Items which are not visible are not rendered. These items can
152
+ * no longer be selected or deselected either. Making a selected item invisible can lead to undefined behavior
153
+ * in the selection state.
154
+ * Clicking an unselected item selects it.
155
+ * Clicking a selected item which is not part of a set or range, deselects it.
156
+ * Clicking a selected item of a list or range will deselect the other items in the range or set
157
+ * Clicking with CTRL adds or removes to a selection set.
158
+ * Clicking with SHIFT will create a selection range, starting or ending with the first item in the list
159
+ * or the last normally selected item (not the last item clicked with CTRL for instance).
160
+ * @vue-prop {Array<VcsListItem>} items
161
+ * @vue-prop {boolean} [draggable=false]
162
+ * @vue-prop {boolean} [selectable=false]
163
+ * @vue-prop {boolean} [singleSelect=false]
164
+ * @vue-prop {Array<VcsListItem>} [value=[]] - the initial items to be selected.
165
+ * @vue-prop {boolean} [searchable=false] - if this list can have its items searched. you can provide your own predicate function by providing "filterPredicate" which is of type function(VcsListItem, string):boolean
166
+ * @vue-prop {string} [searchbarPlaceholder] - placeholder to render inside the search field
167
+ * @vue-prop {boolean} [showTitle=true] - show the title component
168
+ * @vue-prop {number} [actionButtonListOverflowCount] - overflow count to use for action lists in the title and items
169
+ * @vue-prop {string} [title] - the lists title
170
+ * @vue-prop {string} [icon] - icon to prepend to the list title
171
+ * @vue-prop {string} [tooltip] - tooltip to render on the list title
172
+ * @vue-prop {Array<VcsAction>} [actions] - actions to render in the list title
173
+ * @vue-event {ItemMovedEvent} item-moved - event triggered after item was dragged and is dropped
174
+ */
175
+ export default {
176
+ name: 'VcsList',
177
+ components: {
178
+ VcsBadge,
179
+ VcsTreeviewSearchbar,
180
+ VcsActionButtonList,
181
+ VcsTooltip,
182
+ VList,
183
+ VListItem,
184
+ VListItemContent,
185
+ VListItemAction,
186
+ VIcon,
187
+ VListItemTitle,
188
+ VSpacer,
189
+ },
190
+ props: {
191
+ items: {
192
+ type: Array,
193
+ required: true,
194
+ },
195
+ draggable: {
196
+ type: Boolean,
197
+ default: false,
198
+ },
199
+ selectable: {
200
+ type: Boolean,
201
+ default: false,
202
+ },
203
+ singleSelect: {
204
+ type: Boolean,
205
+ default: false,
206
+ },
207
+ value: {
208
+ type: Array,
209
+ default: () => [],
210
+ },
211
+ searchable: {
212
+ type: Boolean,
213
+ default: false,
214
+ },
215
+ searchbarPlaceholder: {
216
+ type: String,
217
+ default: undefined,
218
+ },
219
+ showTitle: {
220
+ type: Boolean,
221
+ default: true,
222
+ },
223
+ actionButtonListOverflowCount: {
224
+ type: Number,
225
+ required: false,
226
+ default: undefined,
227
+ },
228
+ title: {
229
+ type: String,
230
+ required: false,
231
+ default: '',
232
+ },
233
+ icon: {
234
+ type: String,
235
+ required: false,
236
+ default: undefined,
237
+ },
238
+ tooltip: {
239
+ type: String,
240
+ required: false,
241
+ default: '',
242
+ },
243
+ actions: {
244
+ type: Array,
245
+ required: false,
246
+ default: undefined,
247
+ },
248
+ },
249
+ setup(props, { emit }) {
250
+ /** @type {import("vue").Ref<Array<VcsListItem>>} */
251
+ const selected = ref(props.value);
252
+ /** @type {import("vue").Ref<string>} */
253
+ const query = ref('');
254
+ /** @type {import("vue").Ref<number|undefined>} */
255
+ const hovering = ref(undefined);
256
+ /** @type {import("vue").Ref<number|undefined>} */
257
+ const dragging = ref(undefined);
258
+ const borderBottom = (index) => {
259
+ return (
260
+ dragging.value !== undefined &&
261
+ dragging.value < index &&
262
+ index === hovering.value
263
+ );
264
+ };
265
+ const borderTop = (index) => {
266
+ return (
267
+ dragging.value !== undefined &&
268
+ dragging.value > index &&
269
+ index === hovering.value
270
+ );
271
+ };
272
+ const lightenEven = computed(() => {
273
+ return !(!props.searchable && !props.showTitle);
274
+ });
275
+ let firstSelected = null;
276
+ const titles = ref([]);
277
+ const listHeader = ref(null);
278
+
279
+ watch(
280
+ props,
281
+ () => {
282
+ if (selected.value !== props.value) {
283
+ selected.value = props.value;
284
+ }
285
+ if (props.singleSelect && selected.value.length > 1) {
286
+ selected.value
287
+ .filter((i, index) => index && i.selectionChanged)
288
+ .forEach((i) => i.selectionChanged(false));
289
+ selected.value = [selected.value[0]];
290
+ emit('input', selected);
291
+ }
292
+ if (!props.selectable && selected.value.length > 0) {
293
+ selected.value
294
+ .filter((i) => i.selectionChanged)
295
+ .forEach((i) => i.selectionChanged(false));
296
+ selected.value = [];
297
+ emit('input', selected);
298
+ }
299
+ if (!props.searchable) {
300
+ query.value = '';
301
+ }
302
+ },
303
+ { immediate: true, deep: false },
304
+ );
305
+
306
+ const vm = getCurrentInstance().proxy;
307
+ /** @type {function(VcsListItem, string):boolean} */
308
+ const filterPredicate = inject(
309
+ 'filterPredicate',
310
+ (item, queryString = '') => {
311
+ const translatedTitle = vm.$t(item.title);
312
+ return translatedTitle
313
+ .toLocaleLowerCase()
314
+ .includes(queryString.toLocaleLowerCase());
315
+ },
316
+ );
317
+
318
+ /**
319
+ * @type {VcsListItem|null}
320
+ */
321
+ let draggedItem = null;
322
+
323
+ const isDraggable = computed(() => {
324
+ return query.value === '' && props.draggable;
325
+ });
326
+
327
+ /**
328
+ * @param {MouseEvent} e
329
+ * @param {number} targetIndex
330
+ */
331
+ function drop(e, targetIndex) {
332
+ if (isDraggable.value) {
333
+ if (draggedItem !== null && targetIndex !== undefined) {
334
+ emit('item-moved', { item: draggedItem, targetIndex });
335
+ }
336
+ draggedItem = null;
337
+ dragging.value = undefined;
338
+ document.removeEventListener('mouseup', drop);
339
+ }
340
+ }
341
+
342
+ /**
343
+ * @param {MouseEvent} e
344
+ * @param {VcsListItem} item
345
+ * @param {number} index
346
+ */
347
+ function drag(e, item, index) {
348
+ if (isDraggable.value) {
349
+ dragging.value = index;
350
+ draggedItem = item;
351
+ e.dataTransfer.effectAllowed = 'move';
352
+ document.addEventListener('mouseup', drop);
353
+ }
354
+ }
355
+
356
+ return {
357
+ query,
358
+ hovering,
359
+ dragging,
360
+ isDraggable,
361
+ borderBottom,
362
+ borderTop,
363
+ lightenEven,
364
+ /**
365
+ * @type {import("vue").ComputedRef<Array<VcsListItem>>}
366
+ */
367
+ renderingItems: computed(() => {
368
+ let items = props.items.filter((i) => i.visible !== false);
369
+ if (query.value) {
370
+ items = items.filter((i) => filterPredicate(i, query.value));
371
+ }
372
+ return items;
373
+ }),
374
+ /** @type {import("vue").Ref<Array<VcsListItem>>} */
375
+ selected,
376
+ /**
377
+ * @param {VcsListItem} item
378
+ * @param {PointerEvent} event
379
+ */
380
+ select(item, event) {
381
+ if (!props.selectable || item.disabled) {
382
+ return;
383
+ }
384
+ if (props.singleSelect) {
385
+ if (selected.value[0] === item) {
386
+ item.selectionChanged?.(false);
387
+ selected.value = [];
388
+ firstSelected = null;
389
+ } else {
390
+ selected.value[0]?.selectionChanged?.(false);
391
+ item.selectionChanged?.(true);
392
+ selected.value = [item];
393
+ firstSelected = item;
394
+ }
395
+ } else if (event.shiftKey) {
396
+ let firstIndex = 0;
397
+ if (firstSelected) {
398
+ firstIndex = this.renderingItems.indexOf(firstSelected);
399
+ }
400
+ const currentIndex = this.renderingItems.indexOf(item);
401
+ if (firstIndex > -1 && currentIndex > -1) {
402
+ const currentSelection = [...selected.value];
403
+ selected.value = this.renderingItems.slice(
404
+ Math.min(firstIndex, currentIndex),
405
+ Math.max(firstIndex, currentIndex) + 1,
406
+ );
407
+ currentSelection.forEach((oldItem) => {
408
+ if (
409
+ oldItem.selectionChanged &&
410
+ !selected.value.includes(oldItem)
411
+ ) {
412
+ oldItem.selectionChanged(false);
413
+ }
414
+ });
415
+ selected.value.forEach((newItem) => {
416
+ if (
417
+ newItem.selectionChanged &&
418
+ !currentSelection.includes(newItem)
419
+ ) {
420
+ newItem.selectionChanged(true);
421
+ }
422
+ });
423
+ } else {
424
+ selected.value
425
+ .filter((i) => i !== item && i.selectionChanged)
426
+ .forEach((i) => i.selectionChanged(false));
427
+ selected.value = [];
428
+ firstSelected = null;
429
+ }
430
+ } else if (selected.value.includes(item)) {
431
+ if (event.ctrlKey) {
432
+ item.selectionChanged?.(false);
433
+ selected.value = selected.value.filter((i) => i !== item);
434
+ } else if (selected.value.length > 1) {
435
+ selected.value
436
+ .filter((i) => i !== item && i.selectionChanged)
437
+ .forEach((i) => i.selectionChanged(false));
438
+ selected.value = [item];
439
+ firstSelected = item;
440
+ } else {
441
+ item.selectionChanged?.(false);
442
+ selected.value = [];
443
+ firstSelected = null;
444
+ }
445
+ } else if (event.ctrlKey) {
446
+ item.selectionChanged?.(true);
447
+ selected.value = [...selected.value, item];
448
+ if (selected.value.length === 1) {
449
+ firstSelected = item;
450
+ }
451
+ } else {
452
+ selected.value
453
+ .filter((i) => i !== item && i.selectionChanged)
454
+ .forEach((i) => i.selectionChanged(false));
455
+ item.selectionChanged?.(true);
456
+ selected.value = [item];
457
+ firstSelected = item;
458
+ }
459
+
460
+ emit('input', selected.value);
461
+ },
462
+ /**
463
+ * @param {VcsListItem} item
464
+ */
465
+ add(item) {
466
+ if (!selected.value.includes(item) && !item.disabled) {
467
+ item.selectionChanged?.(true);
468
+ selected.value = [...selected.value, item];
469
+ emit('input', selected.value);
470
+ }
471
+ },
472
+ /**
473
+ * @param {VcsListItem} item
474
+ */
475
+ remove(item) {
476
+ if (selected.value.includes(item) && !item.disabled) {
477
+ item.selectionChanged?.(false);
478
+ selected.value = selected.value.filter((i) => i !== item);
479
+ emit('input', selected.value);
480
+ }
481
+ },
482
+ clear() {
483
+ selected.value
484
+ .filter((i) => i.selectionChanged)
485
+ .forEach((i) => i.selectionChanged(false));
486
+ selected.value = [];
487
+ firstSelected = null;
488
+ emit('input', selected.value);
489
+ },
490
+ selectAll() {
491
+ const currentSelection = [...selected.value];
492
+ selected.value = this.renderingItems.slice(0);
493
+ selected.value.forEach((item) => {
494
+ if (item.selectionChanged && !currentSelection.includes(item)) {
495
+ item.selectionChanged(true);
496
+ }
497
+ });
498
+ emit('input', selected.value);
499
+ },
500
+ drag,
501
+ drop,
502
+ titles,
503
+ overflowTitle(index, alternative) {
504
+ const elem = titles.value[index];
505
+ if (elem && elem.offsetWidth < elem.scrollWidth) {
506
+ return alternative;
507
+ }
508
+ return '';
509
+ },
510
+ listHeader,
511
+ listHeaderTooltip: computed(() => {
512
+ if (props.tooltip) {
513
+ return props.tooltip;
514
+ }
515
+ const elem = listHeader.value;
516
+ if (elem && elem.offsetWidth < elem.scrollWidth) {
517
+ return props.title;
518
+ }
519
+ return '';
520
+ }),
521
+ };
522
+ },
523
+ };
524
+ </script>
525
+
526
+ <style lang="scss" scoped>
527
+ ::v-deep {
528
+ .v-list {
529
+ .v-list-item__lighten_even {
530
+ &:nth-child(even) {
531
+ background-color: var(--v-base-lighten4);
532
+ }
533
+ }
534
+ .v-list-item__lighten_odd {
535
+ &:nth-child(odd) {
536
+ background-color: var(--v-base-lighten4);
537
+ }
538
+ }
539
+ .v-list-item__dragged {
540
+ background-color: var(--v-base-lighten2) !important;
541
+ }
542
+ .v-list-item {
543
+ padding: 4px 8px 4px 16px;
544
+ &.vcs-draggable-item:hover {
545
+ cursor: grab;
546
+ user-select: none;
547
+ }
548
+ &.border-bottom {
549
+ border-bottom: solid;
550
+ border-bottom-color: var(--v-base-lighten2);
551
+ }
552
+ &.border-top {
553
+ border-top: solid;
554
+ border-top-color: var(--v-base-lighten2);
555
+ }
556
+ &:after {
557
+ display: none;
558
+ }
559
+ &.font-weight-bold {
560
+ .v-list-item__title {
561
+ font-weight: 700;
562
+ }
563
+ }
564
+ .v-list-item__action {
565
+ .v-icon {
566
+ font-size: 16px;
567
+ }
568
+ &:last-child {
569
+ min-width: auto;
570
+ }
571
+ }
572
+ .v-list-item__content {
573
+ flex-wrap: nowrap;
574
+ column-gap: 4px;
575
+ .v-icon,
576
+ .action-btn-wrap {
577
+ flex: 1 1 auto;
578
+ }
579
+ .v-icon {
580
+ font-size: 16px;
581
+ .v-icon__component {
582
+ width: 16px;
583
+ height: 16px;
584
+ }
585
+ }
586
+ }
587
+ }
588
+ }
589
+ }
590
+ </style>
@@ -0,0 +1,112 @@
1
+ <template>
2
+ <div class="d-contents">
3
+ <VcsTreeviewSearchbar
4
+ v-if="showSearchbar"
5
+ :placeholder="searchbarPlaceholder"
6
+ v-model="search"
7
+ />
8
+ <v-treeview
9
+ class="vcs-treeview"
10
+ v-bind="{ ...$props, ...$attrs }"
11
+ v-on="$listeners"
12
+ expand-icon="mdi-chevron-down"
13
+ item-key="name"
14
+ :search="search"
15
+ :filter="handleFilter"
16
+ >
17
+ <template #label="{ item }">
18
+ <VcsTreeviewLeaf
19
+ :item="item"
20
+ :class="[item.clickable ? 'cursor-pointer' : '']"
21
+ @click.native="item.clickable && item.clicked($event)"
22
+ />
23
+ </template>
24
+ </v-treeview>
25
+ </div>
26
+ </template>
27
+ <style lang="scss" scoped>
28
+ .vcs-treeview {
29
+ ::v-deep {
30
+ // Root Level Entries should be 40px high
31
+ > .v-treeview-node > .v-treeview-node__root {
32
+ min-height: 40px;
33
+ }
34
+ // Border around root nodes with children included
35
+ > .v-treeview-node:not(:last-child) {
36
+ border-bottom: 1px solid var(--v-base-lighten2);
37
+ }
38
+ // Only Root Entries have a bold font
39
+ > .v-treeview-node
40
+ > .v-treeview-node__root
41
+ > .v-treeview-node__content
42
+ > .v-treeview-node__label {
43
+ font-weight: 700;
44
+ }
45
+ // remove ripple effect from expand icon
46
+ .v-icon.v-icon {
47
+ &::after {
48
+ background-color: transparent;
49
+ }
50
+ }
51
+ // Toggle Item Chevron with should be 16px
52
+ .v-treeview-node__toggle {
53
+ width: 16px;
54
+ }
55
+ }
56
+ }
57
+ </style>
58
+
59
+ <script>
60
+ import { getCurrentInstance, ref } from 'vue';
61
+ import { VTreeview } from 'vuetify/lib';
62
+ import VcsTreeviewLeaf from './VcsTreeviewLeaf.vue';
63
+ import VcsTreeviewSearchbar from './VcsTreeviewSearchbar.vue';
64
+
65
+ /**
66
+ * @description extends API of https://vuetifyjs.com/en/api/v-treeview/
67
+ * Can render dynamic components as leaf items.
68
+ * In order to display an item needs to be registered and added to `availableComponents`.
69
+ * @vue-prop {boolean} [showSearchbar=false] - Whether there is a searchbar for this treeview
70
+ * @vue-prop {string} [searchbarPlaceholder] - Placeholder text for the searchbar, will be translated
71
+ */
72
+ export default {
73
+ name: 'VcsTreeview',
74
+ components: {
75
+ VcsTreeviewSearchbar,
76
+ VcsTreeviewLeaf,
77
+ VTreeview,
78
+ },
79
+ props: {
80
+ showSearchbar: {
81
+ type: Boolean,
82
+ default: false,
83
+ },
84
+ searchbarPlaceholder: {
85
+ type: String,
86
+ default: undefined,
87
+ },
88
+ },
89
+ setup() {
90
+ const search = ref('');
91
+ // TODO properly type the tree view item interface & export in index.d.ts
92
+
93
+ const vm = getCurrentInstance().proxy;
94
+ /**
95
+ * @param {{ title: string }} treeNode
96
+ * @param {string} q
97
+ * @returns {boolean}
98
+ */
99
+ const handleFilter = (treeNode, q = '') => {
100
+ const translatedTitle = vm.$t(treeNode.title);
101
+ return translatedTitle
102
+ .toLocaleLowerCase()
103
+ .includes(q.toLocaleLowerCase());
104
+ };
105
+
106
+ return {
107
+ search,
108
+ handleFilter,
109
+ };
110
+ },
111
+ };
112
+ </script>