@cube-dev/ui-kit 0.120.1 → 0.121.1

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 (540) hide show
  1. package/dist/CHANGELOG.md +20 -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 +1 -1
  12. package/dist/components/CollectionItem.js +1 -1
  13. package/dist/components/GlobalStyles.js +1 -1
  14. package/dist/components/GridProvider.js +1 -1
  15. package/dist/components/HiddenInput.js +1 -1
  16. package/dist/components/Root.js +1 -1
  17. package/dist/components/actions/Action/Action.js +1 -1
  18. package/dist/components/actions/Banner/Banner.js +1 -1
  19. package/dist/components/actions/Button/Button.d.ts +1 -0
  20. package/dist/components/actions/Button/Button.js +34 -14
  21. package/dist/components/actions/Button/Button.js.map +1 -1
  22. package/dist/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  23. package/dist/components/actions/ButtonSplit/ButtonSplit.d.ts +47 -0
  24. package/dist/components/actions/ButtonSplit/ButtonSplit.js +105 -0
  25. package/dist/components/actions/ButtonSplit/ButtonSplit.js.map +1 -0
  26. package/dist/components/actions/ButtonSplit/context.d.ts +18 -0
  27. package/dist/components/actions/ButtonSplit/context.js +12 -0
  28. package/dist/components/actions/ButtonSplit/context.js.map +1 -0
  29. package/dist/components/actions/ButtonSplit/index.d.ts +3 -0
  30. package/dist/components/actions/CommandMenu/CommandMenu.js +1 -1
  31. package/dist/components/actions/CommandMenu/styled.js +1 -1
  32. package/dist/components/actions/ItemAction/ItemAction.js +1 -1
  33. package/dist/components/actions/ItemActionContext.js +1 -1
  34. package/dist/components/actions/ItemButton/ItemButton.js +1 -1
  35. package/dist/components/actions/Link/Link.js +1 -1
  36. package/dist/components/actions/Menu/Menu.d.ts +2 -2
  37. package/dist/components/actions/Menu/Menu.js +1 -1
  38. package/dist/components/actions/Menu/MenuItem.js +1 -1
  39. package/dist/components/actions/Menu/MenuSection.js +1 -1
  40. package/dist/components/actions/Menu/MenuTrigger.js +1 -1
  41. package/dist/components/actions/Menu/SubMenuTrigger.js +1 -1
  42. package/dist/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  43. package/dist/components/actions/Menu/context.js +1 -1
  44. package/dist/components/actions/Menu/styled.js +1 -1
  45. package/dist/components/actions/index.d.ts +8 -3
  46. package/dist/components/actions/index.js +10 -5
  47. package/dist/components/actions/index.js.map +1 -1
  48. package/dist/components/actions/use-action.d.ts +1 -0
  49. package/dist/components/actions/use-action.js +21 -18
  50. package/dist/components/actions/use-action.js.map +1 -1
  51. package/dist/components/actions/use-anchored-menu.js +1 -1
  52. package/dist/components/actions/use-context-menu.js +1 -1
  53. package/dist/components/content/ActiveZone/ActiveZone.js +1 -1
  54. package/dist/components/content/Alert/Alert.js +1 -1
  55. package/dist/components/content/Alert/use-alert.js +1 -1
  56. package/dist/components/content/Avatar/Avatar.js +1 -1
  57. package/dist/components/content/Badge/Badge.js +2 -1
  58. package/dist/components/content/Badge/Badge.js.map +1 -1
  59. package/dist/components/content/Card/Card.js +1 -1
  60. package/dist/components/content/Content.js +1 -1
  61. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
  62. package/dist/components/content/CopySnippet/CopySnippet.js +1 -1
  63. package/dist/components/content/Disclosure/Disclosure.js +5 -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 +1 -1
  67. package/dist/components/content/Header.js +1 -1
  68. package/dist/components/content/HotKeys/HotKeys.js +1 -1
  69. package/dist/components/content/Item/Item.js +1 -1
  70. package/dist/components/content/ItemBadge/ItemBadge.js +3 -2
  71. package/dist/components/content/ItemBadge/ItemBadge.js.map +1 -1
  72. package/dist/components/content/ItemCard/ItemCard.js +1 -1
  73. package/dist/components/content/Layout/GridLayout.js +1 -1
  74. package/dist/components/content/Layout/Layout.js +1 -1
  75. package/dist/components/content/Layout/LayoutBlock.js +1 -1
  76. package/dist/components/content/Layout/LayoutCenter.js +1 -1
  77. package/dist/components/content/Layout/LayoutContainer.js +1 -1
  78. package/dist/components/content/Layout/LayoutContent.js +1 -1
  79. package/dist/components/content/Layout/LayoutContext.js +1 -1
  80. package/dist/components/content/Layout/LayoutFlex.js +1 -1
  81. package/dist/components/content/Layout/LayoutFooter.js +1 -1
  82. package/dist/components/content/Layout/LayoutGrid.js +1 -1
  83. package/dist/components/content/Layout/LayoutHeader.js +1 -1
  84. package/dist/components/content/Layout/LayoutPane.js +1 -1
  85. package/dist/components/content/Layout/LayoutPanel.js +1 -1
  86. package/dist/components/content/Layout/LayoutPanelHeader.js +1 -1
  87. package/dist/components/content/Layout/LayoutToolbar.js +1 -1
  88. package/dist/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
  89. package/dist/components/content/Layout/index.js +1 -1
  90. package/dist/components/content/Layout/utils.js +1 -1
  91. package/dist/components/content/Paragraph.js +1 -1
  92. package/dist/components/content/Placeholder/Placeholder.js +1 -1
  93. package/dist/components/content/PrismCode/PrismCode.js +1 -1
  94. package/dist/components/content/PrismCode/prismSetup.js +1 -1
  95. package/dist/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  96. package/dist/components/content/Result/Result.js +1 -1
  97. package/dist/components/content/Skeleton/Skeleton.js +1 -1
  98. package/dist/components/content/Tag/Tag.js +2 -1
  99. package/dist/components/content/Tag/Tag.js.map +1 -1
  100. package/dist/components/content/Text.js +1 -1
  101. package/dist/components/content/TextItem/TextItem.js +1 -1
  102. package/dist/components/content/Title.js +1 -1
  103. package/dist/components/content/highlightText.js +1 -1
  104. package/dist/components/content/use-auto-tooltip.js +1 -1
  105. package/dist/components/fields/Checkbox/Checkbox.js +1 -1
  106. package/dist/components/fields/Checkbox/CheckboxGroup.js +1 -1
  107. package/dist/components/fields/Checkbox/context.js +1 -1
  108. package/dist/components/fields/ComboBox/ComboBox.js +1 -1
  109. package/dist/components/fields/DatePicker/DateInput.js +1 -1
  110. package/dist/components/fields/DatePicker/DateInputBase.js +1 -1
  111. package/dist/components/fields/DatePicker/DatePicker.js +1 -1
  112. package/dist/components/fields/DatePicker/DatePickerButton.js +1 -1
  113. package/dist/components/fields/DatePicker/DatePickerElement.js +1 -1
  114. package/dist/components/fields/DatePicker/DatePickerInput.js +1 -1
  115. package/dist/components/fields/DatePicker/DatePickerSegment.js +1 -1
  116. package/dist/components/fields/DatePicker/DateRangePicker.js +1 -1
  117. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
  118. package/dist/components/fields/DatePicker/TimeInput.js +1 -1
  119. package/dist/components/fields/DatePicker/intl.js +1 -1
  120. package/dist/components/fields/DatePicker/parseDate.js +1 -1
  121. package/dist/components/fields/DatePicker/props.js +1 -1
  122. package/dist/components/fields/DatePicker/utils.js +1 -1
  123. package/dist/components/fields/FileInput/FileInput.js +1 -1
  124. package/dist/components/fields/FilterListBox/FilterListBox.js +1 -1
  125. package/dist/components/fields/FilterPicker/FilterPicker.js +2 -2
  126. package/dist/components/fields/Input/Input.js +1 -1
  127. package/dist/components/fields/ListBox/ListBox.js +1 -1
  128. package/dist/components/fields/NumberInput/NumberInput.js +1 -1
  129. package/dist/components/fields/NumberInput/StepButton.js +1 -1
  130. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  131. package/dist/components/fields/Picker/Picker.js +2 -2
  132. package/dist/components/fields/RadioGroup/Radio.js +3 -1
  133. package/dist/components/fields/RadioGroup/Radio.js.map +1 -1
  134. package/dist/components/fields/RadioGroup/RadioGroup.js +1 -1
  135. package/dist/components/fields/RadioGroup/context.js +1 -1
  136. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  137. package/dist/components/fields/Select/Select.d.ts +8 -2
  138. package/dist/components/fields/Select/Select.js +1 -1
  139. package/dist/components/fields/Select/Select.js.map +1 -1
  140. package/dist/components/fields/Slider/Gradation.js +1 -1
  141. package/dist/components/fields/Slider/HueSlider.js +1 -1
  142. package/dist/components/fields/Slider/RangeSlider.js +1 -1
  143. package/dist/components/fields/Slider/Slider.js +1 -1
  144. package/dist/components/fields/Slider/SliderBase.js +1 -1
  145. package/dist/components/fields/Slider/SliderThumb.js +1 -1
  146. package/dist/components/fields/Slider/SliderTrack.js +1 -1
  147. package/dist/components/fields/Slider/elements.js +1 -1
  148. package/dist/components/fields/Slider/index.js +1 -1
  149. package/dist/components/fields/Switch/Switch.js +1 -1
  150. package/dist/components/fields/TextArea/TextArea.js +1 -1
  151. package/dist/components/fields/TextInput/TextInput.js +1 -1
  152. package/dist/components/fields/TextInput/TextInputBase.js +1 -1
  153. package/dist/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  154. package/dist/components/form/FieldWrapper/FieldWrapper.js +1 -1
  155. package/dist/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  156. package/dist/components/form/Form/Field.js +1 -1
  157. package/dist/components/form/Form/Form.js +1 -1
  158. package/dist/components/form/Form/ResetButton/ResetButton.js +1 -1
  159. package/dist/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  160. package/dist/components/form/Form/SubmitError.js +1 -1
  161. package/dist/components/form/Form/index.js +1 -1
  162. package/dist/components/form/Form/use-field/use-field-props.js +1 -1
  163. package/dist/components/form/Form/use-field/use-field.js +1 -1
  164. package/dist/components/form/Form/use-form.js +1 -1
  165. package/dist/components/form/Form/validation.js +1 -1
  166. package/dist/components/form/Label.js +1 -1
  167. package/dist/components/form/wrapper.js +1 -1
  168. package/dist/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  169. package/dist/components/helpers/IconSwitch/IconSwitch.js +1 -1
  170. package/dist/components/layout/Flex.js +1 -1
  171. package/dist/components/layout/Flow.js +1 -1
  172. package/dist/components/layout/Grid.js +1 -1
  173. package/dist/components/layout/Panel.js +1 -1
  174. package/dist/components/layout/Prefix.js +1 -1
  175. package/dist/components/layout/ResizablePanel.js +1 -1
  176. package/dist/components/layout/Space.js +1 -1
  177. package/dist/components/layout/Suffix.js +1 -1
  178. package/dist/components/navigation/Tabs/DraggableTabList.js +1 -1
  179. package/dist/components/navigation/Tabs/EditableTitle.js +1 -1
  180. package/dist/components/navigation/Tabs/TabButton.js +1 -1
  181. package/dist/components/navigation/Tabs/TabDropIndicator.js +1 -1
  182. package/dist/components/navigation/Tabs/TabPanel.js +1 -1
  183. package/dist/components/navigation/Tabs/TabPicker.js +2 -1
  184. package/dist/components/navigation/Tabs/TabPicker.js.map +1 -1
  185. package/dist/components/navigation/Tabs/Tabs.js +1 -1
  186. package/dist/components/navigation/Tabs/TabsAction.js +1 -1
  187. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  188. package/dist/components/navigation/Tabs/styled.js +3 -1
  189. package/dist/components/navigation/Tabs/styled.js.map +1 -1
  190. package/dist/components/navigation/Tabs/types.d.ts +2 -2
  191. package/dist/components/navigation/Tabs/types.js +1 -1
  192. package/dist/components/navigation/Tabs/types.js.map +1 -1
  193. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  194. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  195. package/dist/components/organisms/FileTabs/FileTabs.js +1 -1
  196. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  197. package/dist/components/other/Calendar/Calendar.js +1 -1
  198. package/dist/components/other/Calendar/CalendarCell.js +1 -1
  199. package/dist/components/other/Calendar/CalendarGrid.js +1 -1
  200. package/dist/components/other/Calendar/RangeCalendar.js +1 -1
  201. package/dist/components/other/CloudLogo/CloudLogo.js +1 -1
  202. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  203. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  204. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  205. package/dist/components/overlays/Dialog/Dialog.js +2 -2
  206. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  207. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  208. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  209. package/dist/components/overlays/Dialog/context.js +1 -1
  210. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  211. package/dist/components/overlays/Modal/Modal.js +1 -1
  212. package/dist/components/overlays/Modal/OpenTransition.js +1 -1
  213. package/dist/components/overlays/Modal/Overlay.js +1 -1
  214. package/dist/components/overlays/Modal/Popover.js +1 -1
  215. package/dist/components/overlays/Modal/Tray.js +1 -1
  216. package/dist/components/overlays/Modal/Underlay.js +1 -1
  217. package/dist/components/overlays/Notifications/Notification.js +1 -1
  218. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  219. package/dist/components/overlays/Notifications/NotificationCard.js +1 -1
  220. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  221. package/dist/components/overlays/Notifications/NotificationItem.js +1 -1
  222. package/dist/components/overlays/Notifications/OverlayContainer.js +1 -1
  223. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  224. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +1 -1
  225. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  226. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  227. package/dist/components/overlays/Notifications/index.js +1 -1
  228. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  229. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  230. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  231. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  232. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  233. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  234. package/dist/components/overlays/Toast/ToastItem.js +1 -1
  235. package/dist/components/overlays/Toast/index.js +1 -1
  236. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  237. package/dist/components/overlays/Toast/useToast.js +1 -1
  238. package/dist/components/overlays/Tooltip/Tooltip.js +1 -1
  239. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  240. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  241. package/dist/components/overlays/Tooltip/context.js +1 -1
  242. package/dist/components/portal/Portal.js +1 -1
  243. package/dist/components/portal/PortalProvider.js +1 -1
  244. package/dist/components/portal/usePortal.js +1 -1
  245. package/dist/components/shared/InvalidIcon.js +1 -1
  246. package/dist/components/shared/ValidIcon.js +1 -1
  247. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  248. package/dist/components/status/Spin/Cube.js +1 -1
  249. package/dist/components/status/Spin/InternalSpinner.js +1 -1
  250. package/dist/components/status/Spin/Spin.js +1 -1
  251. package/dist/components/status/Spin/SpinsContainer.js +1 -1
  252. package/dist/data/item-themes.js +6 -6
  253. package/dist/data/item-themes.js.map +1 -1
  254. package/dist/data/themes.js +1 -1
  255. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  256. package/dist/icons/AdjustmentsIcon.js +1 -1
  257. package/dist/icons/AiIcon.js +1 -1
  258. package/dist/icons/AreaChartIcon.js +1 -1
  259. package/dist/icons/BackwardIcon.js +1 -1
  260. package/dist/icons/BarChartIcon.js +1 -1
  261. package/dist/icons/BellFilledIcon.js +1 -1
  262. package/dist/icons/BellIcon.js +1 -1
  263. package/dist/icons/BooleanIcon.js +1 -1
  264. package/dist/icons/CalendarEditIcon.js +1 -1
  265. package/dist/icons/CalendarIcon.js +1 -1
  266. package/dist/icons/CaretDownIcon.js +1 -1
  267. package/dist/icons/CaretUpIcon.js +1 -1
  268. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  269. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  270. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  271. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  272. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  273. package/dist/icons/ChartBarLineIcon.js +1 -1
  274. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  275. package/dist/icons/ChartBarStackedIcon.js +1 -1
  276. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  277. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  278. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  279. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  280. package/dist/icons/ChartBubbleIcon.js +1 -1
  281. package/dist/icons/ChartDonut2Icon.js +1 -1
  282. package/dist/icons/ChartFunnelIcon.js +1 -1
  283. package/dist/icons/ChartHeatmapIcon.js +1 -1
  284. package/dist/icons/ChartKPIIcon.js +1 -1
  285. package/dist/icons/ChartPie2Icon.js +1 -1
  286. package/dist/icons/ChartScatterIcon.js +1 -1
  287. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  288. package/dist/icons/CheckCircleIcon.js +1 -1
  289. package/dist/icons/CheckIcon.js +1 -1
  290. package/dist/icons/CircleFilledIcon.js +1 -1
  291. package/dist/icons/ClearIcon.js +1 -1
  292. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  293. package/dist/icons/CloseCircleIcon.js +1 -1
  294. package/dist/icons/CloseIcon.js +1 -1
  295. package/dist/icons/CodeIcon.js +1 -1
  296. package/dist/icons/ColumnTotalIcon.js +1 -1
  297. package/dist/icons/CopyIcon.js +1 -1
  298. package/dist/icons/CountIcon.js +1 -1
  299. package/dist/icons/CubeIcon.js +1 -1
  300. package/dist/icons/CubePauseIcon.js +1 -1
  301. package/dist/icons/CubePlayIcon.js +1 -1
  302. package/dist/icons/CurrencyDollarIcon.js +1 -1
  303. package/dist/icons/DangerIcon.js +1 -1
  304. package/dist/icons/DashboardIcon.js +1 -1
  305. package/dist/icons/DatabaseIcon.js +1 -1
  306. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  307. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  308. package/dist/icons/DirectionIcon.js +1 -1
  309. package/dist/icons/DonutIcon.js +1 -1
  310. package/dist/icons/DownIcon.js +1 -1
  311. package/dist/icons/EditIcon.js +1 -1
  312. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  313. package/dist/icons/ExclamationCircleIcon.js +1 -1
  314. package/dist/icons/ExclamationIcon.js +1 -1
  315. package/dist/icons/EyeIcon.js +1 -1
  316. package/dist/icons/EyeInvisibleIcon.js +1 -1
  317. package/dist/icons/FilterIcon.js +1 -1
  318. package/dist/icons/FolderFilledIcon.js +1 -1
  319. package/dist/icons/FolderIcon.js +1 -1
  320. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  321. package/dist/icons/FolderOpenIcon.js +1 -1
  322. package/dist/icons/ForwardIcon.js +1 -1
  323. package/dist/icons/HierarchyIcon.js +1 -1
  324. package/dist/icons/HierarchyOpenIcon.js +1 -1
  325. package/dist/icons/Icon.js +1 -1
  326. package/dist/icons/InfoCircleIcon.js +1 -1
  327. package/dist/icons/InfoIcon.js +1 -1
  328. package/dist/icons/KeyIcon.js +1 -1
  329. package/dist/icons/LeftIcon.js +1 -1
  330. package/dist/icons/LineChartIcon.js +1 -1
  331. package/dist/icons/LoadingIcon.js +1 -1
  332. package/dist/icons/LockFilledIcon.js +1 -1
  333. package/dist/icons/LockIcon.js +1 -1
  334. package/dist/icons/MoreIcon.js +1 -1
  335. package/dist/icons/NotAllowedIcon.js +1 -1
  336. package/dist/icons/Number123Icon.js +1 -1
  337. package/dist/icons/NumberIcon.js +1 -1
  338. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  339. package/dist/icons/PauseCircleIcon.js +1 -1
  340. package/dist/icons/PauseIcon.js +1 -1
  341. package/dist/icons/PercentageIcon.js +1 -1
  342. package/dist/icons/PieChartIcon.js +1 -1
  343. package/dist/icons/PlayCircleIcon.js +1 -1
  344. package/dist/icons/PlayIcon.js +1 -1
  345. package/dist/icons/PlusIcon.js +1 -1
  346. package/dist/icons/ProgressBarIcon.js +1 -1
  347. package/dist/icons/ReloadIcon.js +1 -1
  348. package/dist/icons/ReportIcon.js +1 -1
  349. package/dist/icons/ReturnIcon.js +1 -1
  350. package/dist/icons/RightIcon.js +1 -1
  351. package/dist/icons/RowTotalsIcon.js +1 -1
  352. package/dist/icons/SchemeIcon.js +1 -1
  353. package/dist/icons/SearchIcon.js +1 -1
  354. package/dist/icons/SemanticQueryIcon.js +1 -1
  355. package/dist/icons/SettingsIcon.js +1 -1
  356. package/dist/icons/ShieldFilledIcon.js +1 -1
  357. package/dist/icons/ShieldIcon.js +1 -1
  358. package/dist/icons/SlashIcon.js +1 -1
  359. package/dist/icons/SparklesIcon.js +1 -1
  360. package/dist/icons/SqlIcon.js +1 -1
  361. package/dist/icons/StatsIcon.js +1 -1
  362. package/dist/icons/StopIcon.js +1 -1
  363. package/dist/icons/StringIcon.js +1 -1
  364. package/dist/icons/SubtotalsIcon.js +1 -1
  365. package/dist/icons/SwitchIcon.js +1 -1
  366. package/dist/icons/TableIcon.js +1 -1
  367. package/dist/icons/ThumbsDownIcon.js +1 -1
  368. package/dist/icons/ThumbsUpIcon.js +1 -1
  369. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  370. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  371. package/dist/icons/ThunderboltIcon.js +1 -1
  372. package/dist/icons/TimeIcon.js +1 -1
  373. package/dist/icons/TrashIcon.js +1 -1
  374. package/dist/icons/UnlockIcon.js +1 -1
  375. package/dist/icons/UpIcon.js +1 -1
  376. package/dist/icons/UserGroupIcon.js +1 -1
  377. package/dist/icons/UserIcon.js +1 -1
  378. package/dist/icons/UserLockIcon.js +1 -1
  379. package/dist/icons/ViewIcon.js +1 -1
  380. package/dist/icons/WarningFilledIcon.js +1 -1
  381. package/dist/icons/WarningIcon.js +1 -1
  382. package/dist/icons/wrap-icon.js +1 -1
  383. package/dist/index.d.ts +6 -4
  384. package/dist/index.js +7 -5
  385. package/dist/index.js.map +1 -1
  386. package/dist/provider.js +1 -1
  387. package/dist/providers/TrackingProvider.js +1 -1
  388. package/dist/providers/navigationAdapter.default.js +1 -1
  389. package/dist/tokens/base.js +1 -1
  390. package/dist/tokens/colors.js +1 -1
  391. package/dist/tokens/index.js +1 -1
  392. package/dist/tokens/layout.js +1 -1
  393. package/dist/tokens/shadows.js +1 -1
  394. package/dist/tokens/sizes.js +1 -1
  395. package/dist/tokens/spacing.js +1 -1
  396. package/dist/utils/ResizeSensor.js +1 -1
  397. package/dist/utils/is-dev-env.js +1 -1
  398. package/dist/utils/modules.js +1 -1
  399. package/dist/utils/promise.js +1 -1
  400. package/dist/utils/raf.js +1 -1
  401. package/dist/utils/random.js +1 -1
  402. package/dist/utils/range.js +1 -1
  403. package/dist/utils/react/RenderCache.js +1 -1
  404. package/dist/utils/react/Slots.js +1 -1
  405. package/dist/utils/react/chain.js +1 -1
  406. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  407. package/dist/utils/react/index.js +1 -1
  408. package/dist/utils/react/interactions.js +1 -1
  409. package/dist/utils/react/isTextOnly.js +1 -1
  410. package/dist/utils/react/mapProps.js +1 -1
  411. package/dist/utils/react/mergeProps.js +1 -1
  412. package/dist/utils/react/nullableValue.js +1 -1
  413. package/dist/utils/react/resolveIcon.js +1 -1
  414. package/dist/utils/react/sharedStore.js +1 -1
  415. package/dist/utils/react/useCombinedRefs.js +1 -1
  416. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  417. package/dist/utils/react/useEventBus.js +1 -1
  418. package/dist/utils/react/useId.js +1 -1
  419. package/dist/utils/react/useIsDarwin.js +1 -1
  420. package/dist/utils/react/useKeySymbols.js +1 -1
  421. package/dist/utils/react/useLayoutEffect.js +1 -1
  422. package/dist/utils/react/useLocalStorage.js +1 -1
  423. package/dist/utils/react/useMergeStyles.js +1 -1
  424. package/dist/utils/react/useQaProps.js +1 -1
  425. package/dist/utils/react/useViewportSize.js +1 -1
  426. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  427. package/dist/utils/tree.js +1 -1
  428. package/dist/utils/warnings.js +1 -1
  429. package/dist/version.js +2 -2
  430. package/docs/BaseProperties.md +78 -0
  431. package/docs/ComplexLayout.md +459 -0
  432. package/docs/CreateComponent.md +410 -0
  433. package/docs/FieldProperties.md +117 -0
  434. package/docs/Introduction.md +122 -0
  435. package/docs/RenderCache.md +177 -0
  436. package/docs/Result.md +42 -0
  437. package/docs/SimpleLayout.md +26 -0
  438. package/docs/Typography.md +38 -0
  439. package/docs/components/Block.md +33 -0
  440. package/docs/components/CollectionItem.md +293 -0
  441. package/docs/components/GridProvider.md +38 -0
  442. package/docs/components/Root.md +50 -0
  443. package/docs/components/actions/Action.md +47 -0
  444. package/docs/components/actions/Banner.md +195 -0
  445. package/docs/components/actions/Button.md +209 -0
  446. package/docs/components/actions/ButtonGroup.md +46 -0
  447. package/docs/components/actions/ButtonSplit.md +199 -0
  448. package/docs/components/actions/CommandMenu.md +422 -0
  449. package/docs/components/actions/ItemAction.md +60 -0
  450. package/docs/components/actions/ItemButton.md +316 -0
  451. package/docs/components/actions/Link.md +325 -0
  452. package/docs/components/actions/Menu.md +485 -0
  453. package/docs/components/actions/MenuTrigger.md +47 -0
  454. package/docs/components/actions/SubMenuTrigger.md +38 -0
  455. package/docs/components/actions/use-anchored-menu.md +209 -0
  456. package/docs/components/actions/use-context-menu.md +218 -0
  457. package/docs/components/content/ActiveZone.md +37 -0
  458. package/docs/components/content/Alert.md +40 -0
  459. package/docs/components/content/Avatar.md +37 -0
  460. package/docs/components/content/Badge.md +194 -0
  461. package/docs/components/content/Card.md +40 -0
  462. package/docs/components/content/Content.md +44 -0
  463. package/docs/components/content/CopyPasteBlock.md +36 -0
  464. package/docs/components/content/CopySnippet.md +43 -0
  465. package/docs/components/content/Disclosure.md +181 -0
  466. package/docs/components/content/Divider.md +39 -0
  467. package/docs/components/content/Footer.md +35 -0
  468. package/docs/components/content/Header.md +35 -0
  469. package/docs/components/content/HotKeys.md +352 -0
  470. package/docs/components/content/Item.md +499 -0
  471. package/docs/components/content/ItemBadge.md +31 -0
  472. package/docs/components/content/ItemCard.md +131 -0
  473. package/docs/components/content/Layout.md +843 -0
  474. package/docs/components/content/Paragraph.md +32 -0
  475. package/docs/components/content/Placeholder.md +37 -0
  476. package/docs/components/content/PrismCode.md +36 -0
  477. package/docs/components/content/PrismDiffCode.md +29 -0
  478. package/docs/components/content/Result.md +46 -0
  479. package/docs/components/content/Skeleton.md +35 -0
  480. package/docs/components/content/Tag.md +165 -0
  481. package/docs/components/content/Text.md +54 -0
  482. package/docs/components/content/TextItem.md +217 -0
  483. package/docs/components/content/Title.md +45 -0
  484. package/docs/components/fields/Checkbox.md +176 -0
  485. package/docs/components/fields/ComboBox.md +651 -0
  486. package/docs/components/fields/DatePicker.md +227 -0
  487. package/docs/components/fields/FileInput.md +194 -0
  488. package/docs/components/fields/FilterListBox.md +726 -0
  489. package/docs/components/fields/FilterPicker.md +776 -0
  490. package/docs/components/fields/HueSlider.md +175 -0
  491. package/docs/components/fields/ListBox.md +714 -0
  492. package/docs/components/fields/NumberInput.md +180 -0
  493. package/docs/components/fields/PasswordInput.md +214 -0
  494. package/docs/components/fields/Picker.md +906 -0
  495. package/docs/components/fields/RadioGroup.md +310 -0
  496. package/docs/components/fields/SearchInput.md +224 -0
  497. package/docs/components/fields/Select.md +576 -0
  498. package/docs/components/fields/Slider.md +53 -0
  499. package/docs/components/fields/Switch.md +169 -0
  500. package/docs/components/fields/TextArea.md +61 -0
  501. package/docs/components/fields/TextInput.md +205 -0
  502. package/docs/components/fields/TextInputMapper.md +34 -0
  503. package/docs/components/form/Field.md +333 -0
  504. package/docs/components/form/Form.md +644 -0
  505. package/docs/components/form/FormInstance.md +307 -0
  506. package/docs/components/helpers/DisplayTransition.md +268 -0
  507. package/docs/components/helpers/IconSwitch.md +160 -0
  508. package/docs/components/layout/Flex.md +51 -0
  509. package/docs/components/layout/Flow.md +32 -0
  510. package/docs/components/layout/Grid.md +46 -0
  511. package/docs/components/layout/Panel.md +65 -0
  512. package/docs/components/layout/Prefix.md +37 -0
  513. package/docs/components/layout/ResizablePanel.md +69 -0
  514. package/docs/components/layout/Space.md +44 -0
  515. package/docs/components/layout/Suffix.md +39 -0
  516. package/docs/components/navigation/Tabs.md +726 -0
  517. package/docs/components/organisms/FileTabs.md +39 -0
  518. package/docs/components/organisms/StatsCard.md +40 -0
  519. package/docs/components/other/CloudLogo.md +33 -0
  520. package/docs/components/overlays/AlertDialog.md +51 -0
  521. package/docs/components/overlays/Dialog.md +200 -0
  522. package/docs/components/overlays/DialogContainer.md +201 -0
  523. package/docs/components/overlays/DialogForm.md +295 -0
  524. package/docs/components/overlays/DialogTrigger.md +191 -0
  525. package/docs/components/overlays/Notifications.md +402 -0
  526. package/docs/components/overlays/Toast.md +289 -0
  527. package/docs/components/overlays/Tooltip.md +400 -0
  528. package/docs/components/overlays/TooltipProvider.md +42 -0
  529. package/docs/components/overlays/TooltipTrigger.md +42 -0
  530. package/docs/components/overlays/UseDialogContainer.md +597 -0
  531. package/docs/components/portal/Portal.md +29 -0
  532. package/docs/components/status/LoadingAnimation.md +27 -0
  533. package/docs/components/status/Spin.md +35 -0
  534. package/docs/tasty/configuration.md +211 -0
  535. package/docs/tasty/debug.md +505 -0
  536. package/docs/tasty/injector.md +528 -0
  537. package/docs/tasty/styles.md +567 -0
  538. package/docs/tasty/tasty-static.md +376 -0
  539. package/docs/tasty/usage.md +643 -0
  540. package/package.json +5 -9
