@witchcraft/ui 0.4.0 → 0.4.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 (316) hide show
  1. package/README.md +56 -61
  2. package/dist/module.d.mts +1 -1
  3. package/dist/module.json +1 -1
  4. package/dist/module.mjs +13 -9
  5. package/dist/runtime/assets/animations.css +1 -1
  6. package/dist/runtime/assets/locales/en.json +2 -0
  7. package/dist/runtime/assets/utils.css +1 -1
  8. package/dist/runtime/build/WitchcraftUiResolver.js +1 -2
  9. package/dist/runtime/components/TestControls/TestControls.d.vue.ts +2 -1
  10. package/dist/runtime/components/TestControls/TestControls.vue +3 -3
  11. package/dist/runtime/components/TestControls/TestControls.vue.d.ts +2 -1
  12. package/dist/runtime/components/WButton/WButton.d.vue.ts +34 -0
  13. package/dist/runtime/components/{LibButton/LibButton.vue → WButton/WButton.vue} +26 -38
  14. package/dist/runtime/components/WButton/WButton.vue.d.ts +34 -0
  15. package/dist/runtime/components/WCheckbox/WCheckbox.d.vue.ts +33 -0
  16. package/dist/runtime/components/WCheckbox/WCheckbox.vue +110 -0
  17. package/dist/runtime/components/WCheckbox/WCheckbox.vue.d.ts +33 -0
  18. package/dist/runtime/components/{LibColorInput/LibColorInput.d.vue.ts → WColorInput/WColorInput.d.vue.ts} +18 -36
  19. package/dist/runtime/components/WColorInput/WColorInput.vue +85 -0
  20. package/dist/runtime/components/{LibColorInput/LibColorInput.vue.d.ts → WColorInput/WColorInput.vue.d.ts} +18 -36
  21. package/dist/runtime/components/WColorInput/WColorSwatchButton.d.vue.ts +28 -0
  22. package/dist/runtime/components/WColorInput/WColorSwatchButton.vue +86 -0
  23. package/dist/runtime/components/WColorInput/WColorSwatchButton.vue.d.ts +28 -0
  24. package/dist/runtime/components/{LibColorPicker/LibColorPicker.d.vue.ts → WColorPicker/WColorPicker.d.vue.ts} +12 -9
  25. package/dist/runtime/components/{LibColorPicker/LibColorPicker.vue → WColorPicker/WColorPicker.vue} +41 -29
  26. package/dist/runtime/components/{LibColorPicker/LibColorPicker.vue.d.ts → WColorPicker/WColorPicker.vue.d.ts} +12 -9
  27. package/dist/runtime/components/WCombobox/WCombobox.d.vue.ts +111 -0
  28. package/dist/runtime/components/WCombobox/WCombobox.vue +405 -0
  29. package/dist/runtime/components/WCombobox/WCombobox.vue.d.ts +111 -0
  30. package/dist/runtime/components/WCombobox/storyPlays.d.ts +18 -0
  31. package/dist/runtime/components/WCombobox/storyPlays.js +68 -0
  32. package/dist/runtime/components/{LibDarkModeSwitcher/LibDarkModeSwitcher.d.vue.ts → WDarkModeSwitcher/WDarkModeSwitcher.d.vue.ts} +9 -13
  33. package/dist/runtime/components/{LibDarkModeSwitcher/LibDarkModeSwitcher.vue → WDarkModeSwitcher/WDarkModeSwitcher.vue} +11 -14
  34. package/dist/runtime/components/{LibDarkModeSwitcher/LibDarkModeSwitcher.vue.d.ts → WDarkModeSwitcher/WDarkModeSwitcher.vue.d.ts} +9 -13
  35. package/dist/runtime/components/{LibDatePicker/LibDatePicker.d.vue.ts → WDatePicker/WDatePicker.d.vue.ts} +7 -7
  36. package/dist/runtime/components/{LibDatePicker/LibDatePicker.vue → WDatePicker/WDatePicker.vue} +3 -7
  37. package/dist/runtime/components/{LibDatePicker/LibDatePicker.vue.d.ts → WDatePicker/WDatePicker.vue.d.ts} +7 -7
  38. package/dist/runtime/components/WDatePicker/WRangeDatePicker.d.vue.ts +182 -0
  39. package/dist/runtime/components/{LibDatePicker/LibRangeDatePicker.vue → WDatePicker/WRangeDatePicker.vue} +29 -25
  40. package/dist/runtime/components/WDatePicker/WRangeDatePicker.vue.d.ts +182 -0
  41. package/dist/runtime/components/{LibDatePicker/LibSingleDatePicker.d.vue.ts → WDatePicker/WSingleDatePicker.d.vue.ts} +7 -5
  42. package/dist/runtime/components/{LibDatePicker/LibSingleDatePicker.vue → WDatePicker/WSingleDatePicker.vue} +21 -21
  43. package/dist/runtime/components/{LibDatePicker/LibSingleDatePicker.vue.d.ts → WDatePicker/WSingleDatePicker.vue.d.ts} +7 -5
  44. package/dist/runtime/components/WDatePicker/WTimeZonePicker.d.vue.ts +13 -0
  45. package/dist/runtime/components/{LibDatePicker/LibTimeZonePicker.vue → WDatePicker/WTimeZonePicker.vue} +5 -12
  46. package/dist/runtime/components/WDatePicker/WTimeZonePicker.vue.d.ts +13 -0
  47. package/dist/runtime/components/{LibDebug/LibDebug.d.vue.ts → WDebug/WDebug.d.vue.ts} +3 -2
  48. package/dist/runtime/components/{LibDebug/LibDebug.vue → WDebug/WDebug.vue} +10 -12
  49. package/dist/runtime/components/{LibDebug/LibDebug.vue.d.ts → WDebug/WDebug.vue.d.ts} +3 -2
  50. package/dist/runtime/components/{LibDevOnly/LibDevOnly.d.vue.ts → WDevOnly/WDevOnly.d.vue.ts} +3 -5
  51. package/dist/runtime/components/{LibDevOnly/LibDevOnly.vue.d.ts → WDevOnly/WDevOnly.vue.d.ts} +3 -5
  52. package/dist/runtime/components/WFileInput/WFileInput.d.vue.ts +58 -0
  53. package/dist/runtime/components/WFileInput/WFileInput.vue +348 -0
  54. package/dist/runtime/components/WFileInput/WFileInput.vue.d.ts +58 -0
  55. package/dist/runtime/components/WIcon/WIcon.d.vue.ts +18 -0
  56. package/dist/runtime/components/{Icon/Icon.vue → WIcon/WIcon.vue} +1 -1
  57. package/dist/runtime/components/WIcon/WIcon.vue.d.ts +18 -0
  58. package/dist/runtime/components/WMultiValues/WMultiValues.d.vue.ts +28 -0
  59. package/dist/runtime/components/WMultiValues/WMultiValues.vue +150 -0
  60. package/dist/runtime/components/WMultiValues/WMultiValues.vue.d.ts +28 -0
  61. package/dist/runtime/components/WNotifications/WNotification.d.vue.ts +37 -0
  62. package/dist/runtime/components/{LibNotifications/LibNotification.vue → WNotifications/WNotification.vue} +61 -35
  63. package/dist/runtime/components/WNotifications/WNotification.vue.d.ts +37 -0
  64. package/dist/runtime/components/WNotifications/WNotificationTestMessageComponent.d.vue.ts +7 -0
  65. package/dist/runtime/components/WNotifications/WNotificationTestMessageComponent.vue +29 -0
  66. package/dist/runtime/components/WNotifications/WNotificationTestMessageComponent.vue.d.ts +7 -0
  67. package/dist/runtime/components/WNotifications/WNotifications.d.vue.ts +11 -0
  68. package/dist/runtime/components/{LibNotifications/LibNotifications.vue → WNotifications/WNotifications.vue} +72 -36
  69. package/dist/runtime/components/WNotifications/WNotifications.vue.d.ts +11 -0
  70. package/dist/runtime/components/WNotifications/calculateNotificationProgress.d.ts +2 -0
  71. package/dist/runtime/components/WNotifications/calculateNotificationProgress.js +4 -0
  72. package/dist/runtime/components/WNumberInput/WNumberInput.d.vue.ts +27 -0
  73. package/dist/runtime/components/WNumberInput/WNumberInput.vue +96 -0
  74. package/dist/runtime/components/WNumberInput/WNumberInput.vue.d.ts +27 -0
  75. package/dist/runtime/components/WPagination/WPagination.d.vue.ts +59 -0
  76. package/dist/runtime/components/WPagination/WPagination.vue +182 -0
  77. package/dist/runtime/components/WPagination/WPagination.vue.d.ts +59 -0
  78. package/dist/runtime/components/WPalette/WPalette.d.vue.ts +11 -0
  79. package/dist/runtime/components/{LibPalette/LibPalette.vue → WPalette/WPalette.vue} +3 -8
  80. package/dist/runtime/components/WPalette/WPalette.vue.d.ts +11 -0
  81. package/dist/runtime/components/WPopover/WPopover.d.vue.ts +45 -0
  82. package/dist/runtime/components/WPopover/WPopover.vue +144 -0
  83. package/dist/runtime/components/WPopover/WPopover.vue.d.ts +45 -0
  84. package/dist/runtime/components/WPopup/WPopup.d.vue.ts +51 -0
  85. package/dist/runtime/components/WPopup/WPopup.vue +115 -0
  86. package/dist/runtime/components/WPopup/WPopup.vue.d.ts +51 -0
  87. package/dist/runtime/components/{LibProgressBar/LibProgressBar.d.vue.ts → WProgressBar/WProgressBar.d.vue.ts} +13 -16
  88. package/dist/runtime/components/WProgressBar/WProgressBar.vue +150 -0
  89. package/dist/runtime/components/{LibProgressBar/LibProgressBar.vue.d.ts → WProgressBar/WProgressBar.vue.d.ts} +13 -16
  90. package/dist/runtime/components/{LibRecorder/LibRecorder.d.vue.ts → WRecorder/WRecorder.d.vue.ts} +13 -27
  91. package/dist/runtime/components/{LibRecorder/LibRecorder.vue → WRecorder/WRecorder.vue} +37 -36
  92. package/dist/runtime/components/{LibRecorder/LibRecorder.vue.d.ts → WRecorder/WRecorder.vue.d.ts} +13 -27
  93. package/dist/runtime/components/{LibRoot/LibRoot.d.vue.ts → WRoot/WRoot.d.vue.ts} +11 -9
  94. package/dist/runtime/components/{LibRoot/LibRoot.vue → WRoot/WRoot.vue} +17 -15
  95. package/dist/runtime/components/{LibRoot/LibRoot.vue.d.ts → WRoot/WRoot.vue.d.ts} +11 -9
  96. package/dist/runtime/components/WSimpleInput/WSimpleInput.d.vue.ts +34 -0
  97. package/dist/runtime/components/{LibSimpleInput/LibSimpleInput.vue → WSimpleInput/WSimpleInput.vue} +14 -24
  98. package/dist/runtime/components/WSimpleInput/WSimpleInput.vue.d.ts +34 -0
  99. package/dist/runtime/components/WTable/WTable.d.vue.ts +102 -0
  100. package/dist/runtime/components/WTable/WTable.vue +370 -0
  101. package/dist/runtime/components/WTable/WTable.vue.d.ts +102 -0
  102. package/dist/runtime/components/WTooltip/WTooltip.d.vue.ts +40 -0
  103. package/dist/runtime/components/WTooltip/WTooltip.vue +112 -0
  104. package/dist/runtime/components/WTooltip/WTooltip.vue.d.ts +40 -0
  105. package/dist/runtime/components/index.d.ts +20 -20
  106. package/dist/runtime/components/index.js +20 -20
  107. package/dist/runtime/composables/index.d.ts +4 -4
  108. package/dist/runtime/composables/index.js +4 -4
  109. package/dist/runtime/composables/useDelayedLoadingIndicator.d.ts +9 -0
  110. package/dist/runtime/composables/useDelayedLoadingIndicator.js +18 -0
  111. package/dist/runtime/composables/useDisplayForReka.d.ts +25 -0
  112. package/dist/runtime/composables/useDisplayForReka.js +16 -0
  113. package/dist/runtime/composables/useFallbackId.d.ts +3 -0
  114. package/dist/runtime/composables/useFallbackId.js +5 -0
  115. package/dist/runtime/composables/useInjectedDarkMode.d.ts +1 -1
  116. package/dist/runtime/composables/usePopupConstrainToStyle.d.ts +8 -0
  117. package/dist/runtime/composables/usePopupConstrainToStyle.js +8 -0
  118. package/dist/runtime/composables/useSetupDarkMode.d.ts +2 -3
  119. package/dist/runtime/composables/useSetupDarkMode.js +90 -4
  120. package/dist/runtime/composables/useTimeConditionally.d.ts +16 -0
  121. package/dist/runtime/composables/useTimeConditionally.js +27 -0
  122. package/dist/runtime/directives/vResizableCols.js +101 -34
  123. package/dist/runtime/helpers/NotificationHandler.d.ts +28 -3
  124. package/dist/runtime/helpers/NotificationHandler.js +7 -10
  125. package/dist/runtime/injectionKeys.d.ts +1 -5
  126. package/dist/runtime/injectionKeys.js +0 -2
  127. package/dist/runtime/types/index.d.ts +97 -31
  128. package/dist/runtime/types/index.js +1 -0
  129. package/dist/runtime/utils/notifyIfError.d.ts +3 -1
  130. package/dist/runtime/utils/notifyIfError.js +4 -2
  131. package/dist/runtime/utils/twMerge.d.ts +1 -0
  132. package/dist/runtime/utils/twMerge.js +2 -1
  133. package/package.json +59 -56
  134. package/src/module.ts +16 -8
  135. package/src/runtime/assets/animations.css +53 -6
  136. package/src/runtime/assets/locales/en.json +2 -0
  137. package/src/runtime/assets/tailwind.css +1 -1
  138. package/src/runtime/assets/utils.css +52 -4
  139. package/src/runtime/build/WitchcraftUiResolver.ts +1 -2
  140. package/src/runtime/components/TestControls/TestControls.vue +3 -3
  141. package/src/runtime/components/WButton/WButton.stories.ts +112 -0
  142. package/src/runtime/components/{LibButton/LibButton.vue → WButton/WButton.vue} +34 -50
  143. package/src/runtime/components/{LibCheckbox/LibCheckbox.stories.ts → WCheckbox/WCheckbox.stories.ts} +5 -5
  144. package/src/runtime/components/WCheckbox/WCheckbox.vue +125 -0
  145. package/src/runtime/components/{LibColorInput/LibColorInput.stories.ts → WColorInput/WColorInput.stories.ts} +8 -8
  146. package/src/runtime/components/WColorInput/WColorInput.vue +112 -0
  147. package/src/runtime/components/WColorInput/WColorSwatchButton.vue +102 -0
  148. package/src/runtime/components/{LibColorPicker/LibColorPicker.stories.ts → WColorPicker/WColorPicker.stories.ts} +12 -12
  149. package/src/runtime/components/{LibColorPicker/LibColorPicker.vue → WColorPicker/WColorPicker.vue} +44 -31
  150. package/src/runtime/components/WCombobox/WCombobox.stories.ts +209 -0
  151. package/src/runtime/components/WCombobox/WCombobox.vue +450 -0
  152. package/src/runtime/components/WCombobox/storyPlays.ts +92 -0
  153. package/src/runtime/components/{LibDarkModeSwitcher/LibDarkModeSwitcher.stories.ts → WDarkModeSwitcher/WDarkModeSwitcher.stories.ts} +6 -6
  154. package/src/runtime/components/{LibDarkModeSwitcher/LibDarkModeSwitcher.vue → WDarkModeSwitcher/WDarkModeSwitcher.vue} +19 -30
  155. package/src/runtime/components/{LibDatePicker/LibDatePicker.stories.ts → WDatePicker/WDatePicker.stories.ts} +42 -34
  156. package/src/runtime/components/{LibDatePicker/LibDatePicker.vue → WDatePicker/WDatePicker.vue} +3 -7
  157. package/src/runtime/components/{LibDatePicker/LibRangeDatePicker.vue → WDatePicker/WRangeDatePicker.vue} +29 -25
  158. package/src/runtime/components/{LibDatePicker/LibSingleDatePicker.vue → WDatePicker/WSingleDatePicker.vue} +21 -21
  159. package/src/runtime/components/{LibDatePicker/LibTimeZonePicker.vue → WDatePicker/WTimeZonePicker.vue} +5 -12
  160. package/src/runtime/components/{LibDebug/LibDebug.stories.ts → WDebug/WDebug.stories.ts} +5 -5
  161. package/src/runtime/components/{LibDebug/LibDebug.vue → WDebug/WDebug.vue} +9 -10
  162. package/src/runtime/components/{LibDevOnly/LibDevOnly.vue → WDevOnly/WDevOnly.vue} +0 -4
  163. package/src/runtime/components/{LibFileInput/LibFileInput.stories.ts → WFileInput/WFileInput.stories.ts} +20 -10
  164. package/src/runtime/components/WFileInput/WFileInput.vue +392 -0
  165. package/src/runtime/components/{Icon/Icon.vue → WIcon/WIcon.vue} +5 -8
  166. package/src/runtime/components/{LibMultiValues/LibMultiValues.stories.ts → WMultiValues/WMultiValues.stories.ts} +9 -9
  167. package/src/runtime/components/WMultiValues/WMultiValues.vue +163 -0
  168. package/src/runtime/components/{LibNotifications/LibNotification.stories.ts → WNotifications/WNotification.stories.ts} +42 -6
  169. package/src/runtime/components/{LibNotifications/LibNotification.vue → WNotifications/WNotification.vue} +72 -45
  170. package/src/runtime/components/WNotifications/WNotificationTestMessageComponent.vue +27 -0
  171. package/src/runtime/components/WNotifications/WNotifications.stories.ts +139 -0
  172. package/src/runtime/components/{LibNotifications/LibNotifications.vue → WNotifications/WNotifications.vue} +87 -47
  173. package/src/runtime/components/WNotifications/calculateNotificationProgress.ts +8 -0
  174. package/src/runtime/components/WNumberInput/WNumberInput.vue +109 -0
  175. package/src/runtime/components/WPagination/WPagination.stories.ts +51 -0
  176. package/src/runtime/components/WPagination/WPagination.vue +207 -0
  177. package/src/runtime/components/{LibPalette/LibPalette.stories.ts → WPalette/WPalette.stories.ts} +6 -6
  178. package/src/runtime/components/{LibPalette/LibPalette.vue → WPalette/WPalette.vue} +3 -8
  179. package/src/runtime/components/WPopover/WPopover.stories.ts +218 -0
  180. package/src/runtime/components/WPopover/WPopover.vue +168 -0
  181. package/src/runtime/components/WPopup/WPopup.stories.ts +104 -0
  182. package/src/runtime/components/WPopup/WPopup.vue +134 -0
  183. package/src/runtime/components/WProgressBar/WProgressBar.stories.ts +119 -0
  184. package/src/runtime/components/WProgressBar/WProgressBar.vue +185 -0
  185. package/src/runtime/components/{LibRecorder/LibRecorder.stories.ts → WRecorder/WRecorder.stories.ts} +9 -6
  186. package/src/runtime/components/{LibRecorder/LibRecorder.vue → WRecorder/WRecorder.vue} +69 -68
  187. package/src/runtime/components/{LibRoot/LibRoot.vue → WRoot/WRoot.vue} +18 -15
  188. package/src/runtime/components/{LibSimpleInput/LibSimpleInput.stories.ts → WSimpleInput/WSimpleInput.stories.ts} +11 -12
  189. package/src/runtime/components/{LibSimpleInput/LibSimpleInput.vue → WSimpleInput/WSimpleInput.vue} +28 -42
  190. package/src/runtime/components/WTable/WTable.stories.ts +334 -0
  191. package/src/runtime/components/WTable/WTable.vue +471 -0
  192. package/src/runtime/components/WTooltip/WTooltip.stories.ts +82 -0
  193. package/src/runtime/components/WTooltip/WTooltip.vue +128 -0
  194. package/src/runtime/components/index.ts +20 -20
  195. package/src/runtime/composables/index.ts +4 -4
  196. package/src/runtime/composables/useDelayedLoadingIndicator.ts +30 -0
  197. package/src/runtime/composables/useDisplayForReka.ts +37 -0
  198. package/src/runtime/composables/useFallbackId.ts +6 -0
  199. package/src/runtime/composables/useInjectedDarkMode.ts +1 -2
  200. package/src/runtime/composables/usePopupConstrainToStyle.ts +29 -0
  201. package/src/runtime/composables/useSetupDarkMode.ts +122 -4
  202. package/src/runtime/composables/useTimeConditionally.ts +51 -0
  203. package/src/runtime/directives/vResizableCols.ts +121 -38
  204. package/src/runtime/helpers/NotificationHandler.ts +30 -11
  205. package/src/runtime/injectionKeys.ts +1 -7
  206. package/src/runtime/types/index.ts +118 -36
  207. package/src/runtime/utils/notifyIfError.ts +6 -2
  208. package/src/runtime/utils/twMerge.ts +2 -1
  209. package/types/components.d.ts +14 -15
  210. package/dist/runtime/components/Aria/Aria.d.vue.ts +0 -5
  211. package/dist/runtime/components/Aria/Aria.vue +0 -16
  212. package/dist/runtime/components/Aria/Aria.vue.d.ts +0 -5
  213. package/dist/runtime/components/Icon/Icon.d.vue.ts +0 -21
  214. package/dist/runtime/components/Icon/Icon.vue.d.ts +0 -21
  215. package/dist/runtime/components/LibButton/LibButton.d.vue.ts +0 -36
  216. package/dist/runtime/components/LibButton/LibButton.vue.d.ts +0 -36
  217. package/dist/runtime/components/LibCheckbox/LibCheckbox.d.vue.ts +0 -42
  218. package/dist/runtime/components/LibCheckbox/LibCheckbox.vue +0 -103
  219. package/dist/runtime/components/LibCheckbox/LibCheckbox.vue.d.ts +0 -42
  220. package/dist/runtime/components/LibColorInput/LibColorInput.vue +0 -162
  221. package/dist/runtime/components/LibDatePicker/LibRangeDatePicker.d.vue.ts +0 -34
  222. package/dist/runtime/components/LibDatePicker/LibRangeDatePicker.vue.d.ts +0 -34
  223. package/dist/runtime/components/LibDatePicker/LibTimeZonePicker.d.vue.ts +0 -22
  224. package/dist/runtime/components/LibDatePicker/LibTimeZonePicker.vue.d.ts +0 -22
  225. package/dist/runtime/components/LibFileInput/LibFileInput.d.vue.ts +0 -43
  226. package/dist/runtime/components/LibFileInput/LibFileInput.vue +0 -274
  227. package/dist/runtime/components/LibFileInput/LibFileInput.vue.d.ts +0 -43
  228. package/dist/runtime/components/LibInputDeprecated/LibInputDeprecated.d.vue.ts +0 -165
  229. package/dist/runtime/components/LibInputDeprecated/LibInputDeprecated.vue +0 -387
  230. package/dist/runtime/components/LibInputDeprecated/LibInputDeprecated.vue.d.ts +0 -165
  231. package/dist/runtime/components/LibLabel/LibLabel.d.vue.ts +0 -26
  232. package/dist/runtime/components/LibLabel/LibLabel.vue +0 -45
  233. package/dist/runtime/components/LibLabel/LibLabel.vue.d.ts +0 -26
  234. package/dist/runtime/components/LibMultiValues/LibMultiValues.d.vue.ts +0 -29
  235. package/dist/runtime/components/LibMultiValues/LibMultiValues.vue +0 -109
  236. package/dist/runtime/components/LibMultiValues/LibMultiValues.vue.d.ts +0 -29
  237. package/dist/runtime/components/LibNotifications/LibNotification.d.vue.ts +0 -30
  238. package/dist/runtime/components/LibNotifications/LibNotification.vue.d.ts +0 -30
  239. package/dist/runtime/components/LibNotifications/LibNotifications.d.vue.ts +0 -13
  240. package/dist/runtime/components/LibNotifications/LibNotifications.vue.d.ts +0 -13
  241. package/dist/runtime/components/LibPagination/LibPagination.d.vue.ts +0 -104
  242. package/dist/runtime/components/LibPagination/LibPagination.vue +0 -229
  243. package/dist/runtime/components/LibPagination/LibPagination.vue.d.ts +0 -104
  244. package/dist/runtime/components/LibPalette/LibPalette.d.vue.ts +0 -14
  245. package/dist/runtime/components/LibPalette/LibPalette.vue.d.ts +0 -14
  246. package/dist/runtime/components/LibPopup/LibPopup.d.vue.ts +0 -46
  247. package/dist/runtime/components/LibPopup/LibPopup.vue +0 -365
  248. package/dist/runtime/components/LibPopup/LibPopup.vue.d.ts +0 -46
  249. package/dist/runtime/components/LibProgressBar/LibProgressBar.vue +0 -169
  250. package/dist/runtime/components/LibSimpleInput/LibSimpleInput.d.vue.ts +0 -35
  251. package/dist/runtime/components/LibSimpleInput/LibSimpleInput.vue.d.ts +0 -35
  252. package/dist/runtime/components/LibSuggestions/LibSuggestions.d.vue.ts +0 -94
  253. package/dist/runtime/components/LibSuggestions/LibSuggestions.vue +0 -178
  254. package/dist/runtime/components/LibSuggestions/LibSuggestions.vue.d.ts +0 -94
  255. package/dist/runtime/components/LibTable/LibTable.d.vue.ts +0 -45
  256. package/dist/runtime/components/LibTable/LibTable.vue +0 -155
  257. package/dist/runtime/components/LibTable/LibTable.vue.d.ts +0 -45
  258. package/dist/runtime/components/Template/NAME.d.vue.ts +0 -17
  259. package/dist/runtime/components/Template/NAME.vue +0 -27
  260. package/dist/runtime/components/Template/NAME.vue.d.ts +0 -17
  261. package/dist/runtime/components/Template/TemplateStory.d.ts +0 -7
  262. package/dist/runtime/components/Template/TemplateStory.js +0 -22
  263. package/dist/runtime/components/shared/props.d.ts +0 -171
  264. package/dist/runtime/components/shared/props.js +0 -2
  265. package/dist/runtime/composables/useAriaLabel.d.ts +0 -6
  266. package/dist/runtime/composables/useAriaLabel.js +0 -15
  267. package/dist/runtime/composables/useDarkMode.d.ts +0 -77
  268. package/dist/runtime/composables/useDarkMode.js +0 -89
  269. package/dist/runtime/composables/useDivideAttrs.d.ts +0 -27
  270. package/dist/runtime/composables/useDivideAttrs.js +0 -27
  271. package/dist/runtime/composables/useSuggestions.d.ts +0 -40
  272. package/dist/runtime/composables/useSuggestions.js +0 -263
  273. package/src/runtime/components/Aria/Aria.vue +0 -26
  274. package/src/runtime/components/LibButton/LibButton.stories.ts +0 -106
  275. package/src/runtime/components/LibCheckbox/LibCheckbox.vue +0 -129
  276. package/src/runtime/components/LibColorInput/LibColorInput.vue +0 -203
  277. package/src/runtime/components/LibFileInput/LibFileInput.vue +0 -320
  278. package/src/runtime/components/LibInputDeprecated/LibInputDeprecated.stories.ts +0 -405
  279. package/src/runtime/components/LibInputDeprecated/LibInputDeprecated.vue +0 -414
  280. package/src/runtime/components/LibLabel/LibLabel.stories.ts +0 -33
  281. package/src/runtime/components/LibLabel/LibLabel.vue +0 -65
  282. package/src/runtime/components/LibMultiValues/LibMultiValues.vue +0 -123
  283. package/src/runtime/components/LibNotifications/LibNotifications.stories.ts +0 -120
  284. package/src/runtime/components/LibPagination/LibPagination.stories.ts +0 -49
  285. package/src/runtime/components/LibPagination/LibPagination.vue +0 -274
  286. package/src/runtime/components/LibPopup/LibPopup.stories.ts +0 -153
  287. package/src/runtime/components/LibPopup/LibPopup.vue +0 -396
  288. package/src/runtime/components/LibProgressBar/LibProgressBar.stories.ts +0 -90
  289. package/src/runtime/components/LibProgressBar/LibProgressBar.vue +0 -197
  290. package/src/runtime/components/LibSuggestions/LibSuggestions.stories.ts +0 -134
  291. package/src/runtime/components/LibSuggestions/LibSuggestions.vue +0 -212
  292. package/src/runtime/components/LibTable/LibTable.stories.ts +0 -167
  293. package/src/runtime/components/LibTable/LibTable.vue +0 -190
  294. package/src/runtime/components/Template/NAME.vue +0 -49
  295. package/src/runtime/components/Template/TemplateStory.ts +0 -37
  296. package/src/runtime/components/shared/props.ts +0 -199
  297. package/src/runtime/composables/useAriaLabel.ts +0 -23
  298. package/src/runtime/composables/useDarkMode.ts +0 -199
  299. package/src/runtime/composables/useDivideAttrs.ts +0 -53
  300. package/src/runtime/composables/useSuggestions.ts +0 -339
  301. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToHsva.d.ts +0 -0
  302. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToHsva.js +0 -0
  303. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToRgba.d.ts +0 -0
  304. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToRgba.js +0 -0
  305. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/toLowPrecisionRgbaString.d.ts +0 -0
  306. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/toLowPrecisionRgbaString.js +0 -0
  307. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/truncate.d.ts +0 -0
  308. /package/dist/runtime/components/{LibColorPicker → WColorPicker}/utils/truncate.js +0 -0
  309. /package/dist/runtime/components/{LibDatePicker → WDatePicker}/helpers.d.ts +0 -0
  310. /package/dist/runtime/components/{LibDatePicker → WDatePicker}/helpers.js +0 -0
  311. /package/dist/runtime/components/{LibDevOnly/LibDevOnly.vue → WDevOnly/WDevOnly.vue} +0 -0
  312. /package/src/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToHsva.ts +0 -0
  313. /package/src/runtime/components/{LibColorPicker → WColorPicker}/utils/safeConvertToRgba.ts +0 -0
  314. /package/src/runtime/components/{LibColorPicker → WColorPicker}/utils/toLowPrecisionRgbaString.ts +0 -0
  315. /package/src/runtime/components/{LibColorPicker → WColorPicker}/utils/truncate.ts +0 -0
  316. /package/src/runtime/components/{LibDatePicker → WDatePicker}/helpers.ts +0 -0
