@cube-dev/ui-kit 0.121.5 → 0.121.7

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 (578) hide show
  1. package/dist/CHANGELOG.md +21 -0
  2. package/dist/_internal/hooks/use-chained-callback.js +1 -1
  3. package/dist/_internal/hooks/use-debounced-value.js +1 -1
  4. package/dist/_internal/hooks/use-deprecation-warning.js +1 -1
  5. package/dist/_internal/hooks/use-event.js +1 -1
  6. package/dist/_internal/hooks/use-is-first-render.js +1 -1
  7. package/dist/_internal/hooks/use-sync-ref.js +1 -1
  8. package/dist/_internal/hooks/use-timer/timer.js +1 -1
  9. package/dist/_internal/hooks/use-timer/use-timer.js +1 -1
  10. package/dist/_internal/hooks/use-warn.js +1 -1
  11. package/dist/components/Block.js +3 -2
  12. package/dist/components/Block.js.map +1 -1
  13. package/dist/components/CollectionItem.js +1 -1
  14. package/dist/components/GlobalStyles.js +1 -1
  15. package/dist/components/GridProvider.js +1 -1
  16. package/dist/components/HiddenInput.js +1 -1
  17. package/dist/components/Root.js +3 -2
  18. package/dist/components/Root.js.map +1 -1
  19. package/dist/components/actions/Action/Action.js +3 -2
  20. package/dist/components/actions/Action/Action.js.map +1 -1
  21. package/dist/components/actions/Banner/Banner.js +1 -1
  22. package/dist/components/actions/Button/Button.js +3 -2
  23. package/dist/components/actions/Button/Button.js.map +1 -1
  24. package/dist/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  25. package/dist/components/actions/ButtonSplit/ButtonSplit.js +3 -2
  26. package/dist/components/actions/ButtonSplit/ButtonSplit.js.map +1 -1
  27. package/dist/components/actions/ButtonSplit/context.js +1 -1
  28. package/dist/components/actions/CommandMenu/CommandMenu.js +3 -2
  29. package/dist/components/actions/CommandMenu/CommandMenu.js.map +1 -1
  30. package/dist/components/actions/CommandMenu/styled.js +1 -1
  31. package/dist/components/actions/ItemAction/ItemAction.js +1 -1
  32. package/dist/components/actions/ItemActionContext.js +1 -1
  33. package/dist/components/actions/ItemButton/ItemButton.js +1 -1
  34. package/dist/components/actions/Link/Link.js +1 -1
  35. package/dist/components/actions/Menu/Menu.js +3 -2
  36. package/dist/components/actions/Menu/Menu.js.map +1 -1
  37. package/dist/components/actions/Menu/MenuItem.js +1 -1
  38. package/dist/components/actions/Menu/MenuSection.js +1 -1
  39. package/dist/components/actions/Menu/MenuTrigger.js +1 -1
  40. package/dist/components/actions/Menu/SubMenuTrigger.js +1 -1
  41. package/dist/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  42. package/dist/components/actions/Menu/context.js +1 -1
  43. package/dist/components/actions/Menu/styled.js +1 -1
  44. package/dist/components/actions/index.js +1 -1
  45. package/dist/components/actions/use-action.js +1 -1
  46. package/dist/components/actions/use-anchored-menu.js +1 -1
  47. package/dist/components/actions/use-context-menu.js +1 -1
  48. package/dist/components/content/ActiveZone/ActiveZone.js +3 -2
  49. package/dist/components/content/ActiveZone/ActiveZone.js.map +1 -1
  50. package/dist/components/content/Alert/Alert.js +1 -1
  51. package/dist/components/content/Alert/use-alert.js +3 -2
  52. package/dist/components/content/Alert/use-alert.js.map +1 -1
  53. package/dist/components/content/Avatar/Avatar.js +3 -2
  54. package/dist/components/content/Avatar/Avatar.js.map +1 -1
  55. package/dist/components/content/Badge/Badge.js +1 -1
  56. package/dist/components/content/Card/Card.js +3 -2
  57. package/dist/components/content/Card/Card.js.map +1 -1
  58. package/dist/components/content/Content.js +3 -2
  59. package/dist/components/content/Content.js.map +1 -1
  60. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js +3 -2
  61. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js.map +1 -1
  62. package/dist/components/content/CopySnippet/CopySnippet.js +1 -1
  63. package/dist/components/content/Disclosure/Disclosure.js +3 -2
  64. package/dist/components/content/Disclosure/Disclosure.js.map +1 -1
  65. package/dist/components/content/Divider.js +1 -1
  66. package/dist/components/content/Footer.js +3 -2
  67. package/dist/components/content/Footer.js.map +1 -1
  68. package/dist/components/content/Header.js +3 -2
  69. package/dist/components/content/Header.js.map +1 -1
  70. package/dist/components/content/HotKeys/HotKeys.js +3 -2
  71. package/dist/components/content/HotKeys/HotKeys.js.map +1 -1
  72. package/dist/components/content/Item/Item.js +1 -1
  73. package/dist/components/content/ItemBadge/ItemBadge.js +1 -1
  74. package/dist/components/content/ItemCard/ItemCard.js +1 -1
  75. package/dist/components/content/Layout/GridLayout.js +1 -1
  76. package/dist/components/content/Layout/Layout.js +3 -2
  77. package/dist/components/content/Layout/Layout.js.map +1 -1
  78. package/dist/components/content/Layout/LayoutBlock.js +1 -1
  79. package/dist/components/content/Layout/LayoutCenter.js +1 -1
  80. package/dist/components/content/Layout/LayoutContainer.js +3 -2
  81. package/dist/components/content/Layout/LayoutContainer.js.map +1 -1
  82. package/dist/components/content/Layout/LayoutContent.js +3 -2
  83. package/dist/components/content/Layout/LayoutContent.js.map +1 -1
  84. package/dist/components/content/Layout/LayoutContext.js +1 -1
  85. package/dist/components/content/Layout/LayoutFlex.js +1 -1
  86. package/dist/components/content/Layout/LayoutFooter.js +1 -1
  87. package/dist/components/content/Layout/LayoutGrid.js +1 -1
  88. package/dist/components/content/Layout/LayoutHeader.js +1 -1
  89. package/dist/components/content/Layout/LayoutPane.js +3 -2
  90. package/dist/components/content/Layout/LayoutPane.js.map +1 -1
  91. package/dist/components/content/Layout/LayoutPanel.js +3 -2
  92. package/dist/components/content/Layout/LayoutPanel.js.map +1 -1
  93. package/dist/components/content/Layout/LayoutPanelHeader.js +3 -2
  94. package/dist/components/content/Layout/LayoutPanelHeader.js.map +1 -1
  95. package/dist/components/content/Layout/LayoutToolbar.js +1 -1
  96. package/dist/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
  97. package/dist/components/content/Layout/index.js +1 -1
  98. package/dist/components/content/Layout/utils.js +1 -1
  99. package/dist/components/content/Paragraph.js +3 -2
  100. package/dist/components/content/Paragraph.js.map +1 -1
  101. package/dist/components/content/Placeholder/Placeholder.js +3 -2
  102. package/dist/components/content/Placeholder/Placeholder.js.map +1 -1
  103. package/dist/components/content/PrismCode/PrismCode.js +1 -1
  104. package/dist/components/content/PrismCode/prismSetup.js +1 -1
  105. package/dist/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  106. package/dist/components/content/Result/Result.js +4 -3
  107. package/dist/components/content/Result/Result.js.map +1 -1
  108. package/dist/components/content/Skeleton/Skeleton.js +1 -1
  109. package/dist/components/content/Tag/Tag.js +1 -1
  110. package/dist/components/content/Text.js +3 -2
  111. package/dist/components/content/Text.js.map +1 -1
  112. package/dist/components/content/TextItem/TextItem.js +3 -2
  113. package/dist/components/content/TextItem/TextItem.js.map +1 -1
  114. package/dist/components/content/Title.js +3 -2
  115. package/dist/components/content/Title.js.map +1 -1
  116. package/dist/components/content/highlightText.js +1 -1
  117. package/dist/components/content/use-auto-tooltip.js +1 -1
  118. package/dist/components/fields/Checkbox/Checkbox.js +3 -2
  119. package/dist/components/fields/Checkbox/Checkbox.js.map +1 -1
  120. package/dist/components/fields/Checkbox/CheckboxGroup.js +3 -2
  121. package/dist/components/fields/Checkbox/CheckboxGroup.js.map +1 -1
  122. package/dist/components/fields/Checkbox/context.js +1 -1
  123. package/dist/components/fields/ComboBox/ComboBox.js +3 -2
  124. package/dist/components/fields/ComboBox/ComboBox.js.map +1 -1
  125. package/dist/components/fields/DatePicker/DateInput.js +3 -2
  126. package/dist/components/fields/DatePicker/DateInput.js.map +1 -1
  127. package/dist/components/fields/DatePicker/DateInputBase.js +3 -2
  128. package/dist/components/fields/DatePicker/DateInputBase.js.map +1 -1
  129. package/dist/components/fields/DatePicker/DatePicker.js +3 -2
  130. package/dist/components/fields/DatePicker/DatePicker.js.map +1 -1
  131. package/dist/components/fields/DatePicker/DatePickerButton.js +1 -1
  132. package/dist/components/fields/DatePicker/DatePickerElement.js +1 -1
  133. package/dist/components/fields/DatePicker/DatePickerInput.js +1 -1
  134. package/dist/components/fields/DatePicker/DatePickerSegment.js +1 -1
  135. package/dist/components/fields/DatePicker/DateRangePicker.js +3 -2
  136. package/dist/components/fields/DatePicker/DateRangePicker.js.map +1 -1
  137. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js +3 -2
  138. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js.map +1 -1
  139. package/dist/components/fields/DatePicker/TimeInput.js +3 -2
  140. package/dist/components/fields/DatePicker/TimeInput.js.map +1 -1
  141. package/dist/components/fields/DatePicker/intl.js +1 -1
  142. package/dist/components/fields/DatePicker/parseDate.js +1 -1
  143. package/dist/components/fields/DatePicker/props.js +1 -1
  144. package/dist/components/fields/DatePicker/utils.js +1 -1
  145. package/dist/components/fields/FileInput/FileInput.js +3 -2
  146. package/dist/components/fields/FileInput/FileInput.js.map +1 -1
  147. package/dist/components/fields/FilterListBox/FilterListBox.js +3 -2
  148. package/dist/components/fields/FilterListBox/FilterListBox.js.map +1 -1
  149. package/dist/components/fields/FilterPicker/FilterPicker.js +3 -2
  150. package/dist/components/fields/FilterPicker/FilterPicker.js.map +1 -1
  151. package/dist/components/fields/Input/Input.js +1 -1
  152. package/dist/components/fields/ListBox/ListBox.js +3 -2
  153. package/dist/components/fields/ListBox/ListBox.js.map +1 -1
  154. package/dist/components/fields/NumberInput/NumberInput.js +1 -1
  155. package/dist/components/fields/NumberInput/StepButton.js +1 -1
  156. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  157. package/dist/components/fields/Picker/Picker.js +3 -2
  158. package/dist/components/fields/Picker/Picker.js.map +1 -1
  159. package/dist/components/fields/RadioGroup/Radio.js +3 -2
  160. package/dist/components/fields/RadioGroup/Radio.js.map +1 -1
  161. package/dist/components/fields/RadioGroup/RadioGroup.js +3 -2
  162. package/dist/components/fields/RadioGroup/RadioGroup.js.map +1 -1
  163. package/dist/components/fields/RadioGroup/context.js +1 -1
  164. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  165. package/dist/components/fields/Select/Select.js +3 -2
  166. package/dist/components/fields/Select/Select.js.map +1 -1
  167. package/dist/components/fields/Slider/Gradation.js +1 -1
  168. package/dist/components/fields/Slider/HueSlider.js +1 -1
  169. package/dist/components/fields/Slider/RangeSlider.js +1 -1
  170. package/dist/components/fields/Slider/Slider.js +3 -2
  171. package/dist/components/fields/Slider/Slider.js.map +1 -1
  172. package/dist/components/fields/Slider/SliderBase.js +3 -2
  173. package/dist/components/fields/Slider/SliderBase.js.map +1 -1
  174. package/dist/components/fields/Slider/SliderThumb.js +1 -1
  175. package/dist/components/fields/Slider/SliderTrack.js +1 -1
  176. package/dist/components/fields/Slider/elements.js +1 -1
  177. package/dist/components/fields/Slider/index.js +1 -1
  178. package/dist/components/fields/Switch/Switch.js +6 -5
  179. package/dist/components/fields/Switch/Switch.js.map +1 -1
  180. package/dist/components/fields/TextArea/TextArea.js +1 -1
  181. package/dist/components/fields/TextInput/TextInput.js +1 -1
  182. package/dist/components/fields/TextInput/TextInputBase.d.ts +2 -2
  183. package/dist/components/fields/TextInput/TextInputBase.js +15 -6
  184. package/dist/components/fields/TextInput/TextInputBase.js.map +1 -1
  185. package/dist/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  186. package/dist/components/form/FieldWrapper/FieldWrapper.js +3 -3
  187. package/dist/components/form/FieldWrapper/FieldWrapper.js.map +1 -1
  188. package/dist/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  189. package/dist/components/form/Form/Field.js +1 -1
  190. package/dist/components/form/Form/Form.js +3 -2
  191. package/dist/components/form/Form/Form.js.map +1 -1
  192. package/dist/components/form/Form/ResetButton/ResetButton.js +1 -1
  193. package/dist/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  194. package/dist/components/form/Form/SubmitError.js +1 -1
  195. package/dist/components/form/Form/index.js +1 -1
  196. package/dist/components/form/Form/use-field/use-field-props.js +1 -1
  197. package/dist/components/form/Form/use-field/use-field.js +1 -1
  198. package/dist/components/form/Form/use-form.js +1 -1
  199. package/dist/components/form/Form/validation.js +1 -1
  200. package/dist/components/form/Label.js +3 -2
  201. package/dist/components/form/Label.js.map +1 -1
  202. package/dist/components/form/wrapper.js +1 -1
  203. package/dist/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  204. package/dist/components/helpers/IconSwitch/IconSwitch.js +1 -1
  205. package/dist/components/layout/Flex.js +3 -2
  206. package/dist/components/layout/Flex.js.map +1 -1
  207. package/dist/components/layout/Flow.js +3 -2
  208. package/dist/components/layout/Flow.js.map +1 -1
  209. package/dist/components/layout/Grid.js +3 -2
  210. package/dist/components/layout/Grid.js.map +1 -1
  211. package/dist/components/layout/Panel.js +1 -1
  212. package/dist/components/layout/Prefix.js +3 -2
  213. package/dist/components/layout/Prefix.js.map +1 -1
  214. package/dist/components/layout/ResizablePanel.js +1 -1
  215. package/dist/components/layout/Space.js +3 -2
  216. package/dist/components/layout/Space.js.map +1 -1
  217. package/dist/components/layout/Suffix.js +3 -2
  218. package/dist/components/layout/Suffix.js.map +1 -1
  219. package/dist/components/navigation/Tabs/DraggableTabList.js +1 -1
  220. package/dist/components/navigation/Tabs/EditableTitle.js +1 -1
  221. package/dist/components/navigation/Tabs/TabButton.js +1 -1
  222. package/dist/components/navigation/Tabs/TabDropIndicator.js +1 -1
  223. package/dist/components/navigation/Tabs/TabPanel.js +1 -1
  224. package/dist/components/navigation/Tabs/TabPicker.js +1 -1
  225. package/dist/components/navigation/Tabs/Tabs.js +3 -2
  226. package/dist/components/navigation/Tabs/Tabs.js.map +1 -1
  227. package/dist/components/navigation/Tabs/TabsAction.js +1 -1
  228. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  229. package/dist/components/navigation/Tabs/styled.js +1 -1
  230. package/dist/components/navigation/Tabs/types.js +1 -1
  231. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  232. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  233. package/dist/components/organisms/FileTabs/FileTabs.js +1 -1
  234. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  235. package/dist/components/other/Calendar/Calendar.js +1 -1
  236. package/dist/components/other/Calendar/CalendarCell.js +1 -1
  237. package/dist/components/other/Calendar/CalendarGrid.js +1 -1
  238. package/dist/components/other/Calendar/RangeCalendar.js +1 -1
  239. package/dist/components/other/CloudLogo/CloudLogo.js +1 -1
  240. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  241. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  242. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  243. package/dist/components/overlays/Dialog/Dialog.js +3 -2
  244. package/dist/components/overlays/Dialog/Dialog.js.map +1 -1
  245. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  246. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  247. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  248. package/dist/components/overlays/Dialog/context.js +1 -1
  249. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  250. package/dist/components/overlays/Modal/Modal.js +1 -1
  251. package/dist/components/overlays/Modal/OpenTransition.js +1 -1
  252. package/dist/components/overlays/Modal/Overlay.js +1 -1
  253. package/dist/components/overlays/Modal/Popover.js +1 -1
  254. package/dist/components/overlays/Modal/Tray.js +1 -1
  255. package/dist/components/overlays/Modal/Underlay.js +1 -1
  256. package/dist/components/overlays/Notifications/Notification.js +1 -1
  257. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  258. package/dist/components/overlays/Notifications/NotificationCard.js +1 -1
  259. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  260. package/dist/components/overlays/Notifications/NotificationItem.js +1 -1
  261. package/dist/components/overlays/Notifications/OverlayContainer.js +1 -1
  262. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  263. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +1 -1
  264. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  265. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  266. package/dist/components/overlays/Notifications/index.js +1 -1
  267. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  268. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  269. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  270. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  271. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  272. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  273. package/dist/components/overlays/Toast/ToastItem.js +1 -1
  274. package/dist/components/overlays/Toast/index.js +1 -1
  275. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  276. package/dist/components/overlays/Toast/useToast.js +1 -1
  277. package/dist/components/overlays/Tooltip/Tooltip.js +3 -2
  278. package/dist/components/overlays/Tooltip/Tooltip.js.map +1 -1
  279. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  280. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  281. package/dist/components/overlays/Tooltip/context.js +1 -1
  282. package/dist/components/portal/Portal.js +1 -1
  283. package/dist/components/portal/PortalProvider.js +1 -1
  284. package/dist/components/portal/usePortal.js +1 -1
  285. package/dist/components/shared/InvalidIcon.js +1 -1
  286. package/dist/components/shared/ValidIcon.js +1 -1
  287. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  288. package/dist/components/status/Spin/Cube.js +1 -1
  289. package/dist/components/status/Spin/InternalSpinner.js +1 -1
  290. package/dist/components/status/Spin/Spin.js +1 -1
  291. package/dist/components/status/Spin/SpinsContainer.js +1 -1
  292. package/dist/data/item-themes.js +1 -1
  293. package/dist/data/themes.js +1 -1
  294. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  295. package/dist/icons/AdjustmentsIcon.js +1 -1
  296. package/dist/icons/AiIcon.js +1 -1
  297. package/dist/icons/AreaChartIcon.js +1 -1
  298. package/dist/icons/BackwardIcon.js +1 -1
  299. package/dist/icons/BarChartIcon.js +1 -1
  300. package/dist/icons/BellFilledIcon.js +1 -1
  301. package/dist/icons/BellIcon.js +1 -1
  302. package/dist/icons/BooleanIcon.js +1 -1
  303. package/dist/icons/CalendarEditIcon.js +1 -1
  304. package/dist/icons/CalendarIcon.js +1 -1
  305. package/dist/icons/CaretDownIcon.js +1 -1
  306. package/dist/icons/CaretUpIcon.js +1 -1
  307. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  308. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  309. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  310. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  311. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  312. package/dist/icons/ChartBarLineIcon.js +1 -1
  313. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  314. package/dist/icons/ChartBarStackedIcon.js +1 -1
  315. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  316. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  317. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  318. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  319. package/dist/icons/ChartBubbleIcon.js +1 -1
  320. package/dist/icons/ChartDonut2Icon.js +1 -1
  321. package/dist/icons/ChartFunnelIcon.js +1 -1
  322. package/dist/icons/ChartHeatmapIcon.js +1 -1
  323. package/dist/icons/ChartKPIIcon.js +1 -1
  324. package/dist/icons/ChartPie2Icon.js +1 -1
  325. package/dist/icons/ChartScatterIcon.js +1 -1
  326. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  327. package/dist/icons/CheckCircleIcon.js +1 -1
  328. package/dist/icons/CheckIcon.js +1 -1
  329. package/dist/icons/CircleFilledIcon.js +1 -1
  330. package/dist/icons/ClearIcon.js +1 -1
  331. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  332. package/dist/icons/CloseCircleIcon.js +1 -1
  333. package/dist/icons/CloseIcon.js +1 -1
  334. package/dist/icons/CodeIcon.js +1 -1
  335. package/dist/icons/ColumnTotalIcon.js +1 -1
  336. package/dist/icons/CopyIcon.js +1 -1
  337. package/dist/icons/CountIcon.js +1 -1
  338. package/dist/icons/CubeIcon.js +1 -1
  339. package/dist/icons/CubePauseIcon.js +1 -1
  340. package/dist/icons/CubePlayIcon.js +1 -1
  341. package/dist/icons/CurrencyDollarIcon.js +1 -1
  342. package/dist/icons/DangerIcon.js +1 -1
  343. package/dist/icons/DashboardIcon.js +1 -1
  344. package/dist/icons/DatabaseIcon.js +1 -1
  345. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  346. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  347. package/dist/icons/DirectionIcon.js +1 -1
  348. package/dist/icons/DonutIcon.js +1 -1
  349. package/dist/icons/DownIcon.js +1 -1
  350. package/dist/icons/EditIcon.js +1 -1
  351. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  352. package/dist/icons/ExclamationCircleIcon.js +1 -1
  353. package/dist/icons/ExclamationIcon.js +1 -1
  354. package/dist/icons/EyeIcon.js +1 -1
  355. package/dist/icons/EyeInvisibleIcon.js +1 -1
  356. package/dist/icons/FilterIcon.js +1 -1
  357. package/dist/icons/FolderFilledIcon.js +1 -1
  358. package/dist/icons/FolderIcon.js +1 -1
  359. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  360. package/dist/icons/FolderOpenIcon.js +1 -1
  361. package/dist/icons/ForwardIcon.js +1 -1
  362. package/dist/icons/HierarchyIcon.js +1 -1
  363. package/dist/icons/HierarchyOpenIcon.js +1 -1
  364. package/dist/icons/Icon.js +1 -1
  365. package/dist/icons/InfoCircleIcon.js +1 -1
  366. package/dist/icons/InfoIcon.js +1 -1
  367. package/dist/icons/KeyIcon.js +1 -1
  368. package/dist/icons/LeftIcon.js +1 -1
  369. package/dist/icons/LineChartIcon.js +1 -1
  370. package/dist/icons/LoadingIcon.js +1 -1
  371. package/dist/icons/LockFilledIcon.js +1 -1
  372. package/dist/icons/LockIcon.js +1 -1
  373. package/dist/icons/MoreIcon.js +1 -1
  374. package/dist/icons/NotAllowedIcon.js +1 -1
  375. package/dist/icons/Number123Icon.js +1 -1
  376. package/dist/icons/NumberIcon.js +1 -1
  377. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  378. package/dist/icons/PauseCircleIcon.js +1 -1
  379. package/dist/icons/PauseIcon.js +1 -1
  380. package/dist/icons/PercentageIcon.js +1 -1
  381. package/dist/icons/PieChartIcon.js +1 -1
  382. package/dist/icons/PlayCircleIcon.js +1 -1
  383. package/dist/icons/PlayIcon.js +1 -1
  384. package/dist/icons/PlusIcon.js +1 -1
  385. package/dist/icons/ProgressBarIcon.js +1 -1
  386. package/dist/icons/ReloadIcon.js +1 -1
  387. package/dist/icons/ReportIcon.js +1 -1
  388. package/dist/icons/ReturnIcon.js +1 -1
  389. package/dist/icons/RightIcon.js +1 -1
  390. package/dist/icons/RowTotalsIcon.js +1 -1
  391. package/dist/icons/SchemeIcon.js +1 -1
  392. package/dist/icons/SearchIcon.js +1 -1
  393. package/dist/icons/SemanticQueryIcon.js +1 -1
  394. package/dist/icons/SettingsIcon.js +1 -1
  395. package/dist/icons/ShieldFilledIcon.js +1 -1
  396. package/dist/icons/ShieldIcon.js +1 -1
  397. package/dist/icons/SlashIcon.js +1 -1
  398. package/dist/icons/SparklesIcon.js +1 -1
  399. package/dist/icons/SqlIcon.js +1 -1
  400. package/dist/icons/StatsIcon.js +1 -1
  401. package/dist/icons/StopIcon.js +1 -1
  402. package/dist/icons/StringIcon.js +1 -1
  403. package/dist/icons/SubtotalsIcon.js +1 -1
  404. package/dist/icons/SwitchIcon.js +1 -1
  405. package/dist/icons/TableIcon.js +1 -1
  406. package/dist/icons/ThumbsDownIcon.js +1 -1
  407. package/dist/icons/ThumbsUpIcon.js +1 -1
  408. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  409. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  410. package/dist/icons/ThunderboltIcon.js +1 -1
  411. package/dist/icons/TimeIcon.js +1 -1
  412. package/dist/icons/TrashIcon.js +1 -1
  413. package/dist/icons/UnlockIcon.js +1 -1
  414. package/dist/icons/UpIcon.js +1 -1
  415. package/dist/icons/UserGroupIcon.js +1 -1
  416. package/dist/icons/UserIcon.js +1 -1
  417. package/dist/icons/UserLockIcon.js +1 -1
  418. package/dist/icons/ViewIcon.js +1 -1
  419. package/dist/icons/WarningFilledIcon.js +1 -1
  420. package/dist/icons/WarningIcon.js +1 -1
  421. package/dist/icons/wrap-icon.js +1 -1
  422. package/dist/index.d.ts +3 -1
  423. package/dist/index.js +4 -2
  424. package/dist/index.js.map +1 -1
  425. package/dist/provider.js +1 -1
  426. package/dist/providers/TrackingProvider.js +1 -1
  427. package/dist/providers/navigationAdapter.default.js +1 -1
  428. package/dist/tokens/base.js +1 -1
  429. package/dist/tokens/colors.js +1 -1
  430. package/dist/tokens/index.d.ts +1 -0
  431. package/dist/tokens/index.js +3 -2
  432. package/dist/tokens/index.js.map +1 -1
  433. package/dist/tokens/layout.js +1 -1
  434. package/dist/tokens/shadows.js +1 -1
  435. package/dist/tokens/sizes.js +1 -1
  436. package/dist/tokens/spacing.js +1 -1
  437. package/dist/tokens/typography.d.ts +35 -0
  438. package/dist/tokens/typography.js +238 -0
  439. package/dist/tokens/typography.js.map +1 -0
  440. package/dist/utils/ResizeSensor.js +1 -1
  441. package/dist/utils/index.d.ts +1 -0
  442. package/dist/utils/is-dev-env.js +1 -1
  443. package/dist/utils/modules.js +1 -1
  444. package/dist/utils/promise.js +1 -1
  445. package/dist/utils/raf.js +1 -1
  446. package/dist/utils/random.js +1 -1
  447. package/dist/utils/range.js +1 -1
  448. package/dist/utils/react/RenderCache.js +1 -1
  449. package/dist/utils/react/Slots.js +1 -1
  450. package/dist/utils/react/chain.js +1 -1
  451. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  452. package/dist/utils/react/index.js +1 -1
  453. package/dist/utils/react/interactions.js +1 -1
  454. package/dist/utils/react/isTextOnly.js +1 -1
  455. package/dist/utils/react/mapProps.js +1 -1
  456. package/dist/utils/react/mergeProps.js +1 -1
  457. package/dist/utils/react/nullableValue.js +1 -1
  458. package/dist/utils/react/resolveIcon.js +1 -1
  459. package/dist/utils/react/sharedStore.js +1 -1
  460. package/dist/utils/react/useCombinedRefs.js +1 -1
  461. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  462. package/dist/utils/react/useEventBus.js +1 -1
  463. package/dist/utils/react/useId.js +1 -1
  464. package/dist/utils/react/useIsDarwin.js +1 -1
  465. package/dist/utils/react/useKeySymbols.js +1 -1
  466. package/dist/utils/react/useLayoutEffect.js +1 -1
  467. package/dist/utils/react/useLocalStorage.js +1 -1
  468. package/dist/utils/react/useMergeStyles.js +1 -1
  469. package/dist/utils/react/useQaProps.js +1 -1
  470. package/dist/utils/react/useViewportSize.js +1 -1
  471. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  472. package/dist/utils/styles.d.ts +19 -0
  473. package/dist/utils/styles.js +31 -0
  474. package/dist/utils/styles.js.map +1 -0
  475. package/dist/utils/tree.js +1 -1
  476. package/dist/utils/warnings.js +1 -1
  477. package/dist/version.js +2 -2
  478. package/docs/BaseProperties.md +1 -1
  479. package/docs/Utilities.md +183 -0
  480. package/docs/components/Block.md +11 -0
  481. package/docs/components/CollectionItem.md +37 -8
  482. package/docs/components/GridProvider.md +15 -0
  483. package/docs/components/Root.md +8 -0
  484. package/docs/components/actions/Action.md +12 -0
  485. package/docs/components/actions/Banner.md +28 -2
  486. package/docs/components/actions/Button.md +10 -1
  487. package/docs/components/actions/ButtonGroup.md +11 -0
  488. package/docs/components/actions/ButtonSplit.md +11 -1
  489. package/docs/components/actions/CommandMenu.md +44 -17
  490. package/docs/components/actions/ItemButton.md +14 -37
  491. package/docs/components/actions/Link.md +9 -5
  492. package/docs/components/actions/Menu.md +11 -13
  493. package/docs/components/actions/MenuTrigger.md +17 -0
  494. package/docs/components/actions/SubMenuTrigger.md +17 -0
  495. package/docs/components/actions/use-anchored-menu.md +11 -0
  496. package/docs/components/actions/use-context-menu.md +11 -0
  497. package/docs/components/content/ActiveZone.md +18 -0
  498. package/docs/components/content/Alert.md +12 -0
  499. package/docs/components/content/Avatar.md +11 -0
  500. package/docs/components/content/Badge.md +20 -9
  501. package/docs/components/content/Card.md +11 -0
  502. package/docs/components/content/Content.md +12 -0
  503. package/docs/components/content/CopyPasteBlock.md +8 -0
  504. package/docs/components/content/CopySnippet.md +19 -5
  505. package/docs/components/content/Disclosure.md +5 -1
  506. package/docs/components/content/Divider.md +12 -0
  507. package/docs/components/content/Footer.md +12 -0
  508. package/docs/components/content/Header.md +12 -0
  509. package/docs/components/content/HotKeys.md +7 -14
  510. package/docs/components/content/ItemBadge.md +1 -0
  511. package/docs/components/content/ItemCard.md +20 -5
  512. package/docs/components/content/Layout.md +8 -1
  513. package/docs/components/content/Paragraph.md +20 -1
  514. package/docs/components/content/Placeholder.md +11 -0
  515. package/docs/components/content/Result.md +12 -0
  516. package/docs/components/content/Skeleton.md +15 -0
  517. package/docs/components/content/Tag.md +20 -9
  518. package/docs/components/content/Text.md +8 -0
  519. package/docs/components/content/TextItem.md +15 -9
  520. package/docs/components/content/Title.md +16 -0
  521. package/docs/components/fields/Checkbox.md +8 -3
  522. package/docs/components/fields/ComboBox.md +11 -5
  523. package/docs/components/fields/DatePicker.md +16 -15
  524. package/docs/components/fields/FileInput.md +13 -31
  525. package/docs/components/fields/FilterListBox.md +16 -1
  526. package/docs/components/fields/FilterPicker.md +34 -7
  527. package/docs/components/fields/HueSlider.md +16 -2
  528. package/docs/components/fields/ListBox.md +9 -1
  529. package/docs/components/fields/NumberInput.md +14 -6
  530. package/docs/components/fields/PasswordInput.md +10 -2
  531. package/docs/components/fields/Picker.md +29 -12
  532. package/docs/components/fields/RadioGroup.md +8 -1
  533. package/docs/components/fields/SearchInput.md +12 -2
  534. package/docs/components/fields/Select.md +14 -2
  535. package/docs/components/fields/Slider.md +34 -0
  536. package/docs/components/fields/Switch.md +3 -1
  537. package/docs/components/fields/TextArea.md +43 -0
  538. package/docs/components/fields/TextInput.md +10 -2
  539. package/docs/components/fields/TextInputMapper.md +30 -0
  540. package/docs/components/form/Field.md +9 -1
  541. package/docs/components/form/Form.md +9 -1
  542. package/docs/components/layout/Flex.md +11 -0
  543. package/docs/components/layout/Flow.md +11 -0
  544. package/docs/components/layout/Grid.md +11 -0
  545. package/docs/components/layout/Panel.md +11 -0
  546. package/docs/components/layout/Prefix.md +11 -0
  547. package/docs/components/layout/ResizablePanel.md +17 -0
  548. package/docs/components/layout/Space.md +11 -0
  549. package/docs/components/layout/Suffix.md +11 -0
  550. package/docs/components/navigation/Tabs.md +6 -1
  551. package/docs/components/organisms/FileTabs.md +12 -0
  552. package/docs/components/organisms/StatsCard.md +11 -0
  553. package/docs/components/other/CloudLogo.md +12 -0
  554. package/docs/components/overlays/AlertDialog.md +16 -0
  555. package/docs/components/overlays/Dialog.md +6 -3
  556. package/docs/components/overlays/DialogContainer.md +9 -0
  557. package/docs/components/overlays/DialogForm.md +29 -16
  558. package/docs/components/overlays/DialogTrigger.md +11 -0
  559. package/docs/components/overlays/Tooltip.md +27 -84
  560. package/docs/components/overlays/TooltipProvider.md +24 -4
  561. package/docs/components/overlays/TooltipTrigger.md +14 -0
  562. package/docs/components/portal/Portal.md +4 -0
  563. package/docs/components/status/LoadingAnimation.md +11 -0
  564. package/docs/components/status/Spin.md +11 -0
  565. package/docs/tasty/adoption.md +286 -0
  566. package/docs/tasty/comparison.md +413 -0
  567. package/docs/tasty/configuration.md +41 -10
  568. package/docs/tasty/debug.md +1 -1
  569. package/docs/tasty/design-system.md +401 -0
  570. package/docs/tasty/{usage.md → dsl.md} +254 -409
  571. package/docs/tasty/getting-started.md +201 -0
  572. package/docs/tasty/injector.md +2 -2
  573. package/docs/tasty/methodology.md +501 -0
  574. package/docs/tasty/runtime.md +291 -0
  575. package/docs/tasty/ssr.md +11 -1
  576. package/docs/tasty/styles.md +2 -2
  577. package/docs/tasty/tasty-static.md +64 -20
  578. package/package.json +8 -9
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { useFormProps } from "../../form/Form/Form.js";
@@ -9,7 +10,7 @@ import { DatePickerSegment } from "./DatePickerSegment.js";
9
10
  import { DEFAULT_DATE_PROPS } from "./props.js";
