@auronui/vue 1.0.20 → 1.0.22

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 (371) hide show
  1. package/dist/cjs/index.cjs +3951 -502
  2. package/dist/cjs/index.cjs.map +1 -1
  3. package/dist/components/accordion/Accordion.js.map +1 -1
  4. package/dist/components/accordion/Accordion.vue_vue_type_script_setup_true_lang.js +15 -0
  5. package/dist/components/accordion/Accordion.vue_vue_type_script_setup_true_lang.js.map +1 -1
  6. package/dist/components/accordion/AccordionContent.js.map +1 -1
  7. package/dist/components/accordion/AccordionContent.vue_vue_type_script_setup_true_lang.js +10 -2
  8. package/dist/components/accordion/AccordionContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  9. package/dist/components/accordion/AccordionHeader.js.map +1 -1
  10. package/dist/components/accordion/AccordionHeader.vue_vue_type_script_setup_true_lang.js +13 -3
  11. package/dist/components/accordion/AccordionHeader.vue_vue_type_script_setup_true_lang.js.map +1 -1
  12. package/dist/components/accordion/AccordionItem.js.map +1 -1
  13. package/dist/components/accordion/AccordionItem.vue_vue_type_script_setup_true_lang.js +9 -0
  14. package/dist/components/accordion/AccordionItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  15. package/dist/components/accordion/AccordionTrigger.js.map +1 -1
  16. package/dist/components/accordion/AccordionTrigger.vue_vue_type_script_setup_true_lang.js +13 -3
  17. package/dist/components/accordion/AccordionTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  18. package/dist/components/alert-dialog/AlertDialogAction.js.map +1 -1
  19. package/dist/components/alert-dialog/AlertDialogAction.vue_vue_type_script_setup_true_lang.js +33 -7
  20. package/dist/components/alert-dialog/AlertDialogAction.vue_vue_type_script_setup_true_lang.js.map +1 -1
  21. package/dist/components/alert-dialog/AlertDialogCancel.js.map +1 -1
  22. package/dist/components/alert-dialog/AlertDialogCancel.vue_vue_type_script_setup_true_lang.js +33 -7
  23. package/dist/components/alert-dialog/AlertDialogCancel.vue_vue_type_script_setup_true_lang.js.map +1 -1
  24. package/dist/components/alert-dialog/AlertDialogContent.js.map +1 -1
  25. package/dist/components/alert-dialog/AlertDialogContent.vue_vue_type_script_setup_true_lang.js +42 -6
  26. package/dist/components/alert-dialog/AlertDialogContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  27. package/dist/components/alert-dialog/AlertDialogDescription.js.map +1 -1
  28. package/dist/components/alert-dialog/AlertDialogDescription.vue_vue_type_script_setup_true_lang.js +11 -2
  29. package/dist/components/alert-dialog/AlertDialogDescription.vue_vue_type_script_setup_true_lang.js.map +1 -1
  30. package/dist/components/alert-dialog/AlertDialogOverlay.js.map +1 -1
  31. package/dist/components/alert-dialog/AlertDialogOverlay.vue_vue_type_script_setup_true_lang.js +23 -2
  32. package/dist/components/alert-dialog/AlertDialogOverlay.vue_vue_type_script_setup_true_lang.js.map +1 -1
  33. package/dist/components/alert-dialog/AlertDialogTitle.js.map +1 -1
  34. package/dist/components/alert-dialog/AlertDialogTitle.vue_vue_type_script_setup_true_lang.js +10 -1
  35. package/dist/components/alert-dialog/AlertDialogTitle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  36. package/dist/components/alert-dialog/AlertDialogTrigger.js.map +1 -1
  37. package/dist/components/alert-dialog/AlertDialogTrigger.vue_vue_type_script_setup_true_lang.js +12 -6
  38. package/dist/components/alert-dialog/AlertDialogTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  39. package/dist/components/aspect-ratio/AspectRatio.js.map +1 -1
  40. package/dist/components/aspect-ratio/AspectRatio.vue_vue_type_script_setup_true_lang.js +10 -1
  41. package/dist/components/aspect-ratio/AspectRatio.vue_vue_type_script_setup_true_lang.js.map +1 -1
  42. package/dist/components/autocomplete/Autocomplete.js.map +1 -1
  43. package/dist/components/autocomplete/Autocomplete.vue_vue_type_script_setup_true_lang.js +29 -4
  44. package/dist/components/autocomplete/Autocomplete.vue_vue_type_script_setup_true_lang.js.map +1 -1
  45. package/dist/components/autocomplete/AutocompleteContent.js.map +1 -1
  46. package/dist/components/autocomplete/AutocompleteContent.vue_vue_type_script_setup_true_lang.js +151 -9
  47. package/dist/components/autocomplete/AutocompleteContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  48. package/dist/components/autocomplete/AutocompleteCreateItem.js.map +1 -1
  49. package/dist/components/autocomplete/AutocompleteCreateItem.vue_vue_type_script_setup_true_lang.js +24 -4
  50. package/dist/components/autocomplete/AutocompleteCreateItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  51. package/dist/components/autocomplete/AutocompleteInput.js.map +1 -1
  52. package/dist/components/autocomplete/AutocompleteInput.vue_vue_type_script_setup_true_lang.js +75 -9
  53. package/dist/components/autocomplete/AutocompleteInput.vue_vue_type_script_setup_true_lang.js.map +1 -1
  54. package/dist/components/autocomplete/AutocompleteItem.js.map +1 -1
  55. package/dist/components/autocomplete/AutocompleteItem.vue_vue_type_script_setup_true_lang.js +29 -5
  56. package/dist/components/autocomplete/AutocompleteItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  57. package/dist/components/avatar/Avatar.js.map +1 -1
  58. package/dist/components/avatar/Avatar.vue_vue_type_script_setup_true_lang.js +39 -5
  59. package/dist/components/avatar/Avatar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  60. package/dist/components/button/Button.js.map +1 -1
  61. package/dist/components/button/Button.vue_vue_type_script_setup_true_lang.js +2 -0
  62. package/dist/components/button/Button.vue_vue_type_script_setup_true_lang.js.map +1 -1
  63. package/dist/components/button/ToggleButton.js.map +1 -1
  64. package/dist/components/button/ToggleButton.vue_vue_type_script_setup_true_lang.js +16 -2
  65. package/dist/components/button/ToggleButton.vue_vue_type_script_setup_true_lang.js.map +1 -1
  66. package/dist/components/calendar/Calendar.js.map +1 -1
  67. package/dist/components/calendar/Calendar.vue_vue_type_script_setup_true_lang.js +44 -0
  68. package/dist/components/calendar/Calendar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  69. package/dist/components/calendar-year-picker/CalendarYearPicker.js.map +1 -1
  70. package/dist/components/calendar-year-picker/CalendarYearPicker.vue_vue_type_script_setup_true_lang.js +21 -0
  71. package/dist/components/calendar-year-picker/CalendarYearPicker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  72. package/dist/components/checkbox/Checkbox.js.map +1 -1
  73. package/dist/components/checkbox/Checkbox.vue_vue_type_script_setup_true_lang.js +60 -3
  74. package/dist/components/checkbox/Checkbox.vue_vue_type_script_setup_true_lang.js.map +1 -1
  75. package/dist/components/chip/Chip.js.map +1 -1
  76. package/dist/components/chip/Chip.vue_vue_type_script_setup_true_lang.js +6 -1
  77. package/dist/components/chip/Chip.vue_vue_type_script_setup_true_lang.js.map +1 -1
  78. package/dist/components/collapsible/Collapsible.js.map +1 -1
  79. package/dist/components/collapsible/Collapsible.vue_vue_type_script_setup_true_lang.js +9 -0
  80. package/dist/components/collapsible/Collapsible.vue_vue_type_script_setup_true_lang.js.map +1 -1
  81. package/dist/components/collapsible/CollapsibleContent.js.map +1 -1
  82. package/dist/components/collapsible/CollapsibleContent.vue_vue_type_script_setup_true_lang.js +15 -4
  83. package/dist/components/collapsible/CollapsibleContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  84. package/dist/components/collapsible/CollapsibleTrigger.js.map +1 -1
  85. package/dist/components/collapsible/CollapsibleTrigger.vue_vue_type_script_setup_true_lang.js +13 -3
  86. package/dist/components/collapsible/CollapsibleTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  87. package/dist/components/color-area/ColorArea.js.map +1 -1
  88. package/dist/components/color-area/ColorArea.vue_vue_type_script_setup_true_lang.js +34 -3
  89. package/dist/components/color-area/ColorArea.vue_vue_type_script_setup_true_lang.js.map +1 -1
  90. package/dist/components/color-field/ColorField.js.map +1 -1
  91. package/dist/components/color-field/ColorField.vue_vue_type_script_setup_true_lang.js +39 -2
  92. package/dist/components/color-field/ColorField.vue_vue_type_script_setup_true_lang.js.map +1 -1
  93. package/dist/components/color-input-group/ColorInputGroup.js.map +1 -1
  94. package/dist/components/color-input-group/ColorInputGroup.vue_vue_type_script_setup_true_lang.js +39 -2
  95. package/dist/components/color-input-group/ColorInputGroup.vue_vue_type_script_setup_true_lang.js.map +1 -1
  96. package/dist/components/color-slider/ColorSlider.js.map +1 -1
  97. package/dist/components/color-slider/ColorSlider.vue_vue_type_script_setup_true_lang.js +40 -3
  98. package/dist/components/color-slider/ColorSlider.vue_vue_type_script_setup_true_lang.js.map +1 -1
  99. package/dist/components/color-swatch/ColorSwatch.js.map +1 -1
  100. package/dist/components/color-swatch/ColorSwatch.vue_vue_type_script_setup_true_lang.js +9 -2
  101. package/dist/components/color-swatch/ColorSwatch.vue_vue_type_script_setup_true_lang.js.map +1 -1
  102. package/dist/components/color-swatch-picker/ColorSwatchPicker.js.map +1 -1
  103. package/dist/components/color-swatch-picker/ColorSwatchPicker.vue_vue_type_script_setup_true_lang.js +60 -4
  104. package/dist/components/color-swatch-picker/ColorSwatchPicker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  105. package/dist/components/combo-box/ComboBox.js.map +1 -1
  106. package/dist/components/combo-box/ComboBox.vue_vue_type_script_setup_true_lang.js +74 -3
  107. package/dist/components/combo-box/ComboBox.vue_vue_type_script_setup_true_lang.js.map +1 -1
  108. package/dist/components/combo-box/ComboBoxContent.js.map +1 -1
  109. package/dist/components/combo-box/ComboBoxContent.vue_vue_type_script_setup_true_lang.js +168 -10
  110. package/dist/components/combo-box/ComboBoxContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  111. package/dist/components/combo-box/ComboBoxEmpty.js.map +1 -1
  112. package/dist/components/combo-box/ComboBoxEmpty.vue_vue_type_script_setup_true_lang.js +11 -1
  113. package/dist/components/combo-box/ComboBoxEmpty.vue_vue_type_script_setup_true_lang.js.map +1 -1
  114. package/dist/components/combo-box/ComboBoxInput.js.map +1 -1
  115. package/dist/components/combo-box/ComboBoxInput.vue_vue_type_script_setup_true_lang.js +78 -11
  116. package/dist/components/combo-box/ComboBoxInput.vue_vue_type_script_setup_true_lang.js.map +1 -1
  117. package/dist/components/combo-box/ComboBoxItem.js.map +1 -1
  118. package/dist/components/combo-box/ComboBoxItem.vue_vue_type_script_setup_true_lang.js +31 -7
  119. package/dist/components/combo-box/ComboBoxItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  120. package/dist/components/date-input/DateInput.js.map +1 -1
  121. package/dist/components/date-input/DateInput.vue_vue_type_script_setup_true_lang.js +30 -3
  122. package/dist/components/date-input/DateInput.vue_vue_type_script_setup_true_lang.js.map +1 -1
  123. package/dist/components/date-picker/DatePicker.js.map +1 -1
  124. package/dist/components/date-picker/DatePicker.vue_vue_type_script_setup_true_lang.js +140 -10
  125. package/dist/components/date-picker/DatePicker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  126. package/dist/components/date-range-field/DateRangeField.js.map +1 -1
  127. package/dist/components/date-range-field/DateRangeField.vue_vue_type_script_setup_true_lang.js +24 -3
  128. package/dist/components/date-range-field/DateRangeField.vue_vue_type_script_setup_true_lang.js.map +1 -1
  129. package/dist/components/date-range-picker/DateRangePicker.js.map +1 -1
  130. package/dist/components/date-range-picker/DateRangePicker.vue_vue_type_script_setup_true_lang.js +146 -9
  131. package/dist/components/date-range-picker/DateRangePicker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  132. package/dist/components/date-time-picker/DateTimePicker.js.map +1 -1
  133. package/dist/components/date-time-picker/DateTimePicker.vue_vue_type_script_setup_true_lang.js +143 -11
  134. package/dist/components/date-time-picker/DateTimePicker.vue_vue_type_script_setup_true_lang.js.map +1 -1
  135. package/dist/components/drawer/Drawer.js.map +1 -1
  136. package/dist/components/drawer/Drawer.vue_vue_type_script_lang.js +42 -4
  137. package/dist/components/drawer/Drawer.vue_vue_type_script_lang.js.map +1 -1
  138. package/dist/components/drawer/DrawerClose.js.map +1 -1
  139. package/dist/components/drawer/DrawerClose.vue_vue_type_script_setup_true_lang.js +25 -3
  140. package/dist/components/drawer/DrawerClose.vue_vue_type_script_setup_true_lang.js.map +1 -1
  141. package/dist/components/drawer/DrawerContent.js.map +1 -1
  142. package/dist/components/drawer/DrawerContent.vue_vue_type_script_setup_true_lang.js +124 -12
  143. package/dist/components/drawer/DrawerContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  144. package/dist/components/drawer/DrawerMain.js +7 -0
  145. package/dist/components/drawer/DrawerMain.js.map +1 -0
  146. package/dist/components/drawer/DrawerMain.vue_vue_type_script_setup_true_lang.js +32 -0
  147. package/dist/components/drawer/DrawerMain.vue_vue_type_script_setup_true_lang.js.map +1 -0
  148. package/dist/components/drawer/DrawerOverlay.js.map +1 -1
  149. package/dist/components/drawer/DrawerOverlay.vue_vue_type_script_setup_true_lang.js +25 -1
  150. package/dist/components/drawer/DrawerOverlay.vue_vue_type_script_setup_true_lang.js.map +1 -1
  151. package/dist/components/drawer/DrawerTitle.js.map +1 -1
  152. package/dist/components/drawer/DrawerTitle.vue_vue_type_script_setup_true_lang.js +27 -3
  153. package/dist/components/drawer/DrawerTitle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  154. package/dist/components/drawer/DrawerTrigger.js.map +1 -1
  155. package/dist/components/drawer/DrawerTrigger.vue_vue_type_script_setup_true_lang.js +24 -7
  156. package/dist/components/drawer/DrawerTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  157. package/dist/components/drawer/drawer.context.js.map +1 -1
  158. package/dist/components/dropdown/Dropdown.js.map +1 -1
  159. package/dist/components/dropdown/Dropdown.vue_vue_type_script_setup_true_lang.js +15 -5
  160. package/dist/components/dropdown/Dropdown.vue_vue_type_script_setup_true_lang.js.map +1 -1
  161. package/dist/components/dropdown/DropdownCheckboxItem.js.map +1 -1
  162. package/dist/components/dropdown/DropdownCheckboxItem.vue_vue_type_script_setup_true_lang.js +29 -7
  163. package/dist/components/dropdown/DropdownCheckboxItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  164. package/dist/components/dropdown/DropdownItem.js.map +1 -1
  165. package/dist/components/dropdown/DropdownItem.vue_vue_type_script_setup_true_lang.js +15 -2
  166. package/dist/components/dropdown/DropdownItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  167. package/dist/components/dropdown/DropdownMenu.js.map +1 -1
  168. package/dist/components/dropdown/DropdownMenu.vue_vue_type_script_setup_true_lang.js +121 -5
  169. package/dist/components/dropdown/DropdownMenu.vue_vue_type_script_setup_true_lang.js.map +1 -1
  170. package/dist/components/dropdown/DropdownRadioGroup.js.map +1 -1
  171. package/dist/components/dropdown/DropdownRadioGroup.vue_vue_type_script_setup_true_lang.js +17 -4
  172. package/dist/components/dropdown/DropdownRadioGroup.vue_vue_type_script_setup_true_lang.js.map +1 -1
  173. package/dist/components/dropdown/DropdownRadioItem.js.map +1 -1
  174. package/dist/components/dropdown/DropdownRadioItem.vue_vue_type_script_setup_true_lang.js +21 -5
  175. package/dist/components/dropdown/DropdownRadioItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  176. package/dist/components/dropdown/DropdownSection.js.map +1 -1
  177. package/dist/components/dropdown/DropdownSection.vue_vue_type_script_setup_true_lang.js +16 -3
  178. package/dist/components/dropdown/DropdownSection.vue_vue_type_script_setup_true_lang.js.map +1 -1
  179. package/dist/components/dropdown/DropdownSubContent.js.map +1 -1
  180. package/dist/components/dropdown/DropdownSubContent.vue_vue_type_script_setup_true_lang.js +125 -5
  181. package/dist/components/dropdown/DropdownSubContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  182. package/dist/components/dropdown/DropdownSubTrigger.js.map +1 -1
  183. package/dist/components/dropdown/DropdownSubTrigger.vue_vue_type_script_setup_true_lang.js +15 -2
  184. package/dist/components/dropdown/DropdownSubTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  185. package/dist/components/dropdown/DropdownTrigger.js.map +1 -1
  186. package/dist/components/dropdown/DropdownTrigger.vue_vue_type_script_setup_true_lang.js +22 -2
  187. package/dist/components/dropdown/DropdownTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  188. package/dist/components/input-otp/InputOTP.js.map +1 -1
  189. package/dist/components/input-otp/InputOTP.vue_vue_type_script_setup_true_lang.js +34 -1
  190. package/dist/components/input-otp/InputOTP.vue_vue_type_script_setup_true_lang.js.map +1 -1
  191. package/dist/components/list-box/ListBox.js.map +1 -1
  192. package/dist/components/list-box/ListBox.vue_vue_type_script_setup_true_lang.js +67 -8
  193. package/dist/components/list-box/ListBox.vue_vue_type_script_setup_true_lang.js.map +1 -1
  194. package/dist/components/list-box/ListBoxItem.js.map +1 -1
  195. package/dist/components/list-box/ListBoxItem.vue_vue_type_script_setup_true_lang.js +36 -7
  196. package/dist/components/list-box/ListBoxItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  197. package/dist/components/list-box/ListBoxSection.js.map +1 -1
  198. package/dist/components/list-box/ListBoxSection.vue_vue_type_script_setup_true_lang.js +31 -4
  199. package/dist/components/list-box/ListBoxSection.vue_vue_type_script_setup_true_lang.js.map +1 -1
  200. package/dist/components/modal/ModalClose.js.map +1 -1
  201. package/dist/components/modal/ModalClose.vue_vue_type_script_setup_true_lang.js +7 -1
  202. package/dist/components/modal/ModalClose.vue_vue_type_script_setup_true_lang.js.map +1 -1
  203. package/dist/components/modal/ModalContent.js.map +1 -1
  204. package/dist/components/modal/ModalContent.vue_vue_type_script_setup_true_lang.js +49 -5
  205. package/dist/components/modal/ModalContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  206. package/dist/components/modal/ModalDescription.js.map +1 -1
  207. package/dist/components/modal/ModalDescription.vue_vue_type_script_setup_true_lang.js +10 -1
  208. package/dist/components/modal/ModalDescription.vue_vue_type_script_setup_true_lang.js.map +1 -1
  209. package/dist/components/modal/ModalOverlay.js.map +1 -1
  210. package/dist/components/modal/ModalOverlay.vue_vue_type_script_setup_true_lang.js +23 -2
  211. package/dist/components/modal/ModalOverlay.vue_vue_type_script_setup_true_lang.js.map +1 -1
  212. package/dist/components/modal/ModalTitle.js.map +1 -1
  213. package/dist/components/modal/ModalTitle.vue_vue_type_script_setup_true_lang.js +10 -1
  214. package/dist/components/modal/ModalTitle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  215. package/dist/components/modal/ModalTrigger.js.map +1 -1
  216. package/dist/components/modal/ModalTrigger.vue_vue_type_script_setup_true_lang.js +12 -6
  217. package/dist/components/modal/ModalTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  218. package/dist/components/number-field/NumberField.js.map +1 -1
  219. package/dist/components/number-field/NumberField.vue_vue_type_script_setup_true_lang.js +24 -4
  220. package/dist/components/number-field/NumberField.vue_vue_type_script_setup_true_lang.js.map +1 -1
  221. package/dist/components/pagination/Pagination.js.map +1 -1
  222. package/dist/components/pagination/Pagination.vue_vue_type_script_setup_true_lang.js +7 -1
  223. package/dist/components/pagination/Pagination.vue_vue_type_script_setup_true_lang.js.map +1 -1
  224. package/dist/components/pagination/PaginationContent.js.map +1 -1
  225. package/dist/components/pagination/PaginationContent.vue_vue_type_script_setup_true_lang.js +12 -2
  226. package/dist/components/pagination/PaginationContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  227. package/dist/components/pagination/PaginationEllipsis.js.map +1 -1
  228. package/dist/components/pagination/PaginationEllipsis.vue_vue_type_script_setup_true_lang.js +12 -2
  229. package/dist/components/pagination/PaginationEllipsis.vue_vue_type_script_setup_true_lang.js.map +1 -1
  230. package/dist/components/pagination/PaginationFirst.js.map +1 -1
  231. package/dist/components/pagination/PaginationFirst.vue_vue_type_script_setup_true_lang.js +9 -1
  232. package/dist/components/pagination/PaginationFirst.vue_vue_type_script_setup_true_lang.js.map +1 -1
  233. package/dist/components/pagination/PaginationItem.js.map +1 -1
  234. package/dist/components/pagination/PaginationItem.vue_vue_type_script_setup_true_lang.js +11 -2
  235. package/dist/components/pagination/PaginationItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  236. package/dist/components/pagination/PaginationLast.js.map +1 -1
  237. package/dist/components/pagination/PaginationLast.vue_vue_type_script_setup_true_lang.js +9 -1
  238. package/dist/components/pagination/PaginationLast.vue_vue_type_script_setup_true_lang.js.map +1 -1
  239. package/dist/components/pagination/PaginationNext.js.map +1 -1
  240. package/dist/components/pagination/PaginationNext.vue_vue_type_script_setup_true_lang.js +9 -1
  241. package/dist/components/pagination/PaginationNext.vue_vue_type_script_setup_true_lang.js.map +1 -1
  242. package/dist/components/pagination/PaginationPrev.js.map +1 -1
  243. package/dist/components/pagination/PaginationPrev.vue_vue_type_script_setup_true_lang.js +9 -1
  244. package/dist/components/pagination/PaginationPrev.vue_vue_type_script_setup_true_lang.js.map +1 -1
  245. package/dist/components/popover/PopoverContent.js.map +1 -1
  246. package/dist/components/popover/PopoverContent.vue_vue_type_script_setup_true_lang.js +6 -2
  247. package/dist/components/popover/PopoverContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  248. package/dist/components/progress-bar/ProgressBar.js.map +1 -1
  249. package/dist/components/progress-bar/ProgressBar.vue_vue_type_script_setup_true_lang.js +37 -5
  250. package/dist/components/progress-bar/ProgressBar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  251. package/dist/components/progress-circle/ProgressCircle.js.map +1 -1
  252. package/dist/components/progress-circle/ProgressCircle.vue_vue_type_script_setup_true_lang.js +21 -0
  253. package/dist/components/progress-circle/ProgressCircle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  254. package/dist/components/radio/Radio.js.map +1 -1
  255. package/dist/components/radio/Radio.vue_vue_type_script_setup_true_lang.js +46 -3
  256. package/dist/components/radio/Radio.vue_vue_type_script_setup_true_lang.js.map +1 -1
  257. package/dist/components/radio/RadioGroup.js.map +1 -1
  258. package/dist/components/radio/RadioGroup.vue_vue_type_script_setup_true_lang.js +24 -0
  259. package/dist/components/radio/RadioGroup.vue_vue_type_script_setup_true_lang.js.map +1 -1
  260. package/dist/components/range-calendar/RangeCalendar.js.map +1 -1
  261. package/dist/components/range-calendar/RangeCalendar.vue_vue_type_script_setup_true_lang.js +44 -11
  262. package/dist/components/range-calendar/RangeCalendar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  263. package/dist/components/scroll-area/ScrollArea.js.map +1 -1
  264. package/dist/components/scroll-area/ScrollArea.vue_vue_type_script_setup_true_lang.js +61 -8
  265. package/dist/components/scroll-area/ScrollArea.vue_vue_type_script_setup_true_lang.js.map +1 -1
  266. package/dist/components/select/Select.js.map +1 -1
  267. package/dist/components/select/Select.vue_vue_type_script_setup_true_lang.js +12 -0
  268. package/dist/components/select/Select.vue_vue_type_script_setup_true_lang.js.map +1 -1
  269. package/dist/components/select/SelectContent.js.map +1 -1
  270. package/dist/components/select/SelectContent.vue_vue_type_script_setup_true_lang.js +140 -8
  271. package/dist/components/select/SelectContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  272. package/dist/components/select/SelectItem.js.map +1 -1
  273. package/dist/components/select/SelectItem.vue_vue_type_script_setup_true_lang.js +22 -6
  274. package/dist/components/select/SelectItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  275. package/dist/components/select/SelectTrigger.js.map +1 -1
  276. package/dist/components/select/SelectTrigger.vue_vue_type_script_setup_true_lang.js +23 -2
  277. package/dist/components/select/SelectTrigger.vue_vue_type_script_setup_true_lang.js.map +1 -1
  278. package/dist/components/select/SelectValue.js.map +1 -1
  279. package/dist/components/select/SelectValue.vue_vue_type_script_setup_true_lang.js +14 -2
  280. package/dist/components/select/SelectValue.vue_vue_type_script_setup_true_lang.js.map +1 -1
  281. package/dist/components/slider/Slider.js.map +1 -1
  282. package/dist/components/slider/Slider.vue_vue_type_script_setup_true_lang.js +69 -6
  283. package/dist/components/slider/Slider.vue_vue_type_script_setup_true_lang.js.map +1 -1
  284. package/dist/components/splitter/SplitterGroup.js.map +1 -1
  285. package/dist/components/splitter/SplitterGroup.vue_vue_type_script_setup_true_lang.js +18 -3
  286. package/dist/components/splitter/SplitterGroup.vue_vue_type_script_setup_true_lang.js.map +1 -1
  287. package/dist/components/splitter/SplitterPanel.js.map +1 -1
  288. package/dist/components/splitter/SplitterPanel.vue_vue_type_script_setup_true_lang.js +20 -5
  289. package/dist/components/splitter/SplitterPanel.vue_vue_type_script_setup_true_lang.js.map +1 -1
  290. package/dist/components/splitter/SplitterResizeHandle.js.map +1 -1
  291. package/dist/components/splitter/SplitterResizeHandle.vue_vue_type_script_setup_true_lang.js +16 -1
  292. package/dist/components/splitter/SplitterResizeHandle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  293. package/dist/components/switch/Switch.js.map +1 -1
  294. package/dist/components/switch/Switch.vue_vue_type_script_setup_true_lang.js +53 -2
  295. package/dist/components/switch/Switch.vue_vue_type_script_setup_true_lang.js.map +1 -1
  296. package/dist/components/tabs/Tab.js.map +1 -1
  297. package/dist/components/tabs/Tab.vue_vue_type_script_setup_true_lang.js +7 -1
  298. package/dist/components/tabs/Tab.vue_vue_type_script_setup_true_lang.js.map +1 -1
  299. package/dist/components/tabs/TabIndicator.js.map +1 -1
  300. package/dist/components/tabs/TabIndicator.vue_vue_type_script_setup_true_lang.js +12 -2
  301. package/dist/components/tabs/TabIndicator.vue_vue_type_script_setup_true_lang.js.map +1 -1
  302. package/dist/components/tabs/TabList.js.map +1 -1
  303. package/dist/components/tabs/TabList.vue_vue_type_script_setup_true_lang.js +27 -4
  304. package/dist/components/tabs/TabList.vue_vue_type_script_setup_true_lang.js.map +1 -1
  305. package/dist/components/tabs/TabPanel.js.map +1 -1
  306. package/dist/components/tabs/TabPanel.vue_vue_type_script_setup_true_lang.js +7 -1
  307. package/dist/components/tabs/TabPanel.vue_vue_type_script_setup_true_lang.js.map +1 -1
  308. package/dist/components/tabs/Tabs.js.map +1 -1
  309. package/dist/components/tabs/Tabs.vue_vue_type_script_setup_true_lang.js +13 -1
  310. package/dist/components/tabs/Tabs.vue_vue_type_script_setup_true_lang.js.map +1 -1
  311. package/dist/components/time-field/TimeField.js.map +1 -1
  312. package/dist/components/time-field/TimeField.vue_vue_type_script_setup_true_lang.js +22 -1
  313. package/dist/components/time-field/TimeField.vue_vue_type_script_setup_true_lang.js.map +1 -1
  314. package/dist/components/toast/Toast.js.map +1 -1
  315. package/dist/components/toast/Toast.vue_vue_type_script_setup_true_lang.js +39 -4
  316. package/dist/components/toast/Toast.vue_vue_type_script_setup_true_lang.js.map +1 -1
  317. package/dist/components/toast/ToastAction.js.map +1 -1
  318. package/dist/components/toast/ToastAction.vue_vue_type_script_setup_true_lang.js +3 -1
  319. package/dist/components/toast/ToastAction.vue_vue_type_script_setup_true_lang.js.map +1 -1
  320. package/dist/components/toast/ToastClose.js.map +1 -1
  321. package/dist/components/toast/ToastClose.vue_vue_type_script_setup_true_lang.js +3 -1
  322. package/dist/components/toast/ToastClose.vue_vue_type_script_setup_true_lang.js.map +1 -1
  323. package/dist/components/toast/ToastDescription.js.map +1 -1
  324. package/dist/components/toast/ToastDescription.vue_vue_type_script_setup_true_lang.js +15 -3
  325. package/dist/components/toast/ToastDescription.vue_vue_type_script_setup_true_lang.js.map +1 -1
  326. package/dist/components/toast/ToastTitle.js.map +1 -1
  327. package/dist/components/toast/ToastTitle.vue_vue_type_script_setup_true_lang.js +15 -3
  328. package/dist/components/toast/ToastTitle.vue_vue_type_script_setup_true_lang.js.map +1 -1
  329. package/dist/components/toast/ToastViewport.js.map +1 -1
  330. package/dist/components/toast/ToastViewport.vue_vue_type_script_setup_true_lang.js +22 -3
  331. package/dist/components/toast/ToastViewport.vue_vue_type_script_setup_true_lang.js.map +1 -1
  332. package/dist/components/toolbar/Toolbar.js.map +1 -1
  333. package/dist/components/toolbar/Toolbar.vue_vue_type_script_setup_true_lang.js +10 -1
  334. package/dist/components/toolbar/Toolbar.vue_vue_type_script_setup_true_lang.js.map +1 -1
  335. package/dist/components/toolbar/ToolbarButton.js.map +1 -1
  336. package/dist/components/toolbar/ToolbarButton.vue_vue_type_script_setup_true_lang.js +11 -2
  337. package/dist/components/toolbar/ToolbarButton.vue_vue_type_script_setup_true_lang.js.map +1 -1
  338. package/dist/components/toolbar/ToolbarLink.js.map +1 -1
  339. package/dist/components/toolbar/ToolbarLink.vue_vue_type_script_setup_true_lang.js +11 -2
  340. package/dist/components/toolbar/ToolbarLink.vue_vue_type_script_setup_true_lang.js.map +1 -1
  341. package/dist/components/toolbar/ToolbarSeparator.js.map +1 -1
  342. package/dist/components/toolbar/ToolbarSeparator.vue_vue_type_script_setup_true_lang.js +14 -2
  343. package/dist/components/toolbar/ToolbarSeparator.vue_vue_type_script_setup_true_lang.js.map +1 -1
  344. package/dist/components/toolbar/ToolbarToggleGroup.js.map +1 -1
  345. package/dist/components/toolbar/ToolbarToggleGroup.vue_vue_type_script_setup_true_lang.js +22 -1
  346. package/dist/components/toolbar/ToolbarToggleGroup.vue_vue_type_script_setup_true_lang.js.map +1 -1
  347. package/dist/components/toolbar/ToolbarToggleItem.js.map +1 -1
  348. package/dist/components/toolbar/ToolbarToggleItem.vue_vue_type_script_setup_true_lang.js +7 -1
  349. package/dist/components/toolbar/ToolbarToggleItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  350. package/dist/components/tooltip/Tooltip.js.map +1 -1
  351. package/dist/components/tooltip/Tooltip.vue_vue_type_script_lang.js +20 -0
  352. package/dist/components/tooltip/Tooltip.vue_vue_type_script_lang.js.map +1 -1
  353. package/dist/components/tooltip/TooltipContent.js.map +1 -1
  354. package/dist/components/tooltip/TooltipContent.vue_vue_type_script_setup_true_lang.js +7 -2
  355. package/dist/components/tooltip/TooltipContent.vue_vue_type_script_setup_true_lang.js.map +1 -1
  356. package/dist/components/tooltip/TooltipProvider.js.map +1 -1
  357. package/dist/components/tooltip/TooltipProvider.vue_vue_type_script_setup_true_lang.js +24 -3
  358. package/dist/components/tooltip/TooltipProvider.vue_vue_type_script_setup_true_lang.js.map +1 -1
  359. package/dist/components/tree/Tree.js.map +1 -1
  360. package/dist/components/tree/Tree.vue_vue_type_script_setup_true_lang.js +16 -1
  361. package/dist/components/tree/Tree.vue_vue_type_script_setup_true_lang.js.map +1 -1
  362. package/dist/components/tree/TreeItem.js.map +1 -1
  363. package/dist/components/tree/TreeItem.vue_vue_type_script_setup_true_lang.js +7 -1
  364. package/dist/components/tree/TreeItem.vue_vue_type_script_setup_true_lang.js.map +1 -1
  365. package/dist/index.d.ts +2659 -664
  366. package/dist/index.js +2 -1
  367. package/dist/packages/styles/src/components/drawer/drawer.styles.js +13 -5
  368. package/dist/packages/styles/src/components/drawer/drawer.styles.js.map +1 -1
  369. package/dist/utils/warnDeprecated.js +6 -0
  370. package/dist/utils/warnDeprecated.js.map +1 -0
  371. package/package.json +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxEmpty.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxEmpty.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxEmpty } from 'reka-ui'\n</script>\n\n<template>\n <ComboboxEmpty\n class=\"py-3 text-center text-sm text-default-400\"\n data-slot=\"empty-content\"\n >\n <slot />\n </ComboboxEmpty>\n</template>\n"],"mappings":""}
