@vcmap/ui 5.3.2 → 6.0.0-rc.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 (589) hide show
  1. package/build/build.js +26 -4
  2. package/build/buildHelpers.js +6 -1
  3. package/build/buildTypes.js +18 -0
  4. package/build/commonViteConfig.js +7 -10
  5. package/build/generateOLLib.js +5 -1
  6. package/build/info/publish.js +2 -2
  7. package/build/lintTypes.js +5 -0
  8. package/build/staging/Dockerfile +1 -1
  9. package/config/base.config.json +5 -2
  10. package/config/dev.config.json +14 -10
  11. package/config/www.config.json +1 -1
  12. package/dist/assets/{cesium.a9cd10.js → cesium.6b12b4.js} +1654 -1692
  13. package/dist/assets/cesium.js +1 -1
  14. package/dist/assets/{core.5e0ca2.js → core.074b78.js} +2607 -2581
  15. package/dist/assets/core.js +1 -1
  16. package/dist/assets/index-ca7EmZ3d.js +1 -0
  17. package/dist/assets/{ol.8edcc5.js → ol.8b2e3a.js} +19259 -19196
  18. package/dist/assets/ol.js +1 -1
  19. package/dist/assets/ui.715986.css +1 -0
  20. package/dist/assets/ui.715986.js +34219 -0
  21. package/dist/assets/ui.js +1 -1
  22. package/dist/assets/vue.0f2c53.js +6096 -0
  23. package/dist/assets/vue.js +1 -5
  24. package/dist/assets/vuetify.28d881.css +5 -0
  25. package/dist/assets/vuetify.28d881.js +24605 -0
  26. package/dist/assets/vuetify.js +1 -5
  27. package/dist/index.html +1 -2
  28. package/index.d.ts +25 -9
  29. package/index.js +11 -29
  30. package/lib/vue.js +0 -1
  31. package/lib/vuetify.js +1 -2
  32. package/lib/vuetifyLib.js +6 -0
  33. package/package.json +23 -14
  34. package/plugins/@vcmap-show-case/buttons-example/package.json +2 -2
  35. package/plugins/@vcmap-show-case/buttons-example/src/ButtonsExample.vue +57 -61
  36. package/plugins/@vcmap-show-case/buttons-example/src/index.js +1 -1
  37. package/plugins/@vcmap-show-case/category-tester/package.json +2 -2
  38. package/plugins/@vcmap-show-case/category-tester/src/CategoriesExample.vue +12 -6
  39. package/plugins/@vcmap-show-case/category-tester/src/CollectionComponentOptions.vue +4 -4
  40. package/plugins/@vcmap-show-case/category-tester/src/FoobarEditor.vue +4 -4
  41. package/plugins/@vcmap-show-case/collection-manager-example/src/CollectionManagerExample.vue +11 -7
  42. package/plugins/@vcmap-show-case/config-editor/src/ConfigEditor.vue +2 -2
  43. package/plugins/@vcmap-show-case/extent-example/README.md +1 -1
  44. package/plugins/@vcmap-show-case/extent-example/src/index.js +11 -20
  45. package/plugins/@vcmap-show-case/flight-component-example/src/FlightExample.vue +3 -3
  46. package/plugins/@vcmap-show-case/form-inputs-example/src/FormInputsExample.vue +122 -169
  47. package/plugins/@vcmap-show-case/form-inputs-example/src/index.js +7 -8
  48. package/plugins/@vcmap-show-case/hello-world/src/helloWorld.vue +1 -1
  49. package/plugins/@vcmap-show-case/icons-example/src/AllIconsComponent.vue +1 -1
  50. package/plugins/@vcmap-show-case/list-example/src/ListExample.vue +33 -4
  51. package/plugins/@vcmap-show-case/notifier-tester/src/NotifierTester.vue +4 -6
  52. package/plugins/@vcmap-show-case/panel-tester/src/PanelExample.vue +3 -4
  53. package/plugins/@vcmap-show-case/project-selector/src/ModulesListComponent.vue +3 -7
  54. package/plugins/@vcmap-show-case/project-selector/src/ProjectSelectorComponent.vue +10 -16
  55. package/plugins/@vcmap-show-case/search-example/package.json +5 -0
  56. package/plugins/@vcmap-show-case/search-example/src/index.js +75 -0
  57. package/plugins/@vcmap-show-case/search-example/src/searchImpl.js +99 -0
  58. package/plugins/@vcmap-show-case/simple-graph/src/SimpleGraphComponent.vue +1 -1
  59. package/plugins/@vcmap-show-case/style-input-example/src/StyleExample.vue +1 -1
  60. package/plugins/@vcmap-show-case/table-example/src/DataTableExample.vue +32 -16
  61. package/plugins/@vcmap-show-case/textfields-example/src/TextfieldsExample.vue +7 -1
  62. package/plugins/@vcmap-show-case/theme-changer/src/ThemeChangerComponent.vue +3 -3
  63. package/plugins/@vcmap-show-case/theme-changer/src/index.js +2 -2
  64. package/plugins/@vcmap-show-case/toolbox-example/src/TriStateExampleWindow.vue +1 -1
  65. package/plugins/@vcmap-show-case/vector-properties-example/src/VectorPropertiesExample.vue +1 -1
  66. package/plugins/@vcmap-show-case/viewpoint-component-example/src/ViewpointExample.vue +4 -4
  67. package/plugins/@vcmap-show-case/window-tester/src/BrokenWindow.vue +17 -0
  68. package/plugins/@vcmap-show-case/window-tester/src/EmptyComponent.vue +1 -1
  69. package/plugins/@vcmap-show-case/window-tester/src/WindowExample.vue +10 -0
  70. package/plugins/@vcmap-show-case/window-tester/src/WindowExampleContent.vue +1 -1
  71. package/plugins/@vcmap-show-case/window-tester/src/WindowExampleToggleChild.vue +1 -1
  72. package/plugins/@vcmap-show-case/wizard-example/src/WizardExample.vue +1 -1
  73. package/src/actions/StyleSelector.vue +4 -34
  74. package/src/actions/StyleSelector.vue.d.ts +6 -4
  75. package/src/actions/actionHelper.js +6 -6
  76. package/src/actions/extentActions.d.ts +1 -2
  77. package/src/actions/extentActions.js +19 -8
  78. package/src/actions/flightActions.js +8 -8
  79. package/src/actions/listActions.d.ts +2 -2
  80. package/src/actions/listActions.js +3 -3
  81. package/src/actions/stateRefAction.js +3 -3
  82. package/src/application/VcsApp.vue +19 -28
  83. package/src/application/VcsApp.vue.d.ts +6 -6
  84. package/src/application/VcsAppWrapper.vue +1 -1
  85. package/src/application/VcsAppWrapper.vue.d.ts +2 -2
  86. package/src/application/VcsAttributions.vue +14 -18
  87. package/src/application/VcsAttributions.vue.d.ts +7 -7
  88. package/src/application/VcsAttributionsFooter.vue +1 -1
  89. package/src/application/VcsAttributionsFooter.vue.d.ts +2 -2
  90. package/src/application/VcsContainer.vue +13 -7
  91. package/src/application/VcsContainer.vue.d.ts +3 -2
  92. package/src/application/VcsCustomScreen.vue +1 -1
  93. package/src/application/VcsCustomScreen.vue.d.ts +2 -2
  94. package/src/application/VcsMainMap.vue +4 -1
  95. package/src/application/VcsMainMap.vue.d.ts +1 -1
  96. package/src/application/VcsMap.vue +21 -23
  97. package/src/application/VcsMap.vue.d.ts +2 -2
  98. package/src/application/VcsNavbar.vue +60 -56
  99. package/src/application/VcsNavbar.vue.d.ts +11 -8
  100. package/src/application/VcsPositionDisplay.vue +33 -46
  101. package/src/application/VcsPositionDisplay.vue.d.ts +3 -3
  102. package/src/application/VcsSettings.vue +19 -7
  103. package/src/application/VcsSettings.vue.d.ts +2 -1
  104. package/src/application/VcsSplashScreen.vue +3 -3
  105. package/src/application/VcsSplashScreen.vue.d.ts +3 -3
  106. package/src/application/VcsTextPage.vue +2 -2
  107. package/src/application/VcsTextPage.vue.d.ts +4 -4
  108. package/src/application/VcsTextPageFooter.vue +4 -4
  109. package/src/application/VcsTextPageFooter.vue.d.ts +2 -2
  110. package/src/application/attributionsHelper.d.ts +2 -2
  111. package/src/application/attributionsHelper.js +9 -9
  112. package/src/components/ImageElementInjector.vue.d.ts +2 -2
  113. package/src/components/attrsHelpers.d.ts +5 -0
  114. package/src/components/attrsHelpers.js +14 -0
  115. package/src/components/buttons/VcsActionButtonList.vue +6 -23
  116. package/src/components/buttons/VcsActionButtonList.vue.d.ts +3 -12
  117. package/src/components/buttons/VcsButton.vue +79 -90
  118. package/src/components/buttons/VcsButton.vue.d.ts +17 -32
  119. package/src/components/buttons/VcsFormButton.vue +77 -125
  120. package/src/components/buttons/VcsFormButton.vue.d.ts +8 -41
  121. package/src/components/buttons/VcsToolButton.vue +91 -94
  122. package/src/components/buttons/VcsToolButton.vue.d.ts +18 -25
  123. package/src/components/composables.d.ts +14 -0
  124. package/src/components/composables.js +31 -0
  125. package/src/components/{form-inputs-controls → extent}/VcsExtent.vue +22 -18
  126. package/src/components/{form-inputs-controls → extent}/VcsExtent.vue.d.ts +10 -7
  127. package/src/components/extent/VcsExtentEditor.vue +79 -0
  128. package/src/components/extent/VcsExtentEditor.vue.d.ts +37 -0
  129. package/src/components/flight/VcsFlightAnchorsComponent.vue +7 -2
  130. package/src/components/flight/VcsFlightAnchorsComponent.vue.d.ts +6 -6
  131. package/src/components/flight/VcsFlightComponent.vue +2 -1
  132. package/src/components/flight/VcsFlightComponent.vue.d.ts +4 -4
  133. package/src/components/flight/VcsFlightEditor.vue.d.ts +2 -2
  134. package/src/components/flight/VcsFlightPlayer.vue +2 -3
  135. package/src/components/flight/VcsFlightPlayer.vue.d.ts +3 -3
  136. package/src/components/form-inputs-controls/VcsCheckbox.vue +56 -80
  137. package/src/components/form-inputs-controls/VcsCheckbox.vue.d.ts +13 -4
  138. package/src/components/form-inputs-controls/VcsChipArrayInput.vue +128 -117
  139. package/src/components/form-inputs-controls/VcsChipArrayInput.vue.d.ts +17 -21
  140. package/src/components/form-inputs-controls/VcsCoordinate.vue +31 -41
  141. package/src/components/form-inputs-controls/VcsCoordinate.vue.d.ts +10 -11
  142. package/src/components/form-inputs-controls/VcsDatePicker.vue +39 -72
  143. package/src/components/form-inputs-controls/VcsDatePicker.vue.d.ts +75 -13
  144. package/src/components/form-inputs-controls/VcsFileInput.vue +100 -0
  145. package/src/components/form-inputs-controls/VcsFileInput.vue.d.ts +27 -0
  146. package/src/components/form-inputs-controls/VcsFormSection.vue +12 -12
  147. package/src/components/form-inputs-controls/VcsFormSection.vue.d.ts +6 -4
  148. package/src/components/form-inputs-controls/VcsLabel.vue +8 -28
  149. package/src/components/form-inputs-controls/VcsLabel.vue.d.ts +2 -11
  150. package/src/components/form-inputs-controls/VcsRadio.vue +80 -104
  151. package/src/components/form-inputs-controls/VcsRadio.vue.d.ts +35 -9
  152. package/src/components/form-inputs-controls/VcsSelect.vue +172 -153
  153. package/src/components/form-inputs-controls/VcsSelect.vue.d.ts +36 -9
  154. package/src/components/form-inputs-controls/VcsSlider.vue +71 -52
  155. package/src/components/form-inputs-controls/VcsSlider.vue.d.ts +6 -1
  156. package/src/components/form-inputs-controls/VcsTextArea.vue +126 -144
  157. package/src/components/form-inputs-controls/VcsTextArea.vue.d.ts +13 -10
  158. package/src/components/form-inputs-controls/VcsTextField.vue +95 -278
  159. package/src/components/form-inputs-controls/VcsTextField.vue.d.ts +33 -32
  160. package/src/components/form-inputs-controls/VcsWizard.vue +71 -77
  161. package/src/components/form-inputs-controls/VcsWizard.vue.d.ts +5 -5
  162. package/src/components/form-inputs-controls/VcsWizardStep.vue +14 -14
  163. package/src/components/form-inputs-controls/VcsWizardStep.vue.d.ts +4 -4
  164. package/src/components/form-inputs-controls/vcsTextField.scss +78 -0
  165. package/src/components/form-output/VcsFormattedNumber.vue +20 -27
  166. package/src/components/form-output/VcsFormattedNumber.vue.d.ts +7 -24
  167. package/src/components/icons/+all.js +1 -1
  168. package/src/components/icons/2DAreaIcon.vue +1 -7
  169. package/src/components/icons/2DAreaIcon.vue.d.ts +1 -1
  170. package/src/components/icons/2DDistanceIcon.vue +1 -7
  171. package/src/components/icons/2DDistanceIcon.vue.d.ts +1 -1
  172. package/src/components/icons/2DHeightObliqueIcon.vue.d.ts +1 -1
  173. package/src/components/icons/2DPointIcon.vue +0 -1
  174. package/src/components/icons/2DPointIcon.vue.d.ts +1 -1
  175. package/src/components/icons/3DAreaIcon.vue +1 -7
  176. package/src/components/icons/3DAreaIcon.vue.d.ts +1 -1
  177. package/src/components/icons/3DDistanceIcon.vue +1 -7
  178. package/src/components/icons/3DDistanceIcon.vue.d.ts +1 -1
  179. package/src/components/icons/3DHeightIcon.vue +1 -7
  180. package/src/components/icons/3DHeightIcon.vue.d.ts +1 -1
  181. package/src/components/icons/3DPointIcon.vue +0 -1
  182. package/src/components/icons/3DPointIcon.vue.d.ts +1 -1
  183. package/src/components/icons/AngleIcon.vue +1 -6
  184. package/src/components/icons/AngleIcon.vue.d.ts +1 -1
  185. package/src/components/icons/AssociationsIcon.vue +1 -6
  186. package/src/components/icons/AssociationsIcon.vue.d.ts +1 -1
  187. package/src/components/icons/AxisIcon.vue.d.ts +1 -1
  188. package/src/components/icons/BoundingBoxIcon.vue +1 -6
  189. package/src/components/icons/BoundingBoxIcon.vue.d.ts +1 -1
  190. package/src/components/icons/CheckboxCheckedIcon.vue.d.ts +1 -1
  191. package/src/components/icons/CheckboxIcon.vue +1 -6
  192. package/src/components/icons/CheckboxIcon.vue.d.ts +1 -1
  193. package/src/components/icons/CheckboxIndeterminateIcon.vue.d.ts +1 -1
  194. package/src/components/icons/CircleIcon.vue +1 -6
  195. package/src/components/icons/CircleIcon.vue.d.ts +1 -1
  196. package/src/components/icons/ClippingHorizontalIcon.vue +1 -6
  197. package/src/components/icons/ClippingHorizontalIcon.vue.d.ts +1 -1
  198. package/src/components/icons/ClippingIcon.vue +1 -6
  199. package/src/components/icons/ClippingIcon.vue.d.ts +1 -1
  200. package/src/components/icons/ClippingVerticalIcon.vue +1 -6
  201. package/src/components/icons/ClippingVerticalIcon.vue.d.ts +1 -1
  202. package/src/components/icons/ColorPickerIcon.vue +1 -6
  203. package/src/components/icons/ColorPickerIcon.vue.d.ts +1 -1
  204. package/src/components/icons/ColorSwatchIcon.vue +1 -7
  205. package/src/components/icons/ColorSwatchIcon.vue.d.ts +1 -1
  206. package/src/components/icons/CommentIcon.vue +1 -6
  207. package/src/components/icons/CommentIcon.vue.d.ts +1 -1
  208. package/src/components/icons/CompassIcon.vue +1 -13
  209. package/src/components/icons/CompassIcon.vue.d.ts +1 -1
  210. package/src/components/icons/ComponentsIcon.vue +1 -6
  211. package/src/components/icons/ComponentsIcon.vue.d.ts +1 -1
  212. package/src/components/icons/ComponentsPlusIcon.vue +0 -1
  213. package/src/components/icons/ComponentsPlusIcon.vue.d.ts +1 -1
  214. package/src/components/icons/ConeIcon.vue +1 -13
  215. package/src/components/icons/ConeIcon.vue.d.ts +1 -1
  216. package/src/components/icons/CrosshairIcon.vue +0 -2
  217. package/src/components/icons/CrosshairIcon.vue.d.ts +1 -1
  218. package/src/components/icons/DimensionsHouseIcon.vue +1 -7
  219. package/src/components/icons/DimensionsHouseIcon.vue.d.ts +1 -1
  220. package/src/components/icons/EditIcon.vue +1 -6
  221. package/src/components/icons/EditIcon.vue.d.ts +1 -1
  222. package/src/components/icons/EditVerticesIcon.vue +1 -6
  223. package/src/components/icons/EditVerticesIcon.vue.d.ts +1 -1
  224. package/src/components/icons/ElevationProfileIcon.vue +1 -6
  225. package/src/components/icons/ElevationProfileIcon.vue.d.ts +1 -1
  226. package/src/components/icons/ExportAreaIcon.vue +1 -6
  227. package/src/components/icons/ExportAreaIcon.vue.d.ts +1 -1
  228. package/src/components/icons/ExportFlightIcon.vue +1 -6
  229. package/src/components/icons/ExportFlightIcon.vue.d.ts +1 -1
  230. package/src/components/icons/ExportIcon.vue +1 -13
  231. package/src/components/icons/ExportIcon.vue.d.ts +1 -1
  232. package/src/components/icons/ExternalLinkIcon.vue +1 -6
  233. package/src/components/icons/ExternalLinkIcon.vue.d.ts +1 -1
  234. package/src/components/icons/EyeIcon.vue +1 -6
  235. package/src/components/icons/EyeIcon.vue.d.ts +1 -1
  236. package/src/components/icons/FastForwardIcon.vue +1 -6
  237. package/src/components/icons/FastForwardIcon.vue.d.ts +1 -1
  238. package/src/components/icons/FilterIcon.vue +1 -7
  239. package/src/components/icons/FilterIcon.vue.d.ts +1 -1
  240. package/src/components/icons/GlobalTerrainIcon.vue +1 -6
  241. package/src/components/icons/GlobalTerrainIcon.vue.d.ts +1 -1
  242. package/src/components/icons/GlobeNatureIcon.vue +1 -6
  243. package/src/components/icons/GlobeNatureIcon.vue.d.ts +1 -1
  244. package/src/components/icons/GroundIcon.vue +1 -6
  245. package/src/components/icons/GroundIcon.vue.d.ts +1 -1
  246. package/src/components/icons/HealthCareIndustriesIcon.vue +1 -6
  247. package/src/components/icons/HealthCareIndustriesIcon.vue.d.ts +1 -1
  248. package/src/components/icons/HelpIcon.vue +1 -6
  249. package/src/components/icons/HelpIcon.vue.d.ts +1 -1
  250. package/src/components/icons/HideIcon.vue +1 -6
  251. package/src/components/icons/HideIcon.vue.d.ts +1 -1
  252. package/src/components/icons/HomePointIcon.vue +1 -6
  253. package/src/components/icons/HomePointIcon.vue.d.ts +1 -1
  254. package/src/components/icons/HospitalsIcon.vue +1 -6
  255. package/src/components/icons/HospitalsIcon.vue.d.ts +1 -1
  256. package/src/components/icons/HouseIcon.vue +1 -6
  257. package/src/components/icons/HouseIcon.vue.d.ts +1 -1
  258. package/src/components/icons/ImportIcon.vue +1 -7
  259. package/src/components/icons/ImportIcon.vue.d.ts +1 -1
  260. package/src/components/icons/InfoIcon.vue +1 -6
  261. package/src/components/icons/InfoIcon.vue.d.ts +1 -1
  262. package/src/components/icons/KebabIcon.vue +1 -7
  263. package/src/components/icons/KebabIcon.vue.d.ts +1 -1
  264. package/src/components/icons/LabelIcon.vue +1 -13
  265. package/src/components/icons/LabelIcon.vue.d.ts +1 -1
  266. package/src/components/icons/LayersIcon.vue +1 -7
  267. package/src/components/icons/LayersIcon.vue.d.ts +1 -1
  268. package/src/components/icons/LegendIcon.vue +1 -6
  269. package/src/components/icons/LegendIcon.vue.d.ts +1 -1
  270. package/src/components/icons/LineIcon.vue +1 -13
  271. package/src/components/icons/LineIcon.vue.d.ts +1 -1
  272. package/src/components/icons/LinkIcon.vue +1 -6
  273. package/src/components/icons/LinkIcon.vue.d.ts +1 -1
  274. package/src/components/icons/LogoutIcon.vue +1 -6
  275. package/src/components/icons/LogoutIcon.vue.d.ts +1 -1
  276. package/src/components/icons/MapIcon.vue +1 -7
  277. package/src/components/icons/MapIcon.vue.d.ts +1 -1
  278. package/src/components/icons/MenuIcon.vue +1 -7
  279. package/src/components/icons/MenuIcon.vue.d.ts +1 -1
  280. package/src/components/icons/MinusIcon.vue +1 -7
  281. package/src/components/icons/MinusIcon.vue.d.ts +1 -1
  282. package/src/components/icons/MultiViewIcon.vue +1 -7
  283. package/src/components/icons/MultiViewIcon.vue.d.ts +1 -1
  284. package/src/components/icons/ObjectAttributeIcon.vue +1 -7
  285. package/src/components/icons/ObjectAttributeIcon.vue.d.ts +1 -1
  286. package/src/components/icons/ObjectSelectIcon.vue +1 -7
  287. package/src/components/icons/ObjectSelectIcon.vue.d.ts +1 -1
  288. package/src/components/icons/ObliqueViewIcon.vue +1 -7
  289. package/src/components/icons/ObliqueViewIcon.vue.d.ts +1 -1
  290. package/src/components/icons/PdfIcon.vue +1 -7
  291. package/src/components/icons/PdfIcon.vue.d.ts +1 -1
  292. package/src/components/icons/PedestrianIcon.vue +1 -6
  293. package/src/components/icons/PedestrianIcon.vue.d.ts +1 -1
  294. package/src/components/icons/PenIcon.vue +1 -6
  295. package/src/components/icons/PenIcon.vue.d.ts +1 -1
  296. package/src/components/icons/PlayCircleIcon.vue +1 -6
  297. package/src/components/icons/PlayCircleIcon.vue.d.ts +1 -1
  298. package/src/components/icons/PlusIcon.vue +1 -7
  299. package/src/components/icons/PlusIcon.vue.d.ts +1 -1
  300. package/src/components/icons/PoiIcon.vue +1 -6
  301. package/src/components/icons/PoiIcon.vue.d.ts +1 -1
  302. package/src/components/icons/PointIcon.vue +1 -7
  303. package/src/components/icons/PointIcon.vue.d.ts +1 -1
  304. package/src/components/icons/PointMeasurementIcon.vue.d.ts +1 -1
  305. package/src/components/icons/PointSelectIcon.vue +1 -6
  306. package/src/components/icons/PointSelectIcon.vue.d.ts +1 -1
  307. package/src/components/icons/PresentationModeIcon.vue +1 -6
  308. package/src/components/icons/PresentationModeIcon.vue.d.ts +1 -1
  309. package/src/components/icons/ProgressIcon.vue +0 -1
  310. package/src/components/icons/ProgressIcon.vue.d.ts +1 -1
  311. package/src/components/icons/QueryIcon.vue +1 -6
  312. package/src/components/icons/QueryIcon.vue.d.ts +1 -1
  313. package/src/components/icons/RectangleIcon.vue +1 -13
  314. package/src/components/icons/RectangleIcon.vue.d.ts +1 -1
  315. package/src/components/icons/ReturnIcon.vue +1 -6
  316. package/src/components/icons/ReturnIcon.vue.d.ts +1 -1
  317. package/src/components/icons/RewindIcon.vue +1 -6
  318. package/src/components/icons/RewindIcon.vue.d.ts +1 -1
  319. package/src/components/icons/RotateLeftIcon.vue +1 -6
  320. package/src/components/icons/RotateLeftIcon.vue.d.ts +1 -1
  321. package/src/components/icons/RotateRightIcon.vue +1 -6
  322. package/src/components/icons/RotateRightIcon.vue.d.ts +1 -1
  323. package/src/components/icons/ScreenshotIcon.vue +1 -6
  324. package/src/components/icons/ScreenshotIcon.vue.d.ts +1 -1
  325. package/src/components/icons/SearchIcon.vue +1 -6
  326. package/src/components/icons/SearchIcon.vue.d.ts +1 -1
  327. package/src/components/icons/ShadowIcon.vue +1 -7
  328. package/src/components/icons/ShadowIcon.vue.d.ts +1 -1
  329. package/src/components/icons/ShapesIcon.vue +1 -6
  330. package/src/components/icons/ShapesIcon.vue.d.ts +1 -1
  331. package/src/components/icons/ShareIcon.vue +1 -6
  332. package/src/components/icons/ShareIcon.vue.d.ts +1 -1
  333. package/src/components/icons/SimpleCircleFilledIcon.vue +1 -6
  334. package/src/components/icons/SimpleCircleFilledIcon.vue.d.ts +1 -1
  335. package/src/components/icons/SimpleCircleHalfFilledIcon.vue +1 -6
  336. package/src/components/icons/SimpleCircleHalfFilledIcon.vue.d.ts +1 -1
  337. package/src/components/icons/SimpleCircleOutlinedIcon.vue +1 -6
  338. package/src/components/icons/SimpleCircleOutlinedIcon.vue.d.ts +1 -1
  339. package/src/components/icons/SkipNextIcon.vue +1 -6
  340. package/src/components/icons/SkipNextIcon.vue.d.ts +1 -1
  341. package/src/components/icons/SkipPreviousIcon.vue +1 -6
  342. package/src/components/icons/SkipPreviousIcon.vue.d.ts +1 -1
  343. package/src/components/icons/SplitViewIcon.vue +1 -6
  344. package/src/components/icons/SplitViewIcon.vue.d.ts +1 -1
  345. package/src/components/icons/TerrainBoxIcon.vue +1 -6
  346. package/src/components/icons/TerrainBoxIcon.vue.d.ts +1 -1
  347. package/src/components/icons/TextStyleIcon.vue +1 -7
  348. package/src/components/icons/TextStyleIcon.vue.d.ts +1 -1
  349. package/src/components/icons/ThreeDimensionsIcon.vue +1 -6
  350. package/src/components/icons/ThreeDimensionsIcon.vue.d.ts +1 -1
  351. package/src/components/icons/ToolsIcon.vue +1 -7
  352. package/src/components/icons/ToolsIcon.vue.d.ts +1 -1
  353. package/src/components/icons/TouchIcon.vue +1 -7
  354. package/src/components/icons/TouchIcon.vue.d.ts +1 -1
  355. package/src/components/icons/TransparentTerrainIcon.vue +0 -1
  356. package/src/components/icons/TransparentTerrainIcon.vue.d.ts +1 -1
  357. package/src/components/icons/TrashCanIcon.vue +1 -7
  358. package/src/components/icons/TrashCanIcon.vue.d.ts +1 -1
  359. package/src/components/icons/TriangleIcon.vue +1 -6
  360. package/src/components/icons/TriangleIcon.vue.d.ts +1 -1
  361. package/src/components/icons/TwoDimensionsIcon.vue +1 -7
  362. package/src/components/icons/TwoDimensionsIcon.vue.d.ts +1 -1
  363. package/src/components/icons/UploadIcon.vue +1 -6
  364. package/src/components/icons/UploadIcon.vue.d.ts +1 -1
  365. package/src/components/icons/UserProfileIcon.vue +1 -7
  366. package/src/components/icons/UserProfileIcon.vue.d.ts +1 -1
  367. package/src/components/icons/UserShareIcon.vue +1 -6
  368. package/src/components/icons/UserShareIcon.vue.d.ts +1 -1
  369. package/src/components/icons/VideoRecorderIcon.vue +1 -6
  370. package/src/components/icons/VideoRecorderIcon.vue.d.ts +1 -1
  371. package/src/components/icons/ViewpointFlightIcon.vue +1 -6
  372. package/src/components/icons/ViewpointFlightIcon.vue.d.ts +1 -1
  373. package/src/components/icons/ViewpointIcon.vue +1 -6
  374. package/src/components/icons/ViewpointIcon.vue.d.ts +1 -1
  375. package/src/components/icons/Viewshed360Icon.vue +1 -7
  376. package/src/components/icons/Viewshed360Icon.vue.d.ts +1 -1
  377. package/src/components/icons/ViewshedConeIcon.vue +1 -7
  378. package/src/components/icons/ViewshedConeIcon.vue.d.ts +1 -1
  379. package/src/components/icons/ViewshedIcon.vue +1 -7
  380. package/src/components/icons/ViewshedIcon.vue.d.ts +1 -1
  381. package/src/components/icons/WalkingIcon.vue +1 -6
  382. package/src/components/icons/WalkingIcon.vue.d.ts +1 -1
  383. package/src/components/icons/WallIcon.vue +1 -6
  384. package/src/components/icons/WallIcon.vue.d.ts +1 -1
  385. package/src/components/icons/WandIcon.vue +1 -6
  386. package/src/components/icons/WandIcon.vue.d.ts +1 -1
  387. package/src/components/import/{FileDrop.vue → VcsFileDrop.vue} +21 -10
  388. package/src/components/import/VcsFileDrop.vue.d.ts +37 -0
  389. package/src/components/import/{ImportComponent.vue → VcsImportComponent.vue} +24 -12
  390. package/src/components/import/{ImportComponent.vue.d.ts → VcsImportComponent.vue.d.ts} +6 -3
  391. package/src/components/lists/VcsActionList.vue +15 -27
  392. package/src/components/lists/VcsActionList.vue.d.ts +3 -3
  393. package/src/components/lists/VcsList.vue +159 -152
  394. package/src/components/lists/VcsList.vue.d.ts +20 -20
  395. package/src/components/lists/VcsTreeview.vue +56 -43
  396. package/src/components/lists/VcsTreeview.vue.d.ts +3 -5
  397. package/src/components/lists/VcsTreeviewLeaf.vue +76 -75
  398. package/src/components/lists/VcsTreeviewLeaf.vue.d.ts +5 -17
  399. package/src/components/lists/VcsTreeviewSearchbar.vue +39 -83
  400. package/src/components/lists/VcsTreeviewSearchbar.vue.d.ts +2 -20
  401. package/src/components/modelHelper.d.ts +25 -0
  402. package/src/components/modelHelper.js +88 -0
  403. package/src/components/notification/VcsBadge.vue +8 -6
  404. package/src/components/notification/VcsBadge.vue.d.ts +2 -2
  405. package/src/components/notification/VcsHelp.vue +19 -14
  406. package/src/components/notification/VcsHelp.vue.d.ts +2 -2
  407. package/src/components/notification/VcsTooltip.vue +4 -8
  408. package/src/components/notification/VcsTooltip.vue.d.ts +3 -3
  409. package/src/components/plugins/AbstractConfigEditor.vue +5 -5
  410. package/src/components/plugins/AbstractConfigEditor.vue.d.ts +2 -2
  411. package/src/components/style/MenuWrapper.vue +10 -11
  412. package/src/components/style/MenuWrapper.vue.d.ts +5 -5
  413. package/src/components/style/VcsFeatureStyleComponent.vue +1 -1
  414. package/src/components/style/VcsFeatureStyleComponent.vue.d.ts +7 -7
  415. package/src/components/style/VcsFillMenu.vue +5 -6
  416. package/src/components/style/VcsFillMenu.vue.d.ts +5 -5
  417. package/src/components/style/VcsFillSelector.vue +6 -7
  418. package/src/components/style/VcsFillSelector.vue.d.ts +5 -5
  419. package/src/components/style/VcsImageMenu.vue +13 -9
  420. package/src/components/style/VcsImageMenu.vue.d.ts +5 -5
  421. package/src/components/style/VcsImageSelector.vue +36 -32
  422. package/src/components/style/VcsImageSelector.vue.d.ts +11 -11
  423. package/src/components/style/VcsStrokeMenu.vue +6 -7
  424. package/src/components/style/VcsStrokeMenu.vue.d.ts +5 -5
  425. package/src/components/style/VcsStrokeSelector.vue +19 -13
  426. package/src/components/style/VcsStrokeSelector.vue.d.ts +5 -5
  427. package/src/components/style/VcsTextMenu.vue +9 -8
  428. package/src/components/style/VcsTextMenu.vue.d.ts +5 -5
  429. package/src/components/style/VcsTextSelector.vue +14 -11
  430. package/src/components/style/VcsTextSelector.vue.d.ts +10 -10
  431. package/src/components/style/VcsVectorStyleComponent.vue +4 -4
  432. package/src/components/style/VcsVectorStyleComponent.vue.d.ts +8 -8
  433. package/src/components/style/composables.js +4 -1
  434. package/src/components/tables/VcsDataTable.vue +152 -207
  435. package/src/components/tables/VcsDataTable.vue.d.ts +10 -36
  436. package/src/components/tables/VcsTable.vue +13 -18
  437. package/src/components/tables/VcsTable.vue.d.ts +4 -4
  438. package/src/components/vector-properties/VcsFeatureEditingWindow.vue +2 -2
  439. package/src/components/vector-properties/VcsFeatureEditingWindow.vue.d.ts +4 -4
  440. package/src/components/vector-properties/VcsFeatureTransforms.vue +5 -1
  441. package/src/components/vector-properties/VcsFeatureTransforms.vue.d.ts +2 -2
  442. package/src/components/vector-properties/VcsVectorPropertiesComponent.vue +54 -47
  443. package/src/components/vector-properties/VcsVectorPropertiesComponent.vue.d.ts +7 -7
  444. package/src/components/vector-properties/composables.js +3 -3
  445. package/src/components/viewpoint/VcsViewpointComponent.vue +56 -104
  446. package/src/components/viewpoint/VcsViewpointComponent.vue.d.ts +14 -22
  447. package/src/components/viewpoint/VcsViewpointEditor.vue +2 -5
  448. package/src/components/viewpoint/VcsViewpointEditor.vue.d.ts +3 -3
  449. package/src/contentTree/LayerTree.vue +31 -10
  450. package/src/contentTree/LayerTree.vue.d.ts +3 -3
  451. package/src/contentTree/contentTreeCollection.d.ts +2 -2
  452. package/src/contentTree/contentTreeCollection.js +6 -8
  453. package/src/contentTree/contentTreeItem.d.ts +11 -11
  454. package/src/contentTree/contentTreeItem.js +8 -7
  455. package/src/contentTree/flightContentTreeItem.js +5 -4
  456. package/src/contentTree/viewpointContentTreeItem.d.ts +1 -1
  457. package/src/featureInfo/AddressBalloonComponent.vue +24 -26
  458. package/src/featureInfo/AddressBalloonComponent.vue.d.ts +1 -1
  459. package/src/featureInfo/BalloonComponent.vue +21 -29
  460. package/src/featureInfo/BalloonComponent.vue.d.ts +2 -2
  461. package/src/featureInfo/IframeComponent.vue.d.ts +2 -2
  462. package/src/featureInfo/MarkdownBalloonComponent.vue.d.ts +2 -2
  463. package/src/featureInfo/MarkdownComponent.vue +16 -0
  464. package/src/featureInfo/MarkdownComponent.vue.d.ts +7 -0
  465. package/src/featureInfo/abstractFeatureInfoView.d.ts +5 -5
  466. package/src/featureInfo/abstractFeatureInfoView.js +2 -2
  467. package/src/featureInfo/balloonFeatureInfoView.d.ts +2 -2
  468. package/src/featureInfo/balloonFeatureInfoView.js +1 -1
  469. package/src/featureInfo/featureInfo.js +2 -2
  470. package/src/featureInfo/markdownFeatureInfoView.js +1 -15
  471. package/src/i18n/de.d.ts +105 -0
  472. package/src/i18n/de.js +14 -5
  473. package/src/i18n/en.d.ts +105 -0
  474. package/src/i18n/en.js +14 -5
  475. package/src/init.js +10 -12
  476. package/src/legend/StyleLegendItem.vue +32 -28
  477. package/src/legend/StyleLegendItem.vue.d.ts +3 -2
  478. package/src/legend/VcsLegend.vue +19 -20
  479. package/src/legend/VcsLegend.vue.d.ts +8 -6
  480. package/src/legend/legendHelper.d.ts +2 -2
  481. package/src/legend/legendHelper.js +9 -8
  482. package/src/manager/buttonManager.d.ts +2 -2
  483. package/src/manager/buttonManager.js +6 -4
  484. package/src/manager/collectionManager/CollectionComponent.vue +30 -26
  485. package/src/manager/collectionManager/CollectionComponent.vue.d.ts +14 -2
  486. package/src/manager/collectionManager/CollectionComponentContent.vue +9 -11
  487. package/src/manager/collectionManager/CollectionComponentContent.vue.d.ts +1 -1
  488. package/src/manager/collectionManager/CollectionComponentList.vue +3 -3
  489. package/src/manager/collectionManager/CollectionComponentList.vue.d.ts +2 -2
  490. package/src/manager/collectionManager/CollectionComponentProvider.vue +1 -1
  491. package/src/manager/collectionManager/CollectionComponentProvider.vue.d.ts +2 -2
  492. package/src/manager/collectionManager/CollectionComponentStandalone.vue +1 -1
  493. package/src/manager/collectionManager/CollectionComponentStandalone.vue.d.ts +1 -1
  494. package/src/manager/collectionManager/CollectionManager.vue +11 -9
  495. package/src/manager/collectionManager/CollectionManager.vue.d.ts +1 -1
  496. package/src/manager/collectionManager/categoryManager.d.ts +2 -2
  497. package/src/manager/collectionManager/collectionComponentClass.d.ts +6 -6
  498. package/src/manager/collectionManager/collectionComponentClass.js +3 -3
  499. package/src/manager/collectionManager/collectionManager.d.ts +5 -4
  500. package/src/manager/collectionManager/collectionManager.js +4 -2
  501. package/src/manager/collectionManager/editorCollectionComponentClass.d.ts +1 -1
  502. package/src/manager/contextMenu/ContextMenuComponent.vue.d.ts +2 -2
  503. package/src/manager/panel/PanelComponent.vue.d.ts +2 -2
  504. package/src/manager/panel/PanelManagerComponent.vue +7 -5
  505. package/src/manager/panel/PanelManagerComponent.vue.d.ts +4 -4
  506. package/src/manager/panel/panelManager.d.ts +6 -6
  507. package/src/manager/panel/panelManager.js +4 -4
  508. package/src/manager/toolbox/GroupToolboxComponent.vue +10 -34
  509. package/src/manager/toolbox/GroupToolboxComponent.vue.d.ts +3 -4
  510. package/src/manager/toolbox/SelectToolboxComponent.vue +12 -58
  511. package/src/manager/toolbox/SelectToolboxComponent.vue.d.ts +2 -3
  512. package/src/manager/toolbox/ToolboxManager.vue +12 -38
  513. package/src/manager/toolbox/ToolboxManager.vue.d.ts +3 -2
  514. package/src/manager/toolbox/toolboxManager.d.ts +3 -3
  515. package/src/manager/toolbox/toolboxManager.js +2 -3
  516. package/src/manager/window/WindowComponent.vue +3 -2
  517. package/src/manager/window/WindowComponent.vue.d.ts +2 -2
  518. package/src/manager/window/WindowComponentHeader.vue +8 -4
  519. package/src/manager/window/WindowComponentHeader.vue.d.ts +3 -3
  520. package/src/manager/window/WindowManager.vue +4 -9
  521. package/src/manager/window/WindowManager.vue.d.ts +2 -2
  522. package/src/manager/window/windowManager.d.ts +52 -46
  523. package/src/manager/window/windowManager.js +33 -10
  524. package/src/navigation/MapNavCompass.vue.d.ts +3 -3
  525. package/src/navigation/MapNavigation.vue +11 -7
  526. package/src/navigation/MapNavigation.vue.d.ts +6 -3
  527. package/src/navigation/ObliqueRotation.vue +15 -17
  528. package/src/navigation/ObliqueRotation.vue.d.ts +5 -5
  529. package/src/navigation/OrientationToolsButton.vue +9 -4
  530. package/src/navigation/OrientationToolsButton.vue.d.ts +2 -2
  531. package/src/navigation/TiltSlider.vue +39 -42
  532. package/src/navigation/TiltSlider.vue.d.ts +5 -5
  533. package/src/navigation/VcsCompass.vue +15 -8
  534. package/src/navigation/VcsCompass.vue.d.ts +6 -6
  535. package/src/navigation/VcsZoomButton.vue +12 -14
  536. package/src/navigation/VcsZoomButton.vue.d.ts +2 -2
  537. package/src/navigation/locatorHelper.js +1 -1
  538. package/src/navigation/overviewMap.d.ts +1 -1
  539. package/src/navigation/overviewMap.js +3 -3
  540. package/src/notifier/NotifierComponent.vue +18 -21
  541. package/src/notifier/NotifierComponent.vue.d.ts +1 -1
  542. package/src/notifier/notifier.d.ts +2 -1
  543. package/src/notifier/notifier.js +6 -2
  544. package/src/search/ResultItem.vue +14 -13
  545. package/src/search/ResultItem.vue.d.ts +2 -2
  546. package/src/search/ResultsComponent.vue +13 -24
  547. package/src/search/ResultsComponent.vue.d.ts +2 -2
  548. package/src/search/SearchComponent.vue +16 -15
  549. package/src/search/SearchComponent.vue.d.ts +2 -2
  550. package/src/search/search.d.ts +2 -2
  551. package/src/search/search.js +6 -10
  552. package/src/setup.js +2 -2
  553. package/src/styles/_typography.scss +11 -7
  554. package/src/styles/main.scss +6 -3
  555. package/src/styles/settings.scss +6 -0
  556. package/src/styles/variables.scss +10 -8
  557. package/src/styles/vcsGrid.scss +0 -10
  558. package/src/styles/vcsList.scss +8 -0
  559. package/src/vcsUiApp.d.ts +128 -21
  560. package/src/vcsUiApp.js +53 -24
  561. package/src/vuePlugins/i18n.d.ts +8 -2
  562. package/src/vuePlugins/i18n.js +32 -11
  563. package/src/vuePlugins/vuetify.d.ts +79 -9
  564. package/src/vuePlugins/vuetify.js +173 -68
  565. package/dist/assets/index-2c09148f.js +0 -1
  566. package/dist/assets/ui.078e16.css +0 -5
  567. package/dist/assets/ui.078e16.js +0 -23835
  568. package/dist/assets/vue.007115.js +0 -4920
  569. package/dist/assets/vuetify.6ef1af.css +0 -5
  570. package/dist/assets/vuetify.6ef1af.js +0 -21263
  571. package/plugins/@vcmap-show-case/extent-example/src/ExtentExample.vue +0 -71
  572. package/src/components/form-inputs-controls/VcsRadioGrid.vue +0 -160
  573. package/src/components/form-inputs-controls/VcsRadioGrid.vue.d.ts +0 -35
  574. package/src/components/form-inputs-controls/composables.d.ts +0 -7
  575. package/src/components/form-inputs-controls/composables.js +0 -31
  576. package/src/components/import/FileDrop.vue.d.ts +0 -26
  577. package/src/styles/utils/_all.scss +0 -12
  578. package/src/styles/utils/_border.scss +0 -7
  579. package/src/styles/utils/_cursor.scss +0 -19
  580. package/src/styles/utils/_display.scss +0 -3
  581. package/src/styles/utils/_fade-in.scss +0 -8
  582. package/src/styles/utils/_position.scss +0 -38
  583. package/src/styles/utils/_size.scss +0 -79
  584. package/src/styles/utils/_slide-in.scss +0 -26
  585. package/src/styles/utils/_spacing.scss +0 -11
  586. package/src/styles/utils/_text.scss +0 -30
  587. package/src/styles/utils/_transform.scss +0 -11
  588. package/src/styles/utils/_transition.scss +0 -11
  589. package/src/styles/utils/_z-index.scss +0 -15