10
11
  import { formatSegments, useFocusManagerRef } from "./utils.js";
11
12
  import { parseAbsoluteDate } from "./parseDate.js";
12
- import { CONTAINER_STYLES, extractStyles } from "@tenphi/tasty";
13
+ import { CONTAINER_STYLES } from "@tenphi/tasty";
13
14
  import { forwardRef, useRef } from "react";
14
15
  import { jsx } from "react/jsx-runtime";
15
16
  import { useDateField, useLocale } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"DateInput.js","names":["DateInputBase","mergeProps"],"sources":["../../../../src/components/fields/DatePicker/DateInput.tsx"],"sourcesContent":["import { createCalendar } from '@internationalized/date';\nimport { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDateFieldProps,\n DateValue,\n useDateField,\n useLocale,\n} from 'react-aria';\nimport { useDateFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerSegment } from './DatePickerSegment';\nimport { parseAbsoluteDate } from './parseDate';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { formatSegments, useFocusManagerRef } from './utils';\n\nexport interface CubeDateInputProps<T extends DateValue = DateValue>\n extends Omit<AriaDateFieldProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n useLocale?: boolean;\n}\n\nfunction DateInput<T extends DateValue>(\n props: CubeDateInputProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n valuePropsMapper: ({ value, onChange }) => ({\n value: typeof value === 'string' ? parseAbsoluteDate(value) : value,\n onChange,\n }),\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let {\n qa,\n autoFocus,\n isDisabled,\n inputStyles,\n wrapperStyles,\n isReadOnly,\n isRequired,\n size = 'medium',\n useLocale: useLocaleProp,\n } = props;\n\n let styles = extractStyles(props, CONTAINER_STYLES, wrapperStyles);\n\n let domRef = useFocusManagerRef(ref);\n let { locale } = useLocale();\n let state = useDateFieldState({\n ...props,\n locale: useLocaleProp ? locale : 'en-US',\n createCalendar,\n });\n\n if (useLocaleProp == null) {\n state.segments = formatSegments(state.segments);\n }\n\n let fieldRef = useRef(null);\n let { labelProps, fieldProps } = useDateField(props, state, fieldRef);\n\n const component = (\n <DateInputBase\n ref={fieldRef}\n qa={qa || 'DateInput'}\n inputType=\"dateinput\"\n size={size}\n fieldProps={fieldProps}\n isDisabled={isDisabled}\n autoFocus={autoFocus}\n validationState={state.validationState}\n styles={wrapperStyles}\n inputStyles={inputStyles}\n >\n {state.segments.map((segment, i) => (\n <DatePickerSegment\n key={i}\n segment={segment}\n state={state}\n isDisabled={isDisabled}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n />\n ))}\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\n/**\n * DateInputs allow users to enter and edit date and time values using a keyboard.\n * Each part of a date value is displayed in an individually editable segment.\n */\nconst _DateInput = forwardRef(DateInput) as typeof DateInput;\n\n(_DateInput as any).displayName = 'DateInput';\n\nexport { _DateInput as DateInput };\n"],"mappings":";;;;;;;;;;;;;;;;;;;AA0CA,SAAS,UACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO;EAC3B,0BAA0B;EAC1B,mBAAmB,EAAE,OAAO,gBAAgB;GAC1C,OAAO,OAAO,UAAU,WAAW,kBAAkB,MAAM,GAAG;GAC9D;GACD;EACF,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;CAEpD,IAAI,EACF,IACA,WACA,YACA,aACA,eACA,YACA,YACA,OAAO,UACP,WAAW,kBACT;AAES,eAAc,OAAO,kBAAkB,cAAc;CAElE,IAAI,SAAS,mBAAmB,IAAI;CACpC,IAAI,EAAE,WAAW,WAAW;CAC5B,IAAI,QAAQ,kBAAkB;EAC5B,GAAG;EACH,QAAQ,gBAAgB,SAAS;EACjC;EACD,CAAC;AAEF,KAAI,iBAAiB,KACnB,OAAM,WAAW,eAAe,MAAM,SAAS;CAGjD,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EAAE,YAAY,eAAe,aAAa,OAAO,OAAO,SAAS;AA4BrE,QAAO,cAzBL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACJ;EACM;EACA;EACD;EACX,iBAAiB,MAAM;EACvB,QAAQ;EACK;YAEZ,MAAM,SAAS,KAAK,SAAS,MAC5B,oBAAC;GAEU;GACF;GACK;GACA;GACA;KALP,EAML,CACF;GACY,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYC,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;;;;;AAOJ,MAAM,aAAa,WAAW,UAAU;AAExC,AAAC,WAAmB,cAAc"}
