@cube-dev/ui-kit 0.18.2 → 0.20.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (601) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/cjs/_internal/hooks/index.js +4 -1
  3. package/cjs/_internal/hooks/use-chained-callback.js +1 -1
  4. package/cjs/_internal/hooks/use-deprecation-warning.js +1 -1
  5. package/cjs/_internal/hooks/use-effect-once.js +18 -0
  6. package/cjs/_internal/hooks/use-event.js +1 -1
  7. package/cjs/_internal/hooks/use-is-first-render.js +22 -0
  8. package/cjs/_internal/hooks/use-sync-ref.js +1 -1
  9. package/cjs/_internal/hooks/use-timer/index.js +1 -1
  10. package/cjs/_internal/hooks/use-timer/timer.js +1 -1
  11. package/cjs/_internal/hooks/use-timer/use-timer.js +1 -1
  12. package/cjs/_internal/hooks/use-update-effect.js +24 -0
  13. package/cjs/_internal/hooks/use-warn.js +50 -0
  14. package/cjs/_internal/index.js +1 -1
  15. package/cjs/components/Base.js +1 -1
  16. package/cjs/components/Block.js +1 -1
  17. package/cjs/components/GlobalStyles.js +1 -1
  18. package/cjs/components/GridProvider.js +1 -1
  19. package/cjs/components/HiddenInput.js +1 -1
  20. package/cjs/components/OpenTrasition.js +1 -1
  21. package/cjs/components/Root.js +1 -1
  22. package/cjs/components/actions/Action.js +1 -1
  23. package/cjs/components/actions/Button/Button.js +3 -3
  24. package/cjs/components/actions/Button/Submit.js +1 -1
  25. package/cjs/components/actions/Button/index.js +1 -1
  26. package/cjs/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  27. package/cjs/components/actions/index.js +1 -1
  28. package/cjs/components/actions/use-action.js +1 -1
  29. package/cjs/components/content/ActiveZone/ActiveZone.js +1 -1
  30. package/cjs/components/content/Alert/Alert.js +1 -1
  31. package/cjs/components/content/Alert/index.js +1 -1
  32. package/cjs/components/content/Alert/types.js +1 -1
  33. package/cjs/components/content/Alert/use-alert.js +1 -1
  34. package/cjs/components/content/Avatar/Avatar.js +1 -1
  35. package/cjs/components/content/Badge/Badge.js +1 -1
  36. package/cjs/components/content/Card/Card.js +1 -1
  37. package/cjs/components/content/Content.js +1 -1
  38. package/cjs/components/content/CopySnippet/CopySnippet.js +1 -1
  39. package/cjs/components/content/CopySnippet/index.js +1 -1
  40. package/cjs/components/content/Divider.js +1 -1
  41. package/cjs/components/content/Footer.js +1 -1
  42. package/cjs/components/content/Header.js +1 -1
  43. package/cjs/components/content/Paragraph.js +1 -1
  44. package/cjs/components/content/Placeholder/Placeholder.js +1 -1
  45. package/cjs/components/content/PrismCode/PrismCode.js +1 -1
  46. package/cjs/components/content/Result/Result.js +2 -2
  47. package/cjs/components/content/Skeleton/Skeleton.js +1 -1
  48. package/cjs/components/content/Tag/Tag.js +2 -2
  49. package/cjs/components/content/Text.js +1 -1
  50. package/cjs/components/content/Title.js +1 -1
  51. package/cjs/components/forms/Checkbox/Checkbox.js +14 -5
  52. package/cjs/components/forms/Checkbox/CheckboxGroup.js +12 -24
  53. package/cjs/components/forms/Checkbox/context.js +1 -1
  54. package/cjs/components/forms/{FieldWrapper.js → FieldWrapper/FieldWrapper.js} +19 -17
  55. package/cjs/components/forms/FieldWrapper/extract-field-wrapper-props.js +50 -0
  56. package/cjs/components/forms/FieldWrapper/index.js +28 -0
  57. package/cjs/components/forms/FieldWrapper/types.js +11 -0
  58. package/cjs/components/forms/FileInput/FileInput.js +1 -1
  59. package/cjs/components/forms/Form/Field.js +41 -122
  60. package/cjs/components/forms/Form/Form.js +1 -1
  61. package/cjs/components/forms/Form/Submit/Submit.js +25 -0
  62. package/cjs/components/forms/Form/Submit/index.js +26 -0
  63. package/cjs/components/forms/Form/SubmitError.js +1 -1
  64. package/cjs/components/forms/Form/index.js +4 -2
  65. package/cjs/components/forms/Form/types.js +1 -1
  66. package/cjs/components/forms/Form/use-field/index.js +28 -0
  67. package/cjs/components/forms/Form/use-field/types.js +11 -0
  68. package/cjs/components/forms/Form/use-field/use-field-props.js +56 -0
  69. package/cjs/components/forms/Form/use-field/use-field.js +147 -0
  70. package/cjs/components/forms/Form/useForm.js +2 -1
  71. package/cjs/components/forms/Form/validation.js +1 -1
  72. package/cjs/components/forms/Input/Input.js +1 -1
  73. package/cjs/components/forms/Input/index.js +1 -1
  74. package/cjs/components/forms/Label.js +2 -2
  75. package/cjs/components/forms/NumberInput/NumberInput.js +2 -2
  76. package/cjs/components/forms/NumberInput/StepButton.js +1 -1
  77. package/cjs/components/forms/PasswordInput/PasswordInput.js +14 -5
  78. package/cjs/components/forms/RadioGroup/Radio.js +2 -1
  79. package/cjs/components/forms/RadioGroup/RadioGroup.js +2 -1
  80. package/cjs/components/forms/RadioGroup/context.js +1 -1
  81. package/cjs/components/forms/SearchInput/SearchInput.js +3 -4
  82. package/cjs/components/forms/Slider/Gradation.js +1 -1
  83. package/cjs/components/forms/Slider/Header.js +1 -1
  84. package/cjs/components/forms/Slider/RangeSlider.js +1 -1
  85. package/cjs/components/forms/Slider/Slider.js +5 -5
  86. package/cjs/components/forms/Slider/SliderBase.js +10 -3
  87. package/cjs/components/forms/Slider/SliderInput.js +1 -1
  88. package/cjs/components/forms/Slider/SliderThumb.js +1 -1
  89. package/cjs/components/forms/Slider/SliderTrack.js +12 -4
  90. package/cjs/components/forms/Slider/elements.js +14 -1
  91. package/cjs/components/forms/Slider/index.js +1 -1
  92. package/cjs/components/forms/Slider/types.js +1 -1
  93. package/cjs/components/forms/Switch/Switch.js +29 -8
  94. package/cjs/components/forms/TextArea/TextArea.js +13 -5
  95. package/cjs/components/forms/TextInput/TextInput.js +10 -2
  96. package/cjs/components/forms/TextInput/TextInputBase.js +10 -1
  97. package/cjs/components/forms/index.js +1 -1
  98. package/cjs/components/layout/Flex.js +1 -1
  99. package/cjs/components/layout/Flow.js +1 -1
  100. package/cjs/components/layout/Grid.js +1 -1
  101. package/cjs/components/layout/Prefix.js +1 -1
  102. package/cjs/components/layout/Space.js +1 -1
  103. package/cjs/components/layout/Suffix.js +1 -1
  104. package/cjs/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
  105. package/cjs/components/navigation/Link/Link.js +1 -1
  106. package/cjs/components/organisms/FileTabs/FileTabs.js +1 -1
  107. package/cjs/components/organisms/Modal/Modal.js +1 -1
  108. package/cjs/components/organisms/StatsCard/StatsCard.js +1 -1
  109. package/cjs/components/other/Base64Upload/Base64Upload.js +1 -1
  110. package/cjs/components/other/CloudLogo/CloudLogo.js +1 -1
  111. package/cjs/components/overlays/AlertDialog/AlertDialog.js +1 -1
  112. package/cjs/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  113. package/cjs/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  114. package/cjs/components/overlays/AlertDialog/index.js +1 -1
  115. package/cjs/components/overlays/AlertDialog/types.js +1 -1
  116. package/cjs/components/overlays/Dialog/Dialog.js +1 -1
  117. package/cjs/components/overlays/Dialog/DialogContainer.js +1 -1
  118. package/cjs/components/overlays/Dialog/DialogForm.js +1 -1
  119. package/cjs/components/overlays/Dialog/DialogTrigger.js +1 -1
  120. package/cjs/components/overlays/Dialog/context.js +1 -1
  121. package/cjs/components/overlays/Dialog/index.js +1 -1
  122. package/cjs/components/overlays/Modal/Modal.js +1 -1
  123. package/cjs/components/overlays/Modal/OpenTransition.js +1 -1
  124. package/cjs/components/overlays/Modal/Overlay.js +1 -1
  125. package/cjs/components/overlays/Modal/Popover.js +1 -1
  126. package/cjs/components/overlays/Modal/Tray.js +1 -1
  127. package/cjs/components/overlays/Modal/Underlay.js +1 -1
  128. package/cjs/components/overlays/Modal/index.js +1 -1
  129. package/cjs/components/overlays/Modal/types.js +1 -1
  130. package/cjs/components/overlays/NewNotifications/Bar/FloatingNotification.js +1 -1
  131. package/cjs/components/overlays/NewNotifications/Bar/NotificationsBar.js +1 -1
  132. package/cjs/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  133. package/cjs/components/overlays/NewNotifications/Bar/index.js +1 -1
  134. package/cjs/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +1 -1
  135. package/cjs/components/overlays/NewNotifications/Dialog/index.js +1 -1
  136. package/cjs/components/overlays/NewNotifications/Notification.js +1 -1
  137. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationAction.js +1 -1
  138. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +1 -1
  139. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +2 -2
  140. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +1 -1
  141. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +1 -1
  142. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +1 -1
  143. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +1 -1
  144. package/cjs/components/overlays/NewNotifications/NotificationView/NotificationView.js +1 -1
  145. package/cjs/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  146. package/cjs/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  147. package/cjs/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +1 -1
  148. package/cjs/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  149. package/cjs/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +1 -1
  150. package/cjs/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +1 -1
  151. package/cjs/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +1 -1
  152. package/cjs/components/overlays/NewNotifications/NotificationsList/index.js +1 -1
  153. package/cjs/components/overlays/NewNotifications/NotificationsList/types.js +1 -1
  154. package/cjs/components/overlays/NewNotifications/hooks/index.js +1 -1
  155. package/cjs/components/overlays/NewNotifications/hooks/types.js +1 -1
  156. package/cjs/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  157. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  158. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  159. package/cjs/components/overlays/NewNotifications/hooks/use-notifications-observer.js +1 -1
  160. package/cjs/components/overlays/NewNotifications/index.js +1 -1
  161. package/cjs/components/overlays/NewNotifications/types.js +1 -1
  162. package/cjs/components/overlays/Notification/Notification.js +1 -1
  163. package/cjs/components/overlays/OverlayWrapper.js +1 -1
  164. package/cjs/components/overlays/Toasts/Toast.js +1 -1
  165. package/cjs/components/overlays/Toasts/index.js +1 -1
  166. package/cjs/components/overlays/Toasts/types.js +1 -1
  167. package/cjs/components/overlays/Toasts/use-toasts-api.js +1 -1
  168. package/cjs/components/overlays/Tooltip/Tooltip.js +1 -1
  169. package/cjs/components/overlays/Tooltip/TooltipProvider.js +1 -1
  170. package/cjs/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  171. package/cjs/components/overlays/Tooltip/context.js +1 -1
  172. package/cjs/components/pickers/ComboBox/ComboBox.js +10 -3
  173. package/cjs/components/pickers/Menu/Menu.js +1 -1
  174. package/cjs/components/pickers/Menu/MenuButton.js +1 -1
  175. package/cjs/components/pickers/Menu/MenuItem.js +1 -1
  176. package/cjs/components/pickers/Menu/MenuSection.js +1 -1
  177. package/cjs/components/pickers/Menu/MenuTrigger.js +1 -1
  178. package/cjs/components/pickers/Menu/context.js +1 -1
  179. package/cjs/components/pickers/Menu/styled.js +2 -2
  180. package/cjs/components/pickers/Select/Select.js +8 -1
  181. package/cjs/components/portal/Portal.js +1 -1
  182. package/cjs/components/portal/PortalProvider.js +1 -1
  183. package/cjs/components/portal/index.js +1 -1
  184. package/cjs/components/portal/storybook/templates/CustomRoot.js +1 -1
  185. package/cjs/components/portal/storybook/templates/PortalOrder.js +1 -1
  186. package/cjs/components/portal/storybook/templates/basic.js +1 -1
  187. package/cjs/components/portal/storybook/templates/index.js +1 -1
  188. package/cjs/components/portal/types.js +1 -1
  189. package/cjs/components/portal/usePortal.js +1 -1
  190. package/cjs/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  191. package/cjs/components/status/LoadingAnimation/index.js +1 -1
  192. package/cjs/components/status/Spin/Cube.js +1 -1
  193. package/cjs/components/status/Spin/InternalSpinner.js +1 -1
  194. package/cjs/components/status/Spin/Spin.js +1 -1
  195. package/cjs/components/status/Spin/SpinsContainer.js +1 -1
  196. package/cjs/components/status/Spin/index.js +1 -1
  197. package/cjs/components/status/Spin/types.js +1 -1
  198. package/cjs/components/status/index.js +1 -1
  199. package/cjs/data/themes.js +1 -1
  200. package/cjs/icons/Attention.js +1 -1
  201. package/cjs/icons/Cross.js +1 -1
  202. package/cjs/icons/Danger.js +1 -1
  203. package/cjs/icons/Success.js +1 -1
  204. package/cjs/icons/index.js +1 -1
  205. package/cjs/index.js +1 -1
  206. package/cjs/provider.js +1 -1
  207. package/cjs/providers/TrackingProvider.js +1 -1
  208. package/cjs/services/notification.js +1 -1
  209. package/cjs/shared/form.js +1 -1
  210. package/cjs/shared/index.js +1 -1
  211. package/cjs/stories/FormFieldArgs.js +1 -1
  212. package/cjs/stories/components/ConfirmDeletionDialogForm.js +1 -1
  213. package/cjs/stories/components/DialogFormApp.js +1 -1
  214. package/cjs/stories/components/StyledButton.js +1 -1
  215. package/cjs/stories/lists/baseProps.js +1 -1
  216. package/cjs/tasty/index.js +1 -1
  217. package/cjs/tasty/providers/BreakpointsProvider.js +1 -1
  218. package/cjs/tasty/styles/align.js +1 -1
  219. package/cjs/tasty/styles/border.js +1 -1
  220. package/cjs/tasty/styles/boxShadow.combinator.js +1 -1
  221. package/cjs/tasty/styles/color.js +1 -1
  222. package/cjs/tasty/styles/createStyle.js +1 -1
  223. package/cjs/tasty/styles/dimension.js +1 -1
  224. package/cjs/tasty/styles/display.js +1 -1
  225. package/cjs/tasty/styles/fill.js +1 -1
  226. package/cjs/tasty/styles/flow.js +1 -1
  227. package/cjs/tasty/styles/font.js +1 -1
  228. package/cjs/tasty/styles/fontStyle.js +1 -1
  229. package/cjs/tasty/styles/gap.js +1 -1
  230. package/cjs/tasty/styles/groupRadius.js +1 -1
  231. package/cjs/tasty/styles/height.js +1 -1
  232. package/cjs/tasty/styles/index.js +1 -1
  233. package/cjs/tasty/styles/justify.js +1 -1
  234. package/cjs/tasty/styles/list.js +1 -1
  235. package/cjs/tasty/styles/margin.js +1 -1
  236. package/cjs/tasty/styles/marginBlock.js +1 -1
  237. package/cjs/tasty/styles/marginInline.js +1 -1
  238. package/cjs/tasty/styles/outline.js +1 -1
  239. package/cjs/tasty/styles/padding.js +1 -1
  240. package/cjs/tasty/styles/paddingBlock.js +1 -1
  241. package/cjs/tasty/styles/paddingInline.js +1 -1
  242. package/cjs/tasty/styles/predefined.js +1 -1
  243. package/cjs/tasty/styles/preset.js +1 -1
  244. package/cjs/tasty/styles/radius.js +1 -1
  245. package/cjs/tasty/styles/reset.js +1 -1
  246. package/cjs/tasty/styles/shadow.js +1 -1
  247. package/cjs/tasty/styles/styledScrollbar.js +1 -1
  248. package/cjs/tasty/styles/transition.js +1 -1
  249. package/cjs/tasty/styles/types.js +1 -1
  250. package/cjs/tasty/styles/width.js +1 -1
  251. package/cjs/tasty/tasty.js +1 -1
  252. package/cjs/tasty/types.js +1 -1
  253. package/cjs/tasty/utils/cache-wrapper.js +1 -1
  254. package/cjs/tasty/utils/case-converter.js +1 -1
  255. package/cjs/tasty/utils/colors.js +1 -1
  256. package/cjs/tasty/utils/dotize.js +1 -1
  257. package/cjs/tasty/utils/filterBaseProps.js +1 -1
  258. package/cjs/tasty/utils/getDisplayName.js +1 -1
  259. package/cjs/tasty/utils/index.js +1 -1
  260. package/cjs/tasty/utils/mergeStyles.js +1 -1
  261. package/cjs/tasty/utils/modAttrs.js +1 -1
  262. package/cjs/tasty/utils/renderStyles.js +1 -1
  263. package/cjs/tasty/utils/responsive.js +1 -1
  264. package/cjs/tasty/utils/string.js +1 -1
  265. package/cjs/tasty/utils/styles.js +1 -1
  266. package/cjs/tasty/utils/warnings.js +1 -1
  267. package/cjs/tokens.js +21 -45
  268. package/cjs/type-checks.js +1 -1
  269. package/cjs/utils/ResizeSensor.js +1 -1
  270. package/cjs/utils/modules.js +1 -1
  271. package/cjs/utils/promise.js +1 -1
  272. package/cjs/utils/random.js +1 -1
  273. package/cjs/utils/range.js +1 -1
  274. package/cjs/utils/react/Slots.js +1 -1
  275. package/cjs/utils/react/chain.js +1 -1
  276. package/cjs/utils/react/index.js +1 -1
  277. package/cjs/utils/react/interactions.js +1 -1
  278. package/cjs/utils/react/isTextOnly.js +1 -1
  279. package/cjs/utils/react/mapProps.js +1 -1
  280. package/cjs/utils/react/mergeProps.js +1 -1
  281. package/cjs/utils/react/nullableValue.js +1 -1
  282. package/cjs/utils/react/useCombinedRefs.js +1 -1
  283. package/cjs/utils/react/useId.js +1 -1
  284. package/cjs/utils/react/useLayoutEffect.js +1 -1
  285. package/cjs/utils/react/useViewportSize.js +1 -1
  286. package/cjs/utils/react/wrapNodeIfPlain.js +1 -1
  287. package/cjs/utils/transitions.js +1 -1
  288. package/cjs/utils/tree.js +1 -1
  289. package/cjs/utils/warnings.js +1 -1
  290. package/es/_internal/hooks/index.js +4 -1
  291. package/es/_internal/hooks/use-chained-callback.js +1 -1
  292. package/es/_internal/hooks/use-deprecation-warning.js +1 -1
  293. package/es/_internal/hooks/use-effect-once.js +14 -0
  294. package/es/_internal/hooks/use-event.js +1 -1
  295. package/es/_internal/hooks/use-is-first-render.js +18 -0
  296. package/es/_internal/hooks/use-sync-ref.js +1 -1
  297. package/es/_internal/hooks/use-timer/index.js +1 -1
  298. package/es/_internal/hooks/use-timer/timer.js +1 -1
  299. package/es/_internal/hooks/use-timer/use-timer.js +1 -1
  300. package/es/_internal/hooks/use-update-effect.js +20 -0
  301. package/es/_internal/hooks/use-warn.js +23 -0
  302. package/es/_internal/index.js +1 -1
  303. package/es/components/Base.js +1 -1
  304. package/es/components/Block.js +1 -1
  305. package/es/components/GlobalStyles.js +1 -1
  306. package/es/components/GridProvider.js +1 -1
  307. package/es/components/HiddenInput.js +1 -1
  308. package/es/components/OpenTrasition.js +1 -1
  309. package/es/components/Root.js +1 -1
  310. package/es/components/actions/Action.js +1 -1
  311. package/es/components/actions/Button/Button.js +3 -3
  312. package/es/components/actions/Button/Submit.js +1 -1
  313. package/es/components/actions/Button/index.js +1 -1
  314. package/es/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  315. package/es/components/actions/index.js +1 -1
  316. package/es/components/actions/use-action.js +1 -1
  317. package/es/components/content/ActiveZone/ActiveZone.js +1 -1
  318. package/es/components/content/Alert/Alert.js +1 -1
  319. package/es/components/content/Alert/index.js +1 -1
  320. package/es/components/content/Alert/types.js +1 -1
  321. package/es/components/content/Alert/use-alert.js +1 -1
  322. package/es/components/content/Avatar/Avatar.js +1 -1
  323. package/es/components/content/Badge/Badge.js +1 -1
  324. package/es/components/content/Card/Card.js +1 -1
  325. package/es/components/content/Content.js +1 -1
  326. package/es/components/content/CopySnippet/CopySnippet.js +1 -1
  327. package/es/components/content/CopySnippet/index.js +1 -1
  328. package/es/components/content/Divider.js +1 -1
  329. package/es/components/content/Footer.js +1 -1
  330. package/es/components/content/Header.js +1 -1
  331. package/es/components/content/Paragraph.js +1 -1
  332. package/es/components/content/Placeholder/Placeholder.js +1 -1
  333. package/es/components/content/PrismCode/PrismCode.js +1 -1
  334. package/es/components/content/Result/Result.js +2 -2
  335. package/es/components/content/Skeleton/Skeleton.js +1 -1
  336. package/es/components/content/Tag/Tag.js +2 -2
  337. package/es/components/content/Text.js +1 -1
  338. package/es/components/content/Title.js +1 -1
  339. package/es/components/forms/Checkbox/Checkbox.js +15 -6
  340. package/es/components/forms/Checkbox/CheckboxGroup.js +13 -25
  341. package/es/components/forms/Checkbox/context.js +1 -1
  342. package/es/components/forms/{FieldWrapper.js → FieldWrapper/FieldWrapper.js} +19 -17
  343. package/es/components/forms/FieldWrapper/extract-field-wrapper-props.js +46 -0
  344. package/es/components/forms/FieldWrapper/index.js +12 -0
  345. package/es/components/forms/FieldWrapper/types.js +10 -0
  346. package/es/components/forms/FileInput/FileInput.js +1 -1
  347. package/es/components/forms/Form/Field.js +40 -122
  348. package/es/components/forms/Form/Form.js +1 -1
  349. package/es/components/forms/Form/Submit/Submit.js +22 -0
  350. package/es/components/forms/Form/Submit/index.js +10 -0
  351. package/es/components/forms/Form/SubmitError.js +1 -1
  352. package/es/components/forms/Form/index.js +2 -1
  353. package/es/components/forms/Form/types.js +1 -1
  354. package/es/components/forms/Form/use-field/index.js +12 -0
  355. package/es/components/forms/Form/use-field/types.js +10 -0
  356. package/es/components/forms/Form/use-field/use-field-props.js +52 -0
  357. package/es/components/forms/Form/use-field/use-field.js +143 -0
  358. package/es/components/forms/Form/useForm.js +2 -1
  359. package/es/components/forms/Form/validation.js +1 -1
  360. package/es/components/forms/Input/Input.js +1 -1
  361. package/es/components/forms/Input/index.js +1 -1
  362. package/es/components/forms/Label.js +2 -2
  363. package/es/components/forms/NumberInput/NumberInput.js +3 -3
  364. package/es/components/forms/NumberInput/StepButton.js +1 -1
  365. package/es/components/forms/PasswordInput/PasswordInput.js +14 -5
  366. package/es/components/forms/RadioGroup/Radio.js +3 -2
  367. package/es/components/forms/RadioGroup/RadioGroup.js +3 -2
  368. package/es/components/forms/RadioGroup/context.js +1 -1
  369. package/es/components/forms/SearchInput/SearchInput.js +4 -5
  370. package/es/components/forms/Slider/Gradation.js +1 -1
  371. package/es/components/forms/Slider/Header.js +1 -1
  372. package/es/components/forms/Slider/RangeSlider.js +1 -1
  373. package/es/components/forms/Slider/Slider.js +5 -5
  374. package/es/components/forms/Slider/SliderBase.js +11 -4
  375. package/es/components/forms/Slider/SliderInput.js +1 -1
  376. package/es/components/forms/Slider/SliderThumb.js +1 -1
  377. package/es/components/forms/Slider/SliderTrack.js +12 -4
  378. package/es/components/forms/Slider/elements.js +14 -1
  379. package/es/components/forms/Slider/index.js +1 -1
  380. package/es/components/forms/Slider/types.js +1 -1
  381. package/es/components/forms/Switch/Switch.js +29 -8
  382. package/es/components/forms/TextArea/TextArea.js +14 -6
  383. package/es/components/forms/TextInput/TextInput.js +10 -2
  384. package/es/components/forms/TextInput/TextInputBase.js +11 -2
  385. package/es/components/forms/index.js +1 -1
  386. package/es/components/layout/Flex.js +1 -1
  387. package/es/components/layout/Flow.js +1 -1
  388. package/es/components/layout/Grid.js +1 -1
  389. package/es/components/layout/Prefix.js +1 -1
  390. package/es/components/layout/Space.js +1 -1
  391. package/es/components/layout/Suffix.js +1 -1
  392. package/es/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
  393. package/es/components/navigation/Link/Link.js +1 -1
  394. package/es/components/organisms/FileTabs/FileTabs.js +1 -1
  395. package/es/components/organisms/Modal/Modal.js +1 -1
  396. package/es/components/organisms/StatsCard/StatsCard.js +1 -1
  397. package/es/components/other/Base64Upload/Base64Upload.js +1 -1
  398. package/es/components/other/CloudLogo/CloudLogo.js +1 -1
  399. package/es/components/overlays/AlertDialog/AlertDialog.js +1 -1
  400. package/es/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  401. package/es/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  402. package/es/components/overlays/AlertDialog/index.js +1 -1
  403. package/es/components/overlays/AlertDialog/types.js +1 -1
  404. package/es/components/overlays/Dialog/Dialog.js +1 -1
  405. package/es/components/overlays/Dialog/DialogContainer.js +1 -1
  406. package/es/components/overlays/Dialog/DialogForm.js +1 -1
  407. package/es/components/overlays/Dialog/DialogTrigger.js +1 -1
  408. package/es/components/overlays/Dialog/context.js +1 -1
  409. package/es/components/overlays/Dialog/index.js +1 -1
  410. package/es/components/overlays/Modal/Modal.js +1 -1
  411. package/es/components/overlays/Modal/OpenTransition.js +1 -1
  412. package/es/components/overlays/Modal/Overlay.js +1 -1
  413. package/es/components/overlays/Modal/Popover.js +1 -1
  414. package/es/components/overlays/Modal/Tray.js +1 -1
  415. package/es/components/overlays/Modal/Underlay.js +1 -1
  416. package/es/components/overlays/Modal/index.js +1 -1
  417. package/es/components/overlays/Modal/types.js +1 -1
  418. package/es/components/overlays/NewNotifications/Bar/FloatingNotification.js +1 -1
  419. package/es/components/overlays/NewNotifications/Bar/NotificationsBar.js +1 -1
  420. package/es/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  421. package/es/components/overlays/NewNotifications/Bar/index.js +1 -1
  422. package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +1 -1
  423. package/es/components/overlays/NewNotifications/Dialog/index.js +1 -1
  424. package/es/components/overlays/NewNotifications/Notification.js +1 -1
  425. package/es/components/overlays/NewNotifications/NotificationView/NotificationAction.js +1 -1
  426. package/es/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +1 -1
  427. package/es/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +2 -2
  428. package/es/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +1 -1
  429. package/es/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +1 -1
  430. package/es/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +1 -1
  431. package/es/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +1 -1
  432. package/es/components/overlays/NewNotifications/NotificationView/NotificationView.js +1 -1
  433. package/es/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  434. package/es/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  435. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +1 -1
  436. package/es/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  437. package/es/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +1 -1
  438. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +1 -1
  439. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +1 -1
  440. package/es/components/overlays/NewNotifications/NotificationsList/index.js +1 -1
  441. package/es/components/overlays/NewNotifications/NotificationsList/types.js +1 -1
  442. package/es/components/overlays/NewNotifications/hooks/index.js +1 -1
  443. package/es/components/overlays/NewNotifications/hooks/types.js +1 -1
  444. package/es/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  445. package/es/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  446. package/es/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  447. package/es/components/overlays/NewNotifications/hooks/use-notifications-observer.js +1 -1
  448. package/es/components/overlays/NewNotifications/index.js +1 -1
  449. package/es/components/overlays/NewNotifications/types.js +1 -1
  450. package/es/components/overlays/Notification/Notification.js +1 -1
  451. package/es/components/overlays/OverlayWrapper.js +1 -1
  452. package/es/components/overlays/Toasts/Toast.js +1 -1
  453. package/es/components/overlays/Toasts/index.js +1 -1
  454. package/es/components/overlays/Toasts/types.js +1 -1
  455. package/es/components/overlays/Toasts/use-toasts-api.js +1 -1
  456. package/es/components/overlays/Tooltip/Tooltip.js +1 -1
  457. package/es/components/overlays/Tooltip/TooltipProvider.js +1 -1
  458. package/es/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  459. package/es/components/overlays/Tooltip/context.js +1 -1
  460. package/es/components/pickers/ComboBox/ComboBox.js +9 -2
  461. package/es/components/pickers/Menu/Menu.js +1 -1
  462. package/es/components/pickers/Menu/MenuButton.js +1 -1
  463. package/es/components/pickers/Menu/MenuItem.js +1 -1
  464. package/es/components/pickers/Menu/MenuSection.js +1 -1
  465. package/es/components/pickers/Menu/MenuTrigger.js +1 -1
  466. package/es/components/pickers/Menu/context.js +1 -1
  467. package/es/components/pickers/Menu/styled.js +2 -2
  468. package/es/components/pickers/Select/Select.js +9 -2
  469. package/es/components/portal/Portal.js +1 -1
  470. package/es/components/portal/PortalProvider.js +1 -1
  471. package/es/components/portal/index.js +1 -1
  472. package/es/components/portal/storybook/templates/CustomRoot.js +1 -1
  473. package/es/components/portal/storybook/templates/PortalOrder.js +1 -1
  474. package/es/components/portal/storybook/templates/basic.js +1 -1
  475. package/es/components/portal/storybook/templates/index.js +1 -1
  476. package/es/components/portal/types.js +1 -1
  477. package/es/components/portal/usePortal.js +1 -1
  478. package/es/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  479. package/es/components/status/LoadingAnimation/index.js +1 -1
  480. package/es/components/status/Spin/Cube.js +1 -1
  481. package/es/components/status/Spin/InternalSpinner.js +1 -1
  482. package/es/components/status/Spin/Spin.js +1 -1
  483. package/es/components/status/Spin/SpinsContainer.js +1 -1
  484. package/es/components/status/Spin/index.js +1 -1
  485. package/es/components/status/Spin/types.js +1 -1
  486. package/es/components/status/index.js +1 -1
  487. package/es/data/themes.js +1 -1
  488. package/es/icons/Attention.js +1 -1
  489. package/es/icons/Cross.js +1 -1
  490. package/es/icons/Danger.js +1 -1
  491. package/es/icons/Success.js +1 -1
  492. package/es/icons/index.js +1 -1
  493. package/es/index.js +1 -1
  494. package/es/provider.js +1 -1
  495. package/es/providers/TrackingProvider.js +1 -1
  496. package/es/services/notification.js +1 -1
  497. package/es/shared/form.js +1 -1
  498. package/es/shared/index.js +1 -1
  499. package/es/stories/FormFieldArgs.js +1 -1
  500. package/es/stories/components/ConfirmDeletionDialogForm.js +1 -1
  501. package/es/stories/components/DialogFormApp.js +1 -1
  502. package/es/stories/components/StyledButton.js +1 -1
  503. package/es/stories/lists/baseProps.js +1 -1
  504. package/es/tasty/index.js +1 -1
  505. package/es/tasty/providers/BreakpointsProvider.js +1 -1
  506. package/es/tasty/styles/align.js +1 -1
  507. package/es/tasty/styles/border.js +1 -1
  508. package/es/tasty/styles/boxShadow.combinator.js +1 -1
  509. package/es/tasty/styles/color.js +1 -1
  510. package/es/tasty/styles/createStyle.js +1 -1
  511. package/es/tasty/styles/dimension.js +1 -1
  512. package/es/tasty/styles/display.js +1 -1
  513. package/es/tasty/styles/fill.js +1 -1
  514. package/es/tasty/styles/flow.js +1 -1
  515. package/es/tasty/styles/font.js +1 -1
  516. package/es/tasty/styles/fontStyle.js +1 -1
  517. package/es/tasty/styles/gap.js +1 -1
  518. package/es/tasty/styles/groupRadius.js +1 -1
  519. package/es/tasty/styles/height.js +1 -1
  520. package/es/tasty/styles/index.js +1 -1
  521. package/es/tasty/styles/justify.js +1 -1
  522. package/es/tasty/styles/list.js +1 -1
  523. package/es/tasty/styles/margin.js +1 -1
  524. package/es/tasty/styles/marginBlock.js +1 -1
  525. package/es/tasty/styles/marginInline.js +1 -1
  526. package/es/tasty/styles/outline.js +1 -1
  527. package/es/tasty/styles/padding.js +1 -1
  528. package/es/tasty/styles/paddingBlock.js +1 -1
  529. package/es/tasty/styles/paddingInline.js +1 -1
  530. package/es/tasty/styles/predefined.js +1 -1
  531. package/es/tasty/styles/preset.js +1 -1
  532. package/es/tasty/styles/radius.js +1 -1
  533. package/es/tasty/styles/reset.js +1 -1
  534. package/es/tasty/styles/shadow.js +1 -1
  535. package/es/tasty/styles/styledScrollbar.js +1 -1
  536. package/es/tasty/styles/transition.js +1 -1
  537. package/es/tasty/styles/types.js +1 -1
  538. package/es/tasty/styles/width.js +1 -1
  539. package/es/tasty/tasty.js +1 -1
  540. package/es/tasty/types.js +1 -1
  541. package/es/tasty/utils/cache-wrapper.js +1 -1
  542. package/es/tasty/utils/case-converter.js +1 -1
  543. package/es/tasty/utils/colors.js +1 -1
  544. package/es/tasty/utils/dotize.js +1 -1
  545. package/es/tasty/utils/filterBaseProps.js +1 -1
  546. package/es/tasty/utils/getDisplayName.js +1 -1
  547. package/es/tasty/utils/index.js +1 -1
  548. package/es/tasty/utils/mergeStyles.js +1 -1
  549. package/es/tasty/utils/modAttrs.js +1 -1
  550. package/es/tasty/utils/renderStyles.js +1 -1
  551. package/es/tasty/utils/responsive.js +1 -1
  552. package/es/tasty/utils/string.js +1 -1
  553. package/es/tasty/utils/styles.js +1 -1
  554. package/es/tasty/utils/warnings.js +1 -1
  555. package/es/tokens.js +21 -45
  556. package/es/type-checks.js +1 -1
  557. package/es/utils/ResizeSensor.js +1 -1
  558. package/es/utils/modules.js +1 -1
  559. package/es/utils/promise.js +1 -1
  560. package/es/utils/random.js +1 -1
  561. package/es/utils/range.js +1 -1
  562. package/es/utils/react/Slots.js +1 -1
  563. package/es/utils/react/chain.js +1 -1
  564. package/es/utils/react/index.js +1 -1
  565. package/es/utils/react/interactions.js +1 -1
  566. package/es/utils/react/isTextOnly.js +1 -1
  567. package/es/utils/react/mapProps.js +1 -1
  568. package/es/utils/react/mergeProps.js +1 -1
  569. package/es/utils/react/nullableValue.js +1 -1
  570. package/es/utils/react/useCombinedRefs.js +1 -1
  571. package/es/utils/react/useId.js +1 -1
  572. package/es/utils/react/useLayoutEffect.js +1 -1
  573. package/es/utils/react/useViewportSize.js +1 -1
  574. package/es/utils/react/wrapNodeIfPlain.js +1 -1
  575. package/es/utils/transitions.js +1 -1
  576. package/es/utils/tree.js +1 -1
  577. package/es/utils/warnings.js +1 -1
  578. package/package.json +1 -1
  579. package/types/_internal/hooks/index.d.ts +3 -0
  580. package/types/_internal/hooks/use-effect-once.d.ts +2 -0
  581. package/types/_internal/hooks/use-is-first-render.d.ts +1 -0
  582. package/types/_internal/hooks/use-update-effect.d.ts +2 -0
  583. package/types/_internal/hooks/use-warn.d.ts +2 -0
  584. package/types/components/forms/FieldWrapper/FieldWrapper.d.ts +7 -0
  585. package/types/components/forms/FieldWrapper/extract-field-wrapper-props.d.ts +9 -0
  586. package/types/components/forms/FieldWrapper/index.d.ts +3 -0
  587. package/types/components/forms/{FieldWrapper.d.ts → FieldWrapper/types.d.ts} +15 -20
  588. package/types/components/forms/Form/Field.d.ts +3 -2
  589. package/types/components/forms/Form/Submit/Submit.d.ts +8 -0
  590. package/types/components/forms/Form/Submit/index.d.ts +1 -0
  591. package/types/components/forms/Form/index.d.ts +2 -0
  592. package/types/components/forms/Form/use-field/index.d.ts +3 -0
  593. package/types/components/forms/Form/use-field/types.d.ts +74 -0
  594. package/types/components/forms/Form/use-field/use-field-props.d.ts +19 -0
  595. package/types/components/forms/Form/use-field/use-field.d.ts +7 -0
  596. package/types/components/forms/Form/useForm.d.ts +1 -1
  597. package/types/components/forms/Slider/Slider.d.ts +1 -1
  598. package/types/components/forms/Slider/types.d.ts +1 -1
  599. package/types/components/forms/Switch/Switch.d.ts +1 -0
  600. package/types/tasty/styles/types.d.ts +1 -1
  601. package/types/tokens.d.ts +0 -20