@@ -0,0 +1,218 @@
1
+ /* eslint-disable @typescript-eslint/naming-convention */
2
+ import type { Meta, StoryObj } from "@storybook/vue3"
3
+ import { computed, ref, useTemplateRef, watch } from "vue"
4
+
5
+ import WPopover from "./WPopover.vue"
6
+
7
+ import * as components from "../index.js"
8
+
9
+ type ExtraTestArgs = {
10
+ container?: Record<string, string>
11
+ }
12
+ const meta: Meta<typeof WPopover> = {
13
+ component: WPopover,
14
+ title: "Components/Popover",
15
+ args: {
16
+
17
+ }
18
+ }
19
+
20
+ export default meta
21
+ type Story = StoryObj<typeof WPopover> & { args?: ExtraTestArgs }
22
+
23
+ export const Primary: Story = {
24
+ render: args => {
25
+ const extraArgs = args as ExtraTestArgs
26
+ return {
27
+ components,
28
+ setup: () => {
29
+ const collisionBoundary = useTemplateRef("collisionBoundary")
30
+ const value = ref(false)
31
+ const buttonPositions = ["TL", "TC", "TR", "BL", "BC", "BR"] as const
32
+ const buttonPos = ref<typeof buttonPositions[number]>("TL")
33
+ const autoRotatePos = ref(true)
34
+ const buttonStyle = computed(() => {
35
+ switch (buttonPos.value) {
36
+ case "TL": return `align-self: flex-start; justify-self: flex-start;`
37
+ case "TC": return `align-self: flex-start; justify-self: center;`
38
+ case "TR": return `align-self: flex-start; justify-self: flex-end;`
39
+ case "BL": return `align-self: flex-end; justify-self: flex-start;`
40
+ case "BC": return `align-self: flex-end; justify-self: center;`
41
+ case "BR": return `align-self: flex-end; justify-self: flex-end;`
42
+ default: return ""
43
+ }
44
+ })
45
+
46
+ watch(value, () => {
47
+ if (!value.value && autoRotatePos.value) {
48
+ const buttonI = buttonPositions.indexOf(buttonPos.value)
49
+ if (buttonI < 5) { buttonPos.value = buttonPositions[buttonI + 1]! } else {
50
+ buttonPos.value = buttonPositions[0]!
51
+ }
52
+ }
53
+ })
54
+
55
+ return {
56
+ args,
57
+ buttonPos,
58
+ autoRotatePos,
59
+ buttonStyle,
60
+ value,
61
+ collisionBoundary,
62
+ extraArgs
63
+ }
64
+ },
65
+ template: `
66
+ <WSimpleInput
67
+ :suggestions="['TL', 'TR', 'BL', 'BR']"
68
+ :restrict-to-suggestions="true"
69
+ :suggestions-filter="(_, items) => items"
70
+ :label="'Button Position'"
71
+ v-model="buttonPos"
72
+ >
73
+ </WSimpleInput>
74
+ <div>
75
+ <label>Auto Rotate Position</label>
76
+ <input type="checkbox" v-model="autoRotatePos">
77
+ </div>
78
+ <div
79
+ ref="collisionBoundary"
80
+ class="border border-red-500"
81
+ >
82
+ <div
83
+ class="overflow-auto max-w-[100vw] max-h-[100vh]"
84
+ >
85
+ <div
86
+ class="test bg-transparency-squares"
87
+
88
+ :style="{
89
+ display: 'grid',
90
+ width: '100vw',
91
+ height: '80vh',
92
+ padding: '50px',
93
+ border: '1px solid black',
94
+ ...extraArgs.container
95
+ }"
96
+ >
97
+
98
+ <WPopover v-model="value" v-bind="{
99
+ ...args,
100
+ contentProps: {...args.contentProps, collisionBoundary},
101
+ width:undefined,
102
+ height:undefined,
103
+ }" >
104
+ <template #button>
105
+ <WButton :style="buttonStyle" @click="value = !value" >Toggle Popover</WButton>
106
+ </template>
107
+ <template #popover>
108
+ <WDebug
109
+ :style="{width: args.width, height: args.height}"
110
+ class="overflow-auto"
111
+ >
112
+ Popover Content
113
+ </WDebug>
114
+ </template>
115
+ </WPopover>
116
+ </div>
117
+ </div>
118
+ </div>
119
+ `
120
+ }
121
+ }
122
+ }
123
+
124
+ export const PopoverPreventsBoundaryEscape = {
125
+ ...Primary,
126
+ args: {
127
+ container: {
128
+ width: "150vw",
129
+ height: "150vh"
130
+ }
131
+ }
132
+ }
133
+ export const PopoverAllowBoundaryEscape = {
134
+ ...Primary,
135
+ args: {
136
+ contentProps: {
137
+ sticky: "partial"
138
+ },
139
+ container: {
140
+ width: "150vw",
141
+ height: "150vh"
142
+ }
143
+ }
144
+ }
145
+ /** Should cover button due to prioritizePosition */
146
+ export const PopoverPositionPriority = {
147
+ ...Primary,
148
+ args: {
149
+ height: "500px",
150
+ contentProps: {
151
+ prioritizePosition: true,
152
+ side: "top"
153
+ },
154
+ container: {
155
+ width: "150vw",
156
+ height: "150vh"
157
+ }
158
+ }
159
+ }
160
+ /** When the popover is too wide, it's set to overscroll content although ideally the popover should scroll it's own content. */
161
+ export const PopoverTooBig = {
162
+ ...Primary,
163
+ args: {
164
+ width: "110vw",
165
+ height: "110vh"
166
+ }
167
+ }
168
+ export const PopoverRightStart = {
169
+ ...Primary,
170
+ args: {
171
+ contentProps: {
172
+ side: "right",
173
+ align: "start"
174
+ }
175
+ }
176
+ }
177
+
178
+ export const PopoverLeftEnd = {
179
+ ...Primary,
180
+ args: {
181
+ contentProps: {
182
+ side: "left",
183
+ align: "end"
184
+ }
185
+ }
186
+ }
187
+ export const PopoverBottomStart = {
188
+ ...Primary,
189
+ args: {
190
+ contentProps: {
191
+ side: "bottom",
192
+ align: "start"
193
+ }
194
+ }
195
+ }
196
+
197
+ export const PopoverTopEnd = {
198
+ ...Primary,
199
+ args: {
200
+ contentProps: {
201
+ side: "top",
202
+ align: "end"
203
+ }
204
+ }
205
+ }
206
+
207
+ export const RightMenuShapeExample = {
208
+ ...Primary,
209
+ args: {
210
+ contentProps: {
211
+ width: "300px",
212
+ height: "500px",
213
+ side: "right",
214
+ align: "start"
215
+ },
216
+ animationDirection: "use-align"
217
+ }
218
+ }
@@ -0,0 +1,168 @@
1
+ <template>
2
+ <PopoverRoot
3
+ v-model:open="modelValue"
4
+ v-bind="rootProps"
5
+ >
6
+ <PopoverAnchor
7
+ v-if="$slots.button"
8
+ as-child
9
+ >
10
+ <slot name="button"/>
11
+ </PopoverAnchor>
12
+
13
+ <PopoverPortal :to="to">
14
+ <transition>
15
+ <div
16
+ v-if="showBackdrop && modelValue"
17
+ :class="twMerge(`popover--backdrop absolute inset-0 bg-black/50`, backdropClass)"
18
+ @click="modelValue = false"
19
+ />
20
+ </transition>
21
+
22
+ <PopoverContent
23
+ v-bind="{
24
+ disableOutsidePointerEvents: false,
25
+ side: 'bottom',
26
+ sideFlip: true,
27
+ align: 'center',
28
+ sideOffset: 0,
29
+ alignOffset: 0,
30
+ avoidCollisions: true,
31
+ prioritizePosition: false,
32
+ sticky: 'always',
33
+ collisionPadding: 10,
34
+ positionStrategy: 'absolute',
35
+ ...contentProps,
36
+ style: undefined
37
+ }"
38
+ :style="contentStyle"
39
+ :class="twMerge(`
40
+ popover--content
41
+ focus:outline-none
42
+ overflow-auto
43
+ scrollbar-hidden
44
+ `,
45
+ animationDirection === `use-side` && `
46
+ data-[side=top]:animate-slideInUp
47
+ data-[side=bottom]:animate-slideInDown
48
+ data-[side=left]:animate-slideInLeft
49
+ data-[side=right]:animate-slideInRight
50
+ `,
51
+ animationDirection === `use-align` && (contentProps?.side === 'top' || contentProps?.side === 'bottom' || !contentProps?.side) && `
52
+ data-[align=start]:animate-slideInLeft
53
+ data-[align=end]:animate-slideInRight
54
+ data-[align=center]:animate-contentShow
55
+ `,
56
+ animationDirection === `use-align` && (contentProps?.side === 'left' || contentProps?.side === 'right' || !contentProps?.side) && `
57
+ data-[align=start]:animate-slideInDown
58
+ data-[align=end]:animate-slideInUp
59
+ data-[align=center]:animate-contentShow
60
+ `,
61
+ animationDirection === `left` && `
62
+ animate-slideInLeft
63
+ `,
64
+ animationDirection === `right` && `
65
+ animate-slideInRight
66
+ `,
67
+ animationDirection === `up` && `
68
+ data-[side=top]:animate-slideInUp
69
+ `,
70
+ animationDirection === `down` && `
71
+ animate-slideInDown
72
+ `,
73
+ animationDirection === `show` && `
74
+ animate-contentShow
75
+ `,
76
+ contentProps?.class)"
77
+ >
78
+ <div
79
+ :class="twMerge(`
80
+ popover--content-inner
81
+ flex
82
+ flex-col
83
+ bg-neutral-50
84
+ dark:bg-neutral-900
85
+ rounded-sm
86
+ p-2
87
+ shadow-sm
88
+ shadow-black/30
89
+ border
90
+ border-black/30
91
+ whitespace-pre-wrap
92
+ overflow-auto
93
+ `)"
94
+ >
95
+ <slot name="popover"/>
96
+ </div>
97
+
98
+ <PopoverArrow
99
+ v-if="showArrow"
100
+ :class="twMerge(`
101
+ popover--arrow
102
+ -mt-px
103
+ fill-neutral-50
104
+ dark:fill-neutral-800
105
+ drop-shadow-[0_2px_1px_rgba(0,0,0,0.3)]
106
+ relative
107
+ stroke-black/30
108
+ `)"
109
+ />
110
+ </PopoverContent>
111
+ </PopoverPortal>
112
+ </PopoverRoot>
113
+ </template>
114
+
115
+ <script setup lang="ts">
116
+ import {
117
+ type DialogContentEmits,
118
+ type DialogRootEmits,
119
+ PopoverAnchor,
120
+ PopoverArrow,
121
+ PopoverContent,
122
+ type PopoverContentProps,
123
+ PopoverPortal,
124
+ PopoverRoot,
125
+ type PopoverRootProps
126
+ } from "reka-ui"
127
+ import type { HTMLAttributes } from "vue"
128
+
129
+ import { usePopupConstrainToStyle } from "../../composables/usePopupConstrainToStyle.js"
130
+ import type { EmitsToProps, PopupConstrainToProps, TailwindClassProp } from "../../types/index.js"
131
+ import { twMerge } from "../../utils/twMerge.js"
132
+
133
+ /** Wrapper around reka-ui's `Popover` component. */
134
+ defineOptions({
135
+ name: "WPopover",
136
+ inheritAttrs: false
137
+ })
138
+
139
+
140
+ const props = withDefaults(defineProps<
141
+ & PopupConstrainToProps
142
+ & {
143
+ backdropClass?: string
144
+ /* If true, a backdrop is shown behind the popover. Whether interaction is allowed outside the popover is still determined by `disableOutsidePointerEvents`. */
145
+ showBackdrop?: boolean
146
+ showArrow?: boolean
147
+ animationDirection?: "use-side" | "use-align" | "left" | "right" | "up" | "down" | "show" | "none"
148
+ /** Overrides teleport target. */
149
+ to?: string
150
+ /** Overrides reka-ui's PopoverRootProps */
151
+ rootProps?: PopoverRootProps & EmitsToProps<DialogRootEmits> & Omit<HTMLAttributes, "class"> & TailwindClassProp
152
+ /** Overrides reka-ui's PopoverContentProps */
153
+ contentProps?: PopoverContentProps & EmitsToProps<DialogContentEmits> & Omit<HTMLAttributes, "class"> & TailwindClassProp
154
+ }
155
+ >(), {
156
+ showBackdrop: false,
157
+ showArrow: true,
158
+ constrainWidthTo: 400,
159
+ constrainHeightTo: "available",
160
+ animationDirection: "use-side",
161
+ to: "#root"
162
+ })
163
+
164
+ const modelValue = defineModel<boolean>({ default: false })
165
+
166
+ const contentStyle = usePopupConstrainToStyle("popover", props, [props?.contentProps?.style])
167
+ </script>
168
+
@@ -0,0 +1,104 @@
1
+ /* eslint-disable @typescript-eslint/naming-convention */
2
+ import type { Meta, StoryObj } from "@storybook/vue3"
3
+ import { ref } from "vue"
4
+
5
+ import WPopup from "./WPopup.vue"
6
+
7
+ import * as components from "../index.js"
8
+
9
+ type ExtraTestArgs = {
10
+ _slots: string
11
+ }
12
+ const meta: Meta<typeof WPopup> = {
13
+ component: WPopup,
14
+ title: "Components/Popup",
15
+ args: {
16
+ title: "Popup Title",
17
+ description: "Popup Description"
18
+ }
19
+ }
20
+
21
+ export default meta
22
+ type Story = StoryObj<typeof WPopup> & { args?: ExtraTestArgs }
23
+
24
+ export const Primary: Story = {
25
+ render: args => {
26
+ const extraArgs = args as ExtraTestArgs
27
+ return {
28
+ components,
29
+ setup: () => {
30
+ const value = ref(false)
31
+ return { args, value }
32
+ },
33
+ template: `
34
+ <div class="test bg-transparency-squares flex items-center justify-center" style="height:80vh;border:1px solid black;">
35
+ <WPopup
36
+ :title="args.title"
37
+ :description="args.description"
38
+ v-model="value"
39
+ v-bind="args"
40
+ >
41
+ ${extraArgs._slots}
42
+ <template #button>
43
+ <WButton>Open Modal Popup</WButton>
44
+ </template>
45
+ <template #extra>
46
+ <div
47
+ :style="{width: args.width, height: args.height}"
48
+ >
49
+ <div>Extra Slot</div>
50
+ </div>
51
+ </template>
52
+ </WPopup>
53
+ </div>
54
+ `
55
+ }
56
+ }
57
+ }
58
+
59
+ export const OtherSlots = {
60
+ ...Primary,
61
+ args: {
62
+ _slots: `
63
+ <template #title>
64
+ <div>Title Slot</div>
65
+ </template>
66
+ <template #description>
67
+ <div>Description Slot</div>
68
+ </template>
69
+ <template #close>
70
+ <div>Close Slot</div>
71
+ </template>
72
+ <template #backdrop>
73
+ <div>Backdrop Slot</div>
74
+ </template>
75
+ `
76
+ }
77
+ }
78
+
79
+ export const PopupSlots = {
80
+ ...Primary,
81
+ args: {
82
+ _slots: `
83
+ <template #popup>
84
+ <div>Popup Slot - Replaces Other Slots except Close (note, you must provide reka's DialogTitle and DialogDescription to avoid it's warnings</div>
85
+ </template>
86
+ `
87
+ }
88
+ }
89
+ export const PopupLarge = {
90
+ ...Primary,
91
+ args: {
92
+ width: "80vw",
93
+ height: "80vh"
94
+ }
95
+ }
96
+
97
+ // popup should scroll contents instead of getting to big (popup will limit it)
98
+ export const PopupTooBig = {
99
+ ...Primary,
100
+ args: {
101
+ width: "110vw",
102
+ height: "110vh"
103
+ }
104
+ }
@@ -0,0 +1,134 @@
1
+ <template>
2
+ <DialogRoot
3
+ v-bind="rootProps"
4
+ v-model:open="modelValue"
5
+ >
6
+ <DialogTrigger
7
+ v-if="$slots.button"
8
+ as-child
9
+ >
10
+ <slot name="button"/>
11
+ </DialogTrigger>
12
+
13
+ <DialogPortal :to="to">
14
+ <DialogOverlay
15
+ as-child
16
+ >
17
+ <slot
18
+ name="backdrop"
19
+ class="popup--backdrop absolute inset-0 bg-black/50"
20
+ >
21
+ <div
22
+ class="popup--backdrop absolute inset-0 bg-black/50"
23
+ />
24
+ </slot>
25
+ </DialogOverlay>
26
+
27
+
28
+ <DialogContent
29
+ v-bind="{ ...contentProps, class: undefined }"
30
+ :class="twMerge(`
31
+ popup--content
32
+ z-100
33
+ focus:outline-none
34
+ fixed
35
+ top-1/2
36
+ left-1/2
37
+ -translate-x-1/2
38
+ -translate-y-1/2
39
+ animate-contentShow
40
+ max-w-[100dvw]
41
+ max-h-[100dvh]
42
+ overflow-auto
43
+ scrollbar-hidden
44
+ p-5
45
+ `, contentProps?.class)"
46
+ >
47
+ <div
48
+ :class="twMerge(`
49
+ popup--content-inner
50
+ flex
51
+ flex-col
52
+ bg-neutral-100
53
+ dark:bg-neutral-800
54
+ rounded-md
55
+ flex
56
+ flex-col
57
+ gap-3
58
+ p-2
59
+ `)"
60
+ >
61
+ <slot name="popup">
62
+ <slot name="title">
63
+ <DialogTitle
64
+ v-if="title"
65
+ class="text-lg font-bold"
66
+ >
67
+ {{ title }}
68
+ </DialogTitle>
69
+ </slot>
70
+ <slot name="description">
71
+ <DialogDescription v-if="description">
72
+ {{ description }}
73
+ </DialogDescription>
74
+ </slot>
75
+ <slot name="extra"/>
76
+ </slot>
77
+ <DialogClose as-child>
78
+ <slot name="close">
79
+ <WButton
80
+ class="justify-self-end"
81
+ @click="modelValue = false"
82
+ >
83
+ Close
84
+ </WButton>
85
+ </slot>
86
+ </DialogClose>
87
+ </div>
88
+ </DialogContent>
89
+ </DialogPortal>
90
+ </DialogRoot>
91
+ </template>
92
+
93
+ <script setup lang="ts">
94
+ import type {
95
+ DialogContentEmits,
96
+ DialogContentProps,
97
+ DialogRootEmits,
98
+ DialogRootProps
99
+ } from "reka-ui"
100
+ import {
101
+ DialogClose,
102
+ DialogContent,
103
+ DialogDescription,
104
+ DialogOverlay,
105
+ DialogPortal,
106
+ DialogRoot,
107
+ DialogTitle,
108
+ DialogTrigger } from "reka-ui"
109
+ import type { EmitsToProps, HTMLAttributes } from "vue"
110
+
111
+ import type { TailwindClassProp } from "../../types/index.js"
112
+ import { twMerge } from "../../utils/twMerge.js"
113
+ import WButton from "../WButton/WButton.vue"
114
+
115
+ defineOptions({ name: "WPopup", inheritAttrs: false })
116
+
117
+ withDefaults(defineProps<
118
+ & {
119
+ title?: string
120
+ description?: string
121
+ backdropClass?: string
122
+ /** Overrides reka-ui's DialogContentProps */
123
+ contentProps?: DialogContentProps & EmitsToProps<DialogContentEmits> & Omit<HTMLAttributes, "class"> & TailwindClassProp
124
+ /** Overrides reka-ui's DialogRootProps */
125
+ rootProps?: DialogRootProps & EmitsToProps<DialogRootEmits> & Omit<HTMLAttributes, "class"> & TailwindClassProp
126
+ /** Overrides teleport target. */
127
+ to?: string
128
+ }
129
+ >(), {
130
+ to: "#root"
131
+ })
132
+
133
+ const modelValue = defineModel<boolean>({ default: false })
134
+ </script>