1
+ {"version":3,"file":"DateInput.js","names":["DateInputBase","mergeProps"],"sources":["../../../../src/components/fields/DatePicker/DateInput.tsx"],"sourcesContent":["import { createCalendar } from '@internationalized/date';\nimport { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDateFieldProps,\n DateValue,\n useDateField,\n useLocale,\n} from 'react-aria';\nimport { useDateFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerSegment } from './DatePickerSegment';\nimport { parseAbsoluteDate } from './parseDate';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { formatSegments, useFocusManagerRef } from './utils';\n\nexport interface CubeDateInputProps<T extends DateValue = DateValue>\n extends Omit<AriaDateFieldProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n useLocale?: boolean;\n}\n\nfunction DateInput<T extends DateValue>(\n props: CubeDateInputProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n valuePropsMapper: ({ value, onChange }) => ({\n value: typeof value === 'string' ? parseAbsoluteDate(value) : value,\n onChange,\n }),\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let {\n qa,\n autoFocus,\n isDisabled,\n inputStyles,\n wrapperStyles,\n isReadOnly,\n isRequired,\n size = 'medium',\n useLocale: useLocaleProp,\n } = props;\n\n let styles = extractStyles(props, CONTAINER_STYLES, wrapperStyles);\n\n let domRef = useFocusManagerRef(ref);\n let { locale } = useLocale();\n let state = useDateFieldState({\n ...props,\n locale: useLocaleProp ? locale : 'en-US',\n createCalendar,\n });\n\n if (useLocaleProp == null) {\n state.segments = formatSegments(state.segments);\n }\n\n let fieldRef = useRef(null);\n let { labelProps, fieldProps } = useDateField(props, state, fieldRef);\n\n const component = (\n <DateInputBase\n ref={fieldRef}\n qa={qa || 'DateInput'}\n inputType=\"dateinput\"\n size={size}\n fieldProps={fieldProps}\n isDisabled={isDisabled}\n autoFocus={autoFocus}\n validationState={state.validationState}\n styles={wrapperStyles}\n inputStyles={inputStyles}\n >\n {state.segments.map((segment, i) => (\n <DatePickerSegment\n key={i}\n segment={segment}\n state={state}\n isDisabled={isDisabled}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n />\n ))}\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\n/**\n * DateInputs allow users to enter and edit date and time values using a keyboard.\n * Each part of a date value is displayed in an individually editable segment.\n */\nconst _DateInput = forwardRef(DateInput) as typeof DateInput;\n\n(_DateInput as any).displayName = 'DateInput';\n\nexport { _DateInput as DateInput };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AA0CA,SAAS,UACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO;EAC3B,0BAA0B;EAC1B,mBAAmB,EAAE,OAAO,gBAAgB;GAC1C,OAAO,OAAO,UAAU,WAAW,kBAAkB,MAAM,GAAG;GAC9D;GACD;EACF,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;CAEpD,IAAI,EACF,IACA,WACA,YACA,aACA,eACA,YACA,YACA,OAAO,UACP,WAAW,kBACT;AAES,eAAc,OAAO,kBAAkB,cAAc;CAElE,IAAI,SAAS,mBAAmB,IAAI;CACpC,IAAI,EAAE,WAAW,WAAW;CAC5B,IAAI,QAAQ,kBAAkB;EAC5B,GAAG;EACH,QAAQ,gBAAgB,SAAS;EACjC;EACD,CAAC;AAEF,KAAI,iBAAiB,KACnB,OAAM,WAAW,eAAe,MAAM,SAAS;CAGjD,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EAAE,YAAY,eAAe,aAAa,OAAO,OAAO,SAAS;AA4BrE,QAAO,cAzBL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACJ;EACM;EACA;EACD;EACX,iBAAiB,MAAM;EACvB,QAAQ;EACK;YAEZ,MAAM,SAAS,KAAK,SAAS,MAC5B,oBAAC;GAEU;GACF;GACK;GACA;GACA;KALP,EAML,CACF;GACY,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYC,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;;;;;AAOJ,MAAM,aAAa,WAAW,UAAU;AAExC,AAAC,WAAmB,cAAc"}
@@ -1,9 +1,10 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { InvalidIcon } from "../../shared/InvalidIcon.js";
4
5
  import { ValidIcon } from "../../shared/ValidIcon.js";
5
6
  import { DEFAULT_INPUT_STYLES, INPUT_WRAPPER_STYLES } from "../TextInput/TextInputBase.js";
6
- import { CONTAINER_STYLES, extractStyles, tasty } from "@tenphi/tasty";
7
+ import { CONTAINER_STYLES, tasty } from "@tenphi/tasty";
7
8
  import React, { cloneElement, useRef } from "react";
8
9
  import { jsx, jsxs } from "react/jsx-runtime";
9
10
  import { useFocusRing } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"DateInputBase.js","names":["mergeProps"],"sources":["../../../../src/components/fields/DatePicker/DateInputBase.tsx"],"sourcesContent":["import { mergeRefs } from '@react-aria/utils';\nimport {\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Props,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport React, { cloneElement, useRef } from 'react';\nimport { useFocusRing } from 'react-aria';\n\nimport { ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { InvalidIcon } from '../../shared/InvalidIcon';\nimport { ValidIcon } from '../../shared/ValidIcon';\nimport {\n DEFAULT_INPUT_STYLES,\n INPUT_WRAPPER_STYLES,\n} from '../TextInput/TextInputBase';\n\nconst DateInputWrapperElement = tasty({\n qa: 'DateInputWrapper',\n role: 'presentation',\n styles: {\n ...INPUT_WRAPPER_STYLES,\n display: 'flex',\n },\n});\n\nconst DateInputElement = tasty({\n role: 'presentation',\n styles: {\n ...DEFAULT_INPUT_STYLES,\n height: {\n '': '($size-md - 2bw)',\n 'size=small': '($size-sm - 2bw)',\n 'size=large': '($size-lg - 2bw)',\n },\n display: 'flex',\n flow: 'row',\n placeItems: 'center start',\n },\n});\n\ninterface CubeDateAtomInputProps extends ContainerStyleProps {\n qa?: string;\n inputType?: string;\n isDisabled?: boolean;\n children?: React.ReactNode;\n fieldProps?: Props;\n style?: React.CSSProperties;\n disableFocusRing?: boolean;\n autoFocus?: boolean;\n styles?: Styles;\n inputStyles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n isLoading?: boolean;\n suffix?: React.ReactNode;\n}\n\nfunction DateInputBase(props: CubeDateAtomInputProps, ref) {\n let inputRef = useRef(null);\n let {\n qa,\n inputType,\n isDisabled,\n inputStyles,\n children,\n fieldProps,\n style,\n disableFocusRing,\n autoFocus,\n validationState,\n isLoading,\n size = 'medium',\n suffix,\n } = props;\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let { focusProps, isFocused } = useFocusRing({\n isTextInput: true,\n within: true,\n autoFocus,\n });\n\n let isInvalid = validationState === 'invalid';\n let validationIcon = isInvalid ? InvalidIcon : ValidIcon;\n let validation = cloneElement(validationIcon);\n\n return (\n <DateInputWrapperElement\n qa={qa || 'DateTimeInput'}\n styles={styles}\n data-size={size}\n data-input-type={inputType ? inputType : 'datetimeinput'}\n mods={{\n disabled: isDisabled,\n focused: isFocused && !disableFocusRing,\n invalid: isInvalid,\n suffix: (validationState && !isLoading) || isLoading || !!suffix,\n }}\n {...mergeProps(fieldProps ?? {}, focusProps)}\n style={style}\n >\n <div data-element=\"Contents\" role=\"presentation\">\n <DateInputElement\n ref={mergeRefs(ref, inputRef)}\n data-size={size}\n role=\"presentation\"\n styles={inputStyles}\n >\n {children}\n </DateInputElement>\n </div>\n {(validationState && !isLoading) || isLoading || suffix ? (\n <div data-element=\"Suffix\">\n {(validationState && !isLoading) || isLoading ? (\n <div data-element=\"State\">\n {validationState && !isLoading ? validation : null}\n </div>\n ) : null}\n {suffix}\n </div>\n ) : null}\n </DateInputWrapperElement>\n );\n}\n\nconst _DateInputBase = React.forwardRef(DateInputBase);\n\n_DateInputBase.displayName = 'DateInputBase';\n\nexport { _DateInputBase as DateInputBase };\n"],"mappings":";;;;;;;;;;;;AAqBA,MAAM,0BAA0B,MAAM;CACpC,IAAI;CACJ,MAAM;CACN,QAAQ;EACN,GAAG;EACH,SAAS;EACV;CACF,CAAC;AAEF,MAAM,mBAAmB,MAAM;CAC7B,MAAM;CACN,QAAQ;EACN,GAAG;EACH,QAAQ;GACN,IAAI;GACJ,cAAc;GACd,cAAc;GACf;EACD,SAAS;EACT,MAAM;EACN,YAAY;EACb;CACF,CAAC;AAmBF,SAAS,cAAc,OAA+B,KAAK;CACzD,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EACF,IACA,WACA,YACA,aACA,UACA,YACA,OACA,kBACA,WACA,iBACA,WACA,OAAO,UACP,WACE;CAEJ,IAAI,SAAS,cAAc,OAAO,iBAAiB;CAEnD,IAAI,EAAE,YAAY,cAAc,aAAa;EAC3C,aAAa;EACb,QAAQ;EACR;EACD,CAAC;CAEF,IAAI,YAAY,oBAAoB;CAEpC,IAAI,aAAa,aADI,YAAY,cAAc,UACF;AAE7C,QACE,qBAAC;EACC,IAAI,MAAM;EACF;EACR,aAAW;EACX,mBAAiB,YAAY,YAAY;EACzC,MAAM;GACJ,UAAU;GACV,SAAS,aAAa,CAAC;GACvB,SAAS;GACT,QAAS,mBAAmB,CAAC,aAAc,aAAa,CAAC,CAAC;GAC3D;EACD,GAAIA,aAAW,cAAc,EAAE,EAAE,WAAW;EACrC;aAEP,oBAAC;GAAI,gBAAa;GAAW,MAAK;aAChC,oBAAC;IACC,KAAK,UAAU,KAAK,SAAS;IAC7B,aAAW;IACX,MAAK;IACL,QAAQ;IAEP;KACgB;IACf,EACJ,mBAAmB,CAAC,aAAc,aAAa,SAC/C,qBAAC;GAAI,gBAAa;cACd,mBAAmB,CAAC,aAAc,YAClC,oBAAC;IAAI,gBAAa;cACf,mBAAmB,CAAC,YAAY,aAAa;KAC1C,GACJ,MACH;IACG,GACJ;GACoB;;AAI9B,MAAM,iBAAiB,MAAM,WAAW,cAAc;AAEtD,eAAe,cAAc"}