@@ -3,14 +3,14 @@ declare const _default: import("vue").DefineComponent<{
3
3
  type: BooleanConstructor;
4
4
  default: boolean;
5
5
  };
6
- color: {
7
- type: StringConstructor;
8
- default: undefined;
9
- };
10
6
  disabled: {
11
7
  type: BooleanConstructor;
12
8
  default: boolean;
13
9
  };
10
+ color: {
11
+ type: StringConstructor;
12
+ default: undefined;
13
+ };
14
14
  hasUpdate: {
15
15
  type: BooleanConstructor;
16
16
  default: boolean;
@@ -27,30 +27,25 @@ declare const _default: import("vue").DefineComponent<{
27
27
  type: StringConstructor;
28
28
  default: string;
29
29
  };
30
- tooltipProps: {
31
- type: ObjectConstructor;
32
- default: () => {};
33
- };
34
- customClasses: {
35
- type: ArrayConstructor;
36
- default: () => never[];
37
- };
38
- }, {}, {}, {
39
- appliedColor(): any;
40
- hasDefaultSlot(): boolean;
41
- }, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{
30
+ }, {
31
+ forwardSlots: import("vue").ComputedRef<string[]>;
32
+ hasDefaultSlot: import("vue").ComputedRef<boolean>;
33
+ appliedColor: import("vue").ComputedRef<string | null>;
34
+ iconSize: import("vue").ComputedRef<number>;
35
+ minHeight: import("vue").ComputedRef<number>;
36
+ }, any, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
42
37
  active: {
43
38
  type: BooleanConstructor;
44
39
  default: boolean;
45
40
  };