1
+ {"version":3,"file":"ComboBoxEmpty.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxEmpty.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxEmpty } from 'reka-ui'\n\nconst props = withDefaults(defineProps<{\n /** Render as a different element or component. */\n as?: string\n /** Merge props onto child element instead of rendering a wrapper. */\n asChild?: boolean\n}>(), {\n as: undefined,\n asChild: false,\n})\n</script>\n\n<template>\n <ComboboxEmpty\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n class=\"py-3 text-center text-sm text-default-400\"\n data-slot=\"empty-content\"\n >\n <slot />\n </ComboboxEmpty>\n</template>\n"],"mappings":""}
@@ -3,15 +3,25 @@ import { ComboboxEmpty } from "reka-ui";
3
3
  //#region src/components/combo-box/ComboBoxEmpty.vue?vue&type=script&setup=true&lang.ts
4
4
  var ComboBoxEmpty_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
5
5
  __name: "ComboBoxEmpty",
6
+ props: {
7
+ as: { default: void 0 },
8
+ asChild: {
9
+ type: Boolean,
10
+ default: false
11
+ }
12
+ },
6
13
  setup(__props) {
14
+ const props = __props;
7
15
  return (_ctx, _cache) => {
8
16
  return openBlock(), createBlock(unref(ComboboxEmpty), {
17
+ as: props.as,
18
+ "as-child": props.asChild,
9
19
  class: "py-3 text-center text-sm text-default-400",
10
20
  "data-slot": "empty-content"
11
21
  }, {
12
22
  default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
13
23
  _: 3
14
- });
24
+ }, 8, ["as", "as-child"]);
15
25
  };