1
+ {"version":3,"file":"DateInputBase.js","names":["mergeProps"],"sources":["../../../../src/components/fields/DatePicker/DateInputBase.tsx"],"sourcesContent":["import { mergeRefs } from '@react-aria/utils';\nimport {\n CONTAINER_STYLES,\n ContainerStyleProps,\n Props,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport React, { cloneElement, useRef } from 'react';\nimport { useFocusRing } from 'react-aria';\n\nimport { ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { InvalidIcon } from '../../shared/InvalidIcon';\nimport { ValidIcon } from '../../shared/ValidIcon';\nimport {\n DEFAULT_INPUT_STYLES,\n INPUT_WRAPPER_STYLES,\n} from '../TextInput/TextInputBase';\n\nconst DateInputWrapperElement = tasty({\n qa: 'DateInputWrapper',\n role: 'presentation',\n styles: {\n ...INPUT_WRAPPER_STYLES,\n display: 'flex',\n },\n});\n\nconst DateInputElement = tasty({\n role: 'presentation',\n styles: {\n ...DEFAULT_INPUT_STYLES,\n height: {\n '': '($size-md - 2bw)',\n 'size=small': '($size-sm - 2bw)',\n 'size=large': '($size-lg - 2bw)',\n },\n display: 'flex',\n flow: 'row',\n placeItems: 'center start',\n },\n});\n\ninterface CubeDateAtomInputProps extends ContainerStyleProps {\n qa?: string;\n inputType?: string;\n isDisabled?: boolean;\n children?: React.ReactNode;\n fieldProps?: Props;\n style?: React.CSSProperties;\n disableFocusRing?: boolean;\n autoFocus?: boolean;\n styles?: Styles;\n inputStyles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n isLoading?: boolean;\n suffix?: React.ReactNode;\n}\n\nfunction DateInputBase(props: CubeDateAtomInputProps, ref) {\n let inputRef = useRef(null);\n let {\n qa,\n inputType,\n isDisabled,\n inputStyles,\n children,\n fieldProps,\n style,\n disableFocusRing,\n autoFocus,\n validationState,\n isLoading,\n size = 'medium',\n suffix,\n } = props;\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let { focusProps, isFocused } = useFocusRing({\n isTextInput: true,\n within: true,\n autoFocus,\n });\n\n let isInvalid = validationState === 'invalid';\n let validationIcon = isInvalid ? InvalidIcon : ValidIcon;\n let validation = cloneElement(validationIcon);\n\n return (\n <DateInputWrapperElement\n qa={qa || 'DateTimeInput'}\n styles={styles}\n data-size={size}\n data-input-type={inputType ? inputType : 'datetimeinput'}\n mods={{\n disabled: isDisabled,\n focused: isFocused && !disableFocusRing,\n invalid: isInvalid,\n suffix: (validationState && !isLoading) || isLoading || !!suffix,\n }}\n {...mergeProps(fieldProps ?? {}, focusProps)}\n style={style}\n >\n <div data-element=\"Contents\" role=\"presentation\">\n <DateInputElement\n ref={mergeRefs(ref, inputRef)}\n data-size={size}\n role=\"presentation\"\n styles={inputStyles}\n >\n {children}\n </DateInputElement>\n </div>\n {(validationState && !isLoading) || isLoading || suffix ? (\n <div data-element=\"Suffix\">\n {(validationState && !isLoading) || isLoading ? (\n <div data-element=\"State\">\n {validationState && !isLoading ? validation : null}\n </div>\n ) : null}\n {suffix}\n </div>\n ) : null}\n </DateInputWrapperElement>\n );\n}\n\nconst _DateInputBase = React.forwardRef(DateInputBase);\n\n_DateInputBase.displayName = 'DateInputBase';\n\nexport { _DateInputBase as DateInputBase };\n"],"mappings":";;;;;;;;;;;;;AAqBA,MAAM,0BAA0B,MAAM;CACpC,IAAI;CACJ,MAAM;CACN,QAAQ;EACN,GAAG;EACH,SAAS;EACV;CACF,CAAC;AAEF,MAAM,mBAAmB,MAAM;CAC7B,MAAM;CACN,QAAQ;EACN,GAAG;EACH,QAAQ;GACN,IAAI;GACJ,cAAc;GACd,cAAc;GACf;EACD,SAAS;EACT,MAAM;EACN,YAAY;EACb;CACF,CAAC;AAmBF,SAAS,cAAc,OAA+B,KAAK;CACzD,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EACF,IACA,WACA,YACA,aACA,UACA,YACA,OACA,kBACA,WACA,iBACA,WACA,OAAO,UACP,WACE;CAEJ,IAAI,SAAS,cAAc,OAAO,iBAAiB;CAEnD,IAAI,EAAE,YAAY,cAAc,aAAa;EAC3C,aAAa;EACb,QAAQ;EACR;EACD,CAAC;CAEF,IAAI,YAAY,oBAAoB;CAEpC,IAAI,aAAa,aADI,YAAY,cAAc,UACF;AAE7C,QACE,qBAAC;EACC,IAAI,MAAM;EACF;EACR,aAAW;EACX,mBAAiB,YAAY,YAAY;EACzC,MAAM;GACJ,UAAU;GACV,SAAS,aAAa,CAAC;GACvB,SAAS;GACT,QAAS,mBAAmB,CAAC,aAAc,aAAa,CAAC,CAAC;GAC3D;EACD,GAAIA,aAAW,cAAc,EAAE,EAAE,WAAW;EACrC;aAEP,oBAAC;GAAI,gBAAa;GAAW,MAAK;aAChC,oBAAC;IACC,KAAK,UAAU,KAAK,SAAS;IAC7B,aAAW;IACX,MAAK;IACL,QAAQ;IAEP;KACgB;IACf,EACJ,mBAAmB,CAAC,aAAc,aAAa,SAC/C,qBAAC;GAAI,gBAAa;cACd,mBAAmB,CAAC,aAAc,YAClC,oBAAC;IAAI,gBAAa;cACf,mBAAmB,CAAC,YAAY,aAAa;KAC1C,GACJ,MACH;IACG,GACJ;GACoB;;AAI9B,MAAM,iBAAiB,MAAM,WAAW,cAAc;AAEtD,eAAe,cAAc"}
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { useFormProps } from "../../form/Form/Form.js";
@@ -14,7 +15,7 @@ import { _Calendar } from "../../other/Calendar/Calendar.js";
14
15
  import { DatePickerButton } from "./DatePickerButton.js";
15
16
  import { DatePickerInput } from "./DatePickerInput.js";
16
17
  import { dateMessages } from "./intl.js";
17
- import { CONTAINER_STYLES, extractStyles } from "@tenphi/tasty";
18
+ import { CONTAINER_STYLES } from "@tenphi/tasty";
18
19
  import { forwardRef, useRef } from "react";
19
20
  import { jsx, jsxs } from "react/jsx-runtime";
20
21
  import { useDatePicker, useFocusRing } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"DatePicker.js","names":["DateInputBase","mergeProps","Calendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DatePicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDatePickerProps,\n DateValue,\n useDatePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDatePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Calendar } from '../../other/Calendar/Calendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nexport interface CubeDatePickerProps<T extends DateValue = DateValue>\n extends Omit<AriaDatePickerProps<T>, 'errorMessage'>,\n DateFieldBase<T>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n triggerStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DatePicker<T extends DateValue>(\n props: CubeDatePickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n let state = useDatePickerState({\n ...props,\n shouldCloseOnSelect: () => !state.hasTime,\n });\n let { isOpen, setOpen } = state;\n\n let domRef = useFocusManagerRef(ref);\n\n let { isFocused, focusProps } = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n\n let { isFocused: isFocusedButton, focusProps: focusPropsButton } =\n useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let {\n groupProps,\n labelProps,\n fieldProps,\n buttonProps,\n dialogProps,\n calendarProps,\n } = useDatePicker(props, state, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n const component = (\n <DateInputBase\n ref={targetRef}\n qa={qa || 'DatePicker'}\n inputType=\"datepicker\"\n styles={props.wrapperStyles}\n disableFocusRing={isFocusedButton}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n fieldProps={groupProps}\n {...focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(buttonProps, focusPropsButton)}\n isDisabled={isDisabled}\n />\n <Dialog {...dialogProps} width=\"max-content\">\n <Calendar {...calendarProps} />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={state.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={state.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...fieldProps} />\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DatePicker = forwardRef(DatePicker);\n\n_DatePicker.displayName = 'DatePicker';\n\nexport { _DatePicker as DatePicker };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAkDA,SAAS,WACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,MACA,kBACA,YACA,iBACA,WAAW,eACX,cACE;CACJ,IAAI,YAAY,OAAuB,KAAK;CAC5C,IAAI,QAAQ,mBAAmB;EAC7B,GAAG;EACH,2BAA2B,CAAC,MAAM;EACnC,CAAC;CACF,IAAI,EAAE,QAAQ,YAAY;CAE1B,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,EAAE,WAAW,eAAe,aAAa;EAC3C,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEF,IAAI,EAAE,WAAW,iBAAiB,YAAY,qBAC5C,aAAa;EACX,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEJ,IAAI,EACF,YACA,YACA,YACA,aACA,aACA,kBACE,cAAc,OAAO,OAAO,UAAU;CAE1C,IAAI,cAAqC;CACzC,IAAI,kBACF,eAAe,UAAU,cAAc,cAAc;CACvD,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,kBACF,MAAM,gBAAgB,UACtB,MAAM,gBAAgB,YACtB,MAAM,gBAAgB,WAClB,MAAM,cACN;CACN,IAAI,gBAAgB,CAAC,CAAC;AAuDtB,QAAO,cAnDL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACV,QAAQ,MAAM;EACd,kBAAkB;EACN;EACK;EACX;EACN,YAAY;EACZ,GAAI;EACJ,QACE,qBAAC;GACC;GACA,MAAK;GACL,YAAW;GACX,WAAU;GACC;GACH;GACR,YAAY,MAAM;GAClB,cAAc;cAEd,oBAAC;IACO;IACN,GAAIC,aAAW,aAAa,iBAAiB;IACjC;KACZ,EACF,qBAAC;IAAO,GAAI;IAAa,OAAM;eAC7B,oBAACC,aAAS,GAAI,gBAAiB,EAC9B,iBACC,oBAACC;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM;KACb,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,UAAU,MAAM;MAChB;KAEG;IACK;YAGlB,oBAAC;GAAgB,WAAW;GAAe,GAAI;IAAc;GAC/C,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYF,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;AAGJ,MAAM,cAAc,WAAW,WAAW;AAE1C,YAAY,cAAc"}