@@ -0,0 +1,56 @@
1
+ /**
2
+ * @license MIT
3
+ * author: Cube Dev Team
4
+ * @cube-dev/ui-kit v0.20.0
5
+ * Released under the MIT license.
6
+ */
7
+
8
+ "use strict";
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.useFieldProps = void 0;
11
+ const react_1 = require("react");
12
+ const react_2 = require("react");
13
+ const _internal_1 = require("../../../../_internal");
14
+ const Field_1 = require("../Field");
15
+ const react_3 = require("../../../../utils/react");
16
+ const use_field_1 = require("./use-field");
17
+ function useFieldProps(props, params = {}) {
18
+ // We use ref here to "memoize" initial value
19
+ const isDisabledRef = (0, react_1.useRef)(params.unsafe__isDisabled ?? false);
20
+ const { valuePropsMapper = ({ value, onChange }) => ({
21
+ value: value ?? null,
22
+ onChange,
23
+ }), defaultValidationTrigger = 'onBlur', } = params;
24
+ const isInsideLegacyField = (0, Field_1.useInsideLegacyField)();
25
+ (0, _internal_1.useWarn)(isInsideLegacyField, '<Field /> is deprecated, use component without <Field /> instead.');
26
+ if (isInsideLegacyField === true ||
27
+ isDisabledRef.current === true ||
28
+ props.name == null) {
29
+ return props;
30
+ }
31
+ // eslint-disable-next-line react-hooks/rules-of-hooks
32
+ const field = (0, use_field_1.useField)(props, {
33
+ defaultValidationTrigger: params.defaultValidationTrigger,
34
+ });
35
+ const isOutsideOfForm = field?.form == null;
36
+ // eslint-disable-next-line react-hooks/rules-of-hooks
37
+ const onBlurChained = (0, _internal_1.useChainedCallback)(field?.onBlur,
38
+ // TODO: remove type casting after updating to typescipt@4.9
39
+ 'onBlur' in props ? props.onBlur : undefined);
40
+ // eslint-disable-next-line react-hooks/rules-of-hooks
41
+ const onChangeEvent = (0, _internal_1.useEvent)((value, dontTouch) => field?.onChange?.(value, dontTouch, field?.validateTrigger ?? defaultValidationTrigger));
42
+ const result = isOutsideOfForm
43
+ ? props
44
+ : (0, react_3.mergeProps)(props, field, valuePropsMapper({ value: field.value, onChange: onChangeEvent }), {
45
+ validateTrigger: field.validateTrigger ?? defaultValidationTrigger,
46
+ onBlur: onBlurChained,
47
+ });
48
+ if (process.env.NODE_ENV === 'development') {
49
+ // eslint-disable-next-line react-hooks/rules-of-hooks
50
+ (0, react_2.useDebugValue)(result);
51
+ }
52
+ return result;
53
+ }
54
+ exports.useFieldProps = useFieldProps;
55
+
56
+
@@ -0,0 +1,147 @@
1
+ /**
2
+ * @license MIT
3
+ * author: Cube Dev Team
4
+ * @cube-dev/ui-kit v0.20.0
5
+ * Released under the MIT license.
6
+ */
7
+
8
+ "use strict";
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.useField = void 0;
11
+ const react_1 = require("react");
12
+ const _internal_1 = require("../../../../_internal");
13
+ const Form_1 = require("../Form");
14
+ const ID_MAP = {};
15
+ function createId(name) {
16
+ if (!name)
17
+ return;
18
+ if (!ID_MAP[name]) {
19
+ ID_MAP[name] = [];
20
+ }
21
+ let i = 0;
22
+ let id;
23
+ do {
24
+ id = i ? `${name}_${i}` : name;
25
+ i++;
26
+ } while (ID_MAP[name].includes(id));
27
+ ID_MAP[name].push(id);
28
+ return id;
29
+ }
30
+ function removeId(name, id) {
31
+ if (!ID_MAP[name])
32
+ return;
33
+ ID_MAP[name] = ID_MAP[name].filter((_id) => _id !== id);
34
+ }
35
+ function useField(props, params) {
36
+ props = (0, Form_1.useFormProps)(props);
37
+ let { defaultValue, id, idPrefix, name, form, rules, validateTrigger = params.defaultValidationTrigger, validationState, shouldUpdate, } = props;
38
+ const nonInput = !name;
39
+ const fieldName = name != null ? (Array.isArray(name) ? name.join('.') : name) : '';
40
+ const isFirstRender = (0, _internal_1.useIsFirstRender)();
41
+ let [fieldId, setFieldId] = (0, react_1.useState)(id || (idPrefix ? `${idPrefix}_${fieldName}` : fieldName));
42
+ (0, react_1.useEffect)(() => {
43
+ let newId;
44
+ if (!id && !nonInput) {
45
+ newId = createId(fieldId);
46
+ setFieldId(newId);
47
+ }
48
+ return () => {
49
+ if (!id) {
50
+ removeId(idPrefix ? `${idPrefix}_${fieldName}` : fieldName, newId);
51
+ }
52
+ if (fieldName && form) {
53
+ form.removeField(fieldName);
54
+ }
55
+ };
56
+ }, []);
57
+ let field = form?.getFieldInstance(fieldName);
58
+ if (field) {
59
+ field.rules = rules;
60
+ }
61
+ let isRequired = rules && !!rules.find((rule) => rule.required);
62
+ (0, react_1.useEffect)(() => {
63
+ if (!form)
64
+ return;
65
+ if (field) {
66
+ form.forceReRender();
67
+ }
68
+ else {
69
+ form.createField(fieldName);
70
+ }
71
+ }, [field]);
72
+ if (form) {
73
+ if (isFirstRender) {
74
+ if (!field) {
75
+ field = form.createField(fieldName, true);
76
+ }
77
+ if (field?.value == null) {
78
+ form.setFieldValue(fieldName, defaultValue, false, true);
79
+ field = form?.getFieldInstance(fieldName);
80
+ }
81
+ }
82
+ if (!field?.touched && defaultValue != null) {
83
+ form.setFieldValue(fieldName, defaultValue, false, true);
84
+ }
85
+ }
86
+ const onChangeHandler = (0, _internal_1.useEvent)((val, dontTouch) => {
87
+ if (!form)
88
+ return;
89
+ const field = form.getFieldInstance(fieldName);
90
+ if (shouldUpdate) {
91
+ const fieldsValue = form.getFieldsValue();
92
+ // check if we should update the value of the field
93
+ const shouldNotBeUpdated = typeof shouldUpdate === 'boolean'
94
+ ? !shouldUpdate
95
+ : !shouldUpdate(fieldsValue, {
96
+ ...fieldsValue,
97
+ [fieldName]: val,
98
+ });
99
+ if (shouldNotBeUpdated) {
100
+ return;
101
+ }
102
+ }
103
+ form.setFieldValue(fieldName, val, !dontTouch, false, dontTouch);
104
+ if (!dontTouch &&
105
+ (validateTrigger === 'onChange' ||
106
+ (field && field.errors && field.errors.length))) {
107
+ form.validateField(fieldName).catch(() => { }); // do nothing on fail
108
+ }
109
+ });
110
+ const onBlurHandler = (0, _internal_1.useEvent)(() => {
111
+ if (validateTrigger === 'onBlur') {
112
+ // We need a timeout so the change event can be done.
113
+ setTimeout(() => {
114
+ form?.validateField(fieldName).catch(() => { }); // do nothing on fail
115
+ });
116
+ }
117
+ });
118
+ return (0, react_1.useMemo)(() => ({
119
+ id: fieldId,
120
+ name: fieldName,
121
+ value: field?.inputValue,
122
+ validateTrigger,
123
+ form,
124
+ field,
125
+ nonInput,
126
+ validationState: validationState ?? (field?.errors?.length ? 'invalid' : undefined),
127
+ ...(isRequired && { isRequired }),
128
+ ...(field?.errors?.length && { message: field.errors[0] }),
129
+ onBlur: onBlurHandler,
130
+ onChange: onChangeHandler,
131
+ }), [
132
+ form,
133
+ field,
134
+ field?.inputValue,
135
+ fieldId,
136
+ fieldName,
137
+ isRequired,
138
+ onBlurHandler,
139
+ onChangeHandler,
140
+ validateTrigger,
141
+ validationState,
142
+ nonInput,
143
+ ]);
144
+ }
145
+ exports.useField = useField;
146
+
147
+
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -220,6 +220,7 @@ class CubeFormInstance {
220
220
  if (!skipRender) {
221
221
  this.forceReRender();
222
222
  }
223
+ return this.fields[name];
223
224
  }