46
- color: {
47
- type: StringConstructor;
48
- default: undefined;
49
- };
50
41
  disabled: {
51
42
  type: BooleanConstructor;
52
43
  default: boolean;
53
44
  };
45
+ color: {
46
+ type: StringConstructor;
47
+ default: undefined;
48
+ };
54
49
  hasUpdate: {
55
50
  type: BooleanConstructor;
56
51
  default: boolean;
@@ -67,23 +62,13 @@ declare const _default: import("vue").DefineComponent<{
67
62
  type: StringConstructor;
68
63
  default: string;
69
64
  };
70
- tooltipProps: {
71
- type: ObjectConstructor;
72
- default: () => {};
73
- };
74
- customClasses: {
75
- type: ArrayConstructor;
76
- default: () => never[];
77
- };
78
65
  }>>, {
66
+ disabled: boolean;
79
67
  tooltip: string;
80
68
  tooltipPosition: string;
81
- disabled: boolean;
82
69
  icon: string;
83
70
  active: boolean;
84
71
  hasUpdate: boolean;
85
72
  color: string;
86
- tooltipProps: Record<string, any>;
87
- customClasses: unknown[];
88
- }>;
73
+ }, {}>;
89
74
  export default _default;
@@ -1,132 +1,91 @@
1
1
  <template>
