@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,175 @@
1
+ <script lang="ts">
2
+ import type { FocusOutsideEvent, PointerDownOutsideEvent } from "./utils";
3
+
4
+ import type { PrimitiveProps } from "../Primitive";
5
+ import { computed, nextTick, reactive, watchEffect } from "vue";
6
+ import { useForwardExpose } from "../../shared";
7
+
8
+ export interface DismissableLayerProps extends PrimitiveProps {
9
+ /**
10
+ * When `true`, hover/focus/click interactions will be disabled on elements outside
11
+ * the `DismissableLayer`. Users will need to click twice on outside elements to
12
+ * interact with them: once to close the `DismissableLayer`, and again to trigger the element.
13
+ */
14
+ disableOutsidePointerEvents?: boolean;
15
+ }
16
+
17
+ export type DismissableLayerEmits = {
18
+ /**
19
+ * Event handler called when the escape key is down.
20
+ * Can be prevented.
21
+ */
22
+ escapeKeyDown: [event: KeyboardEvent];
23
+ /**
24
+ * Event handler called when a `pointerdown` event happens outside of the `DismissableLayer`.
25
+ * Can be prevented.
26
+ */
27
+ pointerDownOutside: [event: PointerDownOutsideEvent];
28
+ /**
29
+ * Event handler called when the focus moves outside of the `DismissableLayer`.
30
+ * Can be prevented.
31
+ */
32
+ focusOutside: [event: FocusOutsideEvent];
33
+ /**
34
+ * Event handler called when an interaction happens outside the `DismissableLayer`.
35
+ * Specifically, when a `pointerdown` event happens outside or focus moves outside of it.
36
+ * Can be prevented.
37
+ */
38
+ interactOutside: [event: PointerDownOutsideEvent | FocusOutsideEvent];
39
+ };
40
+
41
+ export type DismissableLayerPrivateEmits = DismissableLayerEmits & {
42
+ /**
43
+ * Handler called when the `DismissableLayer` should be dismissed
44
+ */
45
+ dismiss: [];
46
+ };
47
+
48
+ export const context = reactive({
49
+ layersRoot: new Set<HTMLElement>(),
50
+ layersWithOutsidePointerEventsDisabled: new Set<HTMLElement>(),
51
+ branches: new Set<HTMLElement>(),
52
+ });
53
+ </script>
54
+
55
+ <script setup lang="ts">
56
+ import { onKeyStroke } from "@vueuse/core";
57
+ import { Primitive } from "../Primitive";
58
+ import { useFocusOutside, usePointerDownOutside } from "./utils";
59
+
60
+ const props = withDefaults(defineProps<DismissableLayerProps>(), {
61
+ disableOutsidePointerEvents: false,
62
+ });
63
+
64
+ const emits = defineEmits<DismissableLayerPrivateEmits>();
65
+
66
+ const { forwardRef, currentElement: layerElement } = useForwardExpose();
67
+ const ownerDocument = computed(
68
+ () => layerElement.value?.ownerDocument ?? globalThis.document,
69
+ );
70
+
71
+ const layers = computed(() => context.layersRoot);
72
+
73
+ const index = computed(() => {
74
+ return layerElement.value
75
+ ? Array.from(layers.value).indexOf(layerElement.value)
76
+ : -1;
77
+ });
78
+
79
+ const isBodyPointerEventsDisabled = computed(() => {
80
+ return context.layersWithOutsidePointerEventsDisabled.size > 0;
81
+ });
82
+
83
+ const isPointerEventsEnabled = computed(() => {
84
+ const localLayers = Array.from(layers.value);
85
+ const [highestLayerWithOutsidePointerEventsDisabled] = [
86
+ ...context.layersWithOutsidePointerEventsDisabled,
87
+ ].slice(-1);
88
+ const highestLayerWithOutsidePointerEventsDisabledIndex = localLayers.indexOf(
89
+ highestLayerWithOutsidePointerEventsDisabled,
90
+ );
91
+
92
+ return index.value >= highestLayerWithOutsidePointerEventsDisabledIndex;
93
+ });
94
+
95
+ const pointerDownOutside = usePointerDownOutside(async (event) => {
96
+ const isPointerDownOnBranch = [...context.branches].some((branch) =>
97
+ branch?.contains(event.target as HTMLElement),
98
+ );
99
+
100
+ if (!isPointerEventsEnabled.value || isPointerDownOnBranch) return;
101
+ emits("pointerDownOutside", event);
102
+ emits("interactOutside", event);
103
+ await nextTick();
104
+ if (!event.defaultPrevented) emits("dismiss");
105
+ }, layerElement);
106
+
107
+ const focusOutside = useFocusOutside((event) => {
108
+ const isFocusInBranch = [...context.branches].some((branch) =>
109
+ branch?.contains(event.target as HTMLElement),
110
+ );
111
+
112
+ if (isFocusInBranch) return;
113
+ emits("focusOutside", event);
114
+ emits("interactOutside", event);
115
+ if (!event.defaultPrevented) emits("dismiss");
116
+ }, layerElement);
117
+
118
+ onKeyStroke("Escape", (event) => {
119
+ const isHighestLayer = index.value === layers.value.size - 1;
120
+ if (!isHighestLayer) return;
121
+ emits("escapeKeyDown", event);
122
+ if (!event.defaultPrevented) emits("dismiss");
123
+ });
124
+
125
+ let originalBodyPointerEvents: string;
126
+ watchEffect((cleanupFn) => {
127
+ if (!layerElement.value) return;
128
+ if (props.disableOutsidePointerEvents) {
129
+ if (context.layersWithOutsidePointerEventsDisabled.size === 0) {
130
+ originalBodyPointerEvents = ownerDocument.value.body.style.pointerEvents;
131
+ ownerDocument.value.body.style.pointerEvents = "none";
132
+ }
133
+ context.layersWithOutsidePointerEventsDisabled.add(layerElement.value);
134
+ }
135
+ layers.value.add(layerElement.value);
136
+
137
+ cleanupFn(() => {
138
+ if (
139
+ props.disableOutsidePointerEvents &&
140
+ context.layersWithOutsidePointerEventsDisabled.size === 1
141
+ ) {
142
+ ownerDocument.value.body.style.pointerEvents = originalBodyPointerEvents;
143
+ }
144
+ });
145
+ });
146
+
147
+ watchEffect((cleanupFn) => {
148
+ cleanupFn(() => {
149
+ if (!layerElement.value) return;
150
+ layers.value.delete(layerElement.value);
151
+ context.layersWithOutsidePointerEventsDisabled.delete(layerElement.value);
152
+ });
153
+ });
154
+ </script>
155
+
156
+ <template>
157
+ <Primitive
158
+ :ref="forwardRef"
159
+ :as-child="asChild"
160
+ :as="as"
161
+ data-dismissable-layer
162
+ :style="{
163
+ pointerEvents: isBodyPointerEventsDisabled
164
+ ? isPointerEventsEnabled
165
+ ? 'auto'
166
+ : 'none'
167
+ : undefined,
168
+ }"
169
+ @focus.capture="focusOutside.onFocusCapture"
170
+ @blur.capture="focusOutside.onBlurCapture"
171
+ @pointerdown.capture="pointerDownOutside.onPointerDownCapture"
172
+ >
173
+ <slot />
174
+ </Primitive>
175
+ </template>
@@ -0,0 +1,28 @@
1
+ <script lang="ts">
2
+ import type { PrimitiveProps } from "../Primitive";
3
+ import { useForwardExpose } from "../../shared";
4
+
5
+ export type DismissableLayerBranchProps = PrimitiveProps;
6
+ </script>
7
+
8
+ <script setup lang="ts">
9
+ import { onMounted, onUnmounted } from "vue";
10
+ import { Primitive } from "../Primitive";
11
+ import { context } from "./DismissableLayer.vue";
12
+
13
+ const props = defineProps<DismissableLayerBranchProps>();
14
+
15
+ const { forwardRef, currentElement } = useForwardExpose();
16
+ onMounted(() => {
17
+ context.branches.add(currentElement.value);
18
+ });
19
+ onUnmounted(() => {
20
+ context.branches.delete(currentElement.value);
21
+ });
22
+ </script>
23
+
24
+ <template>
25
+ <Primitive :ref="forwardRef" v-bind="props">
26
+ <slot />
27
+ </Primitive>
28
+ </template>
@@ -0,0 +1,7 @@
1
+ export {
2
+ default as DismissableLayer,
3
+ type DismissableLayerEmits,
4
+ type DismissableLayerProps,
5
+ } from './DismissableLayer.vue'
6
+ export { default as DismissableLayerBranch } from './DismissableLayerBranch.vue'
7
+ export { type FocusOutsideEvent, type PointerDownOutsideEvent, useFocusOutside, usePointerDownOutside } from './utils'
@@ -0,0 +1,194 @@
1
+ import type { MaybeRefOrGetter, Ref } from "vue";
2
+ import { isClient } from "@vueuse/shared";
3
+ import { nextTick, ref, toValue, watchEffect } from "vue";
4
+ import { handleAndDispatchCustomEvent } from "../../shared";
5
+
6
+ export type PointerDownOutsideEvent = CustomEvent<{
7
+ originalEvent: PointerEvent;
8
+ }>;
9
+ export type FocusOutsideEvent = CustomEvent<{ originalEvent: FocusEvent }>;
10
+
11
+ export const DISMISSABLE_LAYER_NAME = "DismissableLayer";
12
+ export const CONTEXT_UPDATE = "dismissableLayer.update";
13
+ export const POINTER_DOWN_OUTSIDE = "dismissableLayer.pointerDownOutside";
14
+ export const FOCUS_OUTSIDE = "dismissableLayer.focusOutside";
15
+
16
+ function isLayerExist(layerElement: HTMLElement, targetElement: HTMLElement) {
17
+ const targetLayer = targetElement.closest("[data-dismissable-layer]");
18
+
19
+ const mainLayer =
20
+ layerElement.dataset.dismissableLayer === ""
21
+ ? layerElement
22
+ : (layerElement.querySelector("[data-dismissable-layer]") as HTMLElement);
23
+
24
+ const nodeList = Array.from(
25
+ layerElement.ownerDocument.querySelectorAll("[data-dismissable-layer]"),
26
+ );
27
+
28
+ if (
29
+ targetLayer &&
30
+ (mainLayer === targetLayer ||
31
+ nodeList.indexOf(mainLayer) < nodeList.indexOf(targetLayer))
32
+ ) {
33
+ return true;
34
+ } else {
35
+ return false;
36
+ }
37
+ }
38
+
39
+ /**
40
+ * Listens for `pointerdown` outside a DOM subtree. We use `pointerdown` rather than `pointerup`
41
+ * to mimic layer dismissing behaviour present in OS.
42
+ * Returns props to pass to the node we want to check for outside events.
43
+ */
44
+ export function usePointerDownOutside(
45
+ onPointerDownOutside?: (event: PointerDownOutsideEvent) => void,
46
+ element?: Ref<HTMLElement | undefined>,
47
+ enabled: MaybeRefOrGetter<boolean> = true,
48
+ ) {
49
+ const ownerDocument: Document =
50
+ element?.value?.ownerDocument ?? globalThis?.document;
51
+
52
+ const isPointerInsideDOMTree = ref(false);
53
+ const handleClickRef = ref(() => {});
54
+
55
+ watchEffect((cleanupFn) => {
56
+ if (!isClient || !toValue(enabled)) return;
57
+ const handlePointerDown = async (event: PointerEvent) => {
58
+ const target = event.target as HTMLElement | undefined;
59
+
60
+ if (!element?.value || !target) return;
61
+
62
+ if (isLayerExist(element.value, target)) {
63
+ isPointerInsideDOMTree.value = false;
64
+ return;
65
+ }
66
+
67
+ if (event.target && !isPointerInsideDOMTree.value) {
68
+ const eventDetail = { originalEvent: event };
69
+
70
+ function handleAndDispatchPointerDownOutsideEvent() {
71
+ handleAndDispatchCustomEvent(
72
+ POINTER_DOWN_OUTSIDE,
73
+ onPointerDownOutside,
74
+ eventDetail,
75
+ );
76
+ }
77
+
78
+ /**
79
+ * On touch devices, we need to wait for a click event because browsers implement
80
+ * a ~350ms delay between the time the user stops touching the display and when the
81
+ * browser executes events. We need to ensure we don't reactivate pointer-events within
82
+ * this timeframe otherwise the browser may execute events that should have been prevented.
83
+ *
84
+ * Additionally, this also lets us deal automatically with cancellations when a click event
85
+ * isn't raised because the page was considered scrolled/drag-scrolled, long-pressed, etc.
86
+ *
87
+ * This is why we also continuously remove the previous listener, because we cannot be
88
+ * certain that it was raised, and therefore cleaned-up.
89
+ */
90
+ if (event.pointerType === "touch") {
91
+ ownerDocument.removeEventListener("click", handleClickRef.value);
92
+ handleClickRef.value = handleAndDispatchPointerDownOutsideEvent;
93
+ ownerDocument.addEventListener("click", handleClickRef.value, {
94
+ once: true,
95
+ });
96
+ } else {
97
+ handleAndDispatchPointerDownOutsideEvent();
98
+ }
99
+ } else {
100
+ // We need to remove the event listener in case the outside click has been canceled.
101
+ // See: https://github.com/radix-ui/primitives/issues/2171
102
+ ownerDocument.removeEventListener("click", handleClickRef.value);
103
+ }
104
+ isPointerInsideDOMTree.value = false;
105
+ };
106
+ /**
107
+ * if this hook executes in a component that mounts via a `pointerdown` event, the event
108
+ * would bubble up to the document and trigger a `pointerDownOutside` event. We avoid
109
+ * this by delaying the event listener registration on the document.
110
+ * This is how the DOM works, ie:
111
+ * ```
112
+ * button.addEventListener('pointerdown', () => {
113
+ * console.log('I will log');
114
+ * document.addEventListener('pointerdown', () => {
115
+ * console.log('I will also log');
116
+ * })
117
+ * });
118
+ */
119
+ const timerId = window.setTimeout(() => {
120
+ ownerDocument.addEventListener("pointerdown", handlePointerDown);
121
+ }, 0);
122
+
123
+ cleanupFn(() => {
124
+ window.clearTimeout(timerId);
125
+ ownerDocument.removeEventListener("pointerdown", handlePointerDown);
126
+ ownerDocument.removeEventListener("click", handleClickRef.value);
127
+ });
128
+ });
129
+
130
+ return {
131
+ onPointerDownCapture: () => {
132
+ if (!toValue(enabled)) return;
133
+ isPointerInsideDOMTree.value = true;
134
+ },
135
+ };
136
+ }
137
+
138
+ /**
139
+ * Listens for when focus happens outside a DOM subtree.
140
+ * Returns props to pass to the root (node) of the subtree we want to check.
141
+ */
142
+ export function useFocusOutside(
143
+ onFocusOutside?: (event: FocusOutsideEvent) => void,
144
+ element?: Ref<HTMLElement | undefined>,
145
+ enabled: MaybeRefOrGetter<boolean> = true,
146
+ ) {
147
+ const ownerDocument: Document =
148
+ element?.value?.ownerDocument ?? globalThis?.document;
149
+
150
+ const isFocusInsideDOMTree = ref(false);
151
+ watchEffect((cleanupFn) => {
152
+ if (!isClient || !toValue(enabled)) return;
153
+ const handleFocus = async (event: FocusEvent) => {
154
+ if (!element?.value) return;
155
+
156
+ await nextTick();
157
+ await nextTick();
158
+ const target = event.target as HTMLElement | undefined;
159
+ if (!element.value || !target || isLayerExist(element.value, target))
160
+ return;
161
+
162
+ if (event.target && !isFocusInsideDOMTree.value) {
163
+ const eventDetail = { originalEvent: event };
164
+ handleAndDispatchCustomEvent(
165
+ FOCUS_OUTSIDE,
166
+ onFocusOutside,
167
+ eventDetail,
168
+ );
169
+ }
170
+ };
171
+
172
+ ownerDocument.addEventListener("focusin", handleFocus);
173
+
174
+ cleanupFn(() => ownerDocument.removeEventListener("focusin", handleFocus));
175
+ });
176
+
177
+ return {
178
+ onFocusCapture: () => {
179
+ if (!toValue(enabled)) return;
180
+
181
+ isFocusInsideDOMTree.value = true;
182
+ },
183
+ onBlurCapture: () => {
184
+ if (!toValue(enabled)) return;
185
+
186
+ isFocusInsideDOMTree.value = false;
187
+ },
188
+ };
189
+ }
190
+
191
+ export function dispatchUpdate() {
192
+ const event = new CustomEvent(CONTEXT_UPDATE);
193
+ document.dispatchEvent(event);
194
+ }
@@ -0,0 +1,220 @@
1
+ <script lang="ts">
2
+ import type { PrimitiveProps } from "../Primitive";
3
+ import { getActiveElement, useForwardExpose } from "../../shared";
4
+
5
+ export type FocusScopeEmits = {
6
+ /**
7
+ * Event handler called when auto-focusing on mount.
8
+ * Can be prevented.
9
+ */
10
+ mountAutoFocus: [event: Event];
11
+
12
+ /**
13
+ * Event handler called when auto-focusing on unmount.
14
+ * Can be prevented.
15
+ */
16
+ unmountAutoFocus: [event: Event];
17
+ };
18
+
19
+ export interface FocusScopeProps extends PrimitiveProps {
20
+ /**
21
+ * When `true`, tabbing from last item will focus first tabbable
22
+ * and shift+tab from first item will focus last tababble.
23
+ * @defaultValue false
24
+ */
25
+ loop?: boolean;
26
+
27
+ /**
28
+ * When `true`, focus cannot escape the focus scope via keyboard,
29
+ * pointer, or a programmatic focus.
30
+ * @defaultValue false
31
+ */
32
+ trapped?: boolean;
33
+ }
34
+ </script>
35
+
36
+ <script setup lang="ts">
37
+ import { isClient } from "@vueuse/shared";
38
+ import { nextTick, reactive, ref, watchEffect } from "vue";
39
+ import { Primitive } from "../Primitive";
40
+ import { createFocusScopesStack, removeLinks } from "./stack";
41
+ import {
42
+ AUTOFOCUS_ON_MOUNT,
43
+ AUTOFOCUS_ON_UNMOUNT,
44
+ EVENT_OPTIONS,
45
+ focus,
46
+ focusFirst,
47
+ getTabbableCandidates,
48
+ getTabbableEdges,
49
+ } from "./utils";
50
+
51
+ const props = withDefaults(defineProps<FocusScopeProps>(), {
52
+ loop: false,
53
+ trapped: false,
54
+ });
55
+ const emits = defineEmits<FocusScopeEmits>();
56
+
57
+ const { currentRef, currentElement } = useForwardExpose();
58
+ const lastFocusedElementRef = ref<HTMLElement | null>(null);
59
+ const focusScopesStack = createFocusScopesStack();
60
+
61
+ const focusScope = reactive({
62
+ paused: false,
63
+ pause() {
64
+ this.paused = true;
65
+ },
66
+ resume() {
67
+ this.paused = false;
68
+ },
69
+ });
70
+
71
+ watchEffect((cleanupFn) => {
72
+ if (!isClient) return;
73
+ const container = currentElement.value;
74
+ if (!props.trapped) return;
75
+
76
+ function handleFocusIn(event: FocusEvent) {
77
+ if (focusScope.paused || !container) return;
78
+ const target = event.target as HTMLElement | null;
79
+ if (container.contains(target)) lastFocusedElementRef.value = target;
80
+ else focus(lastFocusedElementRef.value, { select: true });
81
+ }
82
+
83
+ function handleFocusOut(event: FocusEvent) {
84
+ if (focusScope.paused || !container) return;
85
+ const relatedTarget = event.relatedTarget as HTMLElement | null;
86
+
87
+ // A `focusout` event with a `null` `relatedTarget` will happen in at least two cases:
88
+ //
89
+ // 1. When the user switches app/tabs/windows/the browser itself loses focus.
90
+ // 2. In Google Chrome, when the focused element is removed from the DOM.
91
+ //
92
+ // We let the browser do its thing here because:
93
+ //
94
+ // 1. The browser already keeps a memory of what's focused for when the page gets refocused.
95
+ // 2. In Google Chrome, if we try to focus the deleted focused element (as per below), it
96
+ // throws the CPU to 100%, so we avoid doing anything for this reason here too.
97
+ if (relatedTarget === null) return;
98
+
99
+ // If the focus has moved to an actual legitimate element (`relatedTarget !== null`)
100
+ // that is outside the container, we move focus to the last valid focused element inside.
101
+ if (!container.contains(relatedTarget))
102
+ focus(lastFocusedElementRef.value, { select: true });
103
+ }
104
+
105
+ // When the focused element gets removed from the DOM, browsers move focus
106
+ // back to the document.body. In this case, we move focus to the container
107
+ // to keep focus trapped correctly.
108
+ // -- related: https://github.com/unovue/reka-ui/issues/518
109
+ // Reka UI tentative solution:
110
+ // instead of leaning on document.activeElement, we use lastFocusedElementRef.value to check
111
+ // if the element still exist inside the container,
112
+ // if not then we focus to the container
113
+ function handleMutations(mutations: MutationRecord[]) {
114
+ const isLastFocusedElementExist = container.contains(
115
+ lastFocusedElementRef.value,
116
+ );
117
+ if (!isLastFocusedElementExist) focus(container);
118
+ }
119
+
120
+ document.addEventListener("focusin", handleFocusIn);
121
+ document.addEventListener("focusout", handleFocusOut);
122
+ const mutationObserver = new MutationObserver(handleMutations);
123
+ if (container)
124
+ mutationObserver.observe(container, { childList: true, subtree: true });
125
+
126
+ cleanupFn(() => {
127
+ document.removeEventListener("focusin", handleFocusIn);
128
+ document.removeEventListener("focusout", handleFocusOut);
129
+ mutationObserver.disconnect();
130
+ });
131
+ });
132
+
133
+ watchEffect(async (cleanupFn) => {
134
+ const container = currentElement.value;
135
+
136
+ await nextTick();
137
+ if (!container) return;
138
+ focusScopesStack.add(focusScope);
139
+ const previouslyFocusedElement = getActiveElement() as HTMLElement | null;
140
+ const hasFocusedCandidate = container.contains(previouslyFocusedElement);
141
+
142
+ if (!hasFocusedCandidate) {
143
+ const mountEvent = new CustomEvent(AUTOFOCUS_ON_MOUNT, EVENT_OPTIONS);
144
+ container.addEventListener(AUTOFOCUS_ON_MOUNT, (ev: Event) =>
145
+ emits("mountAutoFocus", ev),
146
+ );
147
+ container.dispatchEvent(mountEvent);
148
+
149
+ if (!mountEvent.defaultPrevented) {
150
+ focusFirst(removeLinks(getTabbableCandidates(container)), {
151
+ select: true,
152
+ });
153
+ if (getActiveElement() === previouslyFocusedElement) focus(container);
154
+ }
155
+ }
156
+
157
+ cleanupFn(() => {
158
+ container.removeEventListener(AUTOFOCUS_ON_MOUNT, (ev: Event) =>
159
+ emits("mountAutoFocus", ev),
160
+ );
161
+
162
+ const unmountEvent = new CustomEvent(AUTOFOCUS_ON_UNMOUNT, EVENT_OPTIONS);
163
+ const unmountEventHandler = (ev: Event) => {
164
+ emits("unmountAutoFocus", ev);
165
+ };
166
+ container.addEventListener(AUTOFOCUS_ON_UNMOUNT, unmountEventHandler);
167
+ container.dispatchEvent(unmountEvent);
168
+
169
+ setTimeout(() => {
170
+ if (!unmountEvent.defaultPrevented)
171
+ focus(previouslyFocusedElement ?? document.body, { select: true });
172
+
173
+ // we need to remove the listener after we `dispatchEvent`
174
+ container.removeEventListener(AUTOFOCUS_ON_UNMOUNT, unmountEventHandler);
175
+
176
+ focusScopesStack.remove(focusScope);
177
+ }, 0);
178
+ });
179
+ });
180
+
181
+ function handleKeyDown(event: KeyboardEvent) {
182
+ if (!props.loop && !props.trapped) return;
183
+ if (focusScope.paused) return;
184
+
185
+ const isTabKey =
186
+ event.key === "Tab" && !event.altKey && !event.ctrlKey && !event.metaKey;
187
+ const focusedElement = getActiveElement() as HTMLElement | null;
188
+
189
+ if (isTabKey && focusedElement) {
190
+ const container = event.currentTarget as HTMLElement;
191
+ const [first, last] = getTabbableEdges(container);
192
+ const hasTabbableElementsInside = first && last;
193
+
194
+ // we can only wrap focus if we have tabbable edges
195
+ if (!hasTabbableElementsInside) {
196
+ if (focusedElement === container) event.preventDefault();
197
+ } else {
198
+ if (!event.shiftKey && focusedElement === last) {
199
+ event.preventDefault();
200
+ if (props.loop) focus(first, { select: true });
201
+ } else if (event.shiftKey && focusedElement === first) {
202
+ event.preventDefault();
203
+ if (props.loop) focus(last, { select: true });
204
+ }
205
+ }
206
+ }
207
+ }
208
+ </script>
209
+
210
+ <template>
211
+ <Primitive
212
+ ref="currentRef"
213
+ tabindex="-1"
214
+ :as-child="asChild"
215
+ :as="as"
216
+ @keydown="handleKeyDown"
217
+ >
218
+ <slot />
219
+ </Primitive>
220
+ </template>
@@ -0,0 +1,5 @@
1
+ export {
2
+ default as FocusScope,
3
+ type FocusScopeEmits,
4
+ type FocusScopeProps,
5
+ } from './FocusScope.vue'
@@ -0,0 +1,49 @@
1
+ import { createGlobalState } from '@vueuse/core'
2
+ import { ref } from 'vue'
3
+
4
+ interface FocusScopeAPI {
5
+ paused: boolean
6
+ pause: () => void
7
+ resume: () => void
8
+ }
9
+
10
+ const useFocusStackState = createGlobalState(() => {
11
+ const stack = ref<FocusScopeAPI[]>([])
12
+ return stack
13
+ })
14
+
15
+ export function createFocusScopesStack() {
16
+ /** A stack of focus scopes, with the active one at the top */
17
+ const stack = useFocusStackState()
18
+
19
+ return {
20
+ add(focusScope: FocusScopeAPI) {
21
+ // pause the currently active focus scope (at the top of the stack)
22
+ const activeFocusScope = stack.value[0]
23
+ if (focusScope !== activeFocusScope)
24
+ activeFocusScope?.pause()
25
+
26
+ // remove in case it already exists (because we'll re-add it at the top of the stack)
27
+ stack.value = arrayRemove(stack.value, focusScope)
28
+ stack.value.unshift(focusScope)
29
+ },
30
+
31
+ remove(focusScope: FocusScopeAPI) {
32
+ stack.value = arrayRemove(stack.value, focusScope)
33
+ stack.value[0]?.resume()
34
+ },
35
+ }
36
+ }
37
+
38
+ export function arrayRemove<T>(array: T[], item: T) {
39
+ const updatedArray = [...array]
40
+ const index = updatedArray.indexOf(item)
41
+ if (index !== -1)
42
+ updatedArray.splice(index, 1)
43
+
44
+ return updatedArray
45
+ }
46
+
47
+ export function removeLinks(items: HTMLElement[]) {
48
+ return items.filter(item => item.tagName !== 'A')
49
+ }