224
225
  removeField(name, skipRender) {
225
226
  if (this.fields[name]) {
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -34,7 +34,7 @@ exports.INLINE_LABEL_STYLES = {
34
34
  };
35
35
  exports.LABEL_STYLES = {
36
36
  display: 'block',
37
- preset: 't3s',
37
+ preset: 'h6',
38
38
  color: {
39
39
  '': '#dark',
40
40
  invalid: '#danger-text',
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -36,7 +36,7 @@ const StepperContainer = (0, tasty_1.tasty)({
36
36
  function NumberInput(props, ref) {
37
37
  props = (0, nullableValue_1.castNullableNumberValue)(props);
38
38
  props = (0, provider_1.useProviderProps)(props);
39
- props = (0, Form_1.useFormProps)(props);
39
+ props = (0, Form_1.useFieldProps)(props);
40
40
  let { hideStepper, suffix, value, defaultValue, onChange, ...otherProps } = props;
41
41
  let showStepper = !hideStepper;
42
42
  let { locale } = (0, i18n_1.useLocale)();
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -16,20 +16,29 @@ const TextInputBase_1 = require("../TextInput/TextInputBase");
16
16
  const provider_1 = require("../../../provider");
17
17
  const actions_1 = require("../../actions");
18
18
  const nullableValue_1 = require("../../../utils/react/nullableValue");
19
+ const Form_1 = require("../Form");
19
20
  function PasswordInput(props, ref) {
20
21
  props = (0, nullableValue_1.castNullableStringValue)(props);
21
- let { suffix, multiLine, ...otherProps } = (0, provider_1.useProviderProps)({ ...props });
22
+ props = (0, provider_1.useProviderProps)(props);
23
+ props = (0, Form_1.useFieldProps)(props, {
24
+ defaultValidationTrigger: 'onBlur',
25
+ valuePropsMapper: ({ value, onChange }) => ({
26
+ value: value?.toString() ?? '',
27
+ onChange,
28
+ }),
29
+ });
22
30
  let [type, setType] = (0, react_1.useState)('password');
23
31
  let inputRef = (0, react_1.useRef)(null);
24
32
  let { labelProps, inputProps } = (0, textfield_1.useTextField)({
25
- ...otherProps,
33
+ ...props,
26
34
  type,
27
35
  }, inputRef);
28
- const toggleType = (0, react_1.useCallback)((e) => {
36
+ const { suffix, multiLine, ...rest } = props;
37
+ const toggleType = (0, react_1.useCallback)(() => {
29
38
  setType((type) => (type === 'password' ? 'text' : 'password'));
30
39
  }, []);
31
40
  const wrappedSuffix = ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [suffix, (0, jsx_runtime_1.jsx)(actions_1.Button, { excludeFromTabOrder: true, type: "neutral", htmlType: "button", placeSelf: "stretch", height: "auto", radius: "right", width: "4x", label: "Toggle masking", icon: type === 'password' ? (0, jsx_runtime_1.jsx)(icons_1.EyeInvisibleOutlined, {}) : (0, jsx_runtime_1.jsx)(icons_1.EyeOutlined, {}), onPress: toggleType })] }));
32
- return ((0, jsx_runtime_1.jsx)(TextInputBase_1.TextInputBase, { ref: ref, labelProps: labelProps, inputProps: inputProps, inputRef: inputRef, inputStyles: { paddingRight: '4x' }, type: type, suffixPosition: "after", suffix: wrappedSuffix, multiLine: multiLine, ...otherProps }));
41
+ return ((0, jsx_runtime_1.jsx)(TextInputBase_1.TextInputBase, { ref: ref, labelProps: labelProps, inputProps: inputProps, inputRef: inputRef, inputStyles: { paddingRight: '4x' }, type: type, suffixPosition: "after", suffix: wrappedSuffix, multiLine: multiLine, ...rest }));
33
42
  }
34
43
  /**
35
44
  * PasswordInputs are password inputs that allow users to input passwords or code entries
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -118,6 +118,7 @@ const RadioLabelElement = (0, tasty_1.tasty)({
118
118
  function Radio(props, ref) {
119
119
  props = (0, provider_1.useProviderProps)(props);
120
120
  props = (0, Form_1.useFormProps)(props);
121
+ props = (0, Form_1.useFieldProps)(props, { defaultValidationTrigger: 'onChange' });
121
122
  let { qa, isDisabled, validationState, children, label, autoFocus, labelStyles, labelProps, inputStyles, type = 'radio', 'aria-label': ariaLabel, ...otherProps } = props;
122
123
  let isButton = type === 'button';
123
124
  label = label || children;
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -36,6 +36,7 @@ function RadioGroup(props, ref) {
36
36
  props = (0, nullableValue_1.castNullableStringValue)(props);
37
37
  props = (0, provider_1.useProviderProps)(props);
38
38
  props = (0, Form_1.useFormProps)(props);
39
+ props = (0, Form_1.useFieldProps)(props, { defaultValidationTrigger: 'onChange' });
39
40
  let { isDisabled, isRequired, necessityIndicator, label, extra, labelPosition = 'top', validationState, children, orientation = 'vertical', message, description, labelStyles, requiredMark = true, tooltip, isHidden, styles, groupStyles, insideForm, labelSuffix, ...otherProps } = props;
40
41
  let domRef = (0, utils_1.useDOMRef)(ref);
41
42
  styles = (0, tasty_1.extractStyles)(otherProps, tasty_1.OUTER_STYLES, styles);
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -35,9 +35,8 @@ exports.SearchInput = (0, react_1.forwardRef)(function SearchInput(props, ref) {
35
35
  let inputRef = (0, react_1.useRef)(null);
36
36
  let state = (0, searchfield_1.useSearchFieldState)(props);
37
37
  let { inputProps, clearButtonProps } = (0, searchfield_2.useSearchField)(props, state, inputRef);
38
- return ((0, jsx_runtime_1.jsx)(TextInputBase_1.TextInputBase, { ref: ref, inputProps: inputProps, inputRef: inputRef, type: "search", icon: (0, jsx_runtime_1.jsx)(icons_1.SearchOutlined, {}), suffixPosition: "after", suffix: isClearable &&
39
- state.value !== '' &&
40
- !props.isReadOnly && ((0, jsx_runtime_1.jsx)(ClearButton, { type: validationState === 'invalid' ? 'clear' : 'neutral', theme: validationState === 'invalid' ? 'danger' : undefined, ...(0, mapProps_1.ariaToCubeButtonProps)(clearButtonProps) })), ...props }));
38
+ let showClearButton = isClearable && state.value !== '' && !props.isReadOnly;
39
+ return ((0, jsx_runtime_1.jsx)(TextInputBase_1.TextInputBase, { ref: ref, inputProps: inputProps, inputRef: inputRef, type: "search", icon: (0, jsx_runtime_1.jsx)(icons_1.SearchOutlined, {}), suffixPosition: "after", ...props, suffix: props.suffix || showClearButton ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [props.suffix, showClearButton && ((0, jsx_runtime_1.jsx)(ClearButton, { type: validationState === 'invalid' ? 'clear' : 'neutral', theme: validationState === 'invalid' ? 'danger' : undefined, ...(0, mapProps_1.ariaToCubeButtonProps)(clearButtonProps) }))] })) : undefined }));
41
40
  });
42
41
 
43
42
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -16,7 +16,7 @@ const SliderTrack_1 = require("./SliderTrack");
16
16
  const SliderBase_1 = require("./SliderBase");
17
17
  const Gradation_1 = require("./Gradation");
18
18
  function Slider(props, ref) {
19
- let { onChange, onChangeEnd, value, defaultValue, getValueLabel, isDisabled, styles, gradation, orientation, ...otherProps } = props;
19
+ const { onChange, onChangeEnd, value, defaultValue, getValueLabel, isDisabled, styles, gradation, orientation, ...otherProps } = props;
20
20
  let baseProps = {
21
21
  ...otherProps,
22
22
  // Normalize `value: number[]` to `value: number`
@@ -28,10 +28,10 @@ function Slider(props, ref) {
28
28
  onChangeEnd: (v) => {
29
29
  onChangeEnd?.(v[0]);
30
30
  },
31
- getValueLabel: getValueLabel ? ([v]) => getValueLabel?.(v) : undefined,
31
+ getValueLabel: getValueLabel ? ([v]) => getValueLabel(v) : undefined,
32
32
  };
33
- styles = (0, tasty_1.extractStyles)(otherProps, tasty_1.OUTER_STYLES, styles);
34
- return ((0, jsx_runtime_1.jsx)(SliderBase_1.SliderBase, { ...otherProps, ...baseProps, orientation: orientation, styles: styles, children: ({ trackRef, inputRef, state }) => {
33
+ const extractedStyles = (0, tasty_1.extractStyles)(otherProps, tasty_1.OUTER_STYLES, styles);
34
+ return ((0, jsx_runtime_1.jsx)(SliderBase_1.SliderBase, { ...otherProps, ...baseProps, ref: ref, orientation: orientation, styles: extractedStyles, children: ({ trackRef, inputRef, state }) => {
35
35
  return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(Gradation_1.Gradation, { state: state, ranges: [0, 1], values: gradation }), (0, jsx_runtime_1.jsx)(SliderTrack_1.SliderTrack, { state: state, isDisabled: isDisabled, orientation: orientation }), (0, jsx_runtime_1.jsx)(SliderThumb_1.SliderThumb, { index: 0, state: state, inputRef: inputRef, trackRef: trackRef, isDisabled: isDisabled })] }));
36
36
  } }));
37
37
  }
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -14,7 +14,7 @@ const utils_1 = require("@react-spectrum/utils");
14
14
  const slider_1 = require("@react-stately/slider");
15
15
  const slider_2 = require("@react-aria/slider");
16
16
  const i18n_1 = require("@react-aria/i18n");
17
- const FieldWrapper_1 = require("../../forms/FieldWrapper");
17
+ const FieldWrapper_1 = require("../FieldWrapper");
18
18
  const tasty_1 = require("../../../tasty");
19
19
  const Form_1 = require("../Form");
20
20
  const Text_1 = require("../../content/Text");
@@ -26,7 +26,14 @@ const LabelValueElement = (0, tasty_1.tasty)(Text_1.Text, {
26
26
  },
27
27
  });
28
28
  function SliderBase(allProps, ref) {
29
- const props = (0, Form_1.useFormProps)(allProps);
29
+ let props = (0, Form_1.useFormProps)(allProps);
30
+ props = (0, Form_1.useFieldProps)(props, {
31
+ defaultValidationTrigger: 'onChange',
32
+ valuePropsMapper: ({ value, onChange }) => ({
33
+ value: value != null ? value : undefined,
34
+ onChange: onChange,
35
+ }),
36
+ });
30
37
  let { labelPosition, label, extra, styles, isRequired, validationState, message, description, requiredMark, labelSuffix, labelStyles, necessityIndicator, gradation, isDisabled, inputStyles, minValue = 0, maxValue = 100, inputWidth, formatOptions, getValueLabel, onChange, onChangeEnd, children, showValueLabel = true, orientation: formOrientation, ...otherProps } = props;
31
38
  let orientation = allProps.orientation || 'horizontal';
32
39
  // `Math.abs(Math.sign(a) - Math.sign(b)) === 2` is true if the values have a different sign.
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -12,12 +12,20 @@ const jsx_runtime_1 = require("react/jsx-runtime");
12
12
  const react_1 = require("react");
13
13
  const elements_1 = require("./elements");
14
14
  function SliderTrack(props) {
15
- const { isDisabled, orientation = 'horizontal' } = props;
15
+ const { isDisabled, state, orientation = 'horizontal' } = props;
16
+ const selectedTrack = [state.getThumbPercent(0), state.getThumbPercent(1)];
17
+ const showRangeTrack = !Number.isNaN(selectedTrack[1]);
16
18
  const mods = (0, react_1.useMemo)(() => ({
17
19
  disabled: isDisabled,
18
20
  horizontal: orientation === 'horizontal',
19
- }), [isDisabled]);
20
- return (0, jsx_runtime_1.jsx)(elements_1.SliderTrackContainerElement, { mods: mods });
21
+ range: showRangeTrack,
22
+ }), [isDisabled, showRangeTrack]);
23
+ return ((0, jsx_runtime_1.jsx)(elements_1.SliderTrackContainerElement, { mods: mods, style: showRangeTrack
24
+ ? {
25
+ '--slider-range-start': `${selectedTrack[0] * 100}%`,
26
+ '--slider-range-end': `${selectedTrack[1] * 100}%`,
27
+ }
28
+ : {} }));
21
29
  }
22
30
  exports.SliderTrack = SliderTrack;
23
31
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -57,6 +57,19 @@ exports.SliderTrackContainerElement = (0, tasty_1.tasty)({
57
57
  horizontal: '100%',
58
58
  },
59
59
  radius: true,
60
+ '&::before': {
61
+ content: '""',
62
+ display: {
63
+ '': 'none',
64
+ range: 'block',
65
+ },
66
+ position: 'absolute',
67
+ top: 0,
68
+ bottom: 0,
69
+ fill: '#purple',
70
+ left: '@slider-range-start',
71
+ width: '(@slider-range-end - @slider-range-start)',
72
+ },
60
73
  },
61
74
  });
62
75
  exports.SliderGradationElement = (0, tasty_1.tasty)({
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.18.2
4
+ * @cube-dev/ui-kit v0.20.0
5
5
  * Released under the MIT license.
6
6
  */
7
7