16
26
  }
17
27
  });
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxEmpty.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxEmpty.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxEmpty } from 'reka-ui'\n</script>\n\n<template>\n <ComboboxEmpty\n class=\"py-3 text-center text-sm text-default-400\"\n data-slot=\"empty-content\"\n >\n <slot />\n </ComboboxEmpty>\n</template>\n"],"mappings":";;;;;;;uBAKE,YAKgB,MAAA,cAAA,EAAA;IAJd,OAAM;IACN,aAAU;;2BAEF,CAAR,WAAQ,KAAA,QAAA,UAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"ComboBoxEmpty.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxEmpty.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxEmpty } from 'reka-ui'\n\nconst props = withDefaults(defineProps<{\n /** Render as a different element or component. */\n as?: string\n /** Merge props onto child element instead of rendering a wrapper. */\n asChild?: boolean\n}>(), {\n as: undefined,\n asChild: false,\n})\n</script>\n\n<template>\n <ComboboxEmpty\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n class=\"py-3 text-center text-sm text-default-400\"\n data-slot=\"empty-content\"\n >\n <slot />\n </ComboboxEmpty>\n</template>\n"],"mappings":";;;;;;;;;;;;;EAGA,MAAM,QAAQ;;uBAYZ,YAOgB,MAAA,cAAA,EAAA;IANb,IAAI,MAAM;IACV,YAAU,MAAM;IACjB,OAAM;IACN,aAAU;;2BAEF,CAAR,WAAQ,KAAA,QAAA,UAAA,CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxInput.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxAnchor, ComboboxInput, ComboboxTrigger, ComboboxCancel } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n placeholder?: string\n class?: string\n}>(), {\n placeholder: undefined,\n class: undefined,\n})\n\nconst ctx = useComboBoxInject()\n</script>\n\n<template>\n <ComboboxAnchor\n :class=\"ctx.slots.value.inputGroup()\"\n data-slot=\"input-group\"\n >\n <ComboboxInput\n :placeholder=\"props.placeholder\"\n :disabled=\"ctx.isDisabled.value\"\n :display-value=\"ctx.displayValue.value\"\n class=\"combo-box__input\"\n data-slot=\"input\"\n autocomplete=\"off\"\n />\n <!-- Clear button: shown when there's input -->\n <ComboboxCancel\n class=\"combo-box__clear-button\"\n data-slot=\"clear-button\"\n aria-label=\"Clear\"\n >\n <slot name=\"clearIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\"\n height=\"10\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n aria-hidden=\"true\"\n >\n <line\n x1=\"18\"\n y1=\"6\"\n x2=\"6\"\n y2=\"18\"\n />\n <line\n x1=\"6\"\n y1=\"6\"\n x2=\"18\"\n y2=\"18\"\n />\n </svg>\n </slot>\n </ComboboxCancel>\n <!-- Dropdown trigger -->\n <ComboboxTrigger\n :class=\"ctx.slots.value.trigger()\"\n data-slot=\"selector-button\"\n aria-label=\"Toggle suggestions\"\n >\n <slot name=\"triggerIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"combo-box-trigger-default-icon\"\n aria-hidden=\"true\"\n >\n <polyline points=\"6 9 12 15 18 9\" />\n </svg>\n </slot>\n </ComboboxTrigger>\n </ComboboxAnchor>\n</template>\n"],"mappings":""}
1
+ {"version":3,"file":"ComboBoxInput.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxAnchor, ComboboxInput, ComboboxTrigger, ComboboxCancel } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n placeholder?: string\n class?: string\n /** Custom reference element for the anchor. */\n anchorReference?: object | null\n /** Render the anchor as a different element. */\n anchorAs?: string\n /** Merge anchor props onto child element. */\n anchorAsChild?: boolean\n /** Function to compute the display value from the current model value. */\n displayValue?: (value: string) => string\n /** Two-way bound search input value. */\n modelValue?: string\n /** Auto-focus the input on mount. */\n autoFocus?: boolean\n /** Disable the input. Falls back to context isDisabled. */\n disabled?: boolean\n /** Render the input as a different element. */\n as?: string\n /** Merge input props onto child element. */\n asChild?: boolean\n /** Disable the trigger button. */\n triggerDisabled?: boolean\n /** Render the trigger as a different element. */\n triggerAs?: string\n /** Merge trigger props onto child element. */\n triggerAsChild?: boolean\n /** Render the cancel button as a different element. */\n cancelAs?: string\n /** Merge cancel props onto child element. */\n cancelAsChild?: boolean\n}>(), {\n placeholder: undefined,\n class: undefined,\n anchorReference: undefined,\n anchorAs: undefined,\n anchorAsChild: false,\n displayValue: undefined,\n modelValue: undefined,\n autoFocus: false,\n disabled: undefined,\n as: undefined,\n asChild: false,\n triggerDisabled: undefined,\n triggerAs: undefined,\n triggerAsChild: false,\n cancelAs: undefined,\n cancelAsChild: false,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst ctx = useComboBoxInject()\n</script>\n\n<template>\n <ComboboxAnchor\n :reference=\"(props.anchorReference as any)\"\n :as=\"props.anchorAs\"\n :as-child=\"props.anchorAsChild\"\n :class=\"ctx.slots.value.inputGroup()\"\n data-slot=\"input-group\"\n >\n <ComboboxInput\n :placeholder=\"props.placeholder\"\n :model-value=\"props.modelValue\"\n :auto-focus=\"props.autoFocus\"\n :disabled=\"props.disabled ?? ctx.isDisabled.value\"\n :display-value=\"props.displayValue ?? ctx.displayValue.value\"\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n class=\"combo-box__input\"\n data-slot=\"input\"\n autocomplete=\"off\"\n @update:model-value=\"emit('update:modelValue', $event)\"\n />\n <!-- Clear button: shown when there's input -->\n <ComboboxCancel\n :as=\"props.cancelAs\"\n :as-child=\"props.cancelAsChild\"\n class=\"combo-box__clear-button\"\n data-slot=\"clear-button\"\n aria-label=\"Clear\"\n >\n <slot name=\"clearIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\"\n height=\"10\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n aria-hidden=\"true\"\n >\n <line\n x1=\"18\"\n y1=\"6\"\n x2=\"6\"\n y2=\"18\"\n />\n <line\n x1=\"6\"\n y1=\"6\"\n x2=\"18\"\n y2=\"18\"\n />\n </svg>\n </slot>\n </ComboboxCancel>\n <!-- Dropdown trigger -->\n <ComboboxTrigger\n :disabled=\"props.triggerDisabled\"\n :as=\"props.triggerAs\"\n :as-child=\"props.triggerAsChild\"\n :class=\"ctx.slots.value.trigger()\"\n data-slot=\"selector-button\"\n aria-label=\"Toggle suggestions\"\n >\n <slot name=\"triggerIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"combo-box-trigger-default-icon\"\n aria-hidden=\"true\"\n >\n <polyline points=\"6 9 12 15 18 9\" />\n </svg>\n </slot>\n </ComboboxTrigger>\n </ComboboxAnchor>\n</template>\n"],"mappings":""}
@@ -6,35 +6,89 @@ var ComboBoxInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
6
6
  __name: "ComboBoxInput",
