@rupe/v-datepicker 1.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (639) hide show
  1. package/LICENSE +21 -0
  2. package/dist/components/Calendar/CalendarCell.d.ts +17 -0
  3. package/dist/components/Calendar/CalendarCell.vue.js +34 -0
  4. package/dist/components/Calendar/CalendarCell.vue.js.map +1 -0
  5. package/dist/components/Calendar/CalendarCell.vue2.js +5 -0
  6. package/dist/components/Calendar/CalendarCell.vue2.js.map +1 -0
  7. package/dist/components/Calendar/CalendarCellTrigger.d.ts +72 -0
  8. package/dist/components/Calendar/CalendarCellTrigger.vue.js +159 -0
  9. package/dist/components/Calendar/CalendarCellTrigger.vue.js.map +1 -0
  10. package/dist/components/Calendar/CalendarCellTrigger.vue2.js +5 -0
  11. package/dist/components/Calendar/CalendarCellTrigger.vue2.js.map +1 -0
  12. package/dist/components/Calendar/CalendarGrid.d.ts +13 -0
  13. package/dist/components/Calendar/CalendarGrid.vue.js +40 -0
  14. package/dist/components/Calendar/CalendarGrid.vue.js.map +1 -0
  15. package/dist/components/Calendar/CalendarGrid.vue2.js +5 -0
  16. package/dist/components/Calendar/CalendarGrid.vue2.js.map +1 -0
  17. package/dist/components/Calendar/CalendarGridBody.d.ts +13 -0
  18. package/dist/components/Calendar/CalendarGridBody.vue.js +25 -0
  19. package/dist/components/Calendar/CalendarGridBody.vue.js.map +1 -0
  20. package/dist/components/Calendar/CalendarGridBody.vue2.js +5 -0
  21. package/dist/components/Calendar/CalendarGridBody.vue2.js.map +1 -0
  22. package/dist/components/Calendar/CalendarGridHead.d.ts +13 -0
  23. package/dist/components/Calendar/CalendarGridHead.vue.js +25 -0
  24. package/dist/components/Calendar/CalendarGridHead.vue.js.map +1 -0
  25. package/dist/components/Calendar/CalendarGridHead.vue2.js +5 -0
  26. package/dist/components/Calendar/CalendarGridHead.vue2.js.map +1 -0
  27. package/dist/components/Calendar/CalendarGridRow.d.ts +13 -0
  28. package/dist/components/Calendar/CalendarGridRow.vue.js +25 -0
  29. package/dist/components/Calendar/CalendarGridRow.vue.js.map +1 -0
  30. package/dist/components/Calendar/CalendarGridRow.vue2.js +5 -0
  31. package/dist/components/Calendar/CalendarGridRow.vue2.js.map +1 -0
  32. package/dist/components/Calendar/CalendarHeadCell.d.ts +13 -0
  33. package/dist/components/Calendar/CalendarHeadCell.vue.js +25 -0
  34. package/dist/components/Calendar/CalendarHeadCell.vue.js.map +1 -0
  35. package/dist/components/Calendar/CalendarHeadCell.vue2.js +5 -0
  36. package/dist/components/Calendar/CalendarHeadCell.vue2.js.map +1 -0
  37. package/dist/components/Calendar/CalendarHeader.d.ts +13 -0
  38. package/dist/components/Calendar/CalendarHeader.vue.js +25 -0
  39. package/dist/components/Calendar/CalendarHeader.vue.js.map +1 -0
  40. package/dist/components/Calendar/CalendarHeader.vue2.js +5 -0
  41. package/dist/components/Calendar/CalendarHeader.vue2.js.map +1 -0
  42. package/dist/components/Calendar/CalendarHeading.d.ts +21 -0
  43. package/dist/components/Calendar/CalendarHeading.vue.js +33 -0
  44. package/dist/components/Calendar/CalendarHeading.vue.js.map +1 -0
  45. package/dist/components/Calendar/CalendarHeading.vue2.js +5 -0
  46. package/dist/components/Calendar/CalendarHeading.vue2.js.map +1 -0
  47. package/dist/components/Calendar/CalendarMonthHeading.d.ts +22 -0
  48. package/dist/components/Calendar/CalendarMonthHeading.vue.js +49 -0
  49. package/dist/components/Calendar/CalendarMonthHeading.vue.js.map +1 -0
  50. package/dist/components/Calendar/CalendarMonthHeading.vue2.js +5 -0
  51. package/dist/components/Calendar/CalendarMonthHeading.vue2.js.map +1 -0
  52. package/dist/components/Calendar/CalendarMonthYearOverlay.d.ts +27 -0
  53. package/dist/components/Calendar/CalendarMonthYearOverlay.vue.js +61 -0
  54. package/dist/components/Calendar/CalendarMonthYearOverlay.vue.js.map +1 -0
  55. package/dist/components/Calendar/CalendarMonthYearOverlay.vue2.js +5 -0
  56. package/dist/components/Calendar/CalendarMonthYearOverlay.vue2.js.map +1 -0
  57. package/dist/components/Calendar/CalendarNext.d.ts +21 -0
  58. package/dist/components/Calendar/CalendarNext.vue.js +42 -0
  59. package/dist/components/Calendar/CalendarNext.vue.js.map +1 -0
  60. package/dist/components/Calendar/CalendarNext.vue2.js +5 -0
  61. package/dist/components/Calendar/CalendarNext.vue2.js.map +1 -0
  62. package/dist/components/Calendar/CalendarOverlayItem.d.ts +24 -0
  63. package/dist/components/Calendar/CalendarOverlayItem.vue.js +34 -0
  64. package/dist/components/Calendar/CalendarOverlayItem.vue.js.map +1 -0
  65. package/dist/components/Calendar/CalendarOverlayItem.vue2.js +5 -0
  66. package/dist/components/Calendar/CalendarOverlayItem.vue2.js.map +1 -0
  67. package/dist/components/Calendar/CalendarPrev.d.ts +21 -0
  68. package/dist/components/Calendar/CalendarPrev.vue.js +42 -0
  69. package/dist/components/Calendar/CalendarPrev.vue.js.map +1 -0
  70. package/dist/components/Calendar/CalendarPrev.vue2.js +5 -0
  71. package/dist/components/Calendar/CalendarPrev.vue2.js.map +1 -0
  72. package/dist/components/Calendar/CalendarRoot.d.ts +210 -0
  73. package/dist/components/Calendar/CalendarRoot.vue.js +253 -0
  74. package/dist/components/Calendar/CalendarRoot.vue.js.map +1 -0
  75. package/dist/components/Calendar/CalendarRoot.vue2.js +8 -0
  76. package/dist/components/Calendar/CalendarRoot.vue2.js.map +1 -0
  77. package/dist/components/Calendar/CalendarYearHeading.d.ts +22 -0
  78. package/dist/components/Calendar/CalendarYearHeading.vue.js +49 -0
  79. package/dist/components/Calendar/CalendarYearHeading.vue.js.map +1 -0
  80. package/dist/components/Calendar/CalendarYearHeading.vue2.js +5 -0
  81. package/dist/components/Calendar/CalendarYearHeading.vue2.js.map +1 -0
  82. package/dist/components/Calendar/index.d.ts +15 -0
  83. package/dist/components/Calendar/useCalendar.d.ts +50 -0
  84. package/dist/components/Calendar/useCalendar.js +317 -0
  85. package/dist/components/Calendar/useCalendar.js.map +1 -0
  86. package/dist/components/ConfigProvider/ConfigProvider.d.ts +51 -0
  87. package/dist/components/ConfigProvider/ConfigProvider.vue.js +7 -0
  88. package/dist/components/ConfigProvider/ConfigProvider.vue.js.map +1 -0
  89. package/dist/components/ConfigProvider/index.d.ts +1 -0
  90. package/dist/components/DateField/DateFieldInput.d.ts +15 -0
  91. package/dist/components/DateField/DateFieldInput.vue.js +70 -0
  92. package/dist/components/DateField/DateFieldInput.vue.js.map +1 -0
  93. package/dist/components/DateField/DateFieldInput.vue2.js +5 -0
  94. package/dist/components/DateField/DateFieldInput.vue2.js.map +1 -0
  95. package/dist/components/DateField/DateFieldRoot.d.ts +151 -0
  96. package/dist/components/DateField/DateFieldRoot.vue.js +237 -0
  97. package/dist/components/DateField/DateFieldRoot.vue.js.map +1 -0
  98. package/dist/components/DateField/DateFieldRoot.vue2.js +8 -0
  99. package/dist/components/DateField/DateFieldRoot.vue2.js.map +1 -0
  100. package/dist/components/DateField/index.d.ts +2 -0
  101. package/dist/components/DatePicker/DatePickerAnchor.d.ts +11 -0
  102. package/dist/components/DatePicker/DatePickerAnchor.vue.js +29 -0
  103. package/dist/components/DatePicker/DatePickerAnchor.vue.js.map +1 -0
  104. package/dist/components/DatePicker/DatePickerAnchor.vue2.js +5 -0
  105. package/dist/components/DatePicker/DatePickerAnchor.vue2.js.map +1 -0
  106. package/dist/components/DatePicker/DatePickerArrow.d.ts +11 -0
  107. package/dist/components/DatePicker/DatePickerArrow.vue.js +31 -0
  108. package/dist/components/DatePicker/DatePickerArrow.vue.js.map +1 -0
  109. package/dist/components/DatePicker/DatePickerArrow.vue2.js +5 -0
  110. package/dist/components/DatePicker/DatePickerArrow.vue2.js.map +1 -0
  111. package/dist/components/DatePicker/DatePickerCalendar.d.ts +17 -0
  112. package/dist/components/DatePicker/DatePickerCalendar.vue.js +60 -0
  113. package/dist/components/DatePicker/DatePickerCalendar.vue.js.map +1 -0
  114. package/dist/components/DatePicker/DatePickerCalendar.vue2.js +5 -0
  115. package/dist/components/DatePicker/DatePickerCalendar.vue2.js.map +1 -0
  116. package/dist/components/DatePicker/DatePickerCell.d.ts +11 -0
  117. package/dist/components/DatePicker/DatePickerCell.vue.js +28 -0
  118. package/dist/components/DatePicker/DatePickerCell.vue.js.map +1 -0
  119. package/dist/components/DatePicker/DatePickerCell.vue2.js +5 -0
  120. package/dist/components/DatePicker/DatePickerCell.vue2.js.map +1 -0
  121. package/dist/components/DatePicker/DatePickerCellTrigger.d.ts +10 -0
  122. package/dist/components/DatePicker/DatePickerCellTrigger.vue.js +29 -0
  123. package/dist/components/DatePicker/DatePickerCellTrigger.vue.js.map +1 -0
  124. package/dist/components/DatePicker/DatePickerCellTrigger.vue2.js +5 -0
  125. package/dist/components/DatePicker/DatePickerCellTrigger.vue2.js.map +1 -0
  126. package/dist/components/DatePicker/DatePickerClose.d.ts +11 -0
  127. package/dist/components/DatePicker/DatePickerClose.vue.js +28 -0
  128. package/dist/components/DatePicker/DatePickerClose.vue.js.map +1 -0
  129. package/dist/components/DatePicker/DatePickerClose.vue2.js +5 -0
  130. package/dist/components/DatePicker/DatePickerClose.vue2.js.map +1 -0
  131. package/dist/components/DatePicker/DatePickerContent.d.ts +31 -0
  132. package/dist/components/DatePicker/DatePickerContent.vue.js +69 -0
  133. package/dist/components/DatePicker/DatePickerContent.vue.js.map +1 -0
  134. package/dist/components/DatePicker/DatePickerContent.vue2.js +5 -0
  135. package/dist/components/DatePicker/DatePickerContent.vue2.js.map +1 -0
  136. package/dist/components/DatePicker/DatePickerField.d.ts +16 -0
  137. package/dist/components/DatePicker/DatePickerField.vue.js +55 -0
  138. package/dist/components/DatePicker/DatePickerField.vue.js.map +1 -0
  139. package/dist/components/DatePicker/DatePickerField.vue2.js +5 -0
  140. package/dist/components/DatePicker/DatePickerField.vue2.js.map +1 -0
  141. package/dist/components/DatePicker/DatePickerGrid.d.ts +11 -0
  142. package/dist/components/DatePicker/DatePickerGrid.vue.js +27 -0
  143. package/dist/components/DatePicker/DatePickerGrid.vue.js.map +1 -0
  144. package/dist/components/DatePicker/DatePickerGrid.vue2.js +5 -0
  145. package/dist/components/DatePicker/DatePickerGrid.vue2.js.map +1 -0
  146. package/dist/components/DatePicker/DatePickerGridBody.d.ts +11 -0
  147. package/dist/components/DatePicker/DatePickerGridBody.vue.js +27 -0
  148. package/dist/components/DatePicker/DatePickerGridBody.vue.js.map +1 -0
  149. package/dist/components/DatePicker/DatePickerGridBody.vue2.js +5 -0
  150. package/dist/components/DatePicker/DatePickerGridBody.vue2.js.map +1 -0
  151. package/dist/components/DatePicker/DatePickerGridHead.d.ts +11 -0
  152. package/dist/components/DatePicker/DatePickerGridHead.vue.js +27 -0
  153. package/dist/components/DatePicker/DatePickerGridHead.vue.js.map +1 -0
  154. package/dist/components/DatePicker/DatePickerGridHead.vue2.js +5 -0
  155. package/dist/components/DatePicker/DatePickerGridHead.vue2.js.map +1 -0
  156. package/dist/components/DatePicker/DatePickerGridRow.d.ts +11 -0
  157. package/dist/components/DatePicker/DatePickerGridRow.vue.js +27 -0
  158. package/dist/components/DatePicker/DatePickerGridRow.vue.js.map +1 -0
  159. package/dist/components/DatePicker/DatePickerGridRow.vue2.js +5 -0
  160. package/dist/components/DatePicker/DatePickerGridRow.vue2.js.map +1 -0
  161. package/dist/components/DatePicker/DatePickerHeadCell.d.ts +11 -0
  162. package/dist/components/DatePicker/DatePickerHeadCell.vue.js +27 -0
  163. package/dist/components/DatePicker/DatePickerHeadCell.vue.js.map +1 -0
  164. package/dist/components/DatePicker/DatePickerHeadCell.vue2.js +5 -0
  165. package/dist/components/DatePicker/DatePickerHeadCell.vue2.js.map +1 -0
  166. package/dist/components/DatePicker/DatePickerHeader.d.ts +11 -0
  167. package/dist/components/DatePicker/DatePickerHeader.vue.js +27 -0
  168. package/dist/components/DatePicker/DatePickerHeader.vue.js.map +1 -0
  169. package/dist/components/DatePicker/DatePickerHeader.vue2.js +5 -0
  170. package/dist/components/DatePicker/DatePickerHeader.vue2.js.map +1 -0
  171. package/dist/components/DatePicker/DatePickerHeading.d.ts +19 -0
  172. package/dist/components/DatePicker/DatePickerHeading.vue.js +29 -0
  173. package/dist/components/DatePicker/DatePickerHeading.vue.js.map +1 -0
  174. package/dist/components/DatePicker/DatePickerHeading.vue2.js +5 -0
  175. package/dist/components/DatePicker/DatePickerHeading.vue2.js.map +1 -0
  176. package/dist/components/DatePicker/DatePickerInput.d.ts +11 -0
  177. package/dist/components/DatePicker/DatePickerInput.vue.js +27 -0
  178. package/dist/components/DatePicker/DatePickerInput.vue.js.map +1 -0
  179. package/dist/components/DatePicker/DatePickerInput.vue2.js +5 -0
  180. package/dist/components/DatePicker/DatePickerInput.vue2.js.map +1 -0
  181. package/dist/components/DatePicker/DatePickerMonthHeading.d.ts +13 -0
  182. package/dist/components/DatePicker/DatePickerMonthHeading.vue.js +27 -0
  183. package/dist/components/DatePicker/DatePickerMonthHeading.vue.js.map +1 -0
  184. package/dist/components/DatePicker/DatePickerMonthHeading.vue2.js +5 -0
  185. package/dist/components/DatePicker/DatePickerMonthHeading.vue2.js.map +1 -0
  186. package/dist/components/DatePicker/DatePickerMonthYearOverlay.d.ts +24 -0
  187. package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue.js +30 -0
  188. package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue.js.map +1 -0
  189. package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue2.js +5 -0
  190. package/dist/components/DatePicker/DatePickerMonthYearOverlay.vue2.js.map +1 -0
  191. package/dist/components/DatePicker/DatePickerNext.d.ts +10 -0
  192. package/dist/components/DatePicker/DatePickerNext.vue.js +28 -0
  193. package/dist/components/DatePicker/DatePickerNext.vue.js.map +1 -0
  194. package/dist/components/DatePicker/DatePickerNext.vue2.js +5 -0
  195. package/dist/components/DatePicker/DatePickerNext.vue2.js.map +1 -0
  196. package/dist/components/DatePicker/DatePickerOverlayItem.d.ts +19 -0
  197. package/dist/components/DatePicker/DatePickerOverlayItem.vue.js +25 -0
  198. package/dist/components/DatePicker/DatePickerOverlayItem.vue.js.map +1 -0
  199. package/dist/components/DatePicker/DatePickerOverlayItem.vue2.js +5 -0
  200. package/dist/components/DatePicker/DatePickerOverlayItem.vue2.js.map +1 -0
  201. package/dist/components/DatePicker/DatePickerPrev.d.ts +10 -0
  202. package/dist/components/DatePicker/DatePickerPrev.vue.js +28 -0
  203. package/dist/components/DatePicker/DatePickerPrev.vue.js.map +1 -0
  204. package/dist/components/DatePicker/DatePickerPrev.vue2.js +5 -0
  205. package/dist/components/DatePicker/DatePickerPrev.vue2.js.map +1 -0
  206. package/dist/components/DatePicker/DatePickerRoot.d.ts +84 -0
  207. package/dist/components/DatePicker/DatePickerRoot.vue.js +169 -0
  208. package/dist/components/DatePicker/DatePickerRoot.vue.js.map +1 -0
  209. package/dist/components/DatePicker/DatePickerRoot.vue2.js +8 -0
  210. package/dist/components/DatePicker/DatePickerRoot.vue2.js.map +1 -0
  211. package/dist/components/DatePicker/DatePickerTrigger.d.ts +11 -0
  212. package/dist/components/DatePicker/DatePickerTrigger.vue.js +37 -0
  213. package/dist/components/DatePicker/DatePickerTrigger.vue.js.map +1 -0
  214. package/dist/components/DatePicker/DatePickerTrigger.vue2.js +5 -0
  215. package/dist/components/DatePicker/DatePickerTrigger.vue2.js.map +1 -0
  216. package/dist/components/DatePicker/DatePickerYearHeading.d.ts +13 -0
  217. package/dist/components/DatePicker/DatePickerYearHeading.vue.js +27 -0
  218. package/dist/components/DatePicker/DatePickerYearHeading.vue.js.map +1 -0
  219. package/dist/components/DatePicker/DatePickerYearHeading.vue2.js +5 -0
  220. package/dist/components/DatePicker/DatePickerYearHeading.vue2.js.map +1 -0
  221. package/dist/components/DatePicker/index.d.ts +24 -0
  222. package/dist/components/DismissableLayer/DismissableLayer.d.ts +67 -0
  223. package/dist/components/DismissableLayer/DismissableLayer.vue.js +118 -0
  224. package/dist/components/DismissableLayer/DismissableLayer.vue.js.map +1 -0
  225. package/dist/components/DismissableLayer/DismissableLayer.vue2.js +7 -0
  226. package/dist/components/DismissableLayer/DismissableLayer.vue2.js.map +1 -0
  227. package/dist/components/DismissableLayer/DismissableLayerBranch.d.ts +11 -0
  228. package/dist/components/DismissableLayer/index.d.ts +3 -0
  229. package/dist/components/DismissableLayer/utils.d.ts +28 -0
  230. package/dist/components/DismissableLayer/utils.js +112 -0
  231. package/dist/components/DismissableLayer/utils.js.map +1 -0
  232. package/dist/components/FocusScope/FocusScope.d.ts +82 -0
  233. package/dist/components/FocusScope/FocusScope.test.d.ts +1 -0
  234. package/dist/components/FocusScope/FocusScope.vue.js +149 -0
  235. package/dist/components/FocusScope/FocusScope.vue.js.map +1 -0
  236. package/dist/components/FocusScope/FocusScope.vue2.js +5 -0
  237. package/dist/components/FocusScope/FocusScope.vue2.js.map +1 -0
  238. package/dist/components/FocusScope/index.d.ts +1 -0
  239. package/dist/components/FocusScope/stack.d.ts +12 -0
  240. package/dist/components/FocusScope/stack.js +38 -0
  241. package/dist/components/FocusScope/stack.js.map +1 -0
  242. package/dist/components/FocusScope/utils.d.ts +46 -0
  243. package/dist/components/FocusScope/utils.js +70 -0
  244. package/dist/components/FocusScope/utils.js.map +1 -0
  245. package/dist/components/Popover/PopoverAnchor.d.ts +11 -0
  246. package/dist/components/Popover/PopoverAnchor.vue.js +37 -0
  247. package/dist/components/Popover/PopoverAnchor.vue.js.map +1 -0
  248. package/dist/components/Popover/PopoverAnchor.vue2.js +5 -0
  249. package/dist/components/Popover/PopoverAnchor.vue2.js.map +1 -0
  250. package/dist/components/Popover/PopoverArrow.d.ts +15 -0
  251. package/dist/components/Popover/PopoverArrow.vue.js +31 -0
  252. package/dist/components/Popover/PopoverArrow.vue.js.map +1 -0
  253. package/dist/components/Popover/PopoverArrow.vue2.js +5 -0
  254. package/dist/components/Popover/PopoverArrow.vue2.js.map +1 -0
  255. package/dist/components/Popover/PopoverClose.d.ts +13 -0
  256. package/dist/components/Popover/PopoverClose.vue.js +34 -0
  257. package/dist/components/Popover/PopoverClose.vue.js.map +1 -0
  258. package/dist/components/Popover/PopoverClose.vue2.js +5 -0
  259. package/dist/components/Popover/PopoverClose.vue2.js.map +1 -0
  260. package/dist/components/Popover/PopoverContent.d.ts +32 -0
  261. package/dist/components/Popover/PopoverContent.vue.js +61 -0
  262. package/dist/components/Popover/PopoverContent.vue.js.map +1 -0
  263. package/dist/components/Popover/PopoverContent.vue2.js +5 -0
  264. package/dist/components/Popover/PopoverContent.vue2.js.map +1 -0
  265. package/dist/components/Popover/PopoverContentImpl.d.ts +47 -0
  266. package/dist/components/Popover/PopoverContentImpl.vue.js +97 -0
  267. package/dist/components/Popover/PopoverContentImpl.vue.js.map +1 -0
  268. package/dist/components/Popover/PopoverContentImpl.vue2.js +5 -0
  269. package/dist/components/Popover/PopoverContentImpl.vue2.js.map +1 -0
  270. package/dist/components/Popover/PopoverContentNonModal.d.ts +32 -0
  271. package/dist/components/Popover/PopoverContentNonModal.vue.js +78 -0
  272. package/dist/components/Popover/PopoverContentNonModal.vue.js.map +1 -0
  273. package/dist/components/Popover/PopoverContentNonModal.vue2.js +5 -0
  274. package/dist/components/Popover/PopoverContentNonModal.vue2.js.map +1 -0
  275. package/dist/components/Popover/PopoverPortal.d.ts +11 -0
  276. package/dist/components/Popover/PopoverPortal.vue.js +26 -0
  277. package/dist/components/Popover/PopoverPortal.vue.js.map +1 -0
  278. package/dist/components/Popover/PopoverPortal.vue2.js +5 -0
  279. package/dist/components/Popover/PopoverPortal.vue2.js.map +1 -0
  280. package/dist/components/Popover/PopoverRoot.d.ts +55 -0
  281. package/dist/components/Popover/PopoverRoot.vue.js +55 -0
  282. package/dist/components/Popover/PopoverRoot.vue.js.map +1 -0
  283. package/dist/components/Popover/PopoverRoot.vue2.js +8 -0
  284. package/dist/components/Popover/PopoverRoot.vue2.js.map +1 -0
  285. package/dist/components/Popover/PopoverTrigger.d.ts +13 -0
  286. package/dist/components/Popover/PopoverTrigger.vue.js +51 -0
  287. package/dist/components/Popover/PopoverTrigger.vue.js.map +1 -0
  288. package/dist/components/Popover/PopoverTrigger.vue2.js +5 -0
  289. package/dist/components/Popover/PopoverTrigger.vue2.js.map +1 -0
  290. package/dist/components/Popover/index.d.ts +7 -0
  291. package/dist/components/Popper/PopperAnchor.d.ts +19 -0
  292. package/dist/components/Popper/PopperAnchor.vue.js +37 -0
  293. package/dist/components/Popper/PopperAnchor.vue.js.map +1 -0
  294. package/dist/components/Popper/PopperAnchor.vue2.js +5 -0
  295. package/dist/components/Popper/PopperAnchor.vue2.js.map +1 -0
  296. package/dist/components/Popper/PopperArrow.d.ts +15 -0
  297. package/dist/components/Popper/PopperArrow.vue.js +76 -0
  298. package/dist/components/Popper/PopperArrow.vue.js.map +1 -0
  299. package/dist/components/Popper/PopperArrow.vue2.js +5 -0
  300. package/dist/components/Popper/PopperArrow.vue2.js.map +1 -0
  301. package/dist/components/Popper/PopperContent.d.ts +179 -0
  302. package/dist/components/Popper/PopperContent.vue.js +9 -0
  303. package/dist/components/Popper/PopperContent.vue.js.map +1 -0
  304. package/dist/components/Popper/PopperContent.vue2.js +230 -0
  305. package/dist/components/Popper/PopperContent.vue2.js.map +1 -0
  306. package/dist/components/Popper/PopperRoot.d.ts +19 -0
  307. package/dist/components/Popper/PopperRoot.vue.js +25 -0
  308. package/dist/components/Popper/PopperRoot.vue.js.map +1 -0
  309. package/dist/components/Popper/PopperRoot.vue2.js +8 -0
  310. package/dist/components/Popper/PopperRoot.vue2.js.map +1 -0
  311. package/dist/components/Popper/index.d.ts +5 -0
  312. package/dist/components/Popper/utils.d.ts +12 -0
  313. package/dist/components/Popper/utils.js +46 -0
  314. package/dist/components/Popper/utils.js.map +1 -0
  315. package/dist/components/Presence/Presence.d.ts +43 -0
  316. package/dist/components/Presence/Presence.js +61 -0
  317. package/dist/components/Presence/Presence.js.map +1 -0
  318. package/dist/components/Presence/index.d.ts +1 -0
  319. package/dist/components/Presence/usePresence.d.ts +4 -0
  320. package/dist/components/Presence/usePresence.js +131 -0
  321. package/dist/components/Presence/usePresence.js.map +1 -0
  322. package/dist/components/Primitive/Primitive.d.ts +39 -0
  323. package/dist/components/Primitive/Primitive.js +29 -0
  324. package/dist/components/Primitive/Primitive.js.map +1 -0
  325. package/dist/components/Primitive/Slot.d.ts +5 -0
  326. package/dist/components/Primitive/Slot.js +30 -0
  327. package/dist/components/Primitive/Slot.js.map +1 -0
  328. package/dist/components/Primitive/index.d.ts +3 -0
  329. package/dist/components/Primitive/usePrimitiveElement.d.ts +5 -0
  330. package/dist/components/Primitive/usePrimitiveElement.js +14 -0
  331. package/dist/components/Primitive/usePrimitiveElement.js.map +1 -0
  332. package/dist/components/Teleport/Teleport.d.ts +37 -0
  333. package/dist/components/Teleport/Teleport.vue.js +28 -0
  334. package/dist/components/Teleport/Teleport.vue.js.map +1 -0
  335. package/dist/components/Teleport/Teleport.vue2.js +5 -0
  336. package/dist/components/Teleport/Teleport.vue2.js.map +1 -0
  337. package/dist/components/Teleport/index.d.ts +1 -0
  338. package/dist/components/VisuallyHidden/VisuallyHidden.d.ts +16 -0
  339. package/dist/components/VisuallyHidden/VisuallyHidden.vue.js +49 -0
  340. package/dist/components/VisuallyHidden/VisuallyHidden.vue.js.map +1 -0
  341. package/dist/components/VisuallyHidden/VisuallyHidden.vue2.js +5 -0
  342. package/dist/components/VisuallyHidden/VisuallyHidden.vue2.js.map +1 -0
  343. package/dist/components/VisuallyHidden/VisuallyHiddenInput.d.ts +14 -0
  344. package/dist/components/VisuallyHidden/VisuallyHiddenInputBubble.d.ts +22 -0
  345. package/dist/components/VisuallyHidden/index.d.ts +2 -0
  346. package/dist/date/calendar.d.ts +59 -0
  347. package/dist/date/calendar.js +90 -0
  348. package/dist/date/calendar.js.map +1 -0
  349. package/dist/date/comparators.d.ts +80 -0
  350. package/dist/date/comparators.js +61 -0
  351. package/dist/date/comparators.js.map +1 -0
  352. package/dist/date/index.d.ts +3 -0
  353. package/dist/date/types.d.ts +28 -0
  354. package/dist/date/utils.d.ts +12 -0
  355. package/dist/date/utils.js +10 -0
  356. package/dist/date/utils.js.map +1 -0
  357. package/dist/index.cjs +9097 -0
  358. package/dist/index.cjs.map +1 -0
  359. package/dist/index.d.ts +27 -0
  360. package/dist/index.js +54 -0
  361. package/dist/index.js.map +1 -0
  362. package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.js +722 -0
  363. package/dist/node_modules/.pnpm/@floating-ui_core@1.7.3/node_modules/@floating-ui/core/dist/floating-ui.core.js.map +1 -0
  364. package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +626 -0
  365. package/dist/node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js.map +1 -0
  366. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +174 -0
  367. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js.map +1 -0
  368. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +155 -0
  369. package/dist/node_modules/.pnpm/@floating-ui_utils@0.2.10/node_modules/@floating-ui/utils/dist/floating-ui.utils.js.map +1 -0
  370. package/dist/node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js +180 -0
  371. package/dist/node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js.map +1 -0
  372. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/BuddhistCalendar.js +34 -0
  373. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/BuddhistCalendar.js.map +1 -0
  374. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/CalendarDate.js +213 -0
  375. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/CalendarDate.js.map +1 -0
  376. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/DateFormatter.js +116 -0
  377. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/DateFormatter.js.map +1 -0
  378. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/EthiopicCalendar.js +129 -0
  379. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/EthiopicCalendar.js.map +1 -0
  380. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/GregorianCalendar.js +123 -0
  381. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/GregorianCalendar.js.map +1 -0
  382. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/HebrewCalendar.js +114 -0
  383. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/HebrewCalendar.js.map +1 -0
  384. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IndianCalendar.js +77 -0
  385. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IndianCalendar.js.map +1 -0
  386. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IslamicCalendar.js +141 -0
  387. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/IslamicCalendar.js.map +1 -0
  388. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/JapaneseCalendar.js +155 -0
  389. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/JapaneseCalendar.js.map +1 -0
  390. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/PersianCalendar.js +59 -0
  391. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/PersianCalendar.js.map +1 -0
  392. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/TaiwanCalendar.js +59 -0
  393. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/TaiwanCalendar.js.map +1 -0
  394. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/conversion.js +170 -0
  395. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/conversion.js.map +1 -0
  396. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/createCalendar.js +44 -0
  397. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/createCalendar.js.map +1 -0
  398. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/manipulation.js +301 -0
  399. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/manipulation.js.map +1 -0
  400. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/queries.js +141 -0
  401. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/queries.js.map +1 -0
  402. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/string.js +35 -0
  403. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/string.js.map +1 -0
  404. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/utils.js +7 -0
  405. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/utils.js.map +1 -0
  406. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/weekStartData.js +101 -0
  407. package/dist/node_modules/.pnpm/@internationalized_date@3.10.1/node_modules/@internationalized/date/dist/weekStartData.js.map +1 -0
  408. package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_check_private_redeclaration.js +9 -0
  409. package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_check_private_redeclaration.js.map +1 -0
  410. package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_class_private_field_init.js +9 -0
  411. package/dist/node_modules/.pnpm/@swc_helpers@0.5.18/node_modules/@swc/helpers/esm/_class_private_field_init.js.map +1 -0
  412. package/dist/node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js +140 -0
  413. package/dist/node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js.map +1 -0
  414. package/dist/node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js +88 -0
  415. package/dist/node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js.map +1 -0
  416. package/dist/node_modules/.pnpm/defu@6.1.4/node_modules/defu/dist/defu.js +60 -0
  417. package/dist/node_modules/.pnpm/defu@6.1.4/node_modules/defu/dist/defu.js.map +1 -0
  418. package/dist/shared/arrays.d.ts +37 -0
  419. package/dist/shared/component/Arrow.d.ts +34 -0
  420. package/dist/shared/component/Arrow.vue.js +45 -0
  421. package/dist/shared/component/Arrow.vue.js.map +1 -0
  422. package/dist/shared/component/Arrow.vue2.js +5 -0
  423. package/dist/shared/component/Arrow.vue2.js.map +1 -0
  424. package/dist/shared/component/BaseSeparator.d.ts +26 -0
  425. package/dist/shared/component/index.d.ts +2 -0
  426. package/dist/shared/constant/countryList.d.ts +1 -0
  427. package/dist/shared/constant/index.d.ts +1 -0
  428. package/dist/shared/createContext.d.ts +8 -0
  429. package/dist/shared/createContext.js +26 -0
  430. package/dist/shared/createContext.js.map +1 -0
  431. package/dist/shared/date/comparators.d.ts +27 -0
  432. package/dist/shared/date/comparators.js +27 -0
  433. package/dist/shared/date/comparators.js.map +1 -0
  434. package/dist/shared/date/index.d.ts +8 -0
  435. package/dist/shared/date/parser.d.ts +37 -0
  436. package/dist/shared/date/parser.js +161 -0
  437. package/dist/shared/date/parser.js.map +1 -0
  438. package/dist/shared/date/parts.d.ts +12 -0
  439. package/dist/shared/date/parts.js +17 -0
  440. package/dist/shared/date/parts.js.map +1 -0
  441. package/dist/shared/date/placeholders.d.ts +8 -0
  442. package/dist/shared/date/placeholders.js +196 -0
  443. package/dist/shared/date/placeholders.js.map +1 -0
  444. package/dist/shared/date/segment.d.ts +5 -0
  445. package/dist/shared/date/segment.js +44 -0
  446. package/dist/shared/date/segment.js.map +1 -0
  447. package/dist/shared/date/types.d.ts +37 -0
  448. package/dist/shared/date/useDateField.d.ts +142 -0
  449. package/dist/shared/date/useDateField.js +618 -0
  450. package/dist/shared/date/useDateField.js.map +1 -0
  451. package/dist/shared/date/utils.d.ts +11 -0
  452. package/dist/shared/date/utils.js +76 -0
  453. package/dist/shared/date/utils.js.map +1 -0
  454. package/dist/shared/getActiveElement.d.ts +1 -0
  455. package/dist/shared/getActiveElement.js +14 -0
  456. package/dist/shared/getActiveElement.js.map +1 -0
  457. package/dist/shared/handleAndDispatchCustomEvent.d.ts +3 -0
  458. package/dist/shared/handleAndDispatchCustomEvent.js +15 -0
  459. package/dist/shared/handleAndDispatchCustomEvent.js.map +1 -0
  460. package/dist/shared/index.d.ts +22 -0
  461. package/dist/shared/nullish.d.ts +1 -0
  462. package/dist/shared/nullish.js +7 -0
  463. package/dist/shared/nullish.js.map +1 -0
  464. package/dist/shared/onFocusOutside.d.ts +2 -0
  465. package/dist/shared/renderSlotFragments.d.ts +2 -0
  466. package/dist/shared/renderSlotFragments.js +14 -0
  467. package/dist/shared/renderSlotFragments.js.map +1 -0
  468. package/dist/shared/trap-focus.d.ts +1 -0
  469. package/dist/shared/types.d.ts +48 -0
  470. package/dist/shared/useDateFormatter.d.ts +30 -0
  471. package/dist/shared/useDateFormatter.js +121 -0
  472. package/dist/shared/useDateFormatter.js.map +1 -0
  473. package/dist/shared/useDirection.d.ts +8 -0
  474. package/dist/shared/useDirection.js +12 -0
  475. package/dist/shared/useDirection.js.map +1 -0
  476. package/dist/shared/useEmitAsProps.d.ts +10 -0
  477. package/dist/shared/useEmitAsProps.js +19 -0
  478. package/dist/shared/useEmitAsProps.js.map +1 -0
  479. package/dist/shared/useFocusGuards.d.ts +5 -0
  480. package/dist/shared/useFocusGuards.js +39 -0
  481. package/dist/shared/useFocusGuards.js.map +1 -0
  482. package/dist/shared/useForwardExpose.d.ts +6 -0
  483. package/dist/shared/useForwardExpose.js +49 -0
  484. package/dist/shared/useForwardExpose.js.map +1 -0
  485. package/dist/shared/useForwardProps.d.ts +9 -0
  486. package/dist/shared/useForwardProps.js +27 -0
  487. package/dist/shared/useForwardProps.js.map +1 -0
  488. package/dist/shared/useForwardPropsEmits.d.ts +14 -0
  489. package/dist/shared/useForwardPropsEmits.js +15 -0
  490. package/dist/shared/useForwardPropsEmits.js.map +1 -0
  491. package/dist/shared/useId.d.ts +9 -0
  492. package/dist/shared/useId.js +19 -0
  493. package/dist/shared/useId.js.map +1 -0
  494. package/dist/shared/useIsUsingKeyboard.d.ts +3 -0
  495. package/dist/shared/useKbd.d.ts +78 -0
  496. package/dist/shared/useKbd.js +42 -0
  497. package/dist/shared/useKbd.js.map +1 -0
  498. package/dist/shared/useLocale.d.ts +7 -0
  499. package/dist/shared/useLocale.js +12 -0
  500. package/dist/shared/useLocale.js.map +1 -0
  501. package/dist/shared/useNonce.d.ts +2 -0
  502. package/dist/shared/useSize.d.ts +5 -0
  503. package/dist/shared/useSize.js +44 -0
  504. package/dist/shared/useSize.js.map +1 -0
  505. package/dist/shared/useStateMachine.d.ts +25 -0
  506. package/dist/shared/useStateMachine.js +19 -0
  507. package/dist/shared/useStateMachine.js.map +1 -0
  508. package/dist/shared/withDefault.d.ts +22 -0
  509. package/package.json +72 -0
  510. package/src/components/Calendar/CalendarCell.vue +39 -0
  511. package/src/components/Calendar/CalendarCellTrigger.vue +206 -0
  512. package/src/components/Calendar/CalendarGrid.vue +35 -0
  513. package/src/components/Calendar/CalendarGridBody.vue +19 -0
  514. package/src/components/Calendar/CalendarGridHead.vue +19 -0
  515. package/src/components/Calendar/CalendarGridRow.vue +17 -0
  516. package/src/components/Calendar/CalendarHeadCell.vue +17 -0
  517. package/src/components/Calendar/CalendarHeader.vue +17 -0
  518. package/src/components/Calendar/CalendarHeading.vue +32 -0
  519. package/src/components/Calendar/CalendarMonthHeading.vue +65 -0
  520. package/src/components/Calendar/CalendarMonthYearOverlay.vue +48 -0
  521. package/src/components/Calendar/CalendarNext.vue +51 -0
  522. package/src/components/Calendar/CalendarOverlayItem.vue +30 -0
  523. package/src/components/Calendar/CalendarPrev.vue +51 -0
  524. package/src/components/Calendar/CalendarRoot.vue +394 -0
  525. package/src/components/Calendar/CalendarYearHeading.vue +63 -0
  526. package/src/components/Calendar/index.ts +63 -0
  527. package/src/components/Calendar/useCalendar.ts +453 -0
  528. package/src/components/ConfigProvider/ConfigProvider.vue +73 -0
  529. package/src/components/ConfigProvider/index.ts +5 -0
  530. package/src/components/DateField/DateFieldInput.vue +72 -0
  531. package/src/components/DateField/DateFieldRoot.vue +359 -0
  532. package/src/components/DateField/index.ts +10 -0
  533. package/src/components/DatePicker/DatePickerAnchor.vue +16 -0
  534. package/src/components/DatePicker/DatePickerArrow.vue +16 -0
  535. package/src/components/DatePicker/DatePickerCalendar.vue +62 -0
  536. package/src/components/DatePicker/DatePickerCell.vue +16 -0
  537. package/src/components/DatePicker/DatePickerCellTrigger.vue +18 -0
  538. package/src/components/DatePicker/DatePickerClose.vue +16 -0
  539. package/src/components/DatePicker/DatePickerContent.vue +50 -0
  540. package/src/components/DatePicker/DatePickerField.vue +53 -0
  541. package/src/components/DatePicker/DatePickerGrid.vue +16 -0
  542. package/src/components/DatePicker/DatePickerGridBody.vue +16 -0
  543. package/src/components/DatePicker/DatePickerGridHead.vue +16 -0
  544. package/src/components/DatePicker/DatePickerGridRow.vue +16 -0
  545. package/src/components/DatePicker/DatePickerHeadCell.vue +16 -0
  546. package/src/components/DatePicker/DatePickerHeader.vue +16 -0
  547. package/src/components/DatePicker/DatePickerHeading.vue +24 -0
  548. package/src/components/DatePicker/DatePickerInput.vue +16 -0
  549. package/src/components/DatePicker/DatePickerMonthHeading.vue +19 -0
  550. package/src/components/DatePicker/DatePickerMonthYearOverlay.vue +13 -0
  551. package/src/components/DatePicker/DatePickerNext.vue +19 -0
  552. package/src/components/DatePicker/DatePickerOverlayItem.vue +16 -0
  553. package/src/components/DatePicker/DatePickerPrev.vue +18 -0
  554. package/src/components/DatePicker/DatePickerRoot.vue +216 -0
  555. package/src/components/DatePicker/DatePickerTrigger.vue +29 -0
  556. package/src/components/DatePicker/DatePickerYearHeading.vue +19 -0
  557. package/src/components/DatePicker/index.ts +92 -0
  558. package/src/components/DismissableLayer/DismissableLayer.vue +175 -0
  559. package/src/components/DismissableLayer/DismissableLayerBranch.vue +28 -0
  560. package/src/components/DismissableLayer/index.ts +7 -0
  561. package/src/components/DismissableLayer/utils.ts +194 -0
  562. package/src/components/FocusScope/FocusScope.vue +220 -0
  563. package/src/components/FocusScope/index.ts +5 -0
  564. package/src/components/FocusScope/stack.ts +49 -0
  565. package/src/components/FocusScope/utils.ts +108 -0
  566. package/src/components/Popover/PopoverAnchor.vue +30 -0
  567. package/src/components/Popover/PopoverArrow.vue +23 -0
  568. package/src/components/Popover/PopoverClose.vue +29 -0
  569. package/src/components/Popover/PopoverContent.vue +41 -0
  570. package/src/components/Popover/PopoverContentImpl.vue +97 -0
  571. package/src/components/Popover/PopoverContentNonModal.vue +74 -0
  572. package/src/components/Popover/PopoverPortal.vue +17 -0
  573. package/src/components/Popover/PopoverRoot.vue +83 -0
  574. package/src/components/Popover/PopoverTrigger.vue +48 -0
  575. package/src/components/Popover/index.ts +31 -0
  576. package/src/components/Popper/PopperAnchor.vue +36 -0
  577. package/src/components/Popper/PopperArrow.vue +81 -0
  578. package/src/components/Popper/PopperContent.vue +399 -0
  579. package/src/components/Popper/PopperRoot.vue +36 -0
  580. package/src/components/Popper/index.ts +15 -0
  581. package/src/components/Popper/utils.ts +63 -0
  582. package/src/components/Presence/Presence.ts +91 -0
  583. package/src/components/Presence/index.ts +1 -0
  584. package/src/components/Presence/usePresence.ts +175 -0
  585. package/src/components/Primitive/Primitive.ts +66 -0
  586. package/src/components/Primitive/Slot.ts +40 -0
  587. package/src/components/Primitive/index.ts +3 -0
  588. package/src/components/Primitive/usePrimitiveElement.ts +13 -0
  589. package/src/components/Teleport/Teleport.vue +49 -0
  590. package/src/components/Teleport/index.ts +1 -0
  591. package/src/components/VisuallyHidden/VisuallyHidden.vue +47 -0
  592. package/src/components/VisuallyHidden/VisuallyHiddenInput.vue +67 -0
  593. package/src/components/VisuallyHidden/VisuallyHiddenInputBubble.vue +56 -0
  594. package/src/components/VisuallyHidden/index.ts +2 -0
  595. package/src/date/calendar.ts +242 -0
  596. package/src/date/comparators.ts +199 -0
  597. package/src/date/index.ts +3 -0
  598. package/src/date/types.ts +37 -0
  599. package/src/date/utils.ts +18 -0
  600. package/src/index.ts +78 -0
  601. package/src/shared/arrays.ts +66 -0
  602. package/src/shared/component/Arrow.vue +55 -0
  603. package/src/shared/component/BaseSeparator.vue +57 -0
  604. package/src/shared/component/index.ts +2 -0
  605. package/src/shared/constant/countryList.ts +251 -0
  606. package/src/shared/constant/index.ts +1 -0
  607. package/src/shared/createContext.ts +57 -0
  608. package/src/shared/date/comparators.ts +74 -0
  609. package/src/shared/date/index.ts +42 -0
  610. package/src/shared/date/parser.ts +252 -0
  611. package/src/shared/date/parts.ts +32 -0
  612. package/src/shared/date/placeholders.ts +221 -0
  613. package/src/shared/date/segment.ts +50 -0
  614. package/src/shared/date/types.ts +50 -0
  615. package/src/shared/date/useDateField.ts +998 -0
  616. package/src/shared/date/utils.ts +84 -0
  617. package/src/shared/getActiveElement.ts +12 -0
  618. package/src/shared/handleAndDispatchCustomEvent.ts +21 -0
  619. package/src/shared/index.ts +27 -0
  620. package/src/shared/nullish.ts +3 -0
  621. package/src/shared/onFocusOutside.ts +29 -0
  622. package/src/shared/renderSlotFragments.ts +13 -0
  623. package/src/shared/trap-focus.ts +45 -0
  624. package/src/shared/types.ts +64 -0
  625. package/src/shared/useDateFormatter.ts +186 -0
  626. package/src/shared/useDirection.ts +16 -0
  627. package/src/shared/useEmitAsProps.ts +32 -0
  628. package/src/shared/useFocusGuards.ts +46 -0
  629. package/src/shared/useForwardExpose.ts +66 -0
  630. package/src/shared/useForwardProps.ts +43 -0
  631. package/src/shared/useForwardPropsEmits.ts +26 -0
  632. package/src/shared/useId.ts +34 -0
  633. package/src/shared/useIsUsingKeyboard.ts +22 -0
  634. package/src/shared/useKbd.ts +58 -0
  635. package/src/shared/useLocale.ts +15 -0
  636. package/src/shared/useNonce.ts +10 -0
  637. package/src/shared/useSize.ts +64 -0
  638. package/src/shared/useStateMachine.ts +48 -0
  639. package/src/shared/withDefault.ts +61 -0