1
+ {"version":3,"file":"DatePicker.js","names":["DateInputBase","mergeProps","Calendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DatePicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDatePickerProps,\n DateValue,\n useDatePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDatePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Calendar } from '../../other/Calendar/Calendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nexport interface CubeDatePickerProps<T extends DateValue = DateValue>\n extends Omit<AriaDatePickerProps<T>, 'errorMessage'>,\n DateFieldBase<T>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n triggerStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DatePicker<T extends DateValue>(\n props: CubeDatePickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n let state = useDatePickerState({\n ...props,\n shouldCloseOnSelect: () => !state.hasTime,\n });\n let { isOpen, setOpen } = state;\n\n let domRef = useFocusManagerRef(ref);\n\n let { isFocused, focusProps } = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n\n let { isFocused: isFocusedButton, focusProps: focusPropsButton } =\n useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let {\n groupProps,\n labelProps,\n fieldProps,\n buttonProps,\n dialogProps,\n calendarProps,\n } = useDatePicker(props, state, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n const component = (\n <DateInputBase\n ref={targetRef}\n qa={qa || 'DatePicker'}\n inputType=\"datepicker\"\n styles={props.wrapperStyles}\n disableFocusRing={isFocusedButton}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n fieldProps={groupProps}\n {...focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(buttonProps, focusPropsButton)}\n isDisabled={isDisabled}\n />\n <Dialog {...dialogProps} width=\"max-content\">\n <Calendar {...calendarProps} />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={state.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={state.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...fieldProps} />\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DatePicker = forwardRef(DatePicker);\n\n_DatePicker.displayName = 'DatePicker';\n\nexport { _DatePicker as DatePicker };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAkDA,SAAS,WACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,MACA,kBACA,YACA,iBACA,WAAW,eACX,cACE;CACJ,IAAI,YAAY,OAAuB,KAAK;CAC5C,IAAI,QAAQ,mBAAmB;EAC7B,GAAG;EACH,2BAA2B,CAAC,MAAM;EACnC,CAAC;CACF,IAAI,EAAE,QAAQ,YAAY;CAE1B,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,EAAE,WAAW,eAAe,aAAa;EAC3C,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEF,IAAI,EAAE,WAAW,iBAAiB,YAAY,qBAC5C,aAAa;EACX,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEJ,IAAI,EACF,YACA,YACA,YACA,aACA,aACA,kBACE,cAAc,OAAO,OAAO,UAAU;CAE1C,IAAI,cAAqC;CACzC,IAAI,kBACF,eAAe,UAAU,cAAc,cAAc;CACvD,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,kBACF,MAAM,gBAAgB,UACtB,MAAM,gBAAgB,YACtB,MAAM,gBAAgB,WAClB,MAAM,cACN;CACN,IAAI,gBAAgB,CAAC,CAAC;AAuDtB,QAAO,cAnDL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACV,QAAQ,MAAM;EACd,kBAAkB;EACN;EACK;EACX;EACN,YAAY;EACZ,GAAI;EACJ,QACE,qBAAC;GACC;GACA,MAAK;GACL,YAAW;GACX,WAAU;GACC;GACH;GACR,YAAY,MAAM;GAClB,cAAc;cAEd,oBAAC;IACO;IACN,GAAIC,aAAW,aAAa,iBAAiB;IACjC;KACZ,EACF,qBAAC;IAAO,GAAI;IAAa,OAAM;eAC7B,oBAACC,aAAS,GAAI,gBAAiB,EAC9B,iBACC,oBAACC;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM;KACb,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,UAAU,MAAM;MAChB;KAEG;IACK;YAGlB,oBAAC;GAAgB,WAAW;GAAe,GAAI;IAAc;GAC/C,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYF,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;AAGJ,MAAM,cAAc,WAAW,WAAW;AAE1C,YAAY,cAAc"}
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { ItemAction } from "../../actions/ItemAction/ItemAction.js";
3
3
  import { CalendarIcon } from "../../../icons/CalendarIcon.js";
4
4
  import { tasty } from "@tenphi/tasty";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { Space } from "../../layout/Space.js";
3
3
  import { tasty } from "@tenphi/tasty";
4
4
 
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
3
  import { DatePickerSegment } from "./DatePickerSegment.js";
4
4
  import { formatSegments } from "./utils.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { tasty } from "@tenphi/tasty";
3
3
  import { useRef } from "react";
4
4
  import { jsx } from "react/jsx-runtime";
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { Space } from "../../layout/Space.js";
@@ -15,7 +16,7 @@ import { DatePickerButton } from "./DatePickerButton.js";
15
16
  import { DatePickerInput } from "./DatePickerInput.js";
16
17
  import { dateMessages } from "./intl.js";
17
18
  import { _RangeCalendar } from "../../other/Calendar/RangeCalendar.js";
18
- import { CONTAINER_STYLES, extractStyles, tasty } from "@tenphi/tasty";
19
+ import { CONTAINER_STYLES, tasty } from "@tenphi/tasty";
19
20
  import { forwardRef, useRef } from "react";
20
21
  import { jsx, jsxs } from "react/jsx-runtime";
21
22
  import { useDateRangePicker, useFocusRing } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"DateRangePicker.js","names":["DateInputBase","mergeProps","RangeCalendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DateRangePicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDateRangePickerProps,\n DateValue,\n useDateRangePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDateRangePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Space } from '../../layout/Space';\nimport { RangeCalendar } from '../../other/Calendar/RangeCalendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nconst DateRangeDash = tasty({\n 'aria-hidden': 'true',\n 'data-qa': 'DateRangeDash',\n children: '–',\n styles: {\n padding: '0 .5x',\n },\n});\n\nexport interface CubeDateRangePickerProps<T extends DateValue = DateValue>\n extends Omit<AriaDateRangePickerProps<T>, 'errorMessage'>,\n BaseProps,\n DateFieldBase<T>,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DateRangePicker<T extends DateValue>(\n props: CubeDateRangePickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n shouldFlip,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n let state = useDateRangePickerState({\n ...props,\n shouldCloseOnSelect: () => !state.hasTime,\n });\n let { isOpen, setOpen } = state;\n\n let { isFocused, focusProps } = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n\n let { isFocused: isFocusedButton, focusProps: focusPropsButton } =\n useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let domRef = useFocusManagerRef(ref);\n\n let {\n groupProps,\n labelProps,\n startFieldProps,\n endFieldProps,\n buttonProps,\n dialogProps,\n calendarProps,\n } = useDateRangePicker(props, state, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n const component = (\n <DateInputBase\n ref={targetRef}\n qa={qa || 'DateRangePicker'}\n inputType=\"daterangepicker\"\n styles={props.wrapperStyles}\n disableFocusRing={isFocusedButton}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n fieldProps={groupProps}\n {...focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={isOpen}\n shouldFlip={shouldFlip}\n onOpenChange={setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(buttonProps, focusPropsButton)}\n isDisabled={isDisabled}\n />\n <Dialog {...dialogProps} width=\"max-content\">\n <RangeCalendar {...calendarProps} />\n {showTimeField && (\n <Space>\n <TimeInput\n padding=\"1x\"\n label={dateMessages['startTime']}\n value={state.timeRange?.start || null}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={(v) => state.setTime('start', v)}\n />\n <TimeInput\n padding=\"1x\"\n label={dateMessages['endTime']}\n value={state.timeRange?.end || null}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={(v) => state.setTime('end', v)}\n />\n </Space>\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...startFieldProps} />\n <DateRangeDash />\n <DatePickerInput useLocale={useLocaleProp} {...endFieldProps} />\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DateRangePicker = forwardRef(DateRangePicker) as typeof DateRangePicker;\n\n(_DateRangePicker as any).displayName = 'DateRangePicker';\n\nexport { _DateRangePicker as DateRangePicker };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAmCA,MAAM,gBAAgB,MAAM;CAC1B,eAAe;CACf,WAAW;CACX,UAAU;CACV,QAAQ,EACN,SAAS,SACV;CACF,CAAC;AAkBF,SAAS,gBACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,MACA,YACA,kBACA,YACA,iBACA,WAAW,eACX,cACE;CACJ,IAAI,YAAY,OAAuB,KAAK;CAC5C,IAAI,QAAQ,wBAAwB;EAClC,GAAG;EACH,2BAA2B,CAAC,MAAM;EACnC,CAAC;CACF,IAAI,EAAE,QAAQ,YAAY;CAE1B,IAAI,EAAE,WAAW,eAAe,aAAa;EAC3C,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEF,IAAI,EAAE,WAAW,iBAAiB,YAAY,qBAC5C,aAAa;EACX,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEJ,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,EACF,YACA,YACA,iBACA,eACA,aACA,aACA,kBACE,mBAAmB,OAAO,OAAO,UAAU;CAE/C,IAAI,cAAqC;CACzC,IAAI,kBACF,eAAe,UAAU,cAAc,cAAc;CACvD,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,kBACF,MAAM,gBAAgB,UACtB,MAAM,gBAAgB,YACtB,MAAM,gBAAgB,WAClB,MAAM,cACN;CACN,IAAI,gBAAgB,CAAC,CAAC;AAuEtB,QAAO,cAnEL,qBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACV,QAAQ,MAAM;EACd,kBAAkB;EACN;EACK;EACX;EACN,YAAY;EACZ,GAAI;EACJ,QACE,qBAAC;GACC;GACA,MAAK;GACL,YAAW;GACX,WAAU;GACC;GACH;GACI;GACZ,cAAc;cAEd,oBAAC;IACO;IACN,GAAIC,aAAW,aAAa,iBAAiB;IACjC;KACZ,EACF,qBAAC;IAAO,GAAI;IAAa,OAAM;eAC7B,oBAACC,kBAAc,GAAI,gBAAiB,EACnC,iBACC,qBAAC,oBACC,oBAACC;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM,WAAW,SAAS;KACjC,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,WAAW,MAAM,MAAM,QAAQ,SAAS,EAAE;MAC1C,EACF,oBAACA;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM,WAAW,OAAO;KAC/B,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,WAAW,MAAM,MAAM,QAAQ,OAAO,EAAE;MACxC,IACI;KAEH;IACK;;GAGlB,oBAAC;IAAgB,WAAW;IAAe,GAAI;KAAmB;GAClE,oBAAC,kBAAgB;GACjB,oBAAC;IAAgB,WAAW;IAAe,GAAI;KAAiB;;GAClD,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYF,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;AAGJ,MAAM,mBAAmB,WAAW,gBAAgB;AAEpD,AAAC,iBAAyB,cAAc"}
1
+ {"version":3,"file":"DateRangePicker.js","names":["DateInputBase","mergeProps","RangeCalendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DateRangePicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaDateRangePickerProps,\n DateValue,\n useDateRangePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDateRangePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Space } from '../../layout/Space';\nimport { RangeCalendar } from '../../other/Calendar/RangeCalendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nconst DateRangeDash = tasty({\n 'aria-hidden': 'true',\n 'data-qa': 'DateRangeDash',\n children: '–',\n styles: {\n padding: '0 .5x',\n },\n});\n\nexport interface CubeDateRangePickerProps<T extends DateValue = DateValue>\n extends Omit<AriaDateRangePickerProps<T>, 'errorMessage'>,\n BaseProps,\n DateFieldBase<T>,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DateRangePicker<T extends DateValue>(\n props: CubeDateRangePickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n shouldFlip,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n let state = useDateRangePickerState({\n ...props,\n shouldCloseOnSelect: () => !state.hasTime,\n });\n let { isOpen, setOpen } = state;\n\n let { isFocused, focusProps } = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n\n let { isFocused: isFocusedButton, focusProps: focusPropsButton } =\n useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let domRef = useFocusManagerRef(ref);\n\n let {\n groupProps,\n labelProps,\n startFieldProps,\n endFieldProps,\n buttonProps,\n dialogProps,\n calendarProps,\n } = useDateRangePicker(props, state, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n const component = (\n <DateInputBase\n ref={targetRef}\n qa={qa || 'DateRangePicker'}\n inputType=\"daterangepicker\"\n styles={props.wrapperStyles}\n disableFocusRing={isFocusedButton}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n fieldProps={groupProps}\n {...focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={isOpen}\n shouldFlip={shouldFlip}\n onOpenChange={setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(buttonProps, focusPropsButton)}\n isDisabled={isDisabled}\n />\n <Dialog {...dialogProps} width=\"max-content\">\n <RangeCalendar {...calendarProps} />\n {showTimeField && (\n <Space>\n <TimeInput\n padding=\"1x\"\n label={dateMessages['startTime']}\n value={state.timeRange?.start || null}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={(v) => state.setTime('start', v)}\n />\n <TimeInput\n padding=\"1x\"\n label={dateMessages['endTime']}\n value={state.timeRange?.end || null}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={(v) => state.setTime('end', v)}\n />\n </Space>\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...startFieldProps} />\n <DateRangeDash />\n <DatePickerInput useLocale={useLocaleProp} {...endFieldProps} />\n </DateInputBase>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DateRangePicker = forwardRef(DateRangePicker) as typeof DateRangePicker;\n\n(_DateRangePicker as any).displayName = 'DateRangePicker';\n\nexport { _DateRangePicker as DateRangePicker };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAmCA,MAAM,gBAAgB,MAAM;CAC1B,eAAe;CACf,WAAW;CACX,UAAU;CACV,QAAQ,EACN,SAAS,SACV;CACF,CAAC;AAkBF,SAAS,gBACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,MACA,YACA,kBACA,YACA,iBACA,WAAW,eACX,cACE;CACJ,IAAI,YAAY,OAAuB,KAAK;CAC5C,IAAI,QAAQ,wBAAwB;EAClC,GAAG;EACH,2BAA2B,CAAC,MAAM;EACnC,CAAC;CACF,IAAI,EAAE,QAAQ,YAAY;CAE1B,IAAI,EAAE,WAAW,eAAe,aAAa;EAC3C,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEF,IAAI,EAAE,WAAW,iBAAiB,YAAY,qBAC5C,aAAa;EACX,QAAQ;EACR,aAAa;EACb;EACD,CAAC;CAEJ,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,EACF,YACA,YACA,iBACA,eACA,aACA,aACA,kBACE,mBAAmB,OAAO,OAAO,UAAU;CAE/C,IAAI,cAAqC;CACzC,IAAI,kBACF,eAAe,UAAU,cAAc,cAAc;CACvD,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,eACF,MAAM,YAAY,UAAU,MAAM,WAAW,MAAM,WAAW;CAChE,IAAI,kBACF,MAAM,gBAAgB,UACtB,MAAM,gBAAgB,YACtB,MAAM,gBAAgB,WAClB,MAAM,cACN;CACN,IAAI,gBAAgB,CAAC,CAAC;AAuEtB,QAAO,cAnEL,qBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACV,QAAQ,MAAM;EACd,kBAAkB;EACN;EACK;EACX;EACN,YAAY;EACZ,GAAI;EACJ,QACE,qBAAC;GACC;GACA,MAAK;GACL,YAAW;GACX,WAAU;GACC;GACH;GACI;GACZ,cAAc;cAEd,oBAAC;IACO;IACN,GAAIC,aAAW,aAAa,iBAAiB;IACjC;KACZ,EACF,qBAAC;IAAO,GAAI;IAAa,OAAM;eAC7B,oBAACC,kBAAc,GAAI,gBAAiB,EACnC,iBACC,qBAAC,oBACC,oBAACC;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM,WAAW,SAAS;KACjC,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,WAAW,MAAM,MAAM,QAAQ,SAAS,EAAE;MAC1C,EACF,oBAACA;KACC,SAAQ;KACR,OAAO,aAAa;KACpB,OAAO,MAAM,WAAW,OAAO;KAC/B,kBAAkB;KAClB,aAAa;KACb,UAAU;KACV,UAAU;KACV,WAAW,MAAM;KACjB,cAAc,MAAM;KACpB,WAAW,MAAM,MAAM,QAAQ,OAAO,EAAE;MACxC,IACI;KAEH;IACK;;GAGlB,oBAAC;IAAgB,WAAW;IAAe,GAAI;KAAmB;GAClE,oBAAC,kBAAgB;GACjB,oBAAC;IAAgB,WAAW;IAAe,GAAI;KAAiB;;GAClD,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYF,aAAW,MAAM,YAAY,WAAW;EACrD,CAAC;;AAGJ,MAAM,mBAAmB,WAAW,gBAAgB;AAEpD,AAAC,iBAAyB,cAAc"}
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { useFormProps } from "../../form/Form/Form.js";
@@ -15,7 +16,7 @@ import { DatePickerButton } from "./DatePickerButton.js";
15
16
  import { DatePickerInput } from "./DatePickerInput.js";
16
17
  import { dateMessages } from "./intl.js";
17
18
  import { DatePickerElement } from "./DatePickerElement.js";
18
- import { CONTAINER_STYLES, extractStyles, tasty } from "@tenphi/tasty";
19
+ import { CONTAINER_STYLES, tasty } from "@tenphi/tasty";
19
20
  import { forwardRef, useRef } from "react";
20
21
  import { jsx, jsxs } from "react/jsx-runtime";
21
22
  import { useDatePicker, useDateRangePicker, useFocusRing } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"DateRangeSeparatedPicker.js","names":["DateInputBase","mergeProps","Calendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DateRangeSeparatedPicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport { forwardRef, ReactElement, useRef } from 'react';\nimport {\n AriaDateRangePickerProps,\n DateValue,\n useDatePicker,\n useDateRangePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDatePickerState, useDateRangePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Calendar } from '../../other/Calendar/Calendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerElement } from './DatePickerElement';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nconst DateRangeDash = tasty({\n 'aria-hidden': 'true',\n 'data-qa': 'DateRangeDash',\n children: '–',\n styles: {\n padding: '0 .5x',\n color: '#dark-03',\n },\n});\n\nexport interface CubeDateRangeSeparatedPickerProps<\n T extends DateValue = DateValue,\n> extends Omit<AriaDateRangePickerProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n DateFieldBase<T>,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DateRangeSeparatedPicker<T extends DateValue>(\n props: CubeDateRangeSeparatedPickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n\n let state = useDateRangePickerState({\n ...props,\n });\n\n let startState = useDatePickerState({\n ...props,\n onChange: null,\n value: state.value?.start,\n });\n\n let endState = useDatePickerState({\n ...props,\n onChange: null,\n value: state.value?.end,\n });\n\n let startFocusRingProps = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n let startFocusProps = useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n let endFocusRingProps = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n let endFocusProps = useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let domRef = useFocusManagerRef(ref);\n\n let { groupProps, labelProps, startFieldProps, endFieldProps } =\n useDateRangePicker(props, state, targetRef);\n\n let startProps = useDatePicker(props, startState, targetRef);\n let endProps = useDatePicker(props, endState, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n function onChange(value: DateValue, type: 'start' | 'end') {\n if (type === 'start') {\n const newRange = { ...state.value, start: value };\n\n if (\n newRange.start &&\n newRange.end &&\n newRange.end.compare(newRange.start) < 0\n ) {\n newRange.end = newRange.start;\n }\n\n state.setValue(newRange);\n startProps.calendarProps.onChange(value);\n startState.setOpen(false);\n } else {\n const newRange = { ...state.value, end: value };\n\n if (\n newRange.start &&\n newRange.end &&\n newRange.end.compare(newRange.start) < 0\n ) {\n newRange.start = newRange.end;\n }\n\n state.setValue(newRange);\n endProps.calendarProps.onChange(value);\n endState.setOpen(false);\n }\n }\n\n const component = (\n <DatePickerElement\n ref={targetRef}\n {...groupProps}\n styles={props.wrapperStyles}\n qa={qa || 'DateRangeSeparatedPicker'}\n data-input-type=\"daterangeseparatedpicker\"\n >\n <DateInputBase\n disableFocusRing={startFocusProps.isFocused}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n {...startFocusRingProps.focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={startState.isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={startState.setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(\n startProps.buttonProps,\n startFocusProps.focusProps,\n )}\n isDisabled={isDisabled}\n />\n <Dialog {...startProps.dialogProps} width=\"max-content\">\n <Calendar\n {...startProps.calendarProps}\n defaultFocusedValue={\n state.value?.start || state.value?.end || undefined\n }\n selectedRange={\n state.value?.start && state.value?.end\n ? state.value\n : undefined\n }\n onChange={(value: DateValue) => onChange(value, 'start')}\n />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={startState.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={startState.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...startFieldProps} />\n </DateInputBase>\n <DateRangeDash />\n <DateInputBase\n disableFocusRing={endFocusProps.isFocused}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n {...endFocusRingProps.focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={endState.isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={endState.setOpen}\n >\n <DatePickerButton\n aria-label=\"Show calendar for the end date\"\n size={size}\n {...mergeProps(endFocusProps.focusProps, endProps.buttonProps)}\n isDisabled={isDisabled}\n />\n <Dialog {...endProps.dialogProps} width=\"max-content\">\n <Calendar\n {...endProps.calendarProps}\n defaultFocusedValue={\n state.value?.end || state.value?.start || undefined\n }\n selectedRange={\n state.value?.start && state.value?.end\n ? state.value\n : undefined\n }\n onChange={(value: DateValue) => {\n onChange(value, 'end');\n }}\n />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={endState.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={endState.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...endFieldProps} />\n </DateInputBase>\n </DatePickerElement>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DateRangeSeparatedPicker = forwardRef(DateRangeSeparatedPicker) as <\n T extends DateValue,\n>(\n props: CubeDateRangeSeparatedPickerProps<T> & {\n ref?: FocusableRef<HTMLElement>;\n },\n) => ReactElement;\n\n(_DateRangeSeparatedPicker as any).displayName = 'DateRangeSeparatedPicker';\n\nexport { _DateRangeSeparatedPicker as DateRangeSeparatedPicker };\n"],"mappings":"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"}
1
+ {"version":3,"file":"DateRangeSeparatedPicker.js","names":["DateInputBase","mergeProps","Calendar","TimeInput"],"sources":["../../../../src/components/fields/DatePicker/DateRangeSeparatedPicker.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport { forwardRef, ReactElement, useRef } from 'react';\nimport {\n AriaDateRangePickerProps,\n DateValue,\n useDatePicker,\n useDateRangePicker,\n useFocusRing,\n} from 'react-aria';\nimport { useDatePickerState, useDateRangePickerState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Calendar } from '../../other/Calendar/Calendar';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerButton } from './DatePickerButton';\nimport { DatePickerElement } from './DatePickerElement';\nimport { DatePickerInput } from './DatePickerInput';\nimport { dateMessages } from './intl';\nimport { DEFAULT_DATE_PROPS } from './props';\nimport { TimeInput } from './TimeInput';\nimport { DateFieldBase } from './types';\nimport { useFocusManagerRef } from './utils';\n\nconst DateRangeDash = tasty({\n 'aria-hidden': 'true',\n 'data-qa': 'DateRangeDash',\n children: '–',\n styles: {\n padding: '0 .5x',\n color: '#dark-03',\n },\n});\n\nexport interface CubeDateRangeSeparatedPickerProps<\n T extends DateValue = DateValue,\n> extends Omit<AriaDateRangePickerProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n DateFieldBase<T>,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n maxVisibleMonths?: number;\n shouldFlip?: boolean;\n useLocale?: boolean;\n}\n\nfunction DateRangeSeparatedPicker<T extends DateValue>(\n props: CubeDateRangeSeparatedPickerProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_DATE_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n size,\n placeholderValue,\n isDisabled,\n validationState,\n useLocale: useLocaleProp,\n autoFocus,\n } = props;\n let targetRef = useRef<HTMLDivElement>(null);\n\n let state = useDateRangePickerState({\n ...props,\n });\n\n let startState = useDatePickerState({\n ...props,\n onChange: null,\n value: state.value?.start,\n });\n\n let endState = useDatePickerState({\n ...props,\n onChange: null,\n value: state.value?.end,\n });\n\n let startFocusRingProps = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n let startFocusProps = useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n let endFocusRingProps = useFocusRing({\n within: true,\n isTextInput: true,\n autoFocus,\n });\n let endFocusProps = useFocusRing({\n within: false,\n isTextInput: false,\n autoFocus,\n });\n\n let domRef = useFocusManagerRef(ref);\n\n let { groupProps, labelProps, startFieldProps, endFieldProps } =\n useDateRangePicker(props, state, targetRef);\n\n let startProps = useDatePicker(props, startState, targetRef);\n let endProps = useDatePicker(props, endState, targetRef);\n\n let placeholder: DateValue | undefined = placeholderValue;\n let timePlaceholder =\n placeholder && 'hour' in placeholder ? placeholder : undefined;\n let timeMinValue =\n props.minValue && 'hour' in props.minValue ? props.minValue : undefined;\n let timeMaxValue =\n props.maxValue && 'hour' in props.maxValue ? props.maxValue : undefined;\n let timeGranularity =\n state.granularity === 'hour' ||\n state.granularity === 'minute' ||\n state.granularity === 'second'\n ? state.granularity\n : null;\n let showTimeField = !!timeGranularity;\n\n // let visibleMonths = useVisibleMonths(maxVisibleMonths);\n\n function onChange(value: DateValue, type: 'start' | 'end') {\n if (type === 'start') {\n const newRange = { ...state.value, start: value };\n\n if (\n newRange.start &&\n newRange.end &&\n newRange.end.compare(newRange.start) < 0\n ) {\n newRange.end = newRange.start;\n }\n\n state.setValue(newRange);\n startProps.calendarProps.onChange(value);\n startState.setOpen(false);\n } else {\n const newRange = { ...state.value, end: value };\n\n if (\n newRange.start &&\n newRange.end &&\n newRange.end.compare(newRange.start) < 0\n ) {\n newRange.start = newRange.end;\n }\n\n state.setValue(newRange);\n endProps.calendarProps.onChange(value);\n endState.setOpen(false);\n }\n }\n\n const component = (\n <DatePickerElement\n ref={targetRef}\n {...groupProps}\n styles={props.wrapperStyles}\n qa={qa || 'DateRangeSeparatedPicker'}\n data-input-type=\"daterangeseparatedpicker\"\n >\n <DateInputBase\n disableFocusRing={startFocusProps.isFocused}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n {...startFocusRingProps.focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={startState.isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={startState.setOpen}\n >\n <DatePickerButton\n size={size}\n {...mergeProps(\n startProps.buttonProps,\n startFocusProps.focusProps,\n )}\n isDisabled={isDisabled}\n />\n <Dialog {...startProps.dialogProps} width=\"max-content\">\n <Calendar\n {...startProps.calendarProps}\n defaultFocusedValue={\n state.value?.start || state.value?.end || undefined\n }\n selectedRange={\n state.value?.start && state.value?.end\n ? state.value\n : undefined\n }\n onChange={(value: DateValue) => onChange(value, 'start')}\n />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={startState.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={startState.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...startFieldProps} />\n </DateInputBase>\n <DateRangeDash />\n <DateInputBase\n disableFocusRing={endFocusProps.isFocused}\n isDisabled={isDisabled}\n validationState={validationState}\n size={size}\n {...endFocusRingProps.focusProps}\n suffix={\n <DialogTrigger\n hideArrow\n type=\"popover\"\n mobileType=\"tray\"\n placement=\"bottom right\"\n targetRef={targetRef}\n isOpen={endState.isOpen}\n shouldFlip={props.shouldFlip}\n onOpenChange={endState.setOpen}\n >\n <DatePickerButton\n aria-label=\"Show calendar for the end date\"\n size={size}\n {...mergeProps(endFocusProps.focusProps, endProps.buttonProps)}\n isDisabled={isDisabled}\n />\n <Dialog {...endProps.dialogProps} width=\"max-content\">\n <Calendar\n {...endProps.calendarProps}\n defaultFocusedValue={\n state.value?.end || state.value?.start || undefined\n }\n selectedRange={\n state.value?.start && state.value?.end\n ? state.value\n : undefined\n }\n onChange={(value: DateValue) => {\n onChange(value, 'end');\n }}\n />\n {showTimeField && (\n <TimeInput\n padding=\"1x\"\n label={dateMessages['time']}\n value={endState.timeValue}\n placeholderValue={timePlaceholder}\n granularity={timeGranularity}\n minValue={timeMinValue}\n maxValue={timeMaxValue}\n hourCycle={props.hourCycle}\n hideTimeZone={props.hideTimeZone}\n onChange={endState.setTimeValue}\n />\n )}\n </Dialog>\n </DialogTrigger>\n }\n >\n <DatePickerInput useLocale={useLocaleProp} {...endFieldProps} />\n </DateInputBase>\n </DatePickerElement>\n );\n\n return wrapWithField(component, domRef, {\n ...props,\n labelProps: mergeProps(props.labelProps, labelProps),\n });\n}\n\nconst _DateRangeSeparatedPicker = forwardRef(DateRangeSeparatedPicker) as <\n T extends DateValue,\n>(\n props: CubeDateRangeSeparatedPickerProps<T> & {\n ref?: FocusableRef<HTMLElement>;\n },\n) => ReactElement;\n\n(_DateRangeSeparatedPicker as any).displayName = 'DateRangeSeparatedPicker';\n\nexport { _DateRangeSeparatedPicker as DateRangeSeparatedPicker };\n"],"mappings":"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"}
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { useFormProps } from "../../form/Form/Form.js";
@@ -8,7 +9,7 @@ import { _DateInputBase } from "./DateInputBase.js";
8
9
  import { DatePickerSegment } from "./DatePickerSegment.js";
9
10
  import { DEFAULT_TIME_PROPS } from "./props.js";
10
11
  import { useFocusManagerRef } from "./utils.js";
11
- import { CONTAINER_STYLES, extractStyles } from "@tenphi/tasty";
12
+ import { CONTAINER_STYLES } from "@tenphi/tasty";
12
13
  import { forwardRef, useRef } from "react";
13
14
  import { jsx } from "react/jsx-runtime";
14
15
  import { useTimeField } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"TimeInput.js","names":["DateInputBase","mergeProps"],"sources":["../../../../src/components/fields/DatePicker/TimeInput.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaTimeFieldProps,\n DateValue,\n TimeValue,\n useTimeField,\n} from 'react-aria';\nimport { useTimeFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerSegment } from './DatePickerSegment';\nimport { DEFAULT_TIME_PROPS } from './props';\nimport { Granularity } from './types';\nimport { useFocusManagerRef } from './utils';\n\nexport interface CubeTimeInputProps<T extends TimeValue = TimeValue>\n extends Omit<AriaTimeFieldProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n value?: TimeValue;\n /** The minimum allowed date that a user may select. */\n minValue?: TimeValue;\n /** The maximum allowed date that a user may select. */\n maxValue?: TimeValue;\n /** Callback that is called for each date of the calendar. If it returns true, then the date is unavailable. */\n isDateUnavailable?: (date: DateValue) => boolean;\n /** A placeholder date that influences the format of the placeholder shown when no value is selected. Defaults to today's date at midnight. */\n placeholderValue?: TimeValue;\n /** Whether to display the time in 12 or 24 hour format. By default, this is determined by the user's locale. */\n hourCycle?: 12 | 24;\n /** Determines the smallest unit that is displayed in the date picker. By default, this is `\"day\"` for dates, and `\"minute\"` for times. */\n granularity?: Granularity;\n /**\n * Whether to hide the time zone abbreviation.\n * @default false\n */\n hideTimeZone?: boolean;\n onChange?: (value: TimeValue) => void;\n}\n\nfunction TimeInput<T extends TimeValue>(\n props: CubeTimeInputProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_TIME_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n inputStyles,\n wrapperStyles,\n autoFocus,\n isDisabled,\n isReadOnly,\n isRequired,\n validationState,\n size = 'medium',\n labelProps: userLabelProps,\n } = props;\n\n let domRef = useFocusManagerRef(ref);\n // let { locale } = useLocale();\n let state = useTimeFieldState({\n ...props,\n locale: 'en-US',\n });\n\n let fieldRef = useRef(null);\n let { labelProps, fieldProps } = useTimeField(props, state, fieldRef);\n\n const timeInput = (\n <DateInputBase\n ref={fieldRef}\n qa={qa || 'TimeInput'}\n inputType=\"timeinput\"\n size={size}\n fieldProps={fieldProps}\n isDisabled={isDisabled}\n autoFocus={autoFocus}\n inputStyles={inputStyles}\n styles={wrapperStyles}\n validationState={validationState}\n >\n {state.segments.map((segment, i) => (\n <DatePickerSegment\n key={i}\n segment={segment}\n state={state}\n isDisabled={isDisabled}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n />\n ))}\n </DateInputBase>\n );\n\n return wrapWithField(timeInput, domRef, {\n ...props,\n labelProps: mergeProps(labelProps, userLabelProps),\n });\n}\n\n/**\n * TimeFields allow users to enter and edit time values using a keyboard.\n * Each part of the time is displayed in an individually editable segment.\n */\nconst _TimeInput = forwardRef(TimeInput);\n\n_TimeInput.displayName = 'TimeInput';\n\nexport { _TimeInput as TimeInput };\n"],"mappings":";;;;;;;;;;;;;;;;;AA2DA,SAAS,UACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,aACA,eACA,WACA,YACA,YACA,YACA,iBACA,OAAO,UACP,YAAY,mBACV;CAEJ,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,QAAQ,kBAAkB;EAC5B,GAAG;EACH,QAAQ;EACT,CAAC;CAEF,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EAAE,YAAY,eAAe,aAAa,OAAO,OAAO,SAAS;AA4BrE,QAAO,cAzBL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACJ;EACM;EACA;EACD;EACE;EACb,QAAQ;EACS;YAEhB,MAAM,SAAS,KAAK,SAAS,MAC5B,oBAAC;GAEU;GACF;GACK;GACA;GACA;KALP,EAML,CACF;GACY,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYC,aAAW,YAAY,eAAe;EACnD,CAAC;;;;;;AAOJ,MAAM,aAAa,WAAW,UAAU;AAExC,WAAW,cAAc"}