7
7
  props: {
8
8
  placeholder: { default: void 0 },
9
- class: { default: void 0 }
9
+ class: { default: void 0 },
10
+ anchorReference: { default: void 0 },
11
+ anchorAs: { default: void 0 },
12
+ anchorAsChild: {
13
+ type: Boolean,
14
+ default: false
15
+ },
16
+ displayValue: {
17
+ type: Function,
18
+ default: void 0
19
+ },
20
+ modelValue: { default: void 0 },
21
+ autoFocus: {
22
+ type: Boolean,
23
+ default: false
24
+ },
25
+ disabled: {
26
+ type: Boolean,
27
+ default: void 0
28
+ },
29
+ as: { default: void 0 },
30
+ asChild: {
31
+ type: Boolean,
32
+ default: false
33
+ },
34
+ triggerDisabled: {
35
+ type: Boolean,
36
+ default: void 0
37
+ },
38
+ triggerAs: { default: void 0 },
39
+ triggerAsChild: {
40
+ type: Boolean,
41
+ default: false
42
+ },
43
+ cancelAs: { default: void 0 },
44
+ cancelAsChild: {
45
+ type: Boolean,
46
+ default: false
47
+ }
10
48
  },
11
- setup(__props) {
49
+ emits: ["update:modelValue"],
50
+ setup(__props, { emit: __emit }) {
12
51
  const props = __props;
52
+ const emit = __emit;
13
53
  const ctx = useComboBoxInject();
14
54
  return (_ctx, _cache) => {
15
55
  return openBlock(), createBlock(unref(ComboboxAnchor), {
56
+ reference: props.anchorReference,
57
+ as: props.anchorAs,
58
+ "as-child": props.anchorAsChild,
16
59
  class: normalizeClass(unref(ctx).slots.value.inputGroup()),
17
60
  "data-slot": "input-group"
18
61
  }, {
19
62
  default: withCtx(() => [
20
63
  createVNode(unref(ComboboxInput), {
21
64
  placeholder: props.placeholder,
22
- disabled: unref(ctx).isDisabled.value,
23
- "display-value": unref(ctx).displayValue.value,
65
+ "model-value": props.modelValue,
66
+ "auto-focus": props.autoFocus,
67
+ disabled: props.disabled ?? unref(ctx).isDisabled.value,
68
+ "display-value": props.displayValue ?? unref(ctx).displayValue.value,
69
+ as: props.as,
70
+ "as-child": props.asChild,
24
71
  class: "combo-box__input",
25
72
  "data-slot": "input",
26
- autocomplete: "off"
73
+ autocomplete: "off",
74
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => emit("update:modelValue", $event))
27
75
  }, null, 8, [
28
76
  "placeholder",
77
+ "model-value",
78
+ "auto-focus",
29
79
  "disabled",
30
- "display-value"
80
+ "display-value",
81
+ "as",
82
+ "as-child"
31
83
  ]),
32
84
  createVNode(unref(ComboboxCancel), {
85
+ as: props.cancelAs,
86
+ "as-child": props.cancelAsChild,
33
87
  class: "combo-box__clear-button",
34
88
  "data-slot": "clear-button",
35
89
  "aria-label": "Clear"
36
90
  }, {
37
- default: withCtx(() => [renderSlot(_ctx.$slots, "clearIcon", {}, () => [_cache[0] || (_cache[0] = createElementVNode("svg", {
91
+ default: withCtx(() => [renderSlot(_ctx.$slots, "clearIcon", {}, () => [_cache[1] || (_cache[1] = createElementVNode("svg", {
38
92
  xmlns: "http://www.w3.org/2000/svg",
39
93
  width: "10",
40
94
  height: "10",
@@ -57,13 +111,16 @@ var ComboBoxInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
57
111
  y2: "18"
58
112
  })], -1))])]),
59
113
  _: 3
60
- }),
114
+ }, 8, ["as", "as-child"]),
61
115
  createVNode(unref(ComboboxTrigger), {
116
+ disabled: props.triggerDisabled,
117
+ as: props.triggerAs,
118
+ "as-child": props.triggerAsChild,
62
119
  class: normalizeClass(unref(ctx).slots.value.trigger()),
63
120
  "data-slot": "selector-button",
64
121
  "aria-label": "Toggle suggestions"
65
122
  }, {
66
- default: withCtx(() => [renderSlot(_ctx.$slots, "triggerIcon", {}, () => [_cache[1] || (_cache[1] = createElementVNode("svg", {
123
+ default: withCtx(() => [renderSlot(_ctx.$slots, "triggerIcon", {}, () => [_cache[2] || (_cache[2] = createElementVNode("svg", {
67
124
  xmlns: "http://www.w3.org/2000/svg",
68
125
  width: "16",
69
126
  height: "16",
@@ -77,10 +134,20 @@ var ComboBoxInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
77
134
  "aria-hidden": "true"
78
135
  }, [createElementVNode("polyline", { points: "6 9 12 15 18 9" })], -1))])]),
79
136
  _: 3
80
- }, 8, ["class"])
137
+ }, 8, [
138
+ "disabled",
139
+ "as",
140
+ "as-child",
141
+ "class"
142
+ ])
81
143
  ]),
82
144
  _: 3
83
- }, 8, ["class"]);
145
+ }, 8, [
146
+ "reference",
147
+ "as",
148
+ "as-child",
149
+ "class"
150
+ ]);
84
151
  };
85
152
  }
86
153
  });
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxInput.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxAnchor, ComboboxInput, ComboboxTrigger, ComboboxCancel } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n placeholder?: string\n class?: string\n}>(), {\n placeholder: undefined,\n class: undefined,\n})\n\nconst ctx = useComboBoxInject()\n</script>\n\n<template>\n <ComboboxAnchor\n :class=\"ctx.slots.value.inputGroup()\"\n data-slot=\"input-group\"\n >\n <ComboboxInput\n :placeholder=\"props.placeholder\"\n :disabled=\"ctx.isDisabled.value\"\n :display-value=\"ctx.displayValue.value\"\n class=\"combo-box__input\"\n data-slot=\"input\"\n autocomplete=\"off\"\n />\n <!-- Clear button: shown when there's input -->\n <ComboboxCancel\n class=\"combo-box__clear-button\"\n data-slot=\"clear-button\"\n aria-label=\"Clear\"\n >\n <slot name=\"clearIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\"\n height=\"10\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n aria-hidden=\"true\"\n >\n <line\n x1=\"18\"\n y1=\"6\"\n x2=\"6\"\n y2=\"18\"\n />\n <line\n x1=\"6\"\n y1=\"6\"\n x2=\"18\"\n y2=\"18\"\n />\n </svg>\n </slot>\n </ComboboxCancel>\n <!-- Dropdown trigger -->\n <ComboboxTrigger\n :class=\"ctx.slots.value.trigger()\"\n data-slot=\"selector-button\"\n aria-label=\"Toggle suggestions\"\n >\n <slot name=\"triggerIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"combo-box-trigger-default-icon\"\n aria-hidden=\"true\"\n >\n <polyline points=\"6 9 12 15 18 9\" />\n </svg>\n </slot>\n </ComboboxTrigger>\n </ComboboxAnchor>\n</template>\n"],"mappings":";;;;;;;;;;;EAIA,MAAM,QAAQ;EAQd,MAAM,MAAM,mBAAkB;;uBAI5B,YAsEiB,MAAA,eAAA,EAAA;IArEd,OAAK,eAAE,MAAA,IAAG,CAAC,MAAM,MAAM,YAAU,CAAA;IAClC,aAAU;;2BASR;KAPF,YAOE,MAAA,cAAA,EAAA;MANC,aAAa,MAAM;MACnB,UAAU,MAAA,IAAG,CAAC,WAAW;MACzB,iBAAe,MAAA,IAAG,CAAC,aAAa;MACjC,OAAM;MACN,aAAU;MACV,cAAa;;;;;;KAGf,YAgCiB,MAAA,eAAA,EAAA;MA/Bf,OAAM;MACN,aAAU;MACV,cAAW;;6BA4BJ,CA1BP,WA0BO,KAAA,QAAA,aAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAzBL,mBAwBM,OAAA;OAvBJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,eAAY;UAEZ,mBAKE,QAAA;OAJA,IAAG;OACH,IAAG;OACH,IAAG;OACH,IAAG;UAEL,mBAKE,QAAA;OAJA,IAAG;OACH,IAAG;OACH,IAAG;OACH,IAAG;;;;KAMX,YAsBkB,MAAA,gBAAA,EAAA;MArBf,OAAK,eAAE,MAAA,IAAG,CAAC,MAAM,MAAM,SAAO,CAAA;MAC/B,aAAU;MACV,cAAW;;6BAkBJ,CAhBP,WAgBO,KAAA,QAAA,eAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAfL,mBAcM,OAAA;OAbJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,aAAU;OACV,eAAY;UAEZ,mBAAoC,YAAA,EAA1B,QAAO,kBAAgB,CAAA,CAAA,EAAA,GAAA,EAAA,CAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"ComboBoxInput.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ComboboxAnchor, ComboboxInput, ComboboxTrigger, ComboboxCancel } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n placeholder?: string\n class?: string\n /** Custom reference element for the anchor. */\n anchorReference?: object | null\n /** Render the anchor as a different element. */\n anchorAs?: string\n /** Merge anchor props onto child element. */\n anchorAsChild?: boolean\n /** Function to compute the display value from the current model value. */\n displayValue?: (value: string) => string\n /** Two-way bound search input value. */\n modelValue?: string\n /** Auto-focus the input on mount. */\n autoFocus?: boolean\n /** Disable the input. Falls back to context isDisabled. */\n disabled?: boolean\n /** Render the input as a different element. */\n as?: string\n /** Merge input props onto child element. */\n asChild?: boolean\n /** Disable the trigger button. */\n triggerDisabled?: boolean\n /** Render the trigger as a different element. */\n triggerAs?: string\n /** Merge trigger props onto child element. */\n triggerAsChild?: boolean\n /** Render the cancel button as a different element. */\n cancelAs?: string\n /** Merge cancel props onto child element. */\n cancelAsChild?: boolean\n}>(), {\n placeholder: undefined,\n class: undefined,\n anchorReference: undefined,\n anchorAs: undefined,\n anchorAsChild: false,\n displayValue: undefined,\n modelValue: undefined,\n autoFocus: false,\n disabled: undefined,\n as: undefined,\n asChild: false,\n triggerDisabled: undefined,\n triggerAs: undefined,\n triggerAsChild: false,\n cancelAs: undefined,\n cancelAsChild: false,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst ctx = useComboBoxInject()\n</script>\n\n<template>\n <ComboboxAnchor\n :reference=\"(props.anchorReference as any)\"\n :as=\"props.anchorAs\"\n :as-child=\"props.anchorAsChild\"\n :class=\"ctx.slots.value.inputGroup()\"\n data-slot=\"input-group\"\n >\n <ComboboxInput\n :placeholder=\"props.placeholder\"\n :model-value=\"props.modelValue\"\n :auto-focus=\"props.autoFocus\"\n :disabled=\"props.disabled ?? ctx.isDisabled.value\"\n :display-value=\"props.displayValue ?? ctx.displayValue.value\"\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n class=\"combo-box__input\"\n data-slot=\"input\"\n autocomplete=\"off\"\n @update:model-value=\"emit('update:modelValue', $event)\"\n />\n <!-- Clear button: shown when there's input -->\n <ComboboxCancel\n :as=\"props.cancelAs\"\n :as-child=\"props.cancelAsChild\"\n class=\"combo-box__clear-button\"\n data-slot=\"clear-button\"\n aria-label=\"Clear\"\n >\n <slot name=\"clearIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\"\n height=\"10\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n aria-hidden=\"true\"\n >\n <line\n x1=\"18\"\n y1=\"6\"\n x2=\"6\"\n y2=\"18\"\n />\n <line\n x1=\"6\"\n y1=\"6\"\n x2=\"18\"\n y2=\"18\"\n />\n </svg>\n </slot>\n </ComboboxCancel>\n <!-- Dropdown trigger -->\n <ComboboxTrigger\n :disabled=\"props.triggerDisabled\"\n :as=\"props.triggerAs\"\n :as-child=\"props.triggerAsChild\"\n :class=\"ctx.slots.value.trigger()\"\n data-slot=\"selector-button\"\n aria-label=\"Toggle suggestions\"\n >\n <slot name=\"triggerIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"combo-box-trigger-default-icon\"\n aria-hidden=\"true\"\n >\n <polyline points=\"6 9 12 15 18 9\" />\n </svg>\n </slot>\n </ComboboxTrigger>\n </ComboboxAnchor>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAIA,MAAM,QAAQ;EAkDd,MAAM,OAAO;EAIb,MAAM,MAAM,mBAAkB;;uBAI5B,YAmFiB,MAAA,eAAA,EAAA;IAlFd,WAAY,MAAM;IAClB,IAAI,MAAM;IACV,YAAU,MAAM;IAChB,OAAK,eAAE,MAAA,IAAG,CAAC,MAAM,MAAM,YAAU,CAAA;IAClC,aAAU;;2BAcR;KAZF,YAYE,MAAA,cAAA,EAAA;MAXC,aAAa,MAAM;MACnB,eAAa,MAAM;MACnB,cAAY,MAAM;MAClB,UAAU,MAAM,YAAY,MAAA,IAAG,CAAC,WAAW;MAC3C,iBAAe,MAAM,gBAAgB,MAAA,IAAG,CAAC,aAAa;MACtD,IAAI,MAAM;MACV,YAAU,MAAM;MACjB,OAAM;MACN,aAAU;MACV,cAAa;MACZ,uBAAkB,OAAA,OAAA,OAAA,MAAA,WAAE,KAAI,qBAAsB,OAAM;;;;;;;;;;KAGvD,YAkCiB,MAAA,eAAA,EAAA;MAjCd,IAAI,MAAM;MACV,YAAU,MAAM;MACjB,OAAM;MACN,aAAU;MACV,cAAW;;6BA4BJ,CA1BP,WA0BO,KAAA,QAAA,aAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAzBL,mBAwBM,OAAA;OAvBJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,eAAY;UAEZ,mBAKE,QAAA;OAJA,IAAG;OACH,IAAG;OACH,IAAG;OACH,IAAG;UAEL,mBAKE,QAAA;OAJA,IAAG;OACH,IAAG;OACH,IAAG;OACH,IAAG;;;;KAMX,YAyBkB,MAAA,gBAAA,EAAA;MAxBf,UAAU,MAAM;MAChB,IAAI,MAAM;MACV,YAAU,MAAM;MAChB,OAAK,eAAE,MAAA,IAAG,CAAC,MAAM,MAAM,SAAO,CAAA;MAC/B,aAAU;MACV,cAAW;;6BAkBJ,CAhBP,WAgBO,KAAA,QAAA,eAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAfL,mBAcM,OAAA;OAbJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,aAAU;OACV,eAAY;UAEZ,mBAAoC,YAAA,EAA1B,QAAO,kBAAgB,CAAA,CAAA,EAAA,GAAA,EAAA,CAAA,CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxItem.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, useSlots, type Slots, type VNode } from 'vue'\nimport { ComboboxItem, ComboboxItemIndicator } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n value: string\n isDisabled?: boolean\n class?: string\n}>(), {\n isDisabled: false,\n class: undefined,\n})\n\nconst slots: Slots = useSlots()\nconst ctx = useComboBoxInject()\n\n// Extract plain text from default slot VNodes at render time.\nfunction extractText(nodes: VNode[]): string {\n return nodes.map(n => {\n if (typeof n.children === 'string') return n.children\n if (Array.isArray(n.children)) return extractText(n.children as VNode[])\n return ''\n }).join('')\n}\n\n// The display text Reka writes into the input when this item is selected.\n// Reads slot text content — no extra props needed.\nconst displayText = computed((): string => {\n const vnodes: VNode[] | undefined = (slots.default as (() => VNode[]) | undefined)?.()\n if (!vnodes) return props.value\n return extractText(vnodes).trim() || props.value\n})\n\n// Register this item's value→label mapping with the parent ComboBox bridge\n// so displayValue() and handleModelValueUpdate() can translate correctly.\nonMounted(() => {\n ctx.registerItem(props.value, displayText.value)\n})\n\nonUnmounted(() => {\n ctx.unregisterItem(props.value)\n})\n</script>\n\n<template>\n <ComboboxItem\n :value=\"displayText\"\n :text-value=\"displayText\"\n :disabled=\"props.isDisabled\"\n :data-item-value=\"props.value\"\n class=\"list-box-item list-box-item--default\"\n data-slot=\"list-box-item\"\n >\n <slot name=\"startContent\" />\n <slot />\n <ComboboxItemIndicator\n class=\"list-box-item__indicator\"\n data-slot=\"list-box-item-indicator\"\n >\n <slot name=\"selectedIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"3\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"list-box-item-indicator--checkmark\"\n aria-hidden=\"true\"\n >\n <polyline points=\"20 6 9 17 4 12\" />\n </svg>\n </slot>\n </ComboboxItemIndicator>\n <slot name=\"endContent\" />\n </ComboboxItem>\n</template>\n"],"mappings":""}
1
+ {"version":3,"file":"ComboBoxItem.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, useSlots, type Slots, type VNode } from 'vue'\nimport { ComboboxItem, ComboboxItemIndicator } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n value: string\n isDisabled?: boolean\n class?: string\n /** A string value for typeahead matching. Defaults to display text. */\n textValue?: string\n /** Whether the item is disabled. Alias for isDisabled. */\n disabled?: boolean\n /** Render as a different element or component. */\n as?: string\n /** Merge props onto child element instead of rendering a wrapper. */\n asChild?: boolean\n /** Render the ComboboxItemIndicator as a different element. */\n indicatorAs?: string\n /** Merge indicator props onto child element. */\n indicatorAsChild?: boolean\n}>(), {\n isDisabled: false,\n class: undefined,\n textValue: undefined,\n disabled: undefined,\n as: undefined,\n asChild: false,\n indicatorAs: undefined,\n indicatorAsChild: false,\n})\n\nconst emit = defineEmits<{\n 'select': [event: Event]\n}>()\n\nconst slots: Slots = useSlots()\nconst ctx = useComboBoxInject()\n\n// Extract plain text from default slot VNodes at render time.\nfunction extractText(nodes: VNode[]): string {\n return nodes.map(n => {\n if (typeof n.children === 'string') return n.children\n if (Array.isArray(n.children)) return extractText(n.children as VNode[])\n return ''\n }).join('')\n}\n\n// The display text Reka writes into the input when this item is selected.\n// Reads slot text content — no extra props needed.\nconst displayText = computed((): string => {\n const vnodes: VNode[] | undefined = (slots.default as (() => VNode[]) | undefined)?.()\n if (!vnodes) return props.value\n return extractText(vnodes).trim() || props.value\n})\n\n// Register this item's value→label mapping with the parent ComboBox bridge\n// so displayValue() and handleModelValueUpdate() can translate correctly.\nonMounted(() => {\n ctx.registerItem(props.value, displayText.value)\n})\n\nonUnmounted(() => {\n ctx.unregisterItem(props.value)\n})\n</script>\n\n<template>\n <ComboboxItem\n :value=\"displayText\"\n :text-value=\"props.textValue ?? displayText\"\n :disabled=\"props.disabled ?? props.isDisabled\"\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n :data-item-value=\"props.value\"\n class=\"list-box-item list-box-item--default\"\n data-slot=\"list-box-item\"\n @select=\"emit('select', $event)\"\n >\n <slot name=\"startContent\" />\n <slot />\n <ComboboxItemIndicator\n :as=\"props.indicatorAs\"\n :as-child=\"props.indicatorAsChild\"\n class=\"list-box-item__indicator\"\n data-slot=\"list-box-item-indicator\"\n >\n <slot name=\"selectedIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"3\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"list-box-item-indicator--checkmark\"\n aria-hidden=\"true\"\n >\n <polyline points=\"20 6 9 17 4 12\" />\n </svg>\n </slot>\n </ComboboxItemIndicator>\n <slot name=\"endContent\" />\n </ComboboxItem>\n</template>\n"],"mappings":""}
@@ -10,10 +10,27 @@ var ComboBoxItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ d
10
10
  type: Boolean,