2
- <div class="vcs-button-wrap">
3
- <v-btn
4
- v-if="!tooltip"
5
- :outlined="variant === 'outlined'"
6
- :disabled="disabled"
7
- :loading="loading"
8
- :ripple="false"
9
- elevation="0"
10
- color="primary"
11
- class="vcs-form-button"
12
- :class="classes"
13
- v-bind="{ ...$attrs }"
14
- v-on="{ ...$listeners }"
15
- >
16
- <v-icon v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
2
+ <v-btn
3
+ :variant="buttonVariant"
4
+ elevation="0"
5
+ color="primary"
6
+ :min-width="itemHeight * 1.5"
7
+ :height="itemHeight"
8
+ class="vcsFormButton"
9
+ :slim="false"
10
+ v-bind="{ ...$attrs }"
11
+ >
12
+ <template #default="scope">
13
+ <v-tooltip
14
+ activator="parent"
15
+ v-if="tooltip"
16
+ :text="tooltip"
17
+ :location="tooltipPosition"
18
+ />
19
+ <v-icon :size="iconSize" v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
17
20
  {{ icon }}
18
21
  </v-icon>
19
- <slot />
20
- </v-btn>
21
- <VcsTooltip
22
- v-else
23
- :tooltip="tooltip"
24
- :tooltip-position="tooltipPosition"
25
- v-bind="{ ...tooltipProps }"
26
- >
27
- <template #activator="{ on, attrs }">
28
- <v-btn
29
- :outlined="variant === 'outlined'"
30
- :disabled="disabled"
31
- :loading="loading"
32
- :ripple="false"
33
- elevation="0"
34
- color="primary"
35
- class="vcs-form-button"
36
- :class="classes"
37
- v-bind="{ ...$attrs, ...attrs }"
38
- v-on="{ ...$listeners, ...on }"
39
- >
40
- <v-icon v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
41
- {{ icon }}
42
- </v-icon>
43
- <slot />
44
- </v-btn>
45
- </template>
46
- </VcsTooltip>
47
- <VcsBadge v-if="hasUpdate" :color="'warning'" class="position-absolute" />
48
- </div>
22
+ <VcsBadge
23
+ v-if="hasUpdate"
24
+ :color="'bg-warning'"
25
+ class="position-absolute"
26
+ />
27
+ <slot name="default" v-bind="scope ?? {}" />
28
+ </template>
29
+ <template v-for="slot of forwardSlots" #[slot]="scope">
30
+ <slot :name="slot" v-bind="scope ?? {}" />
31
+ </template>
32
+ </v-btn>
49
33
  </template>