1
+ {"version":3,"file":"TimeInput.js","names":["DateInputBase","mergeProps"],"sources":["../../../../src/components/fields/DatePicker/TimeInput.tsx"],"sourcesContent":["import { FocusableRef } from '@react-types/shared';\nimport {\n BaseProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n Styles,\n} from '@tenphi/tasty';\nimport { forwardRef, useRef } from 'react';\nimport {\n AriaTimeFieldProps,\n DateValue,\n TimeValue,\n useTimeField,\n} from 'react-aria';\nimport { useTimeFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps, ValidationState } from '../../../shared';\nimport { mergeProps } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport { DateInputBase } from './DateInputBase';\nimport { DatePickerSegment } from './DatePickerSegment';\nimport { DEFAULT_TIME_PROPS } from './props';\nimport { Granularity } from './types';\nimport { useFocusManagerRef } from './utils';\n\nexport interface CubeTimeInputProps<T extends TimeValue = TimeValue>\n extends Omit<AriaTimeFieldProps<T>, 'errorMessage'>,\n BaseProps,\n ContainerStyleProps,\n FieldBaseProps {\n wrapperStyles?: Styles;\n inputStyles?: Styles;\n styles?: Styles;\n size?: 'small' | 'medium' | 'large' | (string & {});\n validationState?: ValidationState;\n value?: TimeValue;\n /** The minimum allowed date that a user may select. */\n minValue?: TimeValue;\n /** The maximum allowed date that a user may select. */\n maxValue?: TimeValue;\n /** Callback that is called for each date of the calendar. If it returns true, then the date is unavailable. */\n isDateUnavailable?: (date: DateValue) => boolean;\n /** A placeholder date that influences the format of the placeholder shown when no value is selected. Defaults to today's date at midnight. */\n placeholderValue?: TimeValue;\n /** Whether to display the time in 12 or 24 hour format. By default, this is determined by the user's locale. */\n hourCycle?: 12 | 24;\n /** Determines the smallest unit that is displayed in the date picker. By default, this is `\"day\"` for dates, and `\"minute\"` for times. */\n granularity?: Granularity;\n /**\n * Whether to hide the time zone abbreviation.\n * @default false\n */\n hideTimeZone?: boolean;\n onChange?: (value: TimeValue) => void;\n}\n\nfunction TimeInput<T extends TimeValue>(\n props: CubeTimeInputProps<T>,\n ref: FocusableRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n defaultValidationTrigger: 'onBlur',\n });\n props = Object.assign({}, DEFAULT_TIME_PROPS, props);\n\n let styles = extractStyles(props, CONTAINER_STYLES);\n\n let {\n qa,\n inputStyles,\n wrapperStyles,\n autoFocus,\n isDisabled,\n isReadOnly,\n isRequired,\n validationState,\n size = 'medium',\n labelProps: userLabelProps,\n } = props;\n\n let domRef = useFocusManagerRef(ref);\n // let { locale } = useLocale();\n let state = useTimeFieldState({\n ...props,\n locale: 'en-US',\n });\n\n let fieldRef = useRef(null);\n let { labelProps, fieldProps } = useTimeField(props, state, fieldRef);\n\n const timeInput = (\n <DateInputBase\n ref={fieldRef}\n qa={qa || 'TimeInput'}\n inputType=\"timeinput\"\n size={size}\n fieldProps={fieldProps}\n isDisabled={isDisabled}\n autoFocus={autoFocus}\n inputStyles={inputStyles}\n styles={wrapperStyles}\n validationState={validationState}\n >\n {state.segments.map((segment, i) => (\n <DatePickerSegment\n key={i}\n segment={segment}\n state={state}\n isDisabled={isDisabled}\n isReadOnly={isReadOnly}\n isRequired={isRequired}\n />\n ))}\n </DateInputBase>\n );\n\n return wrapWithField(timeInput, domRef, {\n ...props,\n labelProps: mergeProps(labelProps, userLabelProps),\n });\n}\n\n/**\n * TimeFields allow users to enter and edit time values using a keyboard.\n * Each part of the time is displayed in an individually editable segment.\n */\nconst _TimeInput = forwardRef(TimeInput);\n\n_TimeInput.displayName = 'TimeInput';\n\nexport { _TimeInput as TimeInput };\n"],"mappings":";;;;;;;;;;;;;;;;;;AA2DA,SAAS,UACP,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,0BAA0B,UAC3B,CAAC;AACF,SAAQ,OAAO,OAAO,EAAE,EAAE,oBAAoB,MAAM;AAEvC,eAAc,OAAO,iBAAiB;CAEnD,IAAI,EACF,IACA,aACA,eACA,WACA,YACA,YACA,YACA,iBACA,OAAO,UACP,YAAY,mBACV;CAEJ,IAAI,SAAS,mBAAmB,IAAI;CAEpC,IAAI,QAAQ,kBAAkB;EAC5B,GAAG;EACH,QAAQ;EACT,CAAC;CAEF,IAAI,WAAW,OAAO,KAAK;CAC3B,IAAI,EAAE,YAAY,eAAe,aAAa,OAAO,OAAO,SAAS;AA4BrE,QAAO,cAzBL,oBAACA;EACC,KAAK;EACL,IAAI,MAAM;EACV,WAAU;EACJ;EACM;EACA;EACD;EACE;EACb,QAAQ;EACS;YAEhB,MAAM,SAAS,KAAK,SAAS,MAC5B,oBAAC;GAEU;GACF;GACK;GACA;GACA;KALP,EAML,CACF;GACY,EAGc,QAAQ;EACtC,GAAG;EACH,YAAYC,aAAW,YAAY,eAAe;EACnD,CAAC;;;;;;AAOJ,MAAM,aAAa,WAAW,UAAU;AAExC,WAAW,cAAc"}
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  //#region src/components/fields/DatePicker/intl.ts
3
3
  const dateMessages = {
4
4
  time: "Time",
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { parseAbsolute } from "@internationalized/date";
3
3
 
4
4
  //#region src/components/fields/DatePicker/parseDate.ts
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  //#region src/components/fields/DatePicker/props.ts
3
3
  const DEFAULT_DATE_PROPS = {
4
4
  granularity: "day",
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
2
  import { useImperativeHandle, useRef } from "react";
3
3
  import { createDOMRef } from "@react-spectrum/utils";
4
4
  import { createFocusManager } from "@react-aria/focus";
@@ -1,11 +1,12 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { useCombinedRefs } from "../../../utils/react/useCombinedRefs.js";
3
4
  import { useProviderProps } from "../../../provider.js";
4
5
  import { Action } from "../../actions/Action/Action.js";
5
6
  import { useFormProps } from "../../form/Form/Form.js";
6
7
  import { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
7
8
  import { wrapWithField } from "../../form/wrapper.js";
8
- import { CONTAINER_STYLES, extractStyles, tasty } from "@tenphi/tasty";
9
+ import { CONTAINER_STYLES, tasty } from "@tenphi/tasty";
9
10
  import { forwardRef, useCallback, useImperativeHandle, useMemo, useRef, useState } from "react";
10
11
  import { jsx, jsxs } from "react/jsx-runtime";
11
12
  import { createFocusableRef } from "@react-spectrum/utils";
@@ -1 +1 @@
1
- {"version":3,"file":"FileInput.js","names":[],"sources":["../../../../src/components/fields/FileInput/FileInput.tsx"],"sourcesContent":["import { createFocusableRef } from '@react-spectrum/utils';\nimport {\n BaseProps,\n BlockStyleProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n extractStyles,\n PositionStyleProps,\n Props,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n forwardRef,\n RefObject,\n useCallback,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps } from '../../../shared';\nimport { useCombinedRefs } from '../../../utils/react';\nimport { Action } from '../../actions';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport type { AriaTextFieldProps } from 'react-aria';\n\nconst FileInputElement = tasty(Action, {\n qa: 'FileInputWrapper',\n styles: {\n display: 'inline-flex',\n position: 'relative',\n preset: 't3',\n padding: '.5x 1x',\n gap: '1x',\n flow: 'row',\n placeItems: 'center start',\n fill: {\n '': '#white',\n 'drag-hover': '#primary.16',\n ':hover': '#primary.08',\n disabled: '#dark.04',\n },\n border: {\n '': true,\n ':focus-within & :focus-visible': '#primary-text',\n },\n radius: true,\n cursor: '$pointer',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n\n Button: {\n radius: true,\n border: {\n '': '#clear',\n pressed: '#primary.30',\n },\n fill: '#primary.12',\n color: {\n '': '#primary',\n disabled: '#dark.30',\n },\n padding: '.5x (1.5x - 1px)',\n transition: 'theme',\n },\n\n Placeholder: {\n color: '#dark-02',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n width: 'max 100%',\n overflow: 'hidden',\n },\n\n Value: {\n color: '#dark-02',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n width: 'max 100%',\n overflow: 'hidden',\n },\n\n Input: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n radius: '$content-radius',\n opacity: 0.01,\n cursor: '$pointer',\n zIndex: 10,\n },\n },\n});\n\nexport interface CubeFileInputProps\n extends BaseProps,\n PositionStyleProps,\n ContainerStyleProps,\n BlockStyleProps,\n AriaTextFieldProps,\n FieldBaseProps {\n /**\n * The size of the input\n * @default default\n */\n size?: 'small' | 'default' | 'large' | string;\n /** The input ref */\n inputRef?: RefObject<HTMLInputElement>;\n /** Style map for the input */\n inputStyles?: Styles;\n /**\n * The type of the input\n * @default file\n */\n type?: 'file' | 'text';\n /** Direct input props */\n inputProps?: Props;\n /** The file types that the input should accept */\n accept?: string;\n value?: string;\n onChange?: (value: string) => void;\n placeholder?: string;\n}\n\nfunction extractContents(element, callback) {\n const files = element?.files;\n\n if (files && files.length > 0) {\n const fileReader = new FileReader();\n\n fileReader.onload = function () {\n callback(fileReader.result);\n };\n\n fileReader.readAsText(files[0]);\n }\n}\n\nfunction extractFileNameFromValue(value?: string) {\n return typeof value === 'string'\n ? (value as string).split('\\\\')?.pop()\n : undefined;\n}\n\nfunction FileInput(props: CubeFileInputProps, ref) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(\n { ...props },\n {\n defaultValidationTrigger: 'onChange',\n valuePropsMapper: ({ value, onChange }) => ({\n onChange,\n value: props.type === 'file' || !props.type ? value : undefined,\n }),\n },\n );\n\n let {\n id,\n name,\n qa,\n value,\n onChange,\n placeholder,\n inputRef,\n isDisabled,\n inputStyles,\n type = 'file',\n inputProps,\n accept,\n form,\n ...otherProps\n } = props;\n\n const [dragHover, setDragHover] = useState(false);\n const defaultValue = useMemo(\n () => (type === 'file' ? value : undefined),\n [type, value],\n );\n const defaultFileName = useMemo(\n () => extractFileNameFromValue(defaultValue),\n [],\n );\n const [fileName, setFileName] = useState<string | undefined>(defaultFileName);\n\n let domRef = useRef(null);\n\n inputRef = useCombinedRefs(inputRef);\n\n const onLocalChange = useCallback(\n (event: any) => {\n const value = event.target.value;\n\n setFileName(extractFileNameFromValue(value));\n\n if (type === 'file') {\n onChange?.(value);\n } else {\n extractContents(event.target, onChange);\n }\n },\n [onChange],\n );\n\n let styles = extractStyles(otherProps, CONTAINER_STYLES);\n\n // Expose imperative interface for ref\n useImperativeHandle(ref, () => ({\n ...createFocusableRef(domRef, inputRef),\n select() {\n if (inputRef?.current) {\n inputRef.current.select();\n }\n },\n getInputElement() {\n return inputRef?.current;\n },\n }));\n\n const fileInput = (\n <FileInputElement\n ref={domRef}\n styles={inputStyles}\n isDisabled={isDisabled}\n mods={{\n selected: !!value,\n 'drag-hover': dragHover,\n }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === 'Space') {\n inputRef?.current?.click();\n }\n }}\n >\n <input\n ref={inputRef}\n id={id}\n name={name}\n accept={accept}\n data-qa={qa || 'FileInput'}\n data-input-type=\"fileinput\"\n data-element=\"Input\"\n disabled={isDisabled}\n type=\"file\"\n multiple={false}\n tabIndex={-1}\n onChange={onLocalChange}\n onDragEnter={() => {\n setDragHover(true);\n }}\n onDragLeave={() => {\n setDragHover(false);\n }}\n onDrop={() => {\n setDragHover(false);\n }}\n {...inputProps}\n />\n <div data-element=\"Button\">Choose file</div>\n <div data-element={fileName ? 'Value' : 'Placeholder'}>\n {fileName || placeholder || 'No file selected'}\n </div>\n </FileInputElement>\n );\n\n return wrapWithField(fileInput, domRef, {\n ...props,\n });\n}\n\n/**\n * FileInputs are file inputs that allow users to select local files to\n * upload them to the server.\n */\nconst _FileInput = forwardRef(FileInput);\n\n_FileInput.displayName = 'FileInput';\n\nexport { _FileInput as FileInput };\n"],"mappings":";;;;;;;;;;;;;AA8BA,MAAM,mBAAmB,MAAM,QAAQ;CACrC,IAAI;CACJ,QAAQ;EACN,SAAS;EACT,UAAU;EACV,QAAQ;EACR,SAAS;EACT,KAAK;EACL,MAAM;EACN,YAAY;EACZ,MAAM;GACJ,IAAI;GACJ,cAAc;GACd,UAAU;GACV,UAAU;GACX;EACD,QAAQ;GACN,IAAI;GACJ,kCAAkC;GACnC;EACD,QAAQ;EACR,QAAQ;EACR,UAAU;EACV,YAAY;EAEZ,QAAQ;GACN,QAAQ;GACR,QAAQ;IACN,IAAI;IACJ,SAAS;IACV;GACD,MAAM;GACN,OAAO;IACL,IAAI;IACJ,UAAU;IACX;GACD,SAAS;GACT,YAAY;GACb;EAED,aAAa;GACX,OAAO;GACP,YAAY;GACZ,cAAc;GACd,OAAO;GACP,UAAU;GACX;EAED,OAAO;GACL,OAAO;GACP,YAAY;GACZ,cAAc;GACd,OAAO;GACP,UAAU;GACX;EAED,OAAO;GACL,UAAU;GACV,KAAK;GACL,OAAO;GACP,QAAQ;GACR,MAAM;GACN,QAAQ;GACR,SAAS;GACT,QAAQ;GACR,QAAQ;GACT;EACF;CACF,CAAC;AAgCF,SAAS,gBAAgB,SAAS,UAAU;CAC1C,MAAM,QAAQ,SAAS;AAEvB,KAAI,SAAS,MAAM,SAAS,GAAG;EAC7B,MAAM,aAAa,IAAI,YAAY;AAEnC,aAAW,SAAS,WAAY;AAC9B,YAAS,WAAW,OAAO;;AAG7B,aAAW,WAAW,MAAM,GAAG;;;AAInC,SAAS,yBAAyB,OAAgB;AAChD,QAAO,OAAO,UAAU,WACnB,MAAiB,MAAM,KAAK,EAAE,KAAK,GACpC;;AAGN,SAAS,UAAU,OAA2B,KAAK;AACjD,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cACN,EAAE,GAAG,OAAO,EACZ;EACE,0BAA0B;EAC1B,mBAAmB,EAAE,OAAO,gBAAgB;GAC1C;GACA,OAAO,MAAM,SAAS,UAAU,CAAC,MAAM,OAAO,QAAQ;GACvD;EACF,CACF;CAED,IAAI,EACF,IACA,MACA,IACA,OACA,UACA,aACA,UACA,YACA,aACA,OAAO,QACP,YACA,QACA,MACA,GAAG,eACD;CAEJ,MAAM,CAAC,WAAW,gBAAgB,SAAS,MAAM;CACjD,MAAM,eAAe,cACZ,SAAS,SAAS,QAAQ,QACjC,CAAC,MAAM,MAAM,CACd;CAKD,MAAM,CAAC,UAAU,eAAe,SAJR,cAChB,yBAAyB,aAAa,EAC5C,EAAE,CACH,CAC4E;CAE7E,IAAI,SAAS,OAAO,KAAK;AAEzB,YAAW,gBAAgB,SAAS;CAEpC,MAAM,gBAAgB,aACnB,UAAe;EACd,MAAM,QAAQ,MAAM,OAAO;AAE3B,cAAY,yBAAyB,MAAM,CAAC;AAE5C,MAAI,SAAS,OACX,YAAW,MAAM;MAEjB,iBAAgB,MAAM,QAAQ,SAAS;IAG3C,CAAC,SAAS,CACX;AAEY,eAAc,YAAY,iBAAiB;AAGxD,qBAAoB,YAAY;EAC9B,GAAG,mBAAmB,QAAQ,SAAS;EACvC,SAAS;AACP,OAAI,UAAU,QACZ,UAAS,QAAQ,QAAQ;;EAG7B,kBAAkB;AAChB,UAAO,UAAU;;EAEpB,EAAE;AAgDH,QAAO,cA7CL,qBAAC;EACC,KAAK;EACL,QAAQ;EACI;EACZ,MAAM;GACJ,UAAU,CAAC,CAAC;GACZ,cAAc;GACf;EACD,YAAY,MAAM;AAChB,OAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,QACjC,WAAU,SAAS,OAAO;;;GAI9B,oBAAC;IACC,KAAK;IACD;IACE;IACE;IACR,WAAS,MAAM;IACf,mBAAgB;IAChB,gBAAa;IACb,UAAU;IACV,MAAK;IACL,UAAU;IACV,UAAU;IACV,UAAU;IACV,mBAAmB;AACjB,kBAAa,KAAK;;IAEpB,mBAAmB;AACjB,kBAAa,MAAM;;IAErB,cAAc;AACZ,kBAAa,MAAM;;IAErB,GAAI;KACJ;GACF,oBAAC;IAAI,gBAAa;cAAS;KAAiB;GAC5C,oBAAC;IAAI,gBAAc,WAAW,UAAU;cACrC,YAAY,eAAe;KACxB;;GACW,EAGW,QAAQ,EACtC,GAAG,OACJ,CAAC;;;;;;AAOJ,MAAM,aAAa,WAAW,UAAU;AAExC,WAAW,cAAc"}
1
+ {"version":3,"file":"FileInput.js","names":[],"sources":["../../../../src/components/fields/FileInput/FileInput.tsx"],"sourcesContent":["import { createFocusableRef } from '@react-spectrum/utils';\nimport {\n BaseProps,\n BlockStyleProps,\n CONTAINER_STYLES,\n ContainerStyleProps,\n PositionStyleProps,\n Props,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n forwardRef,\n RefObject,\n useCallback,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\n\nimport { useProviderProps } from '../../../provider';\nimport { FieldBaseProps } from '../../../shared';\nimport { useCombinedRefs } from '../../../utils/react';\nimport { extractStyles } from '../../../utils/styles';\nimport { Action } from '../../actions';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport type { AriaTextFieldProps } from 'react-aria';\n\nconst FileInputElement = tasty(Action, {\n qa: 'FileInputWrapper',\n styles: {\n display: 'inline-flex',\n position: 'relative',\n preset: 't3',\n padding: '.5x 1x',\n gap: '1x',\n flow: 'row',\n placeItems: 'center start',\n fill: {\n '': '#white',\n 'drag-hover': '#primary.16',\n ':hover': '#primary.08',\n disabled: '#dark.04',\n },\n border: {\n '': true,\n ':focus-within & :focus-visible': '#primary-text',\n },\n radius: true,\n cursor: '$pointer',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n\n Button: {\n radius: true,\n border: {\n '': '#clear',\n pressed: '#primary.30',\n },\n fill: '#primary.12',\n color: {\n '': '#primary',\n disabled: '#dark.30',\n },\n padding: '.5x (1.5x - 1px)',\n transition: 'theme',\n },\n\n Placeholder: {\n color: '#dark-02',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n width: 'max 100%',\n overflow: 'hidden',\n },\n\n Value: {\n color: '#dark-02',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n width: 'max 100%',\n overflow: 'hidden',\n },\n\n Input: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n radius: '$content-radius',\n opacity: 0.01,\n cursor: '$pointer',\n zIndex: 10,\n },\n },\n});\n\nexport interface CubeFileInputProps\n extends BaseProps,\n PositionStyleProps,\n ContainerStyleProps,\n BlockStyleProps,\n AriaTextFieldProps,\n FieldBaseProps {\n /**\n * The size of the input\n * @default default\n */\n size?: 'small' | 'default' | 'large' | string;\n /** The input ref */\n inputRef?: RefObject<HTMLInputElement>;\n /** Style map for the input */\n inputStyles?: Styles;\n /**\n * The type of the input\n * @default file\n */\n type?: 'file' | 'text';\n /** Direct input props */\n inputProps?: Props;\n /** The file types that the input should accept */\n accept?: string;\n value?: string;\n onChange?: (value: string) => void;\n placeholder?: string;\n}\n\nfunction extractContents(element, callback) {\n const files = element?.files;\n\n if (files && files.length > 0) {\n const fileReader = new FileReader();\n\n fileReader.onload = function () {\n callback(fileReader.result);\n };\n\n fileReader.readAsText(files[0]);\n }\n}\n\nfunction extractFileNameFromValue(value?: string) {\n return typeof value === 'string'\n ? (value as string).split('\\\\')?.pop()\n : undefined;\n}\n\nfunction FileInput(props: CubeFileInputProps, ref) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(\n { ...props },\n {\n defaultValidationTrigger: 'onChange',\n valuePropsMapper: ({ value, onChange }) => ({\n onChange,\n value: props.type === 'file' || !props.type ? value : undefined,\n }),\n },\n );\n\n let {\n id,\n name,\n qa,\n value,\n onChange,\n placeholder,\n inputRef,\n isDisabled,\n inputStyles,\n type = 'file',\n inputProps,\n accept,\n form,\n ...otherProps\n } = props;\n\n const [dragHover, setDragHover] = useState(false);\n const defaultValue = useMemo(\n () => (type === 'file' ? value : undefined),\n [type, value],\n );\n const defaultFileName = useMemo(\n () => extractFileNameFromValue(defaultValue),\n [],\n );\n const [fileName, setFileName] = useState<string | undefined>(defaultFileName);\n\n let domRef = useRef(null);\n\n inputRef = useCombinedRefs(inputRef);\n\n const onLocalChange = useCallback(\n (event: any) => {\n const value = event.target.value;\n\n setFileName(extractFileNameFromValue(value));\n\n if (type === 'file') {\n onChange?.(value);\n } else {\n extractContents(event.target, onChange);\n }\n },\n [onChange],\n );\n\n let styles = extractStyles(otherProps, CONTAINER_STYLES);\n\n // Expose imperative interface for ref\n useImperativeHandle(ref, () => ({\n ...createFocusableRef(domRef, inputRef),\n select() {\n if (inputRef?.current) {\n inputRef.current.select();\n }\n },\n getInputElement() {\n return inputRef?.current;\n },\n }));\n\n const fileInput = (\n <FileInputElement\n ref={domRef}\n styles={inputStyles}\n isDisabled={isDisabled}\n mods={{\n selected: !!value,\n 'drag-hover': dragHover,\n }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === 'Space') {\n inputRef?.current?.click();\n }\n }}\n >\n <input\n ref={inputRef}\n id={id}\n name={name}\n accept={accept}\n data-qa={qa || 'FileInput'}\n data-input-type=\"fileinput\"\n data-element=\"Input\"\n disabled={isDisabled}\n type=\"file\"\n multiple={false}\n tabIndex={-1}\n onChange={onLocalChange}\n onDragEnter={() => {\n setDragHover(true);\n }}\n onDragLeave={() => {\n setDragHover(false);\n }}\n onDrop={() => {\n setDragHover(false);\n }}\n {...inputProps}\n />\n <div data-element=\"Button\">Choose file</div>\n <div data-element={fileName ? 'Value' : 'Placeholder'}>\n {fileName || placeholder || 'No file selected'}\n </div>\n </FileInputElement>\n );\n\n return wrapWithField(fileInput, domRef, {\n ...props,\n });\n}\n\n/**\n * FileInputs are file inputs that allow users to select local files to\n * upload them to the server.\n */\nconst _FileInput = forwardRef(FileInput);\n\n_FileInput.displayName = 'FileInput';\n\nexport { _FileInput as FileInput };\n"],"mappings":"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"}
@@ -1,4 +1,5 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.121.5 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.121.7 | Cube Dev Team */
2
+ import { extractStyles } from "../../../utils/styles.js";
2
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
4
  import { useCombinedRefs } from "../../../utils/react/useCombinedRefs.js";
4
5
  import { modAttrs } from "../../../utils/react/index.js";
@@ -11,7 +12,7 @@ import { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
11
12
  import { wrapWithField } from "../../form/wrapper.js";
12
13
  import { ListBox } from "../ListBox/ListBox.js";
13
14
  import { DEFAULT_INPUT_STYLES, INPUT_WRAPPER_STYLES } from "../TextInput/TextInputBase.js";
14
- import { BASE_STYLES, COLOR_STYLES, OUTER_STYLES, extractStyles, tasty } from "@tenphi/tasty";
15
+ import { BASE_STYLES, COLOR_STYLES, OUTER_STYLES, tasty } from "@tenphi/tasty";
15
16
  import { cloneElement, forwardRef, isValidElement, useCallback, useEffect, useLayoutEffect, useMemo, useRef, useState } from "react";
16
17
  import { jsx, jsxs } from "react/jsx-runtime";
17
18
  import { useFilter, useKeyboard } from "react-aria";