@@ -0,0 +1,230 @@
1
+ import { defineComponent, mergeDefaults, ref, computed, watchPostEffect, watchEffect, createElementBlock, openBlock, normalizeStyle, unref, createVNode, mergeProps, withCtx, renderSlot } from "vue";
2
+ import { useFloating, arrow } from "../../node_modules/.pnpm/@floating-ui_vue@1.1.9_vue@3.5.26_typescript@5.9.3_/node_modules/@floating-ui/vue/dist/floating-ui.vue.js";
3
+ import { Primitive } from "../Primitive/Primitive.js";
4
+ import "../Primitive/Slot.js";
5
+ import { injectPopperRootContext } from "./PopperRoot.vue.js";
6
+ import { isNotNull, getSideAndAlignFromPlacement, transformOrigin } from "./utils.js";
7
+ import { createContext } from "../../shared/createContext.js";
8
+ import { computedEager } from "../../node_modules/.pnpm/@vueuse_shared@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/shared/dist/index.js";
9
+ import { useForwardExpose } from "../../shared/useForwardExpose.js";
10
+ import { useSize } from "../../shared/useSize.js";
11
+ import { autoUpdate, offset, flip, shift, size, hide, limitShift } from "../../node_modules/.pnpm/@floating-ui_dom@1.7.4/node_modules/@floating-ui/dom/dist/floating-ui.dom.js";
12
+ const PopperContentPropsDefaultValue = {
13
+ side: "bottom",
14
+ sideOffset: 0,
15
+ sideFlip: true,
16
+ align: "center",
17
+ alignOffset: 0,
18
+ alignFlip: true,
19
+ arrowPadding: 0,
20
+ avoidCollisions: true,
21
+ collisionBoundary: () => [],
22
+ collisionPadding: 0,
23
+ sticky: "partial",
24
+ hideWhenDetached: false,
25
+ positionStrategy: "fixed",
26
+ updatePositionStrategy: "optimized",
27
+ prioritizePosition: false
28
+ };
29
+ const [injectPopperContentContext, providePopperContentContext] = createContext("PopperContent");
30
+ const _sfc_main = /* @__PURE__ */ defineComponent({
31
+ ...{
32
+ inheritAttrs: false
33
+ },
34
+ __name: "PopperContent",
35
+ props: /* @__PURE__ */ mergeDefaults({
36
+ side: {},
37
+ sideOffset: {},
38
+ sideFlip: { type: Boolean },
39
+ align: {},
40
+ alignOffset: {},
41
+ alignFlip: { type: Boolean },
42
+ avoidCollisions: { type: Boolean },
43
+ collisionBoundary: {},
44
+ collisionPadding: {},
45
+ arrowPadding: {},
46
+ sticky: {},
47
+ hideWhenDetached: { type: Boolean },
48
+ positionStrategy: {},
49
+ updatePositionStrategy: {},
50
+ disableUpdateOnLayoutShift: { type: Boolean },
51
+ prioritizePosition: { type: Boolean },
52
+ reference: {},
53
+ asChild: { type: Boolean },
54
+ as: {}
55
+ }, {
56
+ ...PopperContentPropsDefaultValue
57
+ }),
58
+ emits: ["placed"],
59
+ setup(__props, { emit: __emit }) {
60
+ const props = __props;
61
+ const emits = __emit;
62
+ const rootContext = injectPopperRootContext();
63
+ const { forwardRef, currentElement: contentElement } = useForwardExpose();
64
+ const floatingRef = ref();
65
+ const arrow$1 = ref();
66
+ const { width: arrowWidth, height: arrowHeight } = useSize(arrow$1);
67
+ const desiredPlacement = computed(
68
+ () => props.side + (props.align !== "center" ? `-${props.align}` : "")
69
+ );
70
+ const collisionPadding = computed(() => {
71
+ return typeof props.collisionPadding === "number" ? props.collisionPadding : { top: 0, right: 0, bottom: 0, left: 0, ...props.collisionPadding };
72
+ });
73
+ const boundary = computed(() => {
74
+ return Array.isArray(props.collisionBoundary) ? props.collisionBoundary : [props.collisionBoundary];
75
+ });
76
+ const detectOverflowOptions = computed(() => {
77
+ return {
78
+ padding: collisionPadding.value,
79
+ boundary: boundary.value.filter(isNotNull),
80
+ // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries
81
+ altBoundary: boundary.value.length > 0
82
+ };
83
+ });
84
+ const flipOptions = computed(() => {
85
+ return {
86
+ mainAxis: props.sideFlip,
87
+ crossAxis: props.alignFlip
88
+ };
89
+ });
90
+ const computedMiddleware = computedEager(() => {
91
+ return [
92
+ offset({
93
+ mainAxis: props.sideOffset + arrowHeight.value,
94
+ alignmentAxis: props.alignOffset
95
+ }),
96
+ props.prioritizePosition && props.avoidCollisions && flip({
97
+ ...detectOverflowOptions.value,
98
+ ...flipOptions.value
99
+ }),
100
+ props.avoidCollisions && shift({
101
+ mainAxis: true,
102
+ crossAxis: !!props.prioritizePosition,
103
+ limiter: props.sticky === "partial" ? limitShift() : void 0,
104
+ ...detectOverflowOptions.value
105
+ }),
106
+ !props.prioritizePosition && props.avoidCollisions && flip({
107
+ ...detectOverflowOptions.value,
108
+ ...flipOptions.value
109
+ }),
110
+ size({
111
+ ...detectOverflowOptions.value,
112
+ apply: ({ elements, rects, availableWidth, availableHeight }) => {
113
+ const { width: anchorWidth, height: anchorHeight } = rects.reference;
114
+ const contentStyle = elements.floating.style;
115
+ contentStyle.setProperty(
116
+ "--reka-popper-available-width",
117
+ `${availableWidth}px`
118
+ );
119
+ contentStyle.setProperty(
120
+ "--reka-popper-available-height",
121
+ `${availableHeight}px`
122
+ );
123
+ contentStyle.setProperty(
124
+ "--reka-popper-anchor-width",
125
+ `${anchorWidth}px`
126
+ );
127
+ contentStyle.setProperty(
128
+ "--reka-popper-anchor-height",
129
+ `${anchorHeight}px`
130
+ );
131
+ }
132
+ }),
133
+ arrow$1.value && arrow({ element: arrow$1.value, padding: props.arrowPadding }),
134
+ transformOrigin({
135
+ arrowWidth: arrowWidth.value,
136
+ arrowHeight: arrowHeight.value
137
+ }),
138
+ props.hideWhenDetached && hide({ strategy: "referenceHidden", ...detectOverflowOptions.value })
139
+ ];
140
+ });
141
+ const reference = computed(() => props.reference ?? rootContext.anchor.value);
142
+ const { floatingStyles, placement, isPositioned, middlewareData } = useFloating(reference, floatingRef, {
143
+ strategy: props.positionStrategy,
144
+ placement: desiredPlacement,
145
+ whileElementsMounted: (...args) => {
146
+ const cleanup = autoUpdate(...args, {
147
+ layoutShift: !props.disableUpdateOnLayoutShift,
148
+ animationFrame: props.updatePositionStrategy === "always"
149
+ });
150
+ return cleanup;
151
+ },
152
+ middleware: computedMiddleware
153
+ });
154
+ const placedSide = computed(
155
+ () => getSideAndAlignFromPlacement(placement.value)[0]
156
+ );
157
+ const placedAlign = computed(
158
+ () => getSideAndAlignFromPlacement(placement.value)[1]
159
+ );
160
+ watchPostEffect(() => {
161
+ if (isPositioned.value) emits("placed");
162
+ });
163
+ const cannotCenterArrow = computed(
164
+ () => middlewareData.value.arrow?.centerOffset !== 0
165
+ );
166
+ const contentZIndex = ref("");
167
+ watchEffect(() => {
168
+ if (contentElement.value)
169
+ contentZIndex.value = window.getComputedStyle(contentElement.value).zIndex;
170
+ });
171
+ const arrowX = computed(() => middlewareData.value.arrow?.x ?? 0);
172
+ const arrowY = computed(() => middlewareData.value.arrow?.y ?? 0);
173
+ providePopperContentContext({
174
+ placedSide,
175
+ onArrowChange: (element) => arrow$1.value = element,
176
+ arrowX,
177
+ arrowY,
178
+ shouldHideArrow: cannotCenterArrow
179
+ });
180
+ return (_ctx, _cache) => {
181
+ return openBlock(), createElementBlock("div", {
182
+ ref_key: "floatingRef",
183
+ ref: floatingRef,
184
+ "data-reka-popper-content-wrapper": "",
185
+ style: normalizeStyle({
186
+ ...unref(floatingStyles),
187
+ transform: unref(isPositioned) ? unref(floatingStyles).transform : "translate(0, -200%)",
188
+ // keep off the page when measuring
189
+ minWidth: "max-content",
190
+ zIndex: contentZIndex.value,
191
+ ["--reka-popper-transform-origin"]: [
192
+ unref(middlewareData).transformOrigin?.x,
193
+ unref(middlewareData).transformOrigin?.y
194
+ ].join(" "),
195
+ // hide the content if using the hide middleware and should be hidden
196
+ // set visibility to hidden and disable pointer events so the UI behaves
197
+ // as if the PopperContent isn't there at all
198
+ ...unref(middlewareData).hide?.referenceHidden && {
199
+ visibility: "hidden",
200
+ pointerEvents: "none"
201
+ }
202
+ })
203
+ }, [
204
+ createVNode(unref(Primitive), mergeProps({ ref: unref(forwardRef) }, _ctx.$attrs, {
205
+ "as-child": props.asChild,
206
+ as: __props.as,
207
+ "data-side": placedSide.value,
208
+ "data-align": placedAlign.value,
209
+ style: {
210
+ // if the PopperContent hasn't been placed yet (not all measurements done)
211
+ // we prevent animations so that users's animation don't kick in too early referring wrong sides
212
+ animation: !unref(isPositioned) ? "none" : void 0
213
+ }
214
+ }), {
215
+ default: withCtx(() => [
216
+ renderSlot(_ctx.$slots, "default")
217
+ ]),
218
+ _: 3
219
+ }, 16, ["as-child", "as", "data-side", "data-align", "style"])
220
+ ], 4);
221
+ };
222
+ }
223
+ });
224
+ export {
225
+ PopperContentPropsDefaultValue,
226
+ _sfc_main as default,
227
+ injectPopperContentContext,
228
+ providePopperContentContext
229
+ };
230
+ //# sourceMappingURL=PopperContent.vue2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PopperContent.vue2.js","sources":["../../../src/components/Popper/PopperContent.vue"],"sourcesContent":["<script lang=\"ts\">\nimport type { Middleware, Placement, ReferenceElement } from \"@floating-ui/vue\";\nimport type { Ref } from \"vue\";\nimport type { Align, Side } from \"./utils\";\nimport type { PrimitiveProps } from \"../Primitive\";\nimport { createContext, useForwardExpose, useSize } from \"../../shared\";\n\nexport const PopperContentPropsDefaultValue = {\n side: \"bottom\" as Side,\n sideOffset: 0,\n sideFlip: true,\n align: \"center\" as Align,\n alignOffset: 0,\n alignFlip: true,\n arrowPadding: 0,\n avoidCollisions: true,\n collisionBoundary: () => [],\n collisionPadding: 0,\n sticky: \"partial\" as \"partial\" | \"always\",\n hideWhenDetached: false,\n positionStrategy: \"fixed\" as \"absolute\" | \"fixed\",\n updatePositionStrategy: \"optimized\" as \"optimized\" | \"always\",\n prioritizePosition: false,\n};\n\nexport interface PopperContentProps extends PrimitiveProps {\n /**\n * The preferred side of the trigger to render against when open.\n * Will be reversed when collisions occur and avoidCollisions\n * is enabled.\n *\n * @defaultValue \"top\"\n */\n side?: Side;\n\n /**\n * The distance in pixels from the trigger.\n *\n * @defaultValue 0\n */\n sideOffset?: number;\n\n /**\n * Flip to the opposite side when colliding with boundary.\n *\n * @defaultValue true\n */\n sideFlip?: boolean;\n\n /**\n * The preferred alignment against the trigger.\n * May change when collisions occur.\n *\n * @defaultValue \"center\"\n */\n align?: Align;\n\n /**\n * An offset in pixels from the `start` or `end` alignment options.\n *\n * @defaultValue 0\n */\n alignOffset?: number;\n\n /**\n * Flip alignment when colliding with boundary.\n * May only occur when `prioritizePosition` is true.\n *\n * @defaultValue true\n */\n alignFlip?: boolean;\n\n /**\n * When `true`, overrides the side and align preferences\n * to prevent collisions with boundary edges.\n *\n * @defaultValue true\n */\n avoidCollisions?: boolean;\n\n /**\n * The element used as the collision boundary. By default\n * this is the viewport, though you can provide additional\n * element(s) to be included in this check.\n *\n * @defaultValue []\n */\n collisionBoundary?: Element | null | Array<Element | null>;\n\n /**\n * The distance in pixels from the boundary edges where collision\n * detection should occur. Accepts a number (same for all sides),\n * or a partial padding object, for example: { top: 20, left: 20 }.\n *\n * @defaultValue 0\n */\n collisionPadding?: number | Partial<Record<Side, number>>;\n\n /**\n * The padding between the arrow and the edges of the content.\n * If your content has border-radius, this will prevent it from\n * overflowing the corners.\n *\n * @defaultValue 0\n */\n arrowPadding?: number;\n\n /**\n * The sticky behavior on the align axis. `partial` will keep the\n * content in the boundary as long as the trigger is at least partially\n * in the boundary whilst \"always\" will keep the content in the boundary\n * regardless.\n *\n * @defaultValue \"partial\"\n */\n sticky?: \"partial\" | \"always\";\n\n /**\n * Whether to hide the content when the trigger becomes fully occluded.\n *\n * @defaultValue false\n */\n hideWhenDetached?: boolean;\n\n /**\n * The type of CSS position property to use.\n */\n positionStrategy?: \"absolute\" | \"fixed\";\n\n /**\n * Strategy to update the position of the floating element on every animation frame.\n *\n * @defaultValue 'optimized'\n */\n updatePositionStrategy?: \"optimized\" | \"always\";\n\n /**\n * Whether to disable the update position for the content when the layout shifted.\n *\n * @defaultValue false\n */\n disableUpdateOnLayoutShift?: boolean;\n\n /**\n * Force content to be position within the viewport.\n *\n * Might overlap the reference element, which may not be desired.\n *\n * @defaultValue false\n */\n prioritizePosition?: boolean;\n\n /**\n * The custom element or virtual element that will be set as the reference\n * to position the floating element.\n *\n * If provided, it will replace the default anchor element.\n */\n reference?: ReferenceElement;\n}\n\nexport interface PopperContentContext {\n placedSide: Ref<Side>;\n onArrowChange: (arrow: HTMLElement | undefined) => void;\n arrowX?: Ref<number>;\n arrowY?: Ref<number>;\n shouldHideArrow: Ref<boolean>;\n}\n\nexport const [injectPopperContentContext, providePopperContentContext] =\n createContext<PopperContentContext>(\"PopperContent\");\n</script>\n\n<script setup lang=\"ts\">\nimport {\n autoUpdate,\n flip,\n arrow as floatingUIarrow,\n hide,\n limitShift,\n offset,\n shift,\n size,\n useFloating,\n} from \"@floating-ui/vue\";\nimport { computedEager } from \"@vueuse/core\";\nimport { computed, ref, watchEffect, watchPostEffect } from \"vue\";\nimport { Primitive } from \"../Primitive\";\nimport { injectPopperRootContext } from \"./PopperRoot.vue\";\nimport {\n getSideAndAlignFromPlacement,\n isNotNull,\n transformOrigin,\n} from \"./utils\";\n\ndefineOptions({\n inheritAttrs: false,\n});\n\nconst props = withDefaults(defineProps<PopperContentProps>(), {\n ...PopperContentPropsDefaultValue,\n});\nconst emits = defineEmits<{\n placed: [void];\n}>();\n\nconst rootContext = injectPopperRootContext();\nconst { forwardRef, currentElement: contentElement } = useForwardExpose();\n\nconst floatingRef = ref<HTMLElement>();\n\nconst arrow = ref<HTMLElement>();\nconst { width: arrowWidth, height: arrowHeight } = useSize(arrow);\n\nconst desiredPlacement = computed(\n () =>\n (props.side +\n (props.align !== \"center\" ? `-${props.align}` : \"\")) as Placement,\n);\n\nconst collisionPadding = computed(() => {\n return typeof props.collisionPadding === \"number\"\n ? props.collisionPadding\n : { top: 0, right: 0, bottom: 0, left: 0, ...props.collisionPadding };\n});\n\nconst boundary = computed(() => {\n return Array.isArray(props.collisionBoundary)\n ? props.collisionBoundary\n : [props.collisionBoundary];\n});\n\nconst detectOverflowOptions = computed(() => {\n return {\n padding: collisionPadding.value,\n boundary: boundary.value.filter(isNotNull),\n // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries\n altBoundary: boundary.value.length > 0,\n };\n});\n\nconst flipOptions = computed(() => {\n return {\n mainAxis: props.sideFlip,\n crossAxis: props.alignFlip,\n };\n});\n\nconst computedMiddleware = computedEager(() => {\n return [\n offset({\n mainAxis: props.sideOffset + arrowHeight.value,\n alignmentAxis: props.alignOffset,\n }),\n props.prioritizePosition &&\n props.avoidCollisions &&\n flip({\n ...detectOverflowOptions.value,\n ...flipOptions.value,\n }),\n props.avoidCollisions &&\n shift({\n mainAxis: true,\n crossAxis: !!props.prioritizePosition,\n limiter: props.sticky === \"partial\" ? limitShift() : undefined,\n ...detectOverflowOptions.value,\n }),\n !props.prioritizePosition &&\n props.avoidCollisions &&\n flip({\n ...detectOverflowOptions.value,\n ...flipOptions.value,\n }),\n size({\n ...detectOverflowOptions.value,\n apply: ({ elements, rects, availableWidth, availableHeight }) => {\n const { width: anchorWidth, height: anchorHeight } = rects.reference;\n const contentStyle = elements.floating.style;\n contentStyle.setProperty(\n \"--reka-popper-available-width\",\n `${availableWidth}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-available-height\",\n `${availableHeight}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-anchor-width\",\n `${anchorWidth}px`,\n );\n contentStyle.setProperty(\n \"--reka-popper-anchor-height\",\n `${anchorHeight}px`,\n );\n },\n }),\n arrow.value &&\n floatingUIarrow({ element: arrow.value, padding: props.arrowPadding }),\n transformOrigin({\n arrowWidth: arrowWidth.value,\n arrowHeight: arrowHeight.value,\n }),\n props.hideWhenDetached &&\n hide({ strategy: \"referenceHidden\", ...detectOverflowOptions.value }),\n ] as Middleware[];\n});\n\n// If provided custom reference, it will overwrite the default anchor element\nconst reference = computed(() => props.reference ?? rootContext.anchor.value);\n\nconst { floatingStyles, placement, isPositioned, middlewareData, update } =\n useFloating(reference, floatingRef, {\n strategy: props.positionStrategy,\n placement: desiredPlacement,\n whileElementsMounted: (...args) => {\n const cleanup = autoUpdate(...args, {\n layoutShift: !props.disableUpdateOnLayoutShift,\n animationFrame: props.updatePositionStrategy === \"always\",\n });\n return cleanup;\n },\n middleware: computedMiddleware,\n });\n\nconst placedSide = computed(\n () => getSideAndAlignFromPlacement(placement.value)[0],\n);\nconst placedAlign = computed(\n () => getSideAndAlignFromPlacement(placement.value)[1],\n);\n\nwatchPostEffect(() => {\n if (isPositioned.value) emits(\"placed\");\n});\n\nconst cannotCenterArrow = computed(\n () => middlewareData.value.arrow?.centerOffset !== 0,\n);\n\nconst contentZIndex = ref(\"\");\nwatchEffect(() => {\n if (contentElement.value)\n contentZIndex.value = window.getComputedStyle(contentElement.value).zIndex;\n});\n\nconst arrowX = computed(() => middlewareData.value.arrow?.x ?? 0);\nconst arrowY = computed(() => middlewareData.value.arrow?.y ?? 0);\n\nprovidePopperContentContext({\n placedSide,\n onArrowChange: (element) => (arrow.value = element),\n arrowX,\n arrowY,\n shouldHideArrow: cannotCenterArrow,\n});\n</script>\n\n<template>\n <div\n ref=\"floatingRef\"\n data-reka-popper-content-wrapper=\"\"\n :style=\"{\n ...floatingStyles,\n transform: isPositioned\n ? floatingStyles.transform\n : 'translate(0, -200%)', // keep off the page when measuring\n minWidth: 'max-content',\n zIndex: contentZIndex,\n ['--reka-popper-transform-origin' as any]: [\n middlewareData.transformOrigin?.x,\n middlewareData.transformOrigin?.y,\n ].join(' '),\n\n // hide the content if using the hide middleware and should be hidden\n // set visibility to hidden and disable pointer events so the UI behaves\n // as if the PopperContent isn't there at all\n ...(middlewareData.hide?.referenceHidden && {\n visibility: 'hidden',\n pointerEvents: 'none',\n }),\n }\"\n >\n <Primitive\n :ref=\"forwardRef\"\n v-bind=\"$attrs\"\n :as-child=\"props.asChild\"\n :as=\"as\"\n :data-side=\"placedSide\"\n :data-align=\"placedAlign\"\n :style=\"{\n // if the PopperContent hasn't been placed yet (not all measurements done)\n // we prevent animations so that users's animation don't kick in too early referring wrong sides\n animation: !isPositioned ? 'none' : undefined,\n }\"\n >\n <slot />\n </Primitive>\n </div>\n</template>\n"],"names":["arrow","floatingUIarrow","_createElementBlock","_normalizeStyle","_unref","_createVNode","_mergeProps","$attrs","_renderSlot"],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { ReferenceElement } from '@floating-ui/vue';
2
+ import { Ref } from 'vue';
3
+ export interface Measurable {
4
+ getBoundingClientRect: () => DOMRect;
5
+ }
6
+ interface PopperRootContext {
7
+ anchor: Ref<ReferenceElement | undefined>;
8
+ onAnchorChange: (element: ReferenceElement | undefined) => void;
9
+ }
10
+ export declare const injectPopperRootContext: <T extends PopperRootContext | null | undefined = PopperRootContext>(fallback?: T | undefined) => T extends null ? PopperRootContext | null : PopperRootContext, providePopperRootContext: (contextValue: PopperRootContext) => PopperRootContext;
11
+ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>, {
12
+ default?(_: {}): any;
13
+ }>;
14
+ export default _default;
15
+ type __VLS_WithTemplateSlots<T, S> = T & {
16
+ new (): {
17
+ $slots: S;
18
+ };
19
+ };
@@ -0,0 +1,25 @@
1
+ import { defineComponent, ref, renderSlot } from "vue";
2
+ import { createContext } from "../../shared/createContext.js";
3
+ const [injectPopperRootContext, providePopperRootContext] = createContext("PopperRoot");
4
+ const _sfc_main = /* @__PURE__ */ defineComponent({
5
+ ...{
6
+ inheritAttrs: false
7
+ },
8
+ __name: "PopperRoot",
9
+ setup(__props) {
10
+ const anchor = ref();
11
+ providePopperRootContext({
12
+ anchor,
13
+ onAnchorChange: (element) => anchor.value = element
14
+ });
15
+ return (_ctx, _cache) => {
16
+ return renderSlot(_ctx.$slots, "default");
17
+ };
18
+ }
19
+ });
20
+ export {
21
+ _sfc_main as default,
22
+ injectPopperRootContext,
23
+ providePopperRootContext
24
+ };
25
+ //# sourceMappingURL=PopperRoot.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PopperRoot.vue.js","sources":["../../../src/components/Popper/PopperRoot.vue"],"sourcesContent":["<script lang=\"ts\">\nimport type { ReferenceElement } from \"@floating-ui/vue\";\nimport type { Ref } from \"vue\";\nimport { createContext } from \"../../shared\";\n\nexport interface Measurable {\n getBoundingClientRect: () => DOMRect;\n}\n\ninterface PopperRootContext {\n anchor: Ref<ReferenceElement | undefined>;\n onAnchorChange: (element: ReferenceElement | undefined) => void;\n}\n\nexport const [injectPopperRootContext, providePopperRootContext] =\n createContext<PopperRootContext>(\"PopperRoot\");\n</script>\n\n<script setup lang=\"ts\">\nimport { ref } from \"vue\";\n\ndefineOptions({\n inheritAttrs: false,\n});\n\nconst anchor = ref<ReferenceElement>();\n\nprovidePopperRootContext({\n anchor,\n onAnchorChange: (element) => (anchor.value = element),\n});\n</script>\n\n<template>\n <slot />\n</template>\n"],"names":["_renderSlot"],"mappings":";;AAcO,MAAM,CAAC,yBAAyB,wBAAwB,IAC7D,cAAiC,YAAY;;;;;;;AAU/C,UAAM,SAAS,IAAA;AAEf,6BAAyB;AAAA,MACvB;AAAA,MACA,gBAAgB,CAAC,YAAa,OAAO,QAAQ;AAAA,IAAA,CAC9C;;aAICA,WAAQ,KAAA,QAAA,SAAA;AAAA;;;"}
@@ -0,0 +1,8 @@
1
+ import _sfc_main from "./PopperRoot.vue.js";
2
+ import { injectPopperRootContext, providePopperRootContext } from "./PopperRoot.vue.js";
3
+ export {
4
+ _sfc_main as default,
5
+ injectPopperRootContext,
6
+ providePopperRootContext
7
+ };
8
+ //# sourceMappingURL=PopperRoot.vue2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PopperRoot.vue2.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
@@ -0,0 +1,5 @@
1
+ export { default as PopperAnchor, type PopperAnchorProps, } from './PopperAnchor';
2
+ export { default as PopperArrow, type PopperArrowProps, } from './PopperArrow';
3
+ export { default as PopperContent, type PopperContentProps, PopperContentPropsDefaultValue, } from './PopperContent';
4
+ export { injectPopperRootContext, default as PopperRoot } from './PopperRoot';
5
+ export * from './utils';
@@ -0,0 +1,12 @@
1
+ import { Middleware, Placement } from '@floating-ui/vue';
2
+ declare const SIDE_OPTIONS: readonly ["top", "right", "bottom", "left"];
3
+ declare const ALIGN_OPTIONS: readonly ["start", "center", "end"];
4
+ export type Side = (typeof SIDE_OPTIONS)[number];
5
+ export type Align = (typeof ALIGN_OPTIONS)[number];
6
+ export declare function isNotNull<T>(value: T | null): value is T;
7
+ export declare function transformOrigin(options: {
8
+ arrowWidth: number;
9
+ arrowHeight: number;
10
+ }): Middleware;
11
+ export declare function getSideAndAlignFromPlacement(placement: Placement): readonly ["top" | "right" | "bottom" | "left", "start" | "end" | "center"];
12
+ export {};
@@ -0,0 +1,46 @@
1
+ function isNotNull(value) {
2
+ return value !== null;
3
+ }
4
+ function transformOrigin(options) {
5
+ return {
6
+ name: "transformOrigin",
7
+ options,
8
+ fn(data) {
9
+ const { placement, rects, middlewareData } = data;
10
+ const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;
11
+ const isArrowHidden = cannotCenterArrow;
12
+ const arrowWidth = isArrowHidden ? 0 : options.arrowWidth;
13
+ const arrowHeight = isArrowHidden ? 0 : options.arrowHeight;
14
+ const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);
15
+ const noArrowAlign = { start: "0%", center: "50%", end: "100%" }[placedAlign];
16
+ const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2;
17
+ const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2;
18
+ let x = "";
19
+ let y = "";
20
+ if (placedSide === "bottom") {
21
+ x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
22
+ y = `${-arrowHeight}px`;
23
+ } else if (placedSide === "top") {
24
+ x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
25
+ y = `${rects.floating.height + arrowHeight}px`;
26
+ } else if (placedSide === "right") {
27
+ x = `${-arrowHeight}px`;
28
+ y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
29
+ } else if (placedSide === "left") {
30
+ x = `${rects.floating.width + arrowHeight}px`;
31
+ y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
32
+ }
33
+ return { data: { x, y } };
34
+ }
35
+ };
36
+ }
37
+ function getSideAndAlignFromPlacement(placement) {
38
+ const [side, align = "center"] = placement.split("-");
39
+ return [side, align];
40
+ }
41
+ export {
42
+ getSideAndAlignFromPlacement,
43
+ isNotNull,
44
+ transformOrigin
45
+ };
46
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sources":["../../../src/components/Popper/utils.ts"],"sourcesContent":["import type { Middleware, Placement } from '@floating-ui/vue'\n\nconst SIDE_OPTIONS = ['top', 'right', 'bottom', 'left'] as const\nconst ALIGN_OPTIONS = ['start', 'center', 'end'] as const\n\nexport type Side = (typeof SIDE_OPTIONS)[number]\nexport type Align = (typeof ALIGN_OPTIONS)[number]\n\nexport function isNotNull<T>(value: T | null): value is T {\n return value !== null\n}\n\nexport function transformOrigin(options: {\n arrowWidth: number\n arrowHeight: number\n}): Middleware {\n return {\n name: 'transformOrigin',\n options,\n fn(data) {\n const { placement, rects, middlewareData } = data\n\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0\n const isArrowHidden = cannotCenterArrow\n const arrowWidth = isArrowHidden ? 0 : options.arrowWidth\n const arrowHeight = isArrowHidden ? 0 : options.arrowHeight\n\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement)\n const noArrowAlign = { start: '0%', center: '50%', end: '100%' }[\n placedAlign\n ]\n\n const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2\n const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2\n\n let x = ''\n let y = ''\n\n if (placedSide === 'bottom') {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`\n y = `${-arrowHeight}px`\n }\n else if (placedSide === 'top') {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`\n y = `${rects.floating.height + arrowHeight}px`\n }\n else if (placedSide === 'right') {\n x = `${-arrowHeight}px`\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`\n }\n else if (placedSide === 'left') {\n x = `${rects.floating.width + arrowHeight}px`\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`\n }\n return { data: { x, y } }\n },\n }\n}\n\nexport function getSideAndAlignFromPlacement(placement: Placement) {\n const [side, align = 'center'] = placement.split('-')\n return [side as Side, align as Align] as const\n}\n"],"names":[],"mappings":"AAQO,SAAS,UAAa,OAA6B;AACxD,SAAO,UAAU;AACnB;AAEO,SAAS,gBAAgB,SAGjB;AACb,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA,GAAG,MAAM;AACP,YAAM,EAAE,WAAW,OAAO,eAAA,IAAmB;AAE7C,YAAM,oBAAoB,eAAe,OAAO,iBAAiB;AACjE,YAAM,gBAAgB;AACtB,YAAM,aAAa,gBAAgB,IAAI,QAAQ;AAC/C,YAAM,cAAc,gBAAgB,IAAI,QAAQ;AAEhD,YAAM,CAAC,YAAY,WAAW,IAAI,6BAA6B,SAAS;AACxE,YAAM,eAAe,EAAE,OAAO,MAAM,QAAQ,OAAO,KAAK,OAAA,EACtD,WACF;AAEA,YAAM,gBAAgB,eAAe,OAAO,KAAK,KAAK,aAAa;AACnE,YAAM,gBAAgB,eAAe,OAAO,KAAK,KAAK,cAAc;AAEpE,UAAI,IAAI;AACR,UAAI,IAAI;AAER,UAAI,eAAe,UAAU;AAC3B,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAClD,YAAI,GAAG,CAAC,WAAW;AAAA,MACrB,WACS,eAAe,OAAO;AAC7B,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAClD,YAAI,GAAG,MAAM,SAAS,SAAS,WAAW;AAAA,MAC5C,WACS,eAAe,SAAS;AAC/B,YAAI,GAAG,CAAC,WAAW;AACnB,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAAA,MACpD,WACS,eAAe,QAAQ;AAC9B,YAAI,GAAG,MAAM,SAAS,QAAQ,WAAW;AACzC,YAAI,gBAAgB,eAAe,GAAG,YAAY;AAAA,MACpD;AACA,aAAO,EAAE,MAAM,EAAE,GAAG,IAAE;AAAA,IACxB;AAAA,EAAA;AAEJ;AAEO,SAAS,6BAA6B,WAAsB;AACjE,QAAM,CAAC,MAAM,QAAQ,QAAQ,IAAI,UAAU,MAAM,GAAG;AACpD,SAAO,CAAC,MAAc,KAAc;AACtC;"}
@@ -0,0 +1,43 @@
1
+ import { SlotsType, VNode } from 'vue';
2
+ export interface PresenceProps {
3
+ /**
4
+ * Conditional to mount or unmount the child element. Similar to `v-if`
5
+ *
6
+ * @required true
7
+ */
8
+ present: boolean;
9
+ /**
10
+ * Force the element to render all the time.
11
+ *
12
+ * Useful for programmatically render grandchild component with the exposed `present`
13
+ *
14
+ * @defaultValue false
15
+ */
16
+ forceMount?: boolean;
17
+ }
18
+ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
19
+ present: {
20
+ type: BooleanConstructor;
21
+ required: true;
22
+ };
23
+ forceMount: {
24
+ type: BooleanConstructor;
25
+ };
26
+ }>, () => VNode<import('vue').RendererNode, import('vue').RendererElement, {
27
+ [key: string]: any;
28
+ }> | null, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{
29
+ present: {
30
+ type: BooleanConstructor;
31
+ required: true;
32
+ };
33
+ forceMount: {
34
+ type: BooleanConstructor;
35
+ };
36
+ }>> & Readonly<{}>, {
37
+ forceMount: boolean;
38
+ }, SlotsType<{
39
+ default: (opts: {
40
+ present: boolean;
41
+ }) => any;
42
+ }>, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
43
+ export default _default;
@@ -0,0 +1,61 @@
1
+ import { unrefElement } from "../../node_modules/.pnpm/@vueuse_core@14.1.0_vue@3.5.26_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.js";
2
+ import { defineComponent, toRefs, ref, getCurrentInstance, h } from "vue";
3
+ import { renderSlotFragments } from "../../shared/renderSlotFragments.js";
4
+ import { usePresence } from "./usePresence.js";
5
+ const Presence = defineComponent({
6
+ name: "Presence",
7
+ props: {
8
+ present: {
9
+ type: Boolean,
10
+ required: true
11
+ },
12
+ forceMount: {
13
+ type: Boolean
14
+ }
15
+ },
16
+ slots: {},
17
+ setup(props, { slots, expose }) {
18
+ const { present, forceMount } = toRefs(props);
19
+ const node = ref();
20
+ const { isPresent } = usePresence(present, node);
21
+ expose({ present: isPresent });
22
+ let children = slots.default({ present: isPresent.value });
23
+ children = renderSlotFragments(children || []);
24
+ const instance = getCurrentInstance();
25
+ if (children && children?.length > 1) {
26
+ const componentName = instance?.parent?.type.name ? `<${instance.parent.type.name} />` : "component";
27
+ throw new Error(
28
+ [
29
+ `Detected an invalid children for \`${componentName}\` for \`Presence\` component.`,
30
+ "",
31
+ "Note: Presence works similarly to `v-if` directly, but it waits for animation/transition to finished before unmounting. So it expect only one direct child of valid VNode type.",
32
+ "You can apply a few solutions:",
33
+ [
34
+ "Provide a single child element so that `presence` directive attach correctly.",
35
+ "Ensure the first child is an actual element instead of a raw text node or comment node."
36
+ ].map((line) => ` - ${line}`).join("\n")
37
+ ].join("\n")
38
+ );
39
+ }
40
+ return () => {
41
+ if (forceMount.value || present.value || isPresent.value) {
42
+ return h(slots.default({ present: isPresent.value })[0], {
43
+ ref: (v) => {
44
+ const el = unrefElement(v);
45
+ if (typeof el?.hasAttribute === "undefined") return el;
46
+ if (el?.hasAttribute("data-reka-popper-content-wrapper"))
47
+ node.value = el.firstElementChild;
48
+ else node.value = el;
49
+ return el;
50
+ }
51
+ });
52
+ } else {
53
+ return null;
54
+ }
55
+ };
56
+ }
57
+ });
58
+ export {
59
+ Presence as default
60
+ };
61
+ //# sourceMappingURL=Presence.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Presence.js","sources":["../../../src/components/Presence/Presence.ts"],"sourcesContent":["import type { SlotsType, VNode } from \"vue\";\nimport { unrefElement } from \"@vueuse/core\";\nimport { defineComponent, getCurrentInstance, h, ref, toRefs } from \"vue\";\nimport { renderSlotFragments } from \"../../shared\";\nimport { usePresence } from \"./usePresence\";\n\nexport interface PresenceProps {\n /**\n * Conditional to mount or unmount the child element. Similar to `v-if`\n *\n * @required true\n */\n present: boolean;\n /**\n * Force the element to render all the time.\n *\n * Useful for programmatically render grandchild component with the exposed `present`\n *\n * @defaultValue false\n */\n forceMount?: boolean;\n}\n\nexport default defineComponent({\n name: \"Presence\",\n props: {\n present: {\n type: Boolean,\n required: true,\n },\n forceMount: {\n type: Boolean,\n },\n },\n slots: {} as SlotsType<{\n default: (opts: { present: boolean }) => any;\n }>,\n setup(props, { slots, expose }) {\n const { present, forceMount } = toRefs(props);\n\n const node = ref<HTMLElement>();\n // Mount composables once to prevent duplicated eventListener\n const { isPresent } = usePresence(present, node);\n expose({ present: isPresent });\n\n let children = slots.default({ present: isPresent.value });\n children = renderSlotFragments(children || []);\n const instance = getCurrentInstance();\n\n if (children && children?.length > 1) {\n const componentName = instance?.parent?.type.name\n ? `<${instance.parent.type.name} />`\n : \"component\";\n\n throw new Error(\n [\n `Detected an invalid children for \\`${componentName}\\` for \\`Presence\\` component.`,\n \"\",\n \"Note: Presence works similarly to `v-if` directly, but it waits for animation/transition to finished before unmounting. So it expect only one direct child of valid VNode type.\",\n \"You can apply a few solutions:\",\n [\n \"Provide a single child element so that `presence` directive attach correctly.\",\n \"Ensure the first child is an actual element instead of a raw text node or comment node.\",\n ]\n .map((line) => ` - ${line}`)\n .join(\"\\n\"),\n ].join(\"\\n\"),\n );\n }\n\n return () => {\n if (forceMount.value || present.value || isPresent.value) {\n return h(slots.default({ present: isPresent.value })[0] as VNode, {\n ref: (v) => {\n const el = unrefElement(v as HTMLElement);\n if (typeof el?.hasAttribute === \"undefined\") return el;\n\n // special case to handle animation for PopperContent\n if (el?.hasAttribute(\"data-reka-popper-content-wrapper\"))\n node.value = el.firstElementChild as HTMLElement;\n else node.value = el;\n\n return el;\n },\n });\n } else {\n return null;\n }\n };\n },\n});\n"],"names":[],"mappings":";;;;AAuBA,MAAA,WAAe,gBAAgB;AAAA,EAC7B,MAAM;AAAA,EACN,OAAO;AAAA,IACL,SAAS;AAAA,MACP,MAAM;AAAA,MACN,UAAU;AAAA,IAAA;AAAA,IAEZ,YAAY;AAAA,MACV,MAAM;AAAA,IAAA;AAAA,EACR;AAAA,EAEF,OAAO,CAAA;AAAA,EAGP,MAAM,OAAO,EAAE,OAAO,UAAU;AAC9B,UAAM,EAAE,SAAS,eAAe,OAAO,KAAK;AAE5C,UAAM,OAAO,IAAA;AAEb,UAAM,EAAE,UAAA,IAAc,YAAY,SAAS,IAAI;AAC/C,WAAO,EAAE,SAAS,WAAW;AAE7B,QAAI,WAAW,MAAM,QAAQ,EAAE,SAAS,UAAU,OAAO;AACzD,eAAW,oBAAoB,YAAY,EAAE;AAC7C,UAAM,WAAW,mBAAA;AAEjB,QAAI,YAAY,UAAU,SAAS,GAAG;AACpC,YAAM,gBAAgB,UAAU,QAAQ,KAAK,OACzC,IAAI,SAAS,OAAO,KAAK,IAAI,QAC7B;AAEJ,YAAM,IAAI;AAAA,QACR;AAAA,UACE,sCAAsC,aAAa;AAAA,UACnD;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,YACE;AAAA,YACA;AAAA,UAAA,EAEC,IAAI,CAAC,SAAS,OAAO,IAAI,EAAE,EAC3B,KAAK,IAAI;AAAA,QAAA,EACZ,KAAK,IAAI;AAAA,MAAA;AAAA,IAEf;AAEA,WAAO,MAAM;AACX,UAAI,WAAW,SAAS,QAAQ,SAAS,UAAU,OAAO;AACxD,eAAO,EAAE,MAAM,QAAQ,EAAE,SAAS,UAAU,MAAA,CAAO,EAAE,CAAC,GAAY;AAAA,UAChE,KAAK,CAAC,MAAM;AACV,kBAAM,KAAK,aAAa,CAAgB;AACxC,gBAAI,OAAO,IAAI,iBAAiB,YAAa,QAAO;AAGpD,gBAAI,IAAI,aAAa,kCAAkC;AACrD,mBAAK,QAAQ,GAAG;AAAA,sBACR,QAAQ;AAElB,mBAAO;AAAA,UACT;AAAA,QAAA,CACD;AAAA,MACH,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAAA,EACF;AACF,CAAC;"}
@@ -0,0 +1 @@
1
+ export { default as Presence, type PresenceProps } from './Presence';
@@ -0,0 +1,4 @@
1
+ import { Ref } from 'vue';
2
+ export declare function usePresence(present: Ref<boolean>, node: Ref<HTMLElement | undefined>): {
3
+ isPresent: import('vue').ComputedRef<boolean>;
4
+ };