11
11
  default: false
12
12
  },
13
- class: { default: void 0 }
13
+ class: { default: void 0 },
14
+ textValue: { default: void 0 },
15
+ disabled: {
16
+ type: Boolean,
17
+ default: void 0
18
+ },
19
+ as: { default: void 0 },
20
+ asChild: {
21
+ type: Boolean,
22
+ default: false
23
+ },
24
+ indicatorAs: { default: void 0 },
25
+ indicatorAsChild: {
26
+ type: Boolean,
27
+ default: false
28
+ }
14
29
  },
15
- setup(__props) {
30
+ emits: ["select"],
31
+ setup(__props, { emit: __emit }) {
16
32
  const props = __props;
33
+ const emit = __emit;
17
34
  const slots = useSlots();
18
35
  const ctx = useComboBoxInject();
19
36
  function extractText(nodes) {
@@ -37,20 +54,25 @@ var ComboBoxItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ d
37
54
  return (_ctx, _cache) => {
38
55
  return openBlock(), createBlock(unref(ComboboxItem), {
39
56
  value: displayText.value,
40
- "text-value": displayText.value,
41
- disabled: props.isDisabled,
57
+ "text-value": props.textValue ?? displayText.value,
58
+ disabled: props.disabled ?? props.isDisabled,
59
+ as: props.as,
60
+ "as-child": props.asChild,
42
61
  "data-item-value": props.value,
43
62
  class: "list-box-item list-box-item--default",
44
- "data-slot": "list-box-item"
63
+ "data-slot": "list-box-item",
64
+ onSelect: _cache[0] || (_cache[0] = ($event) => emit("select", $event))
45
65
  }, {
46
66
  default: withCtx(() => [
47
67
  renderSlot(_ctx.$slots, "startContent"),
48
68
  renderSlot(_ctx.$slots, "default"),
49
69
  createVNode(unref(ComboboxItemIndicator), {
70
+ as: props.indicatorAs,
71
+ "as-child": props.indicatorAsChild,
50
72
  class: "list-box-item__indicator",
51
73
  "data-slot": "list-box-item-indicator"
52
74
  }, {
53
- default: withCtx(() => [renderSlot(_ctx.$slots, "selectedIcon", {}, () => [_cache[0] || (_cache[0] = createElementVNode("svg", {
75
+ default: withCtx(() => [renderSlot(_ctx.$slots, "selectedIcon", {}, () => [_cache[1] || (_cache[1] = createElementVNode("svg", {
54
76
  xmlns: "http://www.w3.org/2000/svg",
55
77
  width: "12",
56
78
  height: "12",
@@ -64,7 +86,7 @@ var ComboBoxItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ d
64
86
  "aria-hidden": "true"
65
87
  }, [createElementVNode("polyline", { points: "20 6 9 17 4 12" })], -1))])]),
66
88
  _: 3
67
- }),
89
+ }, 8, ["as", "as-child"]),
68
90
  renderSlot(_ctx.$slots, "endContent")
69
91
  ]),
70
92
  _: 3
@@ -72,6 +94,8 @@ var ComboBoxItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ d
72
94
  "value",
73
95
  "text-value",
74
96
  "disabled",
97
+ "as",
98
+ "as-child",
75
99
  "data-item-value"
76
100
  ]);
77
101
  };
@@ -1 +1 @@
1
- {"version":3,"file":"ComboBoxItem.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, useSlots, type Slots, type VNode } from 'vue'\nimport { ComboboxItem, ComboboxItemIndicator } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n value: string\n isDisabled?: boolean\n class?: string\n}>(), {\n isDisabled: false,\n class: undefined,\n})\n\nconst slots: Slots = useSlots()\nconst ctx = useComboBoxInject()\n\n// Extract plain text from default slot VNodes at render time.\nfunction extractText(nodes: VNode[]): string {\n return nodes.map(n => {\n if (typeof n.children === 'string') return n.children\n if (Array.isArray(n.children)) return extractText(n.children as VNode[])\n return ''\n }).join('')\n}\n\n// The display text Reka writes into the input when this item is selected.\n// Reads slot text content — no extra props needed.\nconst displayText = computed((): string => {\n const vnodes: VNode[] | undefined = (slots.default as (() => VNode[]) | undefined)?.()\n if (!vnodes) return props.value\n return extractText(vnodes).trim() || props.value\n})\n\n// Register this item's value→label mapping with the parent ComboBox bridge\n// so displayValue() and handleModelValueUpdate() can translate correctly.\nonMounted(() => {\n ctx.registerItem(props.value, displayText.value)\n})\n\nonUnmounted(() => {\n ctx.unregisterItem(props.value)\n})\n</script>\n\n<template>\n <ComboboxItem\n :value=\"displayText\"\n :text-value=\"displayText\"\n :disabled=\"props.isDisabled\"\n :data-item-value=\"props.value\"\n class=\"list-box-item list-box-item--default\"\n data-slot=\"list-box-item\"\n >\n <slot name=\"startContent\" />\n <slot />\n <ComboboxItemIndicator\n class=\"list-box-item__indicator\"\n data-slot=\"list-box-item-indicator\"\n >\n <slot name=\"selectedIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"3\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"list-box-item-indicator--checkmark\"\n aria-hidden=\"true\"\n >\n <polyline points=\"20 6 9 17 4 12\" />\n </svg>\n </slot>\n </ComboboxItemIndicator>\n <slot name=\"endContent\" />\n </ComboboxItem>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;EAKA,MAAM,QAAQ;EASd,MAAM,QAAe,UAAS;EAC9B,MAAM,MAAM,mBAAkB;EAG9B,SAAS,YAAY,OAAwB;AAC3C,UAAO,MAAM,KAAI,MAAK;AACpB,QAAI,OAAO,EAAE,aAAa,SAAU,QAAO,EAAE;AAC7C,QAAI,MAAM,QAAQ,EAAE,SAAS,CAAE,QAAO,YAAY,EAAE,SAAmB;AACvE,WAAO;KACP,CAAC,KAAK,GAAE;;EAKZ,MAAM,cAAc,eAAuB;GACzC,MAAM,SAA+B,MAAM,WAA0C;AACrF,OAAI,CAAC,OAAQ,QAAO,MAAM;AAC1B,UAAO,YAAY,OAAO,CAAC,MAAM,IAAI,MAAM;IAC5C;AAID,kBAAgB;AACd,OAAI,aAAa,MAAM,OAAO,YAAY,MAAK;IAChD;AAED,oBAAkB;AAChB,OAAI,eAAe,MAAM,MAAK;IAC/B;;uBAIC,YAiCe,MAAA,aAAA,EAAA;IAhCZ,OAAO,YAAA;IACP,cAAY,YAAA;IACZ,UAAU,MAAM;IAChB,mBAAiB,MAAM;IACxB,OAAM;IACN,aAAU;;2BAEkB;KAA5B,WAA4B,KAAA,QAAA,eAAA;KAC5B,WAAQ,KAAA,QAAA,UAAA;KACR,YAqBwB,MAAA,sBAAA,EAAA;MApBtB,OAAM;MACN,aAAU;;6BAkBH,CAhBP,WAgBO,KAAA,QAAA,gBAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAfL,mBAcM,OAAA;OAbJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,aAAU;OACV,eAAY;UAEZ,mBAAoC,YAAA,EAA1B,QAAO,kBAAgB,CAAA,CAAA,EAAA,GAAA,EAAA,CAAA,CAAA,CAAA;;;KAIvC,WAA0B,KAAA,QAAA,aAAA"}
1
+ {"version":3,"file":"ComboBoxItem.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/combo-box/ComboBoxItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, onMounted, onUnmounted, useSlots, type Slots, type VNode } from 'vue'\nimport { ComboboxItem, ComboboxItemIndicator } from 'reka-ui'\nimport { useComboBoxInject } from './ComboBox.context'\n\nconst props = withDefaults(defineProps<{\n value: string\n isDisabled?: boolean\n class?: string\n /** A string value for typeahead matching. Defaults to display text. */\n textValue?: string\n /** Whether the item is disabled. Alias for isDisabled. */\n disabled?: boolean\n /** Render as a different element or component. */\n as?: string\n /** Merge props onto child element instead of rendering a wrapper. */\n asChild?: boolean\n /** Render the ComboboxItemIndicator as a different element. */\n indicatorAs?: string\n /** Merge indicator props onto child element. */\n indicatorAsChild?: boolean\n}>(), {\n isDisabled: false,\n class: undefined,\n textValue: undefined,\n disabled: undefined,\n as: undefined,\n asChild: false,\n indicatorAs: undefined,\n indicatorAsChild: false,\n})\n\nconst emit = defineEmits<{\n 'select': [event: Event]\n}>()\n\nconst slots: Slots = useSlots()\nconst ctx = useComboBoxInject()\n\n// Extract plain text from default slot VNodes at render time.\nfunction extractText(nodes: VNode[]): string {\n return nodes.map(n => {\n if (typeof n.children === 'string') return n.children\n if (Array.isArray(n.children)) return extractText(n.children as VNode[])\n return ''\n }).join('')\n}\n\n// The display text Reka writes into the input when this item is selected.\n// Reads slot text content — no extra props needed.\nconst displayText = computed((): string => {\n const vnodes: VNode[] | undefined = (slots.default as (() => VNode[]) | undefined)?.()\n if (!vnodes) return props.value\n return extractText(vnodes).trim() || props.value\n})\n\n// Register this item's value→label mapping with the parent ComboBox bridge\n// so displayValue() and handleModelValueUpdate() can translate correctly.\nonMounted(() => {\n ctx.registerItem(props.value, displayText.value)\n})\n\nonUnmounted(() => {\n ctx.unregisterItem(props.value)\n})\n</script>\n\n<template>\n <ComboboxItem\n :value=\"displayText\"\n :text-value=\"props.textValue ?? displayText\"\n :disabled=\"props.disabled ?? props.isDisabled\"\n :as=\"props.as\"\n :as-child=\"props.asChild\"\n :data-item-value=\"props.value\"\n class=\"list-box-item list-box-item--default\"\n data-slot=\"list-box-item\"\n @select=\"emit('select', $event)\"\n >\n <slot name=\"startContent\" />\n <slot />\n <ComboboxItemIndicator\n :as=\"props.indicatorAs\"\n :as-child=\"props.indicatorAsChild\"\n class=\"list-box-item__indicator\"\n data-slot=\"list-box-item-indicator\"\n >\n <slot name=\"selectedIcon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"3\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n data-slot=\"list-box-item-indicator--checkmark\"\n aria-hidden=\"true\"\n >\n <polyline points=\"20 6 9 17 4 12\" />\n </svg>\n </slot>\n </ComboboxItemIndicator>\n <slot name=\"endContent\" />\n </ComboboxItem>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAKA,MAAM,QAAQ;EA2Bd,MAAM,OAAO;EAIb,MAAM,QAAe,UAAS;EAC9B,MAAM,MAAM,mBAAkB;EAG9B,SAAS,YAAY,OAAwB;AAC3C,UAAO,MAAM,KAAI,MAAK;AACpB,QAAI,OAAO,EAAE,aAAa,SAAU,QAAO,EAAE;AAC7C,QAAI,MAAM,QAAQ,EAAE,SAAS,CAAE,QAAO,YAAY,EAAE,SAAmB;AACvE,WAAO;KACP,CAAC,KAAK,GAAE;;EAKZ,MAAM,cAAc,eAAuB;GACzC,MAAM,SAA+B,MAAM,WAA0C;AACrF,OAAI,CAAC,OAAQ,QAAO,MAAM;AAC1B,UAAO,YAAY,OAAO,CAAC,MAAM,IAAI,MAAM;IAC5C;AAID,kBAAgB;AACd,OAAI,aAAa,MAAM,OAAO,YAAY,MAAK;IAChD;AAED,oBAAkB;AAChB,OAAI,eAAe,MAAM,MAAK;IAC/B;;uBAIC,YAsCe,MAAA,aAAA,EAAA;IArCZ,OAAO,YAAA;IACP,cAAY,MAAM,aAAa,YAAA;IAC/B,UAAU,MAAM,YAAY,MAAM;IAClC,IAAI,MAAM;IACV,YAAU,MAAM;IAChB,mBAAiB,MAAM;IACxB,OAAM;IACN,aAAU;IACT,UAAM,OAAA,OAAA,OAAA,MAAA,WAAE,KAAI,UAAW,OAAM;;2BAEF;KAA5B,WAA4B,KAAA,QAAA,eAAA;KAC5B,WAAQ,KAAA,QAAA,UAAA;KACR,YAuBwB,MAAA,sBAAA,EAAA;MAtBrB,IAAI,MAAM;MACV,YAAU,MAAM;MACjB,OAAM;MACN,aAAU;;6BAkBH,CAhBP,WAgBO,KAAA,QAAA,gBAAA,EAAA,QAAA,CAAA,OAAA,OAAA,OAAA,KAfL,mBAcM,OAAA;OAbJ,OAAM;OACN,OAAM;OACN,QAAO;OACP,SAAQ;OACR,MAAK;OACL,QAAO;OACP,gBAAa;OACb,kBAAe;OACf,mBAAgB;OAChB,aAAU;OACV,eAAY;UAEZ,mBAAoC,YAAA,EAA1B,QAAO,kBAAgB,CAAA,CAAA,EAAA,GAAA,EAAA,CAAA,CAAA,CAAA;;;KAIvC,WAA0B,KAAA,QAAA,aAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"DateInput.js","names":[],"sources":["../../../src/components/date-input/DateInput.vue"],"sourcesContent":["<!--\n DateInput — form-field mirror of Input.vue for @internationalized/date.\n\n Anatomy, data-attributes, floating-label behavior, start/end content\n slots, and a11y wiring all mirror Input.vue. See the Input.vue docblock\n for the canonical contract.\n-->\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, onMounted, ref, useAttrs, useId, watch } from 'vue'\nimport { DateFieldRoot, DateFieldInput } from 'reka-ui'\nimport type { DateValue } from '@internationalized/date'\nimport { dateInputVariants, type DateInputVariants } from '@auronui/styles'\nimport { composeClassName , type ClassValue} from '../../utils/composeClassName'\n\ndefineOptions({ inheritAttrs: false })\n\nconst props = withDefaults(defineProps<Props>(), {\n variant: 'flat',\n size: 'md',\n color: 'default',\n labelPlacement: 'inside',\n fullWidth: false,\n isInvalid: false,\n isDisabled: false,\n isReadOnly: false,\n isRequired: false,\n hideTimeZone: false,\n})\n\nconst modelValue = defineModel<DateValue | null | undefined>()\n\ntype Props = {\n /** Visual style of the field. @default 'flat' */\n variant?: DateInputVariants['variant']\n /** Field height. @default 'md' */\n size?: DateInputVariants['size']\n /** Accent color applied to focus ring + floating label. @default 'default' */\n color?: DateInputVariants['color']\n /** Label placement relative to the field. @default 'inside' */\n labelPlacement?: DateInputVariants['labelPlacement']\n /** Stretches root wrapper to 100% width. @default false */\n fullWidth?: boolean\n /** Marks the field as invalid. @default false */\n isInvalid?: boolean\n /** Disables the field. @default false */\n isDisabled?: boolean\n /** Makes the field read-only. @default false */\n isReadOnly?: boolean\n /** Adds a required asterisk next to the label. @default false */\n isRequired?: boolean\n /** Field label. When omitted, floating-label behavior is skipped. */\n label?: string\n /** Helper text below the field. Suppressed when isInvalid && errorMessage is shown. */\n description?: string\n /** Error text below the field. Only rendered when isInvalid is true. */\n errorMessage?: string\n /** Extra classes merged onto the root wrapper. */\n class?: ClassValue\n /** Per-slot class overrides. */\n classNames?: Partial<{\n base: ClassValue\n label: ClassValue\n mainWrapper: ClassValue\n inputWrapper: ClassValue\n startContent: ClassValue\n segmentList: ClassValue\n segment: ClassValue\n endContent: ClassValue\n helperWrapper: ClassValue\n errorMessage: ClassValue\n description: ClassValue\n }>\n\n /* ─── DateInput-specific ──────────────────────────────────────── */\n defaultValue?: DateValue\n placeholderValue?: DateValue\n minValue?: DateValue\n maxValue?: DateValue\n granularity?: 'day' | 'hour' | 'minute' | 'second'\n hourCycle?: 12 | 24\n locale?: string\n name?: string\n hideTimeZone?: boolean\n}\n\nconst attrs = useAttrs()\nconst generatedId = useId()\nconst fieldId = computed(() => (attrs.id as string | undefined) ?? `${generatedId}-field`)\nconst labelId = computed(() => `${generatedId}-label`)\nconst descriptionId = computed(() => `${generatedId}-description`)\nconst errorMessageId = computed(() => `${generatedId}-error`)\n\nconst hasLabel = computed(() => !!props.label)\nconst isFilled = computed(() => modelValue.value != null)\n\nconst showError = computed(() => props.isInvalid && !!props.errorMessage)\nconst showDescription = computed(() => !!props.description && !showError.value)\nconst hasHelper = computed(() => showError.value || showDescription.value)\nconst ariaDescribedBy = computed(() => {\n if (showError.value) return errorMessageId.value\n if (showDescription.value) return descriptionId.value\n return undefined\n})\n\nconst fieldRef = ref<HTMLElement | null>(null)\n// Reka components expose their root DOM node via $el — unwrap before using DOM APIs.\nconst fieldEl = computed<HTMLElement | null>(() => {\n const r = fieldRef.value as unknown as { $el?: HTMLElement } | HTMLElement | null\n if (!r) return null\n if (r instanceof HTMLElement) return r\n return r.$el ?? null\n})\n\n// `isFocused` tracks focus on a DATE SEGMENT specifically — not any descendant.\n// This prevents nested interactive children (e.g. a DatePickerTrigger button in\n// endContent) from flipping the field into the focused visual state.\nconst isFocused = ref(false)\nfunction updateSegmentFocus() {\n const root = fieldEl.value\n if (!root) { isFocused.value = false; return }\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n isFocused.value = !!active\n && root.contains(active)\n && active.hasAttribute('data-reka-date-field-segment')\n}\nfunction onDocFocusIn() { updateSegmentFocus() }\nfunction onDocFocusOut() { queueMicrotask(updateSegmentFocus) }\n\n// Guard against a focus snap-back after an outside click. When the user\n// clicks outside the field, we mark a short-lived \"suppress segment focus\"\n// window. Any focusin landing on a segment inside that window gets blurred\n// immediately — kills the two-click-to-blur UX regardless of which internal\n// mechanism (Reka VisuallyHidden, label-for, contenteditable selection\n// restoration) tried to restore the focus.\nlet suppressSegmentFocusUntil = 0\nfunction onDocPointerDown(e: PointerEvent) {\n const root = fieldEl.value\n if (!root) return\n const target = e.target as Node | null\n if (!target || root.contains(target)) return\n suppressSegmentFocusUntil = performance.now() + 250\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n if (active && root.contains(active) && active.hasAttribute('data-reka-date-field-segment')) {\n active.blur()\n }\n}\nfunction onDocFocusInGuard(e: FocusEvent) {\n if (performance.now() >= suppressSegmentFocusUntil) return\n const root = fieldEl.value\n if (!root) return\n const t = e.target as HTMLElement | null\n if (t && root.contains(t) && t.hasAttribute?.('data-reka-date-field-segment')) {\n t.blur()\n }\n}\n\nonMounted(() => {\n document.addEventListener('focusin', onDocFocusIn)\n document.addEventListener('focusout', onDocFocusOut)\n document.addEventListener('pointerdown', onDocPointerDown, true)\n document.addEventListener('focusin', onDocFocusInGuard, true)\n})\nonBeforeUnmount(() => {\n document.removeEventListener('focusin', onDocFocusIn)\n document.removeEventListener('focusout', onDocFocusOut)\n document.removeEventListener('pointerdown', onDocPointerDown, true)\n document.removeEventListener('focusin', onDocFocusInGuard, true)\n})\n\n// Track data-filled synchronously from the rendered segments — defaultValue +\n// isFilled from modelValue misses the uncontrolled case and the partially-typed\n// case. After each value/segment render, sniff any non-literal segment that\n// carries data-placeholder=\"false\".\nconst segmentsFilled = ref(false)\nfunction recomputeFilled() {\n const root = fieldEl.value\n if (!root || typeof root.querySelectorAll !== 'function') {\n segmentsFilled.value = false\n return\n }\n const segs = root.querySelectorAll('[data-reka-date-field-segment]:not([data-reka-date-field-segment=\"literal\"])')\n let anyFilled = false\n segs.forEach((el) => {\n if ((el as HTMLElement).dataset.placeholder === 'false') anyFilled = true\n })\n segmentsFilled.value = anyFilled\n}\nwatch([modelValue, () => props.defaultValue, () => props.granularity], () => {\n queueMicrotask(recomputeFilled)\n}, { immediate: true })\n\nconst effectiveFilled = computed(() => isFilled.value || segmentsFilled.value)\n\n// Only intervene on the INITIAL click that enters the field. Once a segment\n// already holds focus, leave subsequent mousedowns alone so the user can\n// blur naturally (clicking elsewhere) without focus snapping back to a\n// segment and requiring a second click.\nfunction handleFieldMousedown(e: MouseEvent) {\n const target = e.target as HTMLElement | null\n if (!target) return\n if (target.closest('[data-reka-date-field-segment]')) return\n if (target.closest('[data-slot=\"start-content\"]')) return\n if (target.closest('[data-slot=\"end-content\"]')) return\n if (target.closest('button, [role=\"button\"]')) return\n const root = fieldEl.value\n if (!root) return\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n if (active && root.contains(active) && active.hasAttribute('data-reka-date-field-segment')) {\n return\n }\n const first = root.querySelector<HTMLElement>(\n '[data-reka-date-field-segment]:not([data-reka-date-field-segment=\"literal\"])',\n )\n if (first) {\n e.preventDefault()\n first.focus()\n }\n}\n\nconst slotFns = computed(() =>\n dateInputVariants({\n variant: props.variant,\n size: props.size,\n color: props.color,\n fullWidth: props.fullWidth,\n isInvalid: props.isInvalid,\n isDisabled: props.isDisabled,\n isReadonly: props.isReadOnly,\n hasLabel: hasLabel.value,\n labelPlacement: props.labelPlacement,\n }),\n)\n\nconst showOutsideLabel = computed(\n () => hasLabel.value && props.labelPlacement !== 'inside',\n)\nconst showInsideLabel = computed(\n () => hasLabel.value && props.labelPlacement === 'inside',\n)\n</script>\n\n<template>\n <div\n :class=\"composeClassName(slotFns.base(), props.class, props.classNames?.base)\"\n :data-invalid=\"isInvalid || undefined\"\n :data-disabled=\"isDisabled || undefined\"\n :data-readonly=\"isReadOnly || undefined\"\n :data-required=\"isRequired || undefined\"\n :data-has-label=\"hasLabel || undefined\"\n :data-has-helper=\"hasHelper || undefined\"\n >\n <label\n v-if=\"showOutsideLabel\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :class=\"composeClassName(slotFns.label(), props.classNames?.label)\"\n >{{ label }}<span\n v-if=\"isRequired\"\n aria-hidden=\"true\"\n > *</span></label>\n\n <div :class=\"composeClassName(slotFns.mainWrapper(), props.classNames?.mainWrapper)\">\n <DateFieldRoot\n :id=\"fieldId\"\n ref=\"fieldRef\"\n v-model=\"modelValue\"\n :default-value=\"defaultValue\"\n :placeholder=\"placeholderValue\"\n :min-value=\"minValue\"\n :max-value=\"maxValue\"\n :granularity=\"granularity\"\n :hour-cycle=\"hourCycle\"\n :locale=\"locale\"\n :disabled=\"isDisabled\"\n :readonly=\"isReadOnly\"\n :name=\"name\"\n :hide-time-zone=\"hideTimeZone\"\n :aria-labelledby=\"hasLabel ? labelId : undefined\"\n :aria-describedby=\"ariaDescribedBy\"\n :aria-required=\"isRequired || undefined\"\n :aria-invalid=\"isInvalid || undefined\"\n :class=\"composeClassName(slotFns.inputWrapper(), props.classNames?.inputWrapper)\"\n :data-filled=\"hasLabel ? (effectiveFilled || undefined) : undefined\"\n :data-focused=\"isFocused || undefined\"\n :data-invalid=\"isInvalid || undefined\"\n :data-disabled=\"isDisabled || undefined\"\n :data-readonly=\"isReadOnly || undefined\"\n @mousedown=\"handleFieldMousedown\"\n >\n <template #default=\"{ segments }\">\n <label\n v-if=\"showInsideLabel\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :class=\"composeClassName(slotFns.label(), props.classNames?.label)\"\n >{{ label }}<span\n v-if=\"isRequired\"\n aria-hidden=\"true\"\n > *</span></label>\n\n <span\n v-if=\"$slots.startContent\"\n :class=\"composeClassName(slotFns.startContent(), props.classNames?.startContent)\"\n data-slot=\"start-content\"\n >\n <slot name=\"startContent\" />\n </span>\n\n <div\n :class=\"composeClassName(slotFns.segmentList(), props.classNames?.segmentList)\"\n data-slot=\"segment-list\"\n >\n <template\n v-for=\"(segment, _i) in segments\"\n :key=\"_i\"\n >\n <DateFieldInput\n :part=\"segment.part\"\n :class=\"composeClassName(slotFns.segment(), props.classNames?.segment)\"\n >\n {{ segment.value }}\n </DateFieldInput>\n </template>\n </div>\n\n <span\n v-if=\"$slots.endContent\"\n :class=\"composeClassName(slotFns.endContent(), props.classNames?.endContent)\"\n data-slot=\"end-content\"\n >\n <slot name=\"endContent\" />\n </span>\n </template>\n </DateFieldRoot>\n\n <div\n v-if=\"hasHelper\"\n :class=\"composeClassName(slotFns.helperWrapper(), props.classNames?.helperWrapper)\"\n >\n <div\n v-if=\"showError\"\n :id=\"errorMessageId\"\n :class=\"composeClassName(slotFns.errorMessage(), props.classNames?.errorMessage)\"\n role=\"alert\"\n >\n {{ errorMessage }}\n </div>\n <div\n v-else-if=\"showDescription\"\n :id=\"descriptionId\"\n :class=\"composeClassName(slotFns.description(), props.classNames?.description)\"\n >\n {{ description }}\n </div>\n </div>\n </div>\n </div>\n</template>\n"],"mappings":""}
1
+ {"version":3,"file":"DateInput.js","names":[],"sources":["../../../src/components/date-input/DateInput.vue"],"sourcesContent":["<!--\n DateInput — form-field mirror of Input.vue for @internationalized/date.\n\n Anatomy, data-attributes, floating-label behavior, start/end content\n slots, and a11y wiring all mirror Input.vue. See the Input.vue docblock\n for the canonical contract.\n-->\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, onMounted, ref, useAttrs, useId, watch } from 'vue'\nimport { DateFieldRoot, DateFieldInput } from 'reka-ui'\nimport type { DateValue } from '@internationalized/date'\n\nimport { dateInputVariants, type DateInputVariants } from '@auronui/styles'\nimport { composeClassName , type ClassValue} from '../../utils/composeClassName'\n\ndefineOptions({ inheritAttrs: false })\n\nconst props = withDefaults(defineProps<Props>(), {\n variant: 'flat',\n size: 'md',\n color: 'default',\n labelPlacement: 'inside',\n fullWidth: false,\n isInvalid: false,\n isDisabled: false,\n isReadOnly: false,\n isRequired: false,\n hideTimeZone: false,\n})\n\nconst modelValue = defineModel<DateValue | null | undefined>()\n\n// Reka treats `undefined` as \"uncontrolled mode\". Passing undefined back causes\n// DateFieldRoot to drop its controlled state mid-type, breaking updates from a\n// ref that starts with a value. Always pass null (= controlled + empty) instead.\nconst rekaValue = computed<DateValue | null>({\n get: () => modelValue.value ?? null,\n set: (val: DateValue | null) => { modelValue.value = val ?? null },\n})\n\ntype Props = {\n /** Visual style of the field. @default 'flat' */\n variant?: DateInputVariants['variant']\n /** Field height. @default 'md' */\n size?: DateInputVariants['size']\n /** Accent color applied to focus ring + floating label. @default 'default' */\n color?: DateInputVariants['color']\n /** Label placement relative to the field. @default 'inside' */\n labelPlacement?: DateInputVariants['labelPlacement']\n /** Stretches root wrapper to 100% width. @default false */\n fullWidth?: boolean\n /** Marks the field as invalid. @default false */\n isInvalid?: boolean\n /** Disables the field. @default false */\n isDisabled?: boolean\n /** Makes the field read-only. @default false */\n isReadOnly?: boolean\n /** Adds a required asterisk next to the label. @default false */\n isRequired?: boolean\n /** Field label. When omitted, floating-label behavior is skipped. */\n label?: string\n /** Helper text below the field. Suppressed when isInvalid && errorMessage is shown. */\n description?: string\n /** Error text below the field. Only rendered when isInvalid is true. */\n errorMessage?: string\n /** Extra classes merged onto the root wrapper. */\n class?: ClassValue\n /** Per-slot class overrides. */\n classNames?: Partial<{\n base: ClassValue\n label: ClassValue\n mainWrapper: ClassValue\n inputWrapper: ClassValue\n startContent: ClassValue\n segmentList: ClassValue\n segment: ClassValue\n endContent: ClassValue\n helperWrapper: ClassValue\n errorMessage: ClassValue\n description: ClassValue\n }>\n\n /* ─── DateInput-specific ──────────────────────────────────────── */\n defaultValue?: DateValue\n defaultPlaceholder?: DateValue\n placeholderValue?: DateValue\n minValue?: DateValue\n maxValue?: DateValue\n granularity?: 'day' | 'hour' | 'minute' | 'second'\n hourCycle?: 12 | 24\n /** Steps for segment keyboard navigation. */\n step?: Partial<Record<'hour' | 'minute' | 'second' | 'millisecond', number>>\n locale?: string\n name?: string\n hideTimeZone?: boolean\n isDateUnavailable?: (date: DateValue) => boolean\n /** Marks the field as required for form submission. */\n required?: boolean\n /** Text direction for the field. */\n dir?: 'ltr' | 'rtl'\n /** Render as a different element or component. */\n as?: string\n /** Render child as root element. */\n asChild?: boolean\n}\n\nconst attrs = useAttrs()\nconst generatedId = useId()\nconst fieldId = computed(() => (attrs.id as string | undefined) ?? `${generatedId}-field`)\nconst labelId = computed(() => `${generatedId}-label`)\nconst descriptionId = computed(() => `${generatedId}-description`)\nconst errorMessageId = computed(() => `${generatedId}-error`)\n\nconst hasLabel = computed(() => !!props.label)\nconst isFilled = computed(() => modelValue.value != null)\n\nconst showError = computed(() => props.isInvalid && !!props.errorMessage)\nconst showDescription = computed(() => !!props.description && !showError.value)\nconst hasHelper = computed(() => showError.value || showDescription.value)\nconst ariaDescribedBy = computed(() => {\n if (showError.value) return errorMessageId.value\n if (showDescription.value) return descriptionId.value\n return undefined\n})\n\nconst fieldRef = ref<HTMLElement | null>(null)\n// Reka components expose their root DOM node via $el — unwrap before using DOM APIs.\nconst fieldEl = computed<HTMLElement | null>(() => {\n const r = fieldRef.value as unknown as { $el?: HTMLElement } | HTMLElement | null\n if (!r) return null\n if (r instanceof HTMLElement) return r\n return r.$el ?? null\n})\n\n// `isFocused` tracks focus on a DATE SEGMENT specifically — not any descendant.\n// This prevents nested interactive children (e.g. a DatePickerTrigger button in\n// endContent) from flipping the field into the focused visual state.\nconst isFocused = ref(false)\nfunction updateSegmentFocus() {\n const root = fieldEl.value\n if (!root) { isFocused.value = false; return }\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n isFocused.value = !!active\n && root.contains(active)\n && active.hasAttribute('data-reka-date-field-segment')\n}\nfunction onDocFocusIn() { updateSegmentFocus() }\nfunction onDocFocusOut() { queueMicrotask(updateSegmentFocus) }\n\n// Guard against a focus snap-back after an outside click. When the user\n// clicks outside the field, we mark a short-lived \"suppress segment focus\"\n// window. Any focusin landing on a segment inside that window gets blurred\n// immediately — kills the two-click-to-blur UX regardless of which internal\n// mechanism (Reka VisuallyHidden, label-for, contenteditable selection\n// restoration) tried to restore the focus.\nlet suppressSegmentFocusUntil = 0\nfunction onDocPointerDown(e: PointerEvent) {\n const root = fieldEl.value\n if (!root) return\n const target = e.target as Node | null\n if (!target || root.contains(target)) return\n suppressSegmentFocusUntil = performance.now() + 250\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n if (active && root.contains(active) && active.hasAttribute('data-reka-date-field-segment')) {\n active.blur()\n }\n}\nfunction onDocFocusInGuard(e: FocusEvent) {\n if (performance.now() >= suppressSegmentFocusUntil) return\n const root = fieldEl.value\n if (!root) return\n const t = e.target as HTMLElement | null\n if (t && root.contains(t) && t.hasAttribute?.('data-reka-date-field-segment')) {\n t.blur()\n }\n}\n\nonMounted(() => {\n document.addEventListener('focusin', onDocFocusIn)\n document.addEventListener('focusout', onDocFocusOut)\n document.addEventListener('pointerdown', onDocPointerDown, true)\n document.addEventListener('focusin', onDocFocusInGuard, true)\n})\nonBeforeUnmount(() => {\n document.removeEventListener('focusin', onDocFocusIn)\n document.removeEventListener('focusout', onDocFocusOut)\n document.removeEventListener('pointerdown', onDocPointerDown, true)\n document.removeEventListener('focusin', onDocFocusInGuard, true)\n})\n\n// Track data-filled synchronously from the rendered segments — defaultValue +\n// isFilled from modelValue misses the uncontrolled case and the partially-typed\n// case. After each value/segment render, sniff any non-literal segment that\n// carries data-placeholder=\"false\".\nconst segmentsFilled = ref(false)\nfunction recomputeFilled() {\n const root = fieldEl.value\n if (!root || typeof root.querySelectorAll !== 'function') {\n segmentsFilled.value = false\n return\n }\n const segs = root.querySelectorAll('[data-reka-date-field-segment]:not([data-reka-date-field-segment=\"literal\"])')\n let anyFilled = false\n segs.forEach((el) => {\n if ((el as HTMLElement).dataset.placeholder === 'false') anyFilled = true\n })\n segmentsFilled.value = anyFilled\n}\nwatch([modelValue, () => props.defaultValue, () => props.granularity], () => {\n queueMicrotask(recomputeFilled)\n}, { immediate: true })\n\nconst effectiveFilled = computed(() => isFilled.value || segmentsFilled.value)\n\n// Only intervene on the INITIAL click that enters the field. Once a segment\n// already holds focus, leave subsequent mousedowns alone so the user can\n// blur naturally (clicking elsewhere) without focus snapping back to a\n// segment and requiring a second click.\nfunction handleFieldMousedown(e: MouseEvent) {\n const target = e.target as HTMLElement | null\n if (!target) return\n if (target.closest('[data-reka-date-field-segment]')) return\n if (target.closest('[data-slot=\"start-content\"]')) return\n if (target.closest('[data-slot=\"end-content\"]')) return\n if (target.closest('button, [role=\"button\"]')) return\n const root = fieldEl.value\n if (!root) return\n const active = (root.ownerDocument ?? document).activeElement as HTMLElement | null\n if (active && root.contains(active) && active.hasAttribute('data-reka-date-field-segment')) {\n return\n }\n const first = root.querySelector<HTMLElement>(\n '[data-reka-date-field-segment]:not([data-reka-date-field-segment=\"literal\"])',\n )\n if (first) {\n e.preventDefault()\n first.focus()\n }\n}\n\nconst slotFns = computed(() =>\n dateInputVariants({\n variant: props.variant,\n size: props.size,\n color: props.color,\n fullWidth: props.fullWidth,\n isInvalid: props.isInvalid,\n isDisabled: props.isDisabled,\n isReadonly: props.isReadOnly,\n hasLabel: hasLabel.value,\n labelPlacement: props.labelPlacement,\n }),\n)\n\nconst showOutsideLabel = computed(\n () => hasLabel.value && props.labelPlacement !== 'inside',\n)\nconst showInsideLabel = computed(\n () => hasLabel.value && props.labelPlacement === 'inside',\n)\n</script>\n\n<template>\n <div\n :class=\"composeClassName(slotFns.base(), props.class, props.classNames?.base)\"\n :data-invalid=\"isInvalid || undefined\"\n :data-disabled=\"isDisabled || undefined\"\n :data-readonly=\"isReadOnly || undefined\"\n :data-required=\"isRequired || undefined\"\n :data-has-label=\"hasLabel || undefined\"\n :data-has-helper=\"hasHelper || undefined\"\n >\n <label\n v-if=\"showOutsideLabel\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :class=\"composeClassName(slotFns.label(), props.classNames?.label)\"\n >{{ label }}<span\n v-if=\"isRequired\"\n aria-hidden=\"true\"\n > *</span></label>\n\n <div :class=\"composeClassName(slotFns.mainWrapper(), props.classNames?.mainWrapper)\">\n <DateFieldRoot\n :id=\"fieldId\"\n ref=\"fieldRef\"\n v-model=\"rekaValue\"\n :default-value=\"defaultValue\"\n :default-placeholder=\"defaultPlaceholder\"\n :placeholder=\"placeholderValue\"\n :min-value=\"minValue\"\n :max-value=\"maxValue\"\n :granularity=\"granularity\"\n :hour-cycle=\"hourCycle\"\n :step=\"step\"\n :locale=\"locale\"\n :disabled=\"isDisabled\"\n :readonly=\"isReadOnly\"\n :name=\"name\"\n :hide-time-zone=\"hideTimeZone\"\n :is-date-unavailable=\"isDateUnavailable\"\n :required=\"required\"\n :dir=\"dir\"\n :as=\"as\"\n :as-child=\"asChild\"\n :aria-labelledby=\"hasLabel ? labelId : undefined\"\n :aria-describedby=\"ariaDescribedBy\"\n :aria-required=\"isRequired || undefined\"\n :aria-invalid=\"isInvalid || undefined\"\n :class=\"composeClassName(slotFns.inputWrapper(), props.classNames?.inputWrapper)\"\n :data-filled=\"hasLabel ? (effectiveFilled || undefined) : undefined\"\n :data-focused=\"isFocused || undefined\"\n :data-invalid=\"isInvalid || undefined\"\n :data-disabled=\"isDisabled || undefined\"\n :data-readonly=\"isReadOnly || undefined\"\n @mousedown=\"handleFieldMousedown\"\n >\n <template #default=\"{ segments }\">\n <label\n v-if=\"showInsideLabel\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :class=\"composeClassName(slotFns.label(), props.classNames?.label)\"\n >{{ label }}<span\n v-if=\"isRequired\"\n aria-hidden=\"true\"\n > *</span></label>\n\n <span\n v-if=\"$slots.startContent\"\n :class=\"composeClassName(slotFns.startContent(), props.classNames?.startContent)\"\n data-slot=\"start-content\"\n >\n <slot name=\"startContent\" />\n </span>\n\n <div\n :class=\"composeClassName(slotFns.segmentList(), props.classNames?.segmentList)\"\n data-slot=\"segment-list\"\n >\n <template\n v-for=\"(segment, _i) in segments\"\n :key=\"_i\"\n >\n <DateFieldInput\n :part=\"segment.part\"\n :class=\"composeClassName(slotFns.segment(), props.classNames?.segment)\"\n >\n {{ segment.value }}\n </DateFieldInput>\n </template>\n </div>\n\n <span\n v-if=\"$slots.endContent\"\n :class=\"composeClassName(slotFns.endContent(), props.classNames?.endContent)\"\n data-slot=\"end-content\"\n >\n <slot name=\"endContent\" />\n </span>\n </template>\n </DateFieldRoot>\n\n <div\n v-if=\"hasHelper\"\n :class=\"composeClassName(slotFns.helperWrapper(), props.classNames?.helperWrapper)\"\n >\n <div\n v-if=\"showError\"\n :id=\"errorMessageId\"\n :class=\"composeClassName(slotFns.errorMessage(), props.classNames?.errorMessage)\"\n role=\"alert\"\n >\n {{ errorMessage }}\n </div>\n <div\n v-else-if=\"showDescription\"\n :id=\"descriptionId\"\n :class=\"composeClassName(slotFns.description(), props.classNames?.description)\"\n >\n {{ description }}\n </div>\n </div>\n </div>\n </div>\n</template>\n"],"mappings":""}
@@ -63,17 +63,24 @@ var DateInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
63
63
  ] },
64
64
  classNames: {},
65
65
  defaultValue: {},
66
+ defaultPlaceholder: {},
66
67
  placeholderValue: {},
67
68
  minValue: {},
68
69
  maxValue: {},
69
70
  granularity: {},
70
71
  hourCycle: {},
72
+ step: {},
71
73
  locale: {},
72
74
  name: {},
73
75
  hideTimeZone: {
74
76
  type: Boolean,
75
77
  default: false
76
- }
78
+ },
79
+ isDateUnavailable: {},
80
+ required: { type: Boolean },
81
+ dir: {},
82
+ as: {},
83
+ asChild: { type: Boolean }
77
84
  }, {
78
85
  "modelValue": {},
79
86
  "modelModifiers": {}
@@ -82,6 +89,12 @@ var DateInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
82
89
  setup(__props) {
83
90
  const props = __props;
84
91
  const modelValue = useModel(__props, "modelValue");
92
+ const rekaValue = computed({
93
+ get: () => modelValue.value ?? null,
94
+ set: (val) => {
95
+ modelValue.value = val ?? null;
96
+ }
97
+ });
85
98
  const attrs = useAttrs();
86
99
  const generatedId = useId();
87
100
  const fieldId = computed(() => attrs.id ?? `${generatedId}-field`);
@@ -219,19 +232,26 @@ var DateInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
219
232
  id: fieldId.value,
220
233
  ref_key: "fieldRef",
221
234
  ref: fieldRef,
222
- modelValue: modelValue.value,
223
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => modelValue.value = $event),
235
+ modelValue: rekaValue.value,
236
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => rekaValue.value = $event),
224
237
  "default-value": __props.defaultValue,
238
+ "default-placeholder": __props.defaultPlaceholder,
225
239
  placeholder: __props.placeholderValue,
226
240
  "min-value": __props.minValue,
227
241
  "max-value": __props.maxValue,
228
242
  granularity: __props.granularity,
229
243
  "hour-cycle": __props.hourCycle,
244
+ step: __props.step,
230
245
  locale: __props.locale,
231
246
  disabled: __props.isDisabled,
232
247
  readonly: __props.isReadOnly,
233
248
  name: __props.name,
234
249
  "hide-time-zone": __props.hideTimeZone,
250
+ "is-date-unavailable": __props.isDateUnavailable,
251
+ required: __props.required,
252
+ dir: __props.dir,
253
+ as: __props.as,
254
+ "as-child": __props.asChild,
235
255
  "aria-labelledby": hasLabel.value ? labelId.value : void 0,
236
256
  "aria-describedby": ariaDescribedBy.value,
237
257
  "aria-required": __props.isRequired || void 0,
@@ -280,16 +300,23 @@ var DateInput_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defi
280
300
  "id",
281
301
  "modelValue",
282
302
  "default-value",
303
+ "default-placeholder",
283
304
  "placeholder",
284
305
  "min-value",
285
306
  "max-value",
286
307
  "granularity",
287
308
  "hour-cycle",
309
+ "step",
288
310
  "locale",
289
311
  "disabled",
290
312
  "readonly",
291
313
  "name",
292
314
  "hide-time-zone",
315
+ "is-date-unavailable",
316
+ "required",
317
+ "dir",
318
+ "as",
319
+ "as-child",
293
320
  "aria-labelledby",
294
321
  "aria-describedby",
295
322
  "aria-required",