50
34
 
51
35
  <style lang="scss" scoped>
52
- @import '../../styles/shades.scss';
53
-
54
- .vcs-button-wrap {
55
- position: relative;
56
- display: inline-block;
57
- }
58
36
  .badge {
59
37
  top: -3px;
60
38
  right: -3px;
61
39
  }
62
40
  .v-btn {
63
- &--outlined {
64
- border: thin solid currentColor;
41
+ &.v-btn--variant-outlined:hover {
42
+ border-color: rgb(var(--v-theme-primary-lighten-1));
65
43
  }
66
- &--disabled {
67
- // TODO text color primary
68
- border-color: var(--v-primary-lighten1);
69
- background-color: transparent !important;
44
+ &.v-btn--variant-flat:hover {
45
+ background-color: rgb(var(--v-theme-primary-lighten-1)) !important;
46
+ --v-hover-opacity: 0;
70
47
  }
71
- }
72
- .vcs-button-wrap {
73
- .vcs-form-button {
74
- min-width: 48px;
75
- height: 32px;
76
- font-size: 12px;
77
- border: 1px solid transparent;
78
-
79
- &--outlined {
80
- border: thin solid currentColor;
81
- &:hover {
82
- border-color: var(--v-primary-lighten1) !important;
83
- }
84
- &.theme--light:hover::before {
85
- opacity: 0.16;
86
- }
87
- &.theme--dark:hover::before {
88
- opacity: 0.32;
89
- }
90
- }
91
-
92
- &--filled {
93
- &:hover {
94
- color: map-get($shades, 'white') !important;
95
- border-color: var(--v-primary-lighten1) !important;
96
- background-color: var(--v-primary-lighten1) !important;
97
- }
48
+ &.v-btn--disabled.v-btn--variant-outlined {
49
+ opacity: var(--v-disabled-opacity);
50
+ color: rgb(var(--v-theme-on-surface)) !important;
51
+ }
52
+ &.v-btn--disabled.v-btn--variant-flat {
53
+ opacity: var(--v-disabled-opacity);
54
+ background-color: rgb(var(--v-theme-base-lighten-1)) !important;
55
+ :deep(.v-btn__overlay) {
56
+ opacity: 0;
98
57
  }
99
58
  }
59
+ :deep(.v-btn__loader > .v-progress-circular) {
60
+ width: calc(var(--v-vcs-font-size) * (1.2 + 0.1 / 3)) !important;
61
+ height: calc(var(--v-vcs-font-size) * (1.2 + 0.1 / 3)) !important;
62
+ }
100
63
  }
101
64
  </style>
102
65
 
103
66
  <script>
104
- import { VBtn, VIcon } from 'vuetify/lib';
67
+ import { computed } from 'vue';
68
+ import { VBtn, VIcon, VTooltip } from 'vuetify/components';
105
69
  import VcsBadge from '../notification/VcsBadge.vue';
106
- import VcsTooltip from '../notification/VcsTooltip.vue';
70
+ import { useFontSize, useItemHeight } from '../../vuePlugins/vuetify.js';
71
+ import { useForwardSlots } from '../composables.js';
107
72
 
108
73
  /**
109
- * @description a button with tooltip extending {@link https://vuetifyjs.com/en/api/v-btn/|vuetify v-btn} using {@link VcsTooltip}. Meant to be used in forms or window contents.
74
+ * @description a button with tooltip extending {@link https://vuetifyjs.com/en/api/v-btn/|vuetify v-btn}.
75
+ * Meant to be used in forms or window contents.
110
76
  * @vue-prop {('filled' | 'outlined')} [variant='outlined'] - Filled or outlined representation of the button.
111
- * @vue-prop {boolean} disabled
112
- * @vue-prop {boolean} loading
113
77
  * @vue-prop {boolean} hasUpdate - Whether the button shows a badge in the top right.
114
78
  * @vue-prop {string} icon - When given, will display an icon in the button. Replaces vuetify icon property.
115
79
  * @vue-prop {string} tooltip - Text content of a tooltip which appears on hover with default delay.
116
80
  * @vue-prop {('bottom' | 'left' | 'top' | 'right')} tooltipPosition - Position of the tooltip.
117
- * @vue-prop {Object<string, any>} tooltipProps - Properties to be passed to VcsTooltip {@link https://vuetifyjs.com/en/api/v-tooltip/#props|vuetify v-tooltip}
118
- * @vue-prop {string[]} [customClasses] - CSS classes to customize style
119
- * @vue-computed {Object<string, string>} classes - css classes applied to button, depending on variant
120
- * @vue-computed {boolean} hasDefaultSlot
121
- * @vue-event {MouseEvent} click - Emits click event when the button is clicked.
122
81
  */
123
82
  export default {
124
83
  name: 'VcsFormButton',
125
84
  components: {
126
- VcsTooltip,
127
85
  VcsBadge,
128
86
  VBtn,
129
87
  VIcon,
88
+ VTooltip,
130
89
  },
131
90
  inheritAttrs: false,
132
91
  props: {
@@ -135,14 +94,6 @@
135
94
  default: 'outlined',
136
95
  validator: (value) => ['outlined', 'filled'].includes(value),
137
96
  },
138
- disabled: {
139
- type: Boolean,
140
- default: false,
141
- },
142
- loading: {
143
- type: Boolean,
144
- default: false,
145
- },
146
97
  hasUpdate: {
147
98
  type: Boolean,
148
99
  default: false,
@@ -159,29 +110,30 @@
159
110
  type: String,
160
111
  default: 'bottom',
161
112
  },
162
- tooltipProps: {
163
- type: Object,
164
- default: () => ({}),
165
- },
166
- customClasses: {
167
- type: Array,
168
- default: () => [],
169
- },
170
113
  },
171
- computed: {
172
- classes() {
173
- return {
174
- ...this.customClasses.reduce(
175
- (acc, cur) => ({ ...acc, [cur]: true }),
176
- {},
177
- ),
178
- 'vcs-form-button--outlined': this.variant === 'outlined',
179
- 'vcs-form-button--filled': this.variant === 'filled',
180
- };
181
- },
182
- hasDefaultSlot() {
183
- return !!this.$slots?.default?.[0]?.text?.trim();
184
- },
114
+ setup(props, { slots }) {
115
+ const itemHeight = useItemHeight();
116
+ const buttonVariant = computed(() => {
117
+ if (props.variant === 'filled') {
118
+ return 'flat';
119
+ }
120
+ return props.variant;
121
+ });
122
+ const hasDefaultSlot = computed(() => {
123
+ return !!slots?.default;
124
+ });
125
+ const forwardSlots = useForwardSlots(slots, ['default']);
126
+ const fontSize = useFontSize();
127
+ const iconSize = computed(() => {
128
+ return fontSize.value * (1.2 + 0.1 / 3);
129
+ });
130
+ return {
131
+ forwardSlots,
132
+ buttonVariant,
133
+ hasDefaultSlot,
134
+ itemHeight,
135
+ iconSize,
136
+ };
185
137
  },
186
138
  };
187
139
  </script>
@@ -4,14 +4,6 @@ declare const _default: import("vue").DefineComponent<{
4
4
  default: string;
5
5
  validator: (value: unknown) => boolean;
6
6
  };
7
- disabled: {
8
- type: BooleanConstructor;
9
- default: boolean;
10
- };
11
- loading: {
12
- type: BooleanConstructor;
13
- default: boolean;
14
- };
15
7
  hasUpdate: {
16
8
  type: BooleanConstructor;
17
9
  default: boolean;
@@ -28,31 +20,18 @@ declare const _default: import("vue").DefineComponent<{
28
20
  type: StringConstructor;
29
21
  default: string;
30
22
  };
31
- tooltipProps: {
32
- type: ObjectConstructor;
33
- default: () => {};
34
- };
35
- customClasses: {
36
- type: ArrayConstructor;
37
- default: () => never[];
38
- };
39
- }, {}, {}, {
40
- classes(): any;
41
- hasDefaultSlot(): boolean;
42
- }, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{
23
+ }, {
24
+ forwardSlots: import("vue").ComputedRef<string[]>;
25
+ buttonVariant: import("vue").ComputedRef<string>;
26
+ hasDefaultSlot: import("vue").ComputedRef<boolean>;
27
+ itemHeight: import("vue").ComputedRef<number>;
28
+ iconSize: import("vue").ComputedRef<number>;
29
+ }, any, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
43
30
  variant: {
44
31
  type: StringConstructor;
45
32
  default: string;
46
33
  validator: (value: unknown) => boolean;
47
34
  };
48
- disabled: {
49
- type: BooleanConstructor;
50
- default: boolean;
51
- };
52
- loading: {
53
- type: BooleanConstructor;
54
- default: boolean;
55
- };
56
35
  hasUpdate: {
57
36
  type: BooleanConstructor;
58
37
  default: boolean;
@@ -69,23 +48,11 @@ declare const _default: import("vue").DefineComponent<{
69
48
  type: StringConstructor;
70
49
  default: string;
71
50
  };
72
- tooltipProps: {
73
- type: ObjectConstructor;
74
- default: () => {};
75
- };
76
- customClasses: {
77
- type: ArrayConstructor;
78
- default: () => never[];
79
- };
80
51
  }>>, {
81
52
  tooltip: string;
82
53
  tooltipPosition: string;
83
- disabled: boolean;
84
54
  icon: string;
85
55
  hasUpdate: boolean;
86
- tooltipProps: Record<string, any>;
87
- customClasses: unknown[];
88
56
  variant: string;
89
- loading: boolean;
90
- }>;
57
+ }, {}>;
91
58
  export default _default;
@@ -1,85 +1,81 @@
1
1
  <template>
2
- <div class="vcs-button-wrap">
3
- <v-btn
4
- v-if="!tooltip"
5
- :color="appliedColor"
6
- :text="isTextButton"
7
- class="vcs-tool-button"
8
- :class="classes"
9
- :ripple="{ class: 'primary--text text--darken-4' }"
10
- elevation="0"
11
- v-bind="{ ...$attrs }"
12
- v-on="{ ...$listeners }"
13
- >
14
- <v-icon v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
2
+ <v-btn
3
+ :color="appliedColor"
4
+ :variant="buttonVariant"
5
+ :height="itemHeight + 2"
6
+ :min-width="itemHeight + itemHeight / 3"
7
+ class="vcsToolButton"
8
+ :disabled="disabled"
9
+ :class="{
10
+ 'vcs-background': background,
11
+ 'vcs-active': active,
12
+ }"
13
+ elevation="0"
14
+ v-bind="{ ...$attrs }"
15
+ >
16
+ <template #default="scope">
17
+ <v-tooltip
18
+ activator="parent"
19
+ v-if="tooltip"
20
+ :text="tooltip"
21
+ :location="tooltipPosition"
22
+ />
23
+ <v-icon :size="iconSize" v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
15
24
  {{ icon }}
16
25
  </v-icon>
17
- <slot />
18
- </v-btn>
19
- <VcsTooltip
20
- v-else
21
- :tooltip="tooltip"
22
- :tooltip-position="tooltipPosition"
23
- v-bind="{ ...tooltipProps }"
24
- >
25
- <template #activator="{ on, attrs }">
26
- <v-btn
27
- :color="appliedColor"
28
- :text="isTextButton"
29
- class="vcs-tool-button"
30
- :class="classes"
31
- :ripple="{ class: 'primary--text text--darken-4' }"
32
- elevation="0"
33
- v-bind="{ ...$attrs, ...attrs }"
34
- v-on="{ ...$listeners, ...on }"
35
- >
36
- <v-icon v-if="icon" :class="{ 'mr-2': hasDefaultSlot }">
37
- {{ icon }}
38
- </v-icon>
39
- <slot />
40
- </v-btn>
41
- </template>
42
- </VcsTooltip>
43
- <VcsBadge v-if="hasUpdate" :color="'warning'" class="position-absolute" />
44
- </div>
26
+ <VcsBadge
27
+ v-if="hasUpdate"
28
+ :color="'bg-warning'"
29
+ class="position-absolute"
30
+ />
31
+ <slot name="default" v-bind="scope ?? {}" />
32
+ </template>
33
+ <template v-for="slot of forwardSlots" #[slot]="scope">
34
+ <slot :name="slot" v-bind="scope ?? {}" />
35
+ </template>
36
+ </v-btn>
45
37
  </template>
46
38
 
47
39
  <style lang="scss" scoped>
48
- .vcs-button-wrap {
49
- position: relative;
50
- display: inline-block;
51
- }
52
40
  .badge {
53
41
  top: -3px;
54
42
  right: -3px;
55
43
  }
44
+ .vcs-active.vcs-background:not(.v-btn--disabled) :deep(.badge) {
45
+ top: -5px;
46
+ right: -5px;
47
+ }
56
48
  .v-btn {
57
- &.vcs-tool-button {
58
- min-width: 42px;
59
- height: 34px;
60
- padding: 0;
61
- position: relative;
62
-
63
- &.vcs-tool-button--active-background {
64
- border: 2px solid var(--v-primary-base);
65
- background-color: var(--v-base-lighten2) !important;
66
- }
49
+ padding-left: 11px;
50
+ padding-right: 11px;
67
51
 
68
- &.v-btn--disabled {
69
- background-color: transparent !important;
70
- }
52
+ &.vcs-active.vcs-background:not(.v-btn--disabled) {
53
+ padding-left: 9px;
54
+ padding-right: 9px;
55
+ border: 2px solid rgb(var(--v-theme-primary));
56
+ background-color: rgb(var(--v-theme-base-lighten-2)) !important;
57
+ }
58
+ &.v-btn--disabled.v-btn--variant-text {
59
+ opacity: var(--v-disabled-opacity);
60
+ }
61
+ :deep(.v-btn__loader > .v-progress-circular) {
62
+ width: calc(var(--v-vcs-font-size) * (1.2 + 0.1 / 3)) !important;
63
+ height: calc(var(--v-vcs-font-size) * (1.2 + 0.1 / 3)) !important;
71
64
  }
72
65
  }
73
66
  </style>
74
67
 
75
68
  <script>
76
- import { VBtn, VIcon } from 'vuetify/lib';
69
+ import { computed } from 'vue';
70
+ import { VBtn, VIcon, VTooltip } from 'vuetify/components';
77
71
  import VcsBadge from '../notification/VcsBadge.vue';
78
- import VcsTooltip from '../notification/VcsTooltip.vue';
72
+ import { useForwardSlots } from '../composables.js';
73
+ import { useItemHeight, useFontSize } from '../../vuePlugins/vuetify.js';
79
74
 
80
75
  /**
81
76
  * @description a button with tooltip extending {@link https://vuetifyjs.com/en/api/v-btn/|vuetify v-btn} using {@link VcsTooltip}. Used for tool buttons in the Navbar.
82
77
  * @vue-prop {boolean} active - Whether button has background color. Applies vuetify primary color if color property is not set.
78
+ * @vue-prop {boolean} disabled - Whether button is disabled.
83
79
  * @vue-prop {string} color - Passes property to v-btn in case prop active is true.
84
80
  * @vue-prop {boolean} background - When applied with active the button shows an active-background state implying that a tool is active, but running in background, e.g. windowComponent closed.
85
81
  * @vue-prop {boolean} hasUpdate - Whether the button shows a badge in the top right.
@@ -87,20 +83,16 @@
87
83
  * @vue-prop {string} tooltip - Text content of a tooltip which appears on hover with default delay.
88
84
  * @vue-prop {('bottom' | 'left' | 'top' | 'right')} tooltipPosition - Position of the tooltip.
89
85
  * @vue-prop {Object<string, any>} tooltipProps - Properties to be passed to VcsTooltip {@link https://vuetifyjs.com/en/api/v-tooltip/#props|vuetify v-tooltip}
90
- * @vue-prop {string[]} [customClasses] - CSS classes to customize style
91
86
  * @vue-computed {string} appliedColor - color applied to button, depending on size and state
92
- * @vue-computed {Object<string, string>} classes - css classes applied to button, depending on size and state
93
87
  * @vue-computed {boolean} hasDefaultSlot
94
- * @vue-computed {boolean} isTextButton - button is text
95
- * @vue-event {MouseEvent} click - Emits click event when the button is clicked.
96
88
  */
97
89
  export default {
98
90
  name: 'VcsToolButton',
99
91
  components: {
100
- VcsTooltip,
101
92
  VcsBadge,
102
93
  VBtn,
103
94
  VIcon,
95
+ VTooltip,
104
96
  },
105
97
  inheritAttrs: false,
106
98
  props: {
@@ -108,6 +100,10 @@
108
100
  type: Boolean,
109
101
  default: false,
110
102
  },
103
+ disabled: {
104
+ type: Boolean,
105
+ default: false,
106
+ },
111
107
  color: {
112
108
  type: String,
113
109
  default: undefined,
@@ -132,39 +128,40 @@
132
128
  type: String,
133
129
  default: 'bottom',
134
130
  },
135
- tooltipProps: {
136
- type: Object,
137
- default: () => ({}),
138
- },
139
- customClasses: {
140
- type: Array,
141
- default: () => [],
142
- },
143
131
  },
144
- computed: {
145
- appliedColor() {
146
- if (this.active) {
147
- return this.color ? this.color : 'primary';
132
+ setup(props, { slots }) {
133
+ const appliedColor = computed(() => {
134
+ if (props.active && !props.disabled) {
135
+ return props.color ? props.color : 'primary';
148
136
  } else {
149
137
  return null;
150
138
  }
151
- },
152
- classes() {
153
- return {
154
- ...this.customClasses.reduce(
155
- (acc, cur) => ({ ...acc, [cur]: true }),
156
- {},
157
- ),
158
- 'vcs-tool-button--active-background':
159
- this.active && this.background && !this.$attrs.disabled,
160
- };
161
- },
162
- hasDefaultSlot() {
163
- return !!this.$slots?.default?.[0]?.text?.trim();
164
- },
165
- isTextButton() {
166
- return !this.active ? true : null;
167
- },
139
+ });
140
+ const hasDefaultSlot = computed(() => {
141
+ return !!slots?.default;
142
+ });
143
+ const forwardSlots = useForwardSlots(slots, ['default']);
144
+ const buttonVariant = computed(() => {
145
+ if (props.active && !props.disabled) {
146
+ return 'flat';
147
+ }
148
+ return 'text';
149
+ });
150
+
151
+ const fontSize = useFontSize();
152
+ const itemHeight = useItemHeight();
153
+ const iconSize = computed(() => {
154
+ return fontSize.value * 1.5;
155
+ });
156
+
157
+ return {
158
+ itemHeight,
159
+ iconSize,
160
+ appliedColor,
161
+ forwardSlots,
162
+ buttonVariant,
163
+ hasDefaultSlot,
164
+ };
168
165
  },
169
166
  };
170
167
  </script>