@@ -0,0 +1,410 @@
1
+ # Create Component
2
+
3
+ This guide explains how to create components using the `tasty` style helper and React Aria Hooks. Components in the Cube UI Kit follow consistent patterns for styling, accessibility, and functionality.
4
+
5
+ ## Overview
6
+
7
+ Creating a component involves several optional but recommended elements:
8
+
9
+ - **Base properties** handling using `filterBaseProps`
10
+ - **Style properties** for direct styling capabilities
11
+ - **Modifiers (`mods`)** for state-based styling
12
+ - **Additional style properties** for styling inner elements
13
+ - **Sub-elements** for targeted styling within components
14
+ - **React Aria integration** for accessibility
15
+
16
+ Everything is optional - you can create simplified components without all features, but exported UI Kit components should be feature-rich and consistent.
17
+
18
+ ## Core Concepts
19
+
20
+ ### 1. Base Properties with `filterBaseProps`
21
+
22
+ The `filterBaseProps` helper ensures only valid DOM properties are passed to elements, filtering out design system properties and unsupported event handlers.
23
+
24
+ ```tsx
25
+ import { filterBaseProps, AllBaseProps } from '@tenphi/tasty';
26
+
27
+ interface MyComponentProps extends AllBaseProps {
28
+ customProp?: string;
29
+ }
30
+
31
+ function MyComponent(props: MyComponentProps) {
32
+ return (
33
+ <div {...filterBaseProps(props, { eventProps: true })}>
34
+ {props.children}
35
+ </div>
36
+ );
37
+ }
38
+ ```
39
+
40
+ **Filter options:**
41
+ - `eventProps: true` - Include standard DOM event handlers (onClick, onFocus, etc.)
42
+ - `labelable: true` - Include ARIA labeling properties
43
+ - `propNames: Set<string>` - Include specific additional properties
44
+
45
+ ### 2. Style Properties
46
+
47
+ Style properties allow direct styling without using the `styles` prop. Use predefined style property sets from `/src/tasty/styles/list.ts`:
48
+
49
+ ```tsx
50
+ import {
51
+ CONTAINER_STYLES,
52
+ ContainerStyleProps,
53
+ BASE_STYLES,
54
+ BaseStyleProps,
55
+ TEXT_STYLES,
56
+ TextStyleProps,
57
+ extractStyles,
58
+ } from '@tenphi/tasty';
59
+
60
+ interface MyComponentProps
61
+ extends AllBaseProps,
62
+ ContainerStyleProps, // All container styles
63
+ TextStyleProps { // Text-specific styles
64
+ // Component-specific props
65
+ }
66
+
67
+ function MyComponent(props: MyComponentProps) {
68
+ const styles = extractStyles(props, [...CONTAINER_STYLES, ...TEXT_STYLES]);
69
+
70
+ return <Element styles={styles} />;
71
+ }
72
+ ```
73
+
74
+ **Available style property sets:**
75
+
76
+ - `BASE_STYLES` - `display`, `font`, `preset`, `hide`, `opacity`, `whiteSpace`
77
+ - `POSITION_STYLES` - `gridArea`, `order`, `margin`, `inset`, `position`, `zIndex`, etc.
78
+ - `BLOCK_STYLES` - `padding`, `border`, `radius`, `shadow`, `overflow`, etc.
79
+ - `COLOR_STYLES` - `color`, `fill`, `fade`
80
+ - `TEXT_STYLES` - `textTransform` (for other text styling, use `preset`)
81
+ - `DIMENSION_STYLES` - `width`, `height`, `flex`, `flexBasis`, etc.
82
+ - `FLOW_STYLES` - `flow`, `gap`, `align`, `justify`, `gridColumns`, etc.
83
+ - `CONTAINER_STYLES` - Combination of all above styles
84
+ - `OUTER_STYLES` - Position and dimension styles only
85
+
86
+ ### 3. Modifiers (`mods`) Property
87
+
88
+ Modifiers enable state-based styling through the `mods` prop, which creates `data-*` attributes:
89
+
90
+ ```tsx
91
+ interface MyComponentProps extends AllBaseProps {
92
+ isLoading?: boolean;
93
+ }
94
+
95
+ function MyComponent({ isLoading, mods, ...props }: MyComponentProps) {
96
+ return (
97
+ <Element
98
+ mods={{
99
+ loading: isLoading,
100
+ ...mods, // Allow external mods to override
101
+ }}
102
+ styles={{
103
+ color: {
104
+ '': '#dark',
105
+ loading: '#gray',
106
+ 'loading & hovered': '#light-gray',
107
+ }
108
+ }}
109
+ />
110
+ );
111
+ }
112
+ ```
113
+
114
+ **Usage:**
115
+ ```tsx
116
+ <MyComponent mods={{ custom: true, highlighted: isHighlighted }} />
117
+ // Renders: <div data-custom data-highlighted class="...">
118
+ ```
119
+
120
+ ### 4. Sub-elements for Targeted Styling
121
+
122
+ Sub-elements allow styling inner parts through the main `styles` prop. They automatically inherit the parent's state and modifiers, making them ideal for tightly coupled UI elements.
123
+
124
+ ```tsx
125
+ const MyElement = tasty({
126
+ styles: {
127
+ display: 'flex',
128
+ gap: '1x',
129
+
130
+ // Sub-element styles
131
+ Icon: {
132
+ preset: 'h3',
133
+ color: '#purple',
134
+ },
135
+ Label: {
136
+ preset: 'default bold',
137
+ },
138
+ },
139
+ });
140
+
141
+ function MyComponent(props) {
142
+ return (
143
+ <MyElement {...props}>
144
+ <span data-element="Icon">🎉</span>
145
+ <span data-element="Label">{props.children}</span>
146
+ </MyElement>
147
+ );
148
+ }
149
+ ```
150
+
151
+ **Usage with style overrides:**
152
+ ```tsx
153
+ <MyComponent
154
+ styles={{
155
+ Icon: { color: '#red' }, // Override icon color
156
+ Label: { preset: 'h4' }, // Override label size
157
+ }}
158
+ >
159
+ Custom styled content
160
+ </MyComponent>
161
+ ```
162
+
163
+ **When to use sub-elements:**
164
+ - Elements that should share the parent's state (hover, focus, disabled, etc.)
165
+ - Tightly coupled UI parts (icon + label, title + subtitle)
166
+ - When you want a single `styles` prop to control everything
167
+ - Simpler components with predictable inner structure
168
+
169
+ ### 5. Additional Style Properties
170
+
171
+ Create dedicated style properties for styling inner elements independently. This approach gives more control and allows inner elements to have their own state.
172
+
173
+ ```tsx
174
+ import { Styles } from '@tenphi/tasty';
175
+
176
+ interface MyComponentProps extends AllBaseProps {
177
+ styles?: Styles;
178
+ iconStyles?: Styles; // Additional style property
179
+ labelStyles?: Styles; // Another additional style property
180
+ }
181
+
182
+ function MyComponent({ iconStyles, labelStyles, ...props }: MyComponentProps) {
183
+ const styles = extractStyles(props, CONTAINER_STYLES);
184
+
185
+ return (
186
+ <Element styles={styles}>
187
+ <IconElement styles={iconStyles} />
188
+ <LabelElement styles={labelStyles} />
189
+ </Element>
190
+ );
191
+ }
192
+ ```
193
+
194
+ **When to use additional style properties:**
195
+ - Inner elements need independent state management (separate hover, focus behaviors)
196
+ - Complex components with multiple logical sections
197
+ - Components that need fine-grained styling control
198
+ - When different parts of the component might have different interaction patterns
199
+
200
+ ### 6. React Aria Integration
201
+
202
+ Use React Aria hooks for accessibility and behavior:
203
+
204
+ ```tsx
205
+ import { useButton } from 'react-aria';
206
+ import { useRef } from 'react';
207
+
208
+ function MyButton(props) {
209
+ const ref = useRef();
210
+ const { buttonProps } = useButton(props, ref);
211
+
212
+ return (
213
+ <Element
214
+ {...buttonProps}
215
+ ref={ref}
216
+ styles={extractStyles(props, CONTAINER_STYLES)}
217
+ />
218
+ );
219
+ }
220
+ ```
221
+
222
+ ## Examples
223
+
224
+ ### Example 1: Block Component (Basic)
225
+
226
+ This demonstrates a basic component with:
227
+ - Base properties support
228
+ - All container style properties
229
+ - Clean, minimal implementation
230
+
231
+ ```tsx
232
+ import { forwardRef } from 'react';
233
+ import {
234
+ AllBaseProps,
235
+ CONTAINER_STYLES,
236
+ ContainerStyleProps,
237
+ extractStyles,
238
+ filterBaseProps,
239
+ tasty,
240
+ } from '@tenphi/tasty';
241
+
242
+ const BlockElement = tasty({
243
+ styles: {
244
+ display: 'block',
245
+ },
246
+ });
247
+
248
+ export interface CubeBlockProps
249
+ extends Omit<AllBaseProps, keyof ContainerStyleProps | 'as'>,
250
+ ContainerStyleProps {}
251
+
252
+ export const Block = forwardRef(function Block(props: CubeBlockProps, ref) {
253
+ const styles = extractStyles(props, CONTAINER_STYLES);
254
+
255
+ return (
256
+ <BlockElement
257
+ {...filterBaseProps(props, { eventProps: true })}
258
+ ref={ref}
259
+ styles={styles}
260
+ />
261
+ );
262
+ });
263
+ ```
264
+
265
+ ### Example 2: Action Component (Advanced)
266
+
267
+ This demonstrates advanced features:
268
+ - React Aria integration (`useButton`)
269
+ - Complex modifier handling
270
+ - Multiple style property sets
271
+ - Custom behavior logic
272
+
273
+ ```tsx
274
+ import { FocusableRef } from '@react-types/shared';
275
+ import { forwardRef } from 'react';
276
+ import { AriaButtonProps, useButton, useHover } from 'react-aria';
277
+ import {
278
+ AllBaseProps,
279
+ BaseStyleProps,
280
+ CONTAINER_STYLES,
281
+ ContainerStyleProps,
282
+ extractStyles,
283
+ Styles,
284
+ TagName,
285
+ tasty,
286
+ TEXT_STYLES,
287
+ TextStyleProps,
288
+ } from '@tenphi/tasty';
289
+
290
+ export interface CubeActionProps<T extends TagName = 'button'>
291
+ extends Omit<AllBaseProps<T>, 'htmlType'>,
292
+ BaseStyleProps,
293
+ ContainerStyleProps,
294
+ TextStyleProps,
295
+ Omit<AriaButtonProps, 'type'> {
296
+ to?: string;
297
+ label?: string;
298
+ htmlType?: 'button' | 'submit' | 'reset';
299
+ }
300
+
301
+ const DEFAULT_ACTION_STYLES: Styles = {
302
+ recipe: 'reset button',
303
+ position: 'relative',
304
+ preset: 'inherit',
305
+ outline: {
306
+ '': '#purple-03.0',
307
+ focused: '#purple-03',
308
+ },
309
+ transition: 'theme',
310
+ cursor: '$pointer',
311
+ } as const;
312
+
313
+ const ActionElement = tasty({
314
+ as: 'button',
315
+ styles: DEFAULT_ACTION_STYLES,
316
+ });
317
+
318
+ const STYLE_PROPS = [...CONTAINER_STYLES, ...TEXT_STYLES];
319
+
320
+ export const Action = forwardRef(function Action(
321
+ {
322
+ to,
323
+ as = 'button',
324
+ htmlType,
325
+ label,
326
+ theme,
327
+ mods,
328
+ onPress,
329
+ isDisabled,
330
+ ...props
331
+ }: CubeActionProps,
332
+ ref: FocusableRef<HTMLElement>,
333
+ ) {
334
+ const domRef = useRef();
335
+ const { buttonProps, isPressed } = useButton(
336
+ {
337
+ 'aria-label': label,
338
+ onPress,
339
+ isDisabled,
340
+ ...props,
341
+ },
342
+ domRef,
343
+ );
344
+
345
+ const { hoverProps, isHovered } = useHover({ isDisabled });
346
+
347
+ const styles = extractStyles(props, STYLE_PROPS);
348
+
349
+ return (
350
+ <ActionElement
351
+ data-theme={theme}
352
+ {...buttonProps}
353
+ {...hoverProps}
354
+ mods={{
355
+ hovered: isHovered && !isDisabled,
356
+ pressed: isPressed && !isDisabled,
357
+ disabled: isDisabled,
358
+ ...mods, // Allow external mods to override
359
+ }}
360
+ ref={domRef}
361
+ type={htmlType || 'button'}
362
+ as={as}
363
+ styles={styles}
364
+ />
365
+ );
366
+ });
367
+ ```
368
+
369
+ ## Form Integration
370
+
371
+ For input components that need to integrate with forms, see the [Field documentation](./components/form/Field.md) for comprehensive guidance on:
372
+
373
+ - Form state management
374
+ - Validation integration
375
+ - Label and help text handling
376
+ - Error state management
377
+ - Accessibility requirements for form controls
378
+
379
+ ## Best Practices
380
+
381
+ 1. **Always support base properties**: Use `filterBaseProps` and extend `AllBaseProps`
382
+
383
+ 2. **Provide appropriate style properties**: Choose the right combination of style property sets for your component's needs
384
+
385
+ 3. **Design for extensibility**: Allow `mods` overrides and provide additional style properties for inner elements
386
+
387
+ 4. **Use React Aria**: Integrate appropriate React Aria hooks for accessibility and standard behavior
388
+
389
+ 5. **Follow naming conventions**: Use `Cube[ComponentName]Props` for interfaces and descriptive names for sub-elements
390
+
391
+ 6. **Document sub-elements**: Clearly document what sub-elements are available for styling
392
+
393
+ 7. **Keep it simple when appropriate**: Not every component needs all features - use what makes sense for your use case
394
+
395
+ ## Component Checklist
396
+
397
+ When creating a new component, consider:
398
+
399
+ - [ ] Base properties support (`AllBaseProps`, `filterBaseProps`)
400
+ - [ ] Appropriate style property sets
401
+ - [ ] Modifier (`mods`) support for state-based styling
402
+ - [ ] Additional style properties for inner elements
403
+ - [ ] Sub-element definitions for targeted styling
404
+ - [ ] React Aria integration for accessibility
405
+ - [ ] TypeScript interfaces following naming conventions
406
+ - [ ] forwardRef for ref passing
407
+ - [ ] Default styles and theme support
408
+ - [ ] Documentation following UI Kit standards
409
+
410
+ Remember: Start simple and add features as needed. A basic, working component is better than an over-engineered one!
@@ -0,0 +1,117 @@
1
+ # Field Properties
2
+
3
+ All input components in UI Kit (`TextInput`, `Select`, `ComboBox`, `Checkbox`, `RadioGroup`, `NumberInput`, `Switch`, `DatePicker`, `Slider`, `FileInput`, etc.) share a common set of field properties. These properties are provided by the `FieldBaseProps` interface and enable form integration, validation, labeling, and state management.
4
+
5
+ When used inside a [Form](./components/form/Form.md), these properties are automatically inherited from the form context and can be overridden at the field level.
6
+
7
+ ## Identity & Form Integration
8
+
9
+ - **`name`** `string` — Field name for form data binding. Required when used within a Form.
10
+ - **`form`** `CubeFormInstance` — Form instance. Automatically provided when inside a Form context.
11
+ - **`defaultValue`** `any` — Default value for the field in uncontrolled mode.
12
+ - **`id`** `string` — Unique ID for the field element.
13
+ - **`idPrefix`** `string` — ID prefix to avoid collisions between multiple forms.
14
+
15
+ ## Labels & Description
16
+
17
+ - **`label`** `ReactNode` — Label text displayed above or beside the input.
18
+ - **`labelPosition`** `'top' | 'side' | 'split'` (default: `top`) — Position of the label relative to the input.
19
+ - **`description`** `ReactNode` — Description text placed below the label.
20
+ - **`extra`** `ReactNode` — Additional content displayed next to the label.
21
+ - **`tooltip`** `ReactNode` — Tooltip shown inside the label.
22
+ - **`labelSuffix`** `ReactNode` — Content displayed after the label text.
23
+ - **`labelProps`** `object` — Additional HTML props passed to the label element.
24
+ - **`labelStyles`** `Styles` — Tasty styles for the label element.
25
+
26
+ ## Necessity Indicators
27
+
28
+ - **`isRequired`** `boolean` (default: `false`) — Whether user input is required before form submission.
29
+ - **`necessityIndicator`** `'icon' | 'label'` — Type of necessity indicator shown next to the label.
30
+ - **`necessityLabel`** `ReactNode` — Custom text for the necessity indicator (e.g., "Required" or "Optional").
31
+
32
+ ## State
33
+
34
+ - **`isDisabled`** `boolean` (default: `false`) — Whether the field is disabled and non-interactive.
35
+ - **`isReadOnly`** `boolean` (default: `false`) — Whether the field can be focused but not changed.
36
+ - **`isLoading`** `boolean` (default: `false`) — Whether to show a loading spinner and disable interactions.
37
+ - **`isHidden`** `boolean` (default: `false`) — Whether the field is hidden.
38
+ - **`validationState`** `'valid' | 'invalid'` — Visual validation state of the field.
39
+ - **`autoFocus`** `boolean` (default: `false`) — Whether the field should receive focus on render.
40
+
41
+ ## Validation
42
+
43
+ - **`rules`** `ValidationRule[]` — Array of validation rules for the field.
44
+ - **`validateTrigger`** `'onBlur' | 'onChange' | 'onSubmit'` — When to trigger validation.
45
+ - **`validationDelay`** `number` — Debounce delay in milliseconds before running validation.
46
+ - **`showValid`** `boolean` — Whether to show the valid state icon after successful validation.
47
+ - **`errorMessage`** `ReactNode` — Error message always displayed in danger state, regardless of validation state.
48
+ - **`message`** `ReactNode` — _(deprecated)_ Use `errorMessage` for errors and `description` for help text.
49
+
50
+ ## Styling
51
+
52
+ - **`fieldStyles`** `Styles` — Tasty styles for the field wrapper.
53
+ - **`messageStyles`** `Styles` — Tasty styles for the message/error text.
54
+
55
+ ## Validation Rules
56
+
57
+ The `rules` prop accepts an array of rule objects. Built-in validators include:
58
+
59
+ - **`required`** `boolean` — Field must have a value.
60
+ - **`type`** `string` — Validates data type (`email`, `url`, `number`, etc.).
61
+ - **`pattern`** `RegExp` — Value must match the regular expression.
62
+ - **`min`** / **`max`** `number` — Minimum/maximum length or value constraints.
63
+ - **`enum`** `any[]` — Value must be one of the allowed values.
64
+ - **`whitespace`** `boolean` — Value must contain non-whitespace characters.
65
+ - **`message`** `string` — Custom error message for the rule.
66
+ - **`validator`** `(rule, value) => Promise<string | void>` — Custom async validation function.
67
+
68
+ ```jsx
69
+ <TextInput
70
+ name="email"
71
+ label="Email Address"
72
+ isRequired
73
+ rules={[
74
+ { required: true, message: 'Email is required' },
75
+ { type: 'email', message: 'Enter a valid email' },
76
+ ]}
77
+ />
78
+ ```
79
+
80
+ ## Usage Example
81
+
82
+ ```jsx
83
+ import { Form, TextInput, Select } from '@cube-dev/ui-kit';
84
+
85
+ function ExampleForm() {
86
+ return (
87
+ <Form defaultValues={{ name: '', role: undefined }}>
88
+ <TextInput
89
+ name="name"
90
+ label="Full Name"
91
+ description="As it appears on your ID"
92
+ isRequired
93
+ rules={[{ required: true, min: 2 }]}
94
+ />
95
+
96
+ <Select
97
+ name="role"
98
+ label="Role"
99
+ tooltip="Your primary role in the organization"
100
+ necessityIndicator="label"
101
+ isRequired
102
+ >
103
+ <Select.Item key="admin">Admin</Select.Item>
104
+ <Select.Item key="member">Member</Select.Item>
105
+ </Select>
106
+
107
+ <Form.Submit>Save</Form.Submit>
108
+ </Form>
109
+ );
110
+ }
111
+ ```
112
+
113
+ ## Related
114
+
115
+ - [Base Properties](./BaseProperties.md) — Common styling and layout properties
116
+ - [Form](./components/form/Form.md) — Form container with validation and state management
117
+ - [Field](./components/form/Field.md) — Legacy field wrapper (for custom components only)
@@ -0,0 +1,122 @@
1
+ # Welcome to Cube Cloud UI Kit
2
+
3
+ A comprehensive React component library built for modern web applications with accessibility, theming, and developer experience at its core.
4
+
5
+ ## What is Cube UI Kit?
6
+
7
+ Cube UI Kit is a complete design system that provides:
8
+ - **Accessible Components** - Built with React Aria hooks for WCAG compliance
9
+ - **Powerful Styling System** - The `tasty` style system for maintainable, theme-able components
10
+ - **Form Management** - Integrated form handling with validation and state management
11
+ - **Consistent Design** - Unified visual language across all components
12
+
13
+ Browse example stories by navigating to them in the sidebar to see components in action.
14
+
15
+ ## Key Features
16
+
17
+ ### 🎨 Tasty Style System
18
+ A declarative styling approach that makes it easy to create consistent, maintainable styles:
19
+ - **State-based styling** - Bind styles to hover, focus, and custom modifiers
20
+ - **Responsive design** - Use arrays for breakpoint-specific styles
21
+ - **Token-based theming** - Built-in color tokens and semantic units
22
+ - **Component variants** - Pre-defined style variations for different use cases
23
+
24
+ ### ♿ Accessibility First
25
+ Every component is built with accessibility as a priority:
26
+ - React Aria hooks provide keyboard navigation and screen reader support
27
+ - ARIA attributes are automatically managed
28
+ - Focus management follows best practices
29
+ - High contrast and reduced motion support
30
+
31
+ ### 📝 Modern Form Handling
32
+ Streamlined form development with built-in field support:
33
+ - All input components have integrated field properties
34
+ - Automatic validation and error handling
35
+ - Form-level configuration inheritance
36
+ - No wrapper components needed for most use cases
37
+
38
+ ## Getting Started
39
+
40
+ ### Basic Usage
41
+
42
+ ```jsx
43
+ import { Button, TextInput, Form } from '@cube-dev/ui-kit';
44
+
45
+ function MyApp() {
46
+ return (
47
+ <Form onSubmit={handleSubmit}>
48
+ <TextInput
49
+ name="email"
50
+ label="Email"
51
+ type="email"
52
+ isRequired
53
+ />
54
+ <Button type="primary">Submit</Button>
55
+ </Form>
56
+ );
57
+ }
58
+ ```
59
+
60
+ ### Styling Components
61
+
62
+ Use the `tasty` system for consistent styling:
63
+
64
+ ```jsx
65
+ import { tasty, Button } from '@cube-dev/ui-kit';
66
+
67
+ const CustomButton = tasty(Button, {
68
+ styles: {
69
+ padding: '2x 4x',
70
+ fill: {
71
+ '': '#purple',
72
+ hovered: '#purple.8',
73
+ },
74
+ color: '#white',
75
+ },
76
+ });
77
+ ```
78
+
79
+ ## Core Concepts
80
+
81
+ ### Styling with Tasty
82
+
83
+ The `tasty` style system provides a powerful, declarative way to style components:
84
+
85
+ - **Custom Units** - Use semantic units like `2x` (gap), `1r` (radius), `#purple` (color tokens)
86
+ - **State Bindings** - Style different states using modifiers like `hovered`, `focused`, `disabled`
87
+ - **Responsive Arrays** - Define breakpoint-specific styles with arrays: `padding: ['4x', '2x', '1x']`
88
+ - **Sub-element Styling** - Style internal component parts using element names
89
+
90
+ ### Form Integration
91
+
92
+ All input components work seamlessly with the Form component:
93
+
94
+ - **Built-in Field Support** - No wrapper components needed
95
+ - **Automatic Validation** - Validation rules and error display
96
+ - **Form-level Configuration** - Inherit settings like `labelPosition` and `validationState`
97
+ - **Programmatic Control** - Use `Form.useForm()` for advanced form management
98
+
99
+ ### Component Architecture
100
+
101
+ Components are designed with composition and reusability in mind:
102
+
103
+ - **Base Properties** - Common props like `qa`, styling, and accessibility
104
+ - **Style Properties** - Direct style application without the `styles` prop
105
+ - **Modifiers** - Control component states through the `mods` prop
106
+ - **Variants** - Pre-defined style themes and sizes
107
+
108
+ ## Documentation Structure
109
+
110
+ Each component includes comprehensive documentation:
111
+
112
+ - **Usage Examples** - Real-world implementation patterns
113
+ - **Accessibility Guidelines** - Keyboard navigation and screen reader support
114
+ - **Styling Reference** - Available sub-elements and modifiers
115
+ - **Best Practices** - Recommended usage patterns and common pitfalls
116
+
117
+ ## Next Steps
118
+
119
+ 1. **Explore Components** - Browse the sidebar to see all available components
120
+ 2. **Learn Tasty** - Visit the [Tasty documentation](./tasty/usage.md) to master the styling system
121
+ 3. **Build Forms** - Check out [Form documentation](./components/form/Form.md) for form development patterns
122
+ 4. **Accessibility** - Review accessibility guidelines for inclusive design