@planningcenter/tapestry-react 2.10.0-rc.13 → 2.10.0-rc.15

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 (1326) hide show
  1. package/dist/cjs/ActionsDropdown/ActionsDropdown.js +118 -0
  2. package/dist/cjs/ActionsDropdown/index.js +15 -0
  3. package/dist/cjs/Alert/Alert.js +37 -0
  4. package/dist/cjs/Alert/Alert.test.js +20 -0
  5. package/dist/cjs/Alert/index.js +15 -0
  6. package/dist/cjs/Avatar/Avatar.js +59 -0
  7. package/dist/cjs/Avatar/index.js +11 -0
  8. package/dist/cjs/Badge/Badge.js +143 -0
  9. package/dist/cjs/Badge/Status.js +89 -0
  10. package/dist/cjs/Badge/index.js +14 -0
  11. package/dist/cjs/Box/Box.js +48 -0
  12. package/dist/cjs/Box/index.js +15 -0
  13. package/dist/cjs/Button/Button.js +319 -0
  14. package/dist/cjs/Button/Button.test.js +155 -0
  15. package/dist/cjs/Button/Input.js +180 -0
  16. package/dist/cjs/Button/index.js +15 -0
  17. package/dist/cjs/Calendar/Calendar.js +397 -0
  18. package/dist/cjs/Calendar/Day.js +101 -0
  19. package/dist/cjs/Calendar/index.js +11 -0
  20. package/dist/cjs/Calendar/utils.js +104 -0
  21. package/dist/cjs/Card/Card.js +52 -0
  22. package/dist/cjs/Card/Section.js +28 -0
  23. package/dist/cjs/Card/index.js +15 -0
  24. package/dist/cjs/Checkbox/Checkbox.js +208 -0
  25. package/dist/cjs/Checkbox/index.js +11 -0
  26. package/dist/cjs/CheckboxCard/CheckboxCard.js +76 -0
  27. package/dist/cjs/CheckboxCard/index.js +11 -0
  28. package/dist/cjs/CheckboxGroup/CheckboxGroup.js +73 -0
  29. package/dist/cjs/CheckboxGroup/CheckboxGroupContext.js +10 -0
  30. package/dist/cjs/CheckboxGroup/index.js +11 -0
  31. package/dist/cjs/ChurchCenterStatus/ChurchCenterStatus.js +144 -0
  32. package/dist/cjs/ChurchCenterStatus/index.js +15 -0
  33. package/dist/cjs/Collapse/Collapse.js +126 -0
  34. package/dist/cjs/Collapse/Collapse.test.js +56 -0
  35. package/dist/cjs/Collapse/index.js +11 -0
  36. package/dist/cjs/ColumnView/ColumnView.js +66 -0
  37. package/dist/cjs/ColumnView/index.js +11 -0
  38. package/dist/cjs/Combobox/Combobox.js +34 -0
  39. package/dist/cjs/Combobox/ComboboxInput.js +145 -0
  40. package/dist/cjs/Combobox/ComboboxItem.js +57 -0
  41. package/dist/cjs/Combobox/ComboboxItems.js +90 -0
  42. package/dist/cjs/Combobox/ComboboxPopover.js +264 -0
  43. package/dist/cjs/Combobox/index.js +23 -0
  44. package/dist/cjs/DataTable/DataTable.js +272 -0
  45. package/dist/cjs/DataTable/components/BodyRow.js +58 -0
  46. package/dist/cjs/DataTable/components/BodyRows.js +131 -0
  47. package/dist/cjs/DataTable/components/BodySubRows.js +104 -0
  48. package/dist/cjs/DataTable/components/CheckboxCell.js +116 -0
  49. package/dist/cjs/DataTable/components/ColumnPicker.js +75 -0
  50. package/dist/cjs/DataTable/components/HeaderCell.js +88 -0
  51. package/dist/cjs/DataTable/components/Icon.js +70 -0
  52. package/dist/cjs/DataTable/components/index.js +22 -0
  53. package/dist/cjs/DataTable/hooks/index.js +42 -0
  54. package/dist/cjs/DataTable/hooks/useCollapsibleRows.js +127 -0
  55. package/dist/cjs/DataTable/hooks/useColumnSort.js +100 -0
  56. package/dist/cjs/DataTable/hooks/useColumnWidths.js +113 -0
  57. package/dist/cjs/DataTable/hooks/useHoverFocus.js +33 -0
  58. package/dist/cjs/DataTable/hooks/useRefManager.js +28 -0
  59. package/dist/cjs/DataTable/hooks/useScrollShadows.js +106 -0
  60. package/dist/cjs/DataTable/hooks/useScrollSync.js +52 -0
  61. package/dist/cjs/DataTable/hooks/useVariants.js +15 -0
  62. package/dist/cjs/DataTable/index.js +29 -0
  63. package/dist/cjs/DataTable/utils/getCell.js +24 -0
  64. package/dist/cjs/DataTable/utils/getParsedColumns.js +158 -0
  65. package/dist/cjs/DataTable/utils/getRowLinkProps.js +16 -0
  66. package/dist/cjs/DataTable/utils/index.js +22 -0
  67. package/dist/cjs/DataTable/utils/variants.js +176 -0
  68. package/dist/cjs/DateField/DateField.js +182 -0
  69. package/dist/cjs/DateField/index.js +11 -0
  70. package/dist/cjs/DateField/parse.js +106 -0
  71. package/dist/cjs/DateField/parse.test.js +46 -0
  72. package/dist/cjs/DateField/useArrowKeysToNavigateCalendar.js +48 -0
  73. package/dist/cjs/DateField/useEditableDate.js +72 -0
  74. package/dist/cjs/Dialog/Dialog.js +119 -0
  75. package/dist/cjs/Dialog/Dialog.test.js +200 -0
  76. package/dist/cjs/Dialog/index.js +15 -0
  77. package/dist/cjs/Divider/Divider.js +44 -0
  78. package/dist/cjs/Divider/index.js +15 -0
  79. package/dist/cjs/DragDrop/DragDrop.js +233 -0
  80. package/dist/cjs/DragDrop/index.js +11 -0
  81. package/dist/cjs/Drawer/Drawer.js +102 -0
  82. package/dist/cjs/Drawer/index.js +11 -0
  83. package/dist/cjs/Dropdown/Dropdown.js +314 -0
  84. package/dist/cjs/Dropdown/Dropdown.test.js +210 -0
  85. package/dist/cjs/Dropdown/Item.js +74 -0
  86. package/dist/cjs/Dropdown/Link.js +85 -0
  87. package/dist/cjs/Dropdown/index.js +11 -0
  88. package/dist/cjs/EditActions/EditActions.js +100 -0
  89. package/dist/cjs/EditActions/index.js +11 -0
  90. package/dist/cjs/Field/Field.js +105 -0
  91. package/dist/cjs/Field/index.js +11 -0
  92. package/dist/cjs/FieldSet/FieldSet.js +63 -0
  93. package/dist/cjs/FieldSet/index.js +11 -0
  94. package/dist/cjs/FilterLayout/FilterLayout.js +99 -0
  95. package/dist/cjs/FilterLayout/index.js +15 -0
  96. package/dist/cjs/FocusGroup/FocusGroup.js +127 -0
  97. package/dist/cjs/FocusGroup/index.js +11 -0
  98. package/dist/cjs/Form/Form.js +188 -0
  99. package/dist/cjs/Form/index.js +11 -0
  100. package/dist/cjs/GridView/GridView.js +111 -0
  101. package/dist/cjs/GridView/index.js +15 -0
  102. package/dist/cjs/Group/Group.js +55 -0
  103. package/dist/cjs/Group/index.js +15 -0
  104. package/dist/cjs/Heading/Heading.js +33 -0
  105. package/dist/cjs/Heading/index.js +11 -0
  106. package/dist/cjs/HeadingUppercase/HeadingUppercase.js +35 -0
  107. package/dist/cjs/HeadingUppercase/index.js +11 -0
  108. package/dist/cjs/HelperDrawer/HelperDrawer.js +91 -0
  109. package/dist/cjs/HelperDrawer/index.js +11 -0
  110. package/dist/cjs/Highlight/Highlight.js +53 -0
  111. package/dist/cjs/Highlight/index.js +11 -0
  112. package/dist/cjs/Highlight/utils.js +52 -0
  113. package/dist/cjs/Icon/Icon.js +58 -0
  114. package/dist/cjs/Icon/Path.js +34 -0
  115. package/dist/cjs/Icon/Status.js +58 -0
  116. package/dist/cjs/Icon/index.js +17 -0
  117. package/dist/cjs/Input/Inline.js +61 -0
  118. package/dist/cjs/Input/Input.js +132 -0
  119. package/dist/cjs/Input/InputBox.js +352 -0
  120. package/dist/cjs/Input/InputContext.js +10 -0
  121. package/dist/cjs/Input/InputField.js +290 -0
  122. package/dist/cjs/Input/InputLabel.js +70 -0
  123. package/dist/cjs/Input/index.js +23 -0
  124. package/dist/cjs/Input/utils.js +13 -0
  125. package/dist/cjs/ItemList/ItemList.js +265 -0
  126. package/dist/cjs/ItemList/ItemListContext.js +10 -0
  127. package/dist/cjs/ItemList/ItemListController.js +67 -0
  128. package/dist/cjs/ItemList/ItemListItem.js +100 -0
  129. package/dist/cjs/ItemList/index.js +17 -0
  130. package/dist/cjs/ItemList/utils.js +73 -0
  131. package/dist/cjs/Link/Inline.js +50 -0
  132. package/dist/cjs/Link/Link.js +80 -0
  133. package/dist/cjs/Link/Link.test.js +93 -0
  134. package/dist/cjs/Link/index.js +14 -0
  135. package/dist/cjs/LinkList/LinkList.js +41 -0
  136. package/dist/cjs/LinkList/index.js +11 -0
  137. package/dist/cjs/List/List.js +63 -0
  138. package/dist/cjs/List/ListItem.js +52 -0
  139. package/dist/cjs/List/index.js +11 -0
  140. package/dist/cjs/Logo/Logo.js +63 -0
  141. package/dist/cjs/Logo/index.js +11 -0
  142. package/dist/cjs/Menu/Heading.js +28 -0
  143. package/dist/cjs/Menu/Item.js +113 -0
  144. package/dist/cjs/Menu/Menu.js +30 -0
  145. package/dist/cjs/Menu/index.js +11 -0
  146. package/dist/cjs/Modal/Modal.js +76 -0
  147. package/dist/cjs/Modal/Modal.test.js +156 -0
  148. package/dist/cjs/Modal/index.js +11 -0
  149. package/dist/cjs/NumberField/NumberField.js +330 -0
  150. package/dist/cjs/NumberField/NumberField.test.js +340 -0
  151. package/dist/cjs/NumberField/index.js +11 -0
  152. package/dist/cjs/Page/PageActions.js +27 -0
  153. package/dist/cjs/Page/PageBody.js +56 -0
  154. package/dist/cjs/Page/PageButton.js +24 -0
  155. package/dist/cjs/Page/PageDropdown.js +25 -0
  156. package/dist/cjs/Page/PageHeader.js +44 -0
  157. package/dist/cjs/Page/PageTab.js +30 -0
  158. package/dist/cjs/Page/PageTabList.js +21 -0
  159. package/dist/cjs/Page/PageTitle.js +26 -0
  160. package/dist/cjs/Page/PageToolbar.js +47 -0
  161. package/dist/cjs/Page/index.js +41 -0
  162. package/dist/cjs/PagerView/PagerView.js +230 -0
  163. package/dist/cjs/PagerView/index.js +11 -0
  164. package/dist/cjs/Pagination/Pagination.js +178 -0
  165. package/dist/cjs/Pagination/index.js +11 -0
  166. package/dist/cjs/Popover/Popover.js +226 -0
  167. package/dist/cjs/Popover/Popover.test.js +65 -0
  168. package/dist/cjs/Popover/index.js +15 -0
  169. package/dist/cjs/Popover/rewireTabOrder.js +106 -0
  170. package/dist/cjs/Popover/utils.js +73 -0
  171. package/dist/cjs/Portal/Portal.js +177 -0
  172. package/dist/cjs/Portal/index.js +15 -0
  173. package/dist/cjs/Progress/Progress.js +51 -0
  174. package/dist/cjs/Progress/index.js +11 -0
  175. package/dist/cjs/Radio/Radio.js +159 -0
  176. package/dist/cjs/Radio/index.js +11 -0
  177. package/dist/cjs/RangeSlider/RangeSlider.js +230 -0
  178. package/dist/cjs/RangeSlider/index.js +11 -0
  179. package/dist/cjs/ScreenReader/ScreenReader.js +38 -0
  180. package/dist/cjs/ScreenReader/index.js +11 -0
  181. package/dist/cjs/Scrim/Scrim.js +48 -0
  182. package/dist/cjs/Scrim/index.js +15 -0
  183. package/dist/cjs/Section/Section.js +56 -0
  184. package/dist/cjs/Section/index.js +11 -0
  185. package/dist/cjs/SegmentedControl/SegmentedControl.js +118 -0
  186. package/dist/cjs/SegmentedControl/index.js +11 -0
  187. package/dist/cjs/SegmentedTabs/SegmentedTabs.js +119 -0
  188. package/dist/cjs/SegmentedTabs/index.js +11 -0
  189. package/dist/cjs/Select/Context.js +10 -0
  190. package/dist/cjs/Select/Inline.js +52 -0
  191. package/dist/cjs/Select/Option.js +103 -0
  192. package/dist/cjs/Select/OptionGroup.js +32 -0
  193. package/dist/cjs/Select/Select.js +557 -0
  194. package/dist/cjs/Select/Select.test.js +142 -0
  195. package/dist/cjs/Select/Value.js +28 -0
  196. package/dist/cjs/Select/constants.js +10 -0
  197. package/dist/cjs/Select/index.js +26 -0
  198. package/dist/cjs/Select/utils.js +129 -0
  199. package/dist/cjs/Sidebar/Sidebar.js +56 -0
  200. package/dist/cjs/Sidebar/SidebarItem.js +53 -0
  201. package/dist/cjs/Sidebar/SidebarList.js +27 -0
  202. package/dist/cjs/Sidebar/index.js +11 -0
  203. package/dist/cjs/Sortable/SortableEmpty.js +42 -0
  204. package/dist/cjs/Sortable/SortableItem.js +57 -0
  205. package/dist/cjs/Sortable/SortableList.js +106 -0
  206. package/dist/cjs/Sortable/SortableManager.js +31 -0
  207. package/dist/cjs/Sortable/constants.js +6 -0
  208. package/dist/cjs/Sortable/index.js +57 -0
  209. package/dist/cjs/Spinner/Spinner.js +79 -0
  210. package/dist/cjs/Spinner/index.js +15 -0
  211. package/dist/cjs/StackView/StackView.js +106 -0
  212. package/dist/cjs/StackView/index.js +15 -0
  213. package/dist/cjs/StepperField/StepperField.js +84 -0
  214. package/dist/cjs/StepperField/index.js +11 -0
  215. package/dist/cjs/StepperProgress/Context.js +10 -0
  216. package/dist/cjs/StepperProgress/Step.js +87 -0
  217. package/dist/cjs/StepperProgress/StepperProgress.js +49 -0
  218. package/dist/cjs/StepperProgress/index.js +14 -0
  219. package/dist/cjs/Summary/Summary.js +41 -0
  220. package/dist/cjs/Summary/index.js +11 -0
  221. package/dist/cjs/Tab/Tab.js +77 -0
  222. package/dist/cjs/Tab/index.js +15 -0
  223. package/dist/cjs/TabNav/Tab.js +111 -0
  224. package/dist/cjs/TabNav/TabNav.js +60 -0
  225. package/dist/cjs/TabNav/TabNav.test.js +53 -0
  226. package/dist/cjs/TabNav/index.js +15 -0
  227. package/dist/cjs/Table/AnimateScroll.js +88 -0
  228. package/dist/cjs/Table/AvatarCell.js +44 -0
  229. package/dist/cjs/Table/Body.js +33 -0
  230. package/dist/cjs/Table/BodyCell.js +24 -0
  231. package/dist/cjs/Table/BodyInnerCell.js +34 -0
  232. package/dist/cjs/Table/BodyRow.js +70 -0
  233. package/dist/cjs/Table/CheckboxCell.js +40 -0
  234. package/dist/cjs/Table/ColumnPicker.js +73 -0
  235. package/dist/cjs/Table/DateCell.js +21 -0
  236. package/dist/cjs/Table/DragCell.js +47 -0
  237. package/dist/cjs/Table/DragHandle.js +22 -0
  238. package/dist/cjs/Table/Header.js +44 -0
  239. package/dist/cjs/Table/HeaderCell.js +26 -0
  240. package/dist/cjs/Table/HeaderInnerCell.js +30 -0
  241. package/dist/cjs/Table/HeaderRow.js +24 -0
  242. package/dist/cjs/Table/NavigationArrow.js +78 -0
  243. package/dist/cjs/Table/ScrollShadow.js +47 -0
  244. package/dist/cjs/Table/SubRowToggleCell.js +47 -0
  245. package/dist/cjs/Table/Table.js +697 -0
  246. package/dist/cjs/Table/TableBase.js +180 -0
  247. package/dist/cjs/Table/TableContainer.js +25 -0
  248. package/dist/cjs/Table/TableWrapper.js +22 -0
  249. package/dist/cjs/Table/index.js +11 -0
  250. package/dist/cjs/Tabs/Tab.js +63 -0
  251. package/dist/cjs/Tabs/TabList.js +77 -0
  252. package/dist/cjs/Tabs/TabPanel.js +32 -0
  253. package/dist/cjs/Tabs/TabPanels.js +36 -0
  254. package/dist/cjs/Tabs/Tabs.js +106 -0
  255. package/dist/cjs/Tabs/index.js +23 -0
  256. package/dist/cjs/Text/Text.js +103 -0
  257. package/dist/cjs/Text/index.js +15 -0
  258. package/dist/cjs/TextArea/TextArea.js +29 -0
  259. package/dist/cjs/TextArea/index.js +11 -0
  260. package/dist/cjs/ThemeProvider/ThemeProvider.js +138 -0
  261. package/dist/cjs/ThemeProvider/index.js +15 -0
  262. package/dist/cjs/ThemeProvider/styles.js +52 -0
  263. package/dist/cjs/TileView/TileView.js +66 -0
  264. package/dist/cjs/TileView/index.js +15 -0
  265. package/dist/cjs/TimeField/TimeField.js +333 -0
  266. package/dist/cjs/TimeField/TimeField.test.js +442 -0
  267. package/dist/cjs/TimeField/index.js +11 -0
  268. package/dist/cjs/TimeField/utils.js +61 -0
  269. package/dist/cjs/ToggleSwitch/ToggleSwitch.js +102 -0
  270. package/dist/cjs/ToggleSwitch/ToggleSwitch.test.js +148 -0
  271. package/dist/cjs/ToggleSwitch/index.js +15 -0
  272. package/dist/cjs/TokenInput/DefaultToken.js +42 -0
  273. package/dist/cjs/TokenInput/TokenInput.js +257 -0
  274. package/dist/cjs/TokenInput/default-renders.js +54 -0
  275. package/dist/cjs/TokenInput/index.js +11 -0
  276. package/dist/cjs/Toolbar/Action.js +27 -0
  277. package/dist/cjs/Toolbar/Toolbar.js +113 -0
  278. package/dist/cjs/Toolbar/index.js +11 -0
  279. package/dist/cjs/Tooltip/Tooltip.js +214 -0
  280. package/dist/cjs/Tooltip/Tooltip.test.js +178 -0
  281. package/dist/cjs/Tooltip/index.js +11 -0
  282. package/dist/cjs/VariantProvider/VariantProvider.js +31 -0
  283. package/dist/cjs/VariantProvider/index.js +9 -0
  284. package/dist/cjs/Wizard/Step.js +33 -0
  285. package/dist/cjs/Wizard/Wizard.js +189 -0
  286. package/dist/cjs/Wizard/WizardContext.js +10 -0
  287. package/dist/cjs/Wizard/index.js +14 -0
  288. package/dist/cjs/WrapView/WrapView.js +37 -0
  289. package/dist/cjs/WrapView/index.js +15 -0
  290. package/dist/cjs/designTokens/index.js +87 -0
  291. package/dist/cjs/hooks/index.js +36 -0
  292. package/dist/cjs/hooks/use-accessibility-violation.js +79 -0
  293. package/dist/cjs/hooks/use-document-event.js +38 -0
  294. package/dist/cjs/hooks/use-focus.js +29 -0
  295. package/dist/cjs/hooks/use-hover.js +24 -0
  296. package/dist/cjs/hooks/use-id.js +26 -0
  297. package/dist/cjs/hooks/use-keyboard-shortcuts.js +38 -0
  298. package/dist/cjs/hooks/use-measure.js +125 -0
  299. package/dist/cjs/hooks/use-media-query.js +47 -0
  300. package/dist/cjs/hooks/use-roving-index.js +58 -0
  301. package/dist/cjs/hooks/useConstant.js +23 -0
  302. package/dist/cjs/index.d.js +432 -0
  303. package/dist/cjs/index.js +352 -0
  304. package/dist/cjs/server.js +27 -0
  305. package/dist/cjs/system/box-sizes.js +64 -0
  306. package/dist/cjs/system/button-themes.js +286 -0
  307. package/dist/cjs/system/colors/colors.js +128 -0
  308. package/dist/cjs/system/colors/index.js +18 -0
  309. package/dist/cjs/system/colors/utils.js +213 -0
  310. package/dist/cjs/system/css.js +14 -0
  311. package/dist/cjs/system/cxs.js +106 -0
  312. package/dist/cjs/system/default-theme.js +81 -0
  313. package/dist/cjs/system/index.js +90 -0
  314. package/dist/cjs/system/parse-styles.js +61 -0
  315. package/dist/cjs/system/plugins/border.js +93 -0
  316. package/dist/cjs/system/plugins/color.js +49 -0
  317. package/dist/cjs/system/plugins/elevation.js +22 -0
  318. package/dist/cjs/system/plugins/flex.js +84 -0
  319. package/dist/cjs/system/plugins/grid.js +52 -0
  320. package/dist/cjs/system/plugins/index.js +33 -0
  321. package/dist/cjs/system/plugins/misc.js +34 -0
  322. package/dist/cjs/system/plugins/position.js +49 -0
  323. package/dist/cjs/system/plugins/size.js +39 -0
  324. package/dist/cjs/system/plugins/space.js +112 -0
  325. package/dist/cjs/system/plugins/stroke.js +48 -0
  326. package/dist/cjs/system/plugins/transform.js +46 -0
  327. package/dist/cjs/system/plugins/typography.js +23 -0
  328. package/dist/cjs/system/split-styles.js +119 -0
  329. package/dist/cjs/system/style-names.js +14 -0
  330. package/dist/cjs/system/use-css.js +21 -0
  331. package/dist/cjs/system/utils.js +191 -0
  332. package/dist/cjs/utils.js +870 -0
  333. package/dist/cjs/vendor/react-measure/Measure.js +160 -0
  334. package/dist/cjs/vendor/react-measure/Viewport.js +172 -0
  335. package/dist/cjs/vendor/react-measure/index.js +14 -0
  336. package/dist/cjs/vendor/react-measure/utils.js +89 -0
  337. package/dist/esm/ActionsDropdown/ActionsDropdown.js +112 -0
  338. package/dist/esm/ActionsDropdown/index.js +2 -0
  339. package/dist/esm/Alert/Alert.js +22 -0
  340. package/dist/esm/Alert/Alert.test.js +13 -0
  341. package/dist/esm/Alert/index.js +2 -0
  342. package/dist/esm/Avatar/Avatar.js +46 -0
  343. package/dist/esm/Avatar/index.js +2 -0
  344. package/dist/esm/Badge/Badge.js +126 -0
  345. package/dist/esm/Badge/Status.js +73 -0
  346. package/dist/esm/Badge/index.js +4 -0
  347. package/dist/esm/Box/Box.js +33 -0
  348. package/dist/esm/Box/index.js +2 -0
  349. package/dist/esm/Button/Button.js +302 -0
  350. package/dist/esm/Button/Button.test.js +170 -0
  351. package/dist/esm/Button/Input.js +163 -0
  352. package/dist/esm/Button/index.js +2 -0
  353. package/dist/esm/Calendar/Calendar.js +370 -0
  354. package/dist/esm/Calendar/Day.js +89 -0
  355. package/dist/esm/Calendar/index.js +2 -0
  356. package/dist/esm/Calendar/utils.js +80 -0
  357. package/dist/esm/Card/Card.js +36 -0
  358. package/dist/esm/Card/Section.js +15 -0
  359. package/dist/esm/Card/index.js +2 -0
  360. package/dist/esm/Checkbox/Checkbox.js +187 -0
  361. package/dist/esm/Checkbox/index.js +2 -0
  362. package/dist/esm/CheckboxCard/CheckboxCard.js +60 -0
  363. package/dist/esm/CheckboxCard/index.js +2 -0
  364. package/dist/esm/CheckboxGroup/CheckboxGroup.js +61 -0
  365. package/dist/esm/CheckboxGroup/CheckboxGroupContext.js +3 -0
  366. package/dist/esm/CheckboxGroup/index.js +2 -0
  367. package/dist/esm/ChurchCenterStatus/ChurchCenterStatus.js +139 -0
  368. package/dist/esm/ChurchCenterStatus/index.js +2 -0
  369. package/dist/esm/Collapse/Collapse.js +115 -0
  370. package/dist/esm/Collapse/Collapse.test.js +53 -0
  371. package/dist/esm/Collapse/index.js +2 -0
  372. package/dist/esm/ColumnView/ColumnView.js +51 -0
  373. package/dist/esm/ColumnView/index.js +2 -0
  374. package/dist/esm/Combobox/Combobox.js +22 -0
  375. package/dist/esm/Combobox/ComboboxInput.js +128 -0
  376. package/dist/esm/Combobox/ComboboxItem.js +44 -0
  377. package/dist/esm/Combobox/ComboboxItems.js +71 -0
  378. package/dist/esm/Combobox/ComboboxPopover.js +257 -0
  379. package/dist/esm/Combobox/index.js +10 -0
  380. package/dist/esm/DataTable/DataTable.js +248 -0
  381. package/dist/esm/DataTable/components/BodyRow.js +49 -0
  382. package/dist/esm/DataTable/components/BodyRows.js +114 -0
  383. package/dist/esm/DataTable/components/BodySubRows.js +90 -0
  384. package/dist/esm/DataTable/components/CheckboxCell.js +104 -0
  385. package/dist/esm/DataTable/components/ColumnPicker.js +63 -0
  386. package/dist/esm/DataTable/components/HeaderCell.js +75 -0
  387. package/dist/esm/DataTable/components/Icon.js +61 -0
  388. package/dist/esm/DataTable/components/index.js +4 -0
  389. package/dist/esm/DataTable/hooks/index.js +6 -0
  390. package/dist/esm/DataTable/hooks/useCollapsibleRows.js +107 -0
  391. package/dist/esm/DataTable/hooks/useColumnSort.js +85 -0
  392. package/dist/esm/DataTable/hooks/useColumnWidths.js +104 -0
  393. package/dist/esm/DataTable/hooks/useHoverFocus.js +27 -0
  394. package/dist/esm/DataTable/hooks/useRefManager.js +22 -0
  395. package/dist/esm/DataTable/hooks/useScrollShadows.js +94 -0
  396. package/dist/esm/DataTable/hooks/useScrollSync.js +46 -0
  397. package/dist/esm/DataTable/hooks/useVariants.js +9 -0
  398. package/dist/esm/DataTable/index.js +14 -0
  399. package/dist/esm/DataTable/utils/getCell.js +18 -0
  400. package/dist/esm/DataTable/utils/getParsedColumns.js +144 -0
  401. package/dist/esm/DataTable/utils/getRowLinkProps.js +10 -0
  402. package/dist/esm/DataTable/utils/index.js +4 -0
  403. package/dist/esm/DataTable/utils/variants.js +167 -0
  404. package/dist/esm/DateField/DateField.js +163 -0
  405. package/dist/esm/DateField/index.js +2 -0
  406. package/dist/esm/DateField/parse.js +93 -0
  407. package/dist/esm/DateField/parse.test.js +42 -0
  408. package/dist/esm/DateField/useArrowKeysToNavigateCalendar.js +40 -0
  409. package/dist/esm/DateField/useEditableDate.js +62 -0
  410. package/dist/esm/Dialog/Dialog.js +110 -0
  411. package/dist/esm/Dialog/Dialog.test.js +188 -0
  412. package/dist/esm/Dialog/index.js +2 -0
  413. package/dist/esm/Divider/Divider.js +35 -0
  414. package/dist/esm/Divider/index.js +2 -0
  415. package/dist/esm/DragDrop/DragDrop.js +218 -0
  416. package/dist/esm/DragDrop/index.js +2 -0
  417. package/dist/esm/Drawer/Drawer.js +89 -0
  418. package/dist/esm/Drawer/index.js +2 -0
  419. package/dist/esm/Dropdown/Dropdown.js +301 -0
  420. package/dist/esm/Dropdown/Dropdown.test.js +167 -0
  421. package/dist/esm/Dropdown/Item.js +58 -0
  422. package/dist/esm/Dropdown/Link.js +68 -0
  423. package/dist/esm/Dropdown/index.js +2 -0
  424. package/dist/esm/EditActions/EditActions.js +84 -0
  425. package/dist/esm/EditActions/index.js +2 -0
  426. package/dist/esm/Field/Field.js +88 -0
  427. package/dist/esm/Field/index.js +2 -0
  428. package/dist/esm/FieldSet/FieldSet.js +48 -0
  429. package/dist/esm/FieldSet/index.js +2 -0
  430. package/dist/esm/FilterLayout/FilterLayout.js +86 -0
  431. package/dist/esm/FilterLayout/index.js +2 -0
  432. package/dist/esm/FocusGroup/FocusGroup.js +121 -0
  433. package/dist/esm/FocusGroup/index.js +2 -0
  434. package/dist/esm/Form/Form.js +184 -0
  435. package/dist/esm/Form/index.js +2 -0
  436. package/dist/esm/GridView/GridView.js +99 -0
  437. package/dist/esm/GridView/index.js +2 -0
  438. package/dist/esm/Group/Group.js +43 -0
  439. package/dist/esm/Group/index.js +2 -0
  440. package/dist/esm/Heading/Heading.js +22 -0
  441. package/dist/esm/Heading/index.js +2 -0
  442. package/dist/esm/HeadingUppercase/HeadingUppercase.js +24 -0
  443. package/dist/esm/HeadingUppercase/index.js +2 -0
  444. package/dist/esm/HelperDrawer/HelperDrawer.js +78 -0
  445. package/dist/esm/HelperDrawer/index.js +2 -0
  446. package/dist/esm/Highlight/Highlight.js +40 -0
  447. package/dist/esm/Highlight/index.js +2 -0
  448. package/dist/esm/Highlight/utils.js +46 -0
  449. package/dist/esm/Icon/Icon.js +46 -0
  450. package/dist/esm/Icon/Path.js +23 -0
  451. package/dist/esm/Icon/Status.js +46 -0
  452. package/dist/esm/Icon/index.js +6 -0
  453. package/dist/esm/Input/Inline.js +50 -0
  454. package/dist/esm/Input/Input.js +118 -0
  455. package/dist/esm/Input/InputBox.js +340 -0
  456. package/dist/esm/Input/InputContext.js +3 -0
  457. package/dist/esm/Input/InputField.js +281 -0
  458. package/dist/esm/Input/InputLabel.js +56 -0
  459. package/dist/esm/Input/index.js +10 -0
  460. package/dist/esm/Input/utils.js +5 -0
  461. package/dist/esm/ItemList/ItemList.js +275 -0
  462. package/dist/esm/ItemList/ItemListContext.js +3 -0
  463. package/dist/esm/ItemList/ItemListController.js +56 -0
  464. package/dist/esm/ItemList/ItemListItem.js +91 -0
  465. package/dist/esm/ItemList/index.js +4 -0
  466. package/dist/esm/ItemList/utils.js +55 -0
  467. package/dist/esm/Link/Inline.js +40 -0
  468. package/dist/esm/Link/Link.js +70 -0
  469. package/dist/esm/Link/Link.test.js +90 -0
  470. package/dist/esm/Link/index.js +4 -0
  471. package/dist/esm/LinkList/LinkList.js +31 -0
  472. package/dist/esm/LinkList/index.js +2 -0
  473. package/dist/esm/List/List.js +51 -0
  474. package/dist/esm/List/ListItem.js +39 -0
  475. package/dist/esm/List/index.js +2 -0
  476. package/dist/esm/Logo/Logo.js +51 -0
  477. package/dist/esm/Logo/index.js +2 -0
  478. package/dist/esm/Menu/Heading.js +18 -0
  479. package/dist/esm/Menu/Item.js +100 -0
  480. package/dist/esm/Menu/Menu.js +18 -0
  481. package/dist/esm/Menu/index.js +2 -0
  482. package/dist/esm/Modal/Modal.js +59 -0
  483. package/dist/esm/Modal/Modal.test.js +122 -0
  484. package/dist/esm/Modal/index.js +2 -0
  485. package/dist/esm/NumberField/NumberField.js +326 -0
  486. package/dist/esm/NumberField/NumberField.test.js +293 -0
  487. package/dist/esm/NumberField/index.js +2 -0
  488. package/dist/esm/Page/PageActions.js +17 -0
  489. package/dist/esm/Page/PageBody.js +43 -0
  490. package/dist/esm/Page/PageButton.js +13 -0
  491. package/dist/esm/Page/PageDropdown.js +14 -0
  492. package/dist/esm/Page/PageHeader.js +33 -0
  493. package/dist/esm/Page/PageTab.js +19 -0
  494. package/dist/esm/Page/PageTabList.js +11 -0
  495. package/dist/esm/Page/PageTitle.js +15 -0
  496. package/dist/esm/Page/PageToolbar.js +36 -0
  497. package/dist/esm/Page/index.js +10 -0
  498. package/dist/esm/PagerView/PagerView.js +209 -0
  499. package/dist/esm/PagerView/index.js +2 -0
  500. package/dist/esm/Pagination/Pagination.js +162 -0
  501. package/dist/esm/Pagination/index.js +2 -0
  502. package/dist/esm/Popover/Popover.js +207 -0
  503. package/dist/esm/Popover/Popover.test.js +51 -0
  504. package/dist/esm/Popover/index.js +2 -0
  505. package/dist/esm/Popover/rewireTabOrder.js +102 -0
  506. package/dist/esm/Popover/utils.js +63 -0
  507. package/dist/esm/Portal/Portal.js +169 -0
  508. package/dist/esm/Portal/index.js +2 -0
  509. package/dist/esm/Progress/Progress.js +39 -0
  510. package/dist/esm/Progress/index.js +2 -0
  511. package/dist/esm/Radio/Radio.js +140 -0
  512. package/dist/esm/Radio/index.js +2 -0
  513. package/dist/esm/RangeSlider/RangeSlider.js +214 -0
  514. package/dist/esm/RangeSlider/index.js +2 -0
  515. package/dist/esm/ScreenReader/ScreenReader.js +28 -0
  516. package/dist/esm/ScreenReader/index.js +2 -0
  517. package/dist/esm/Scrim/Scrim.js +35 -0
  518. package/dist/esm/Scrim/index.js +2 -0
  519. package/dist/esm/Section/Section.js +42 -0
  520. package/dist/esm/Section/index.js +2 -0
  521. package/dist/esm/SegmentedControl/SegmentedControl.js +105 -0
  522. package/dist/esm/SegmentedControl/index.js +2 -0
  523. package/dist/esm/SegmentedTabs/SegmentedTabs.js +105 -0
  524. package/dist/esm/SegmentedTabs/index.js +2 -0
  525. package/dist/esm/Select/Context.js +3 -0
  526. package/dist/esm/Select/Inline.js +42 -0
  527. package/dist/esm/Select/Option.js +88 -0
  528. package/dist/esm/Select/OptionGroup.js +23 -0
  529. package/dist/esm/Select/Select.js +549 -0
  530. package/dist/esm/Select/Select.test.js +127 -0
  531. package/dist/esm/Select/Value.js +18 -0
  532. package/dist/esm/Select/constants.js +3 -0
  533. package/dist/esm/Select/index.js +12 -0
  534. package/dist/esm/Select/utils.js +106 -0
  535. package/dist/esm/Sidebar/Sidebar.js +41 -0
  536. package/dist/esm/Sidebar/SidebarItem.js +44 -0
  537. package/dist/esm/Sidebar/SidebarList.js +17 -0
  538. package/dist/esm/Sidebar/index.js +2 -0
  539. package/dist/esm/Sortable/SortableEmpty.js +31 -0
  540. package/dist/esm/Sortable/SortableItem.js +43 -0
  541. package/dist/esm/Sortable/SortableList.js +85 -0
  542. package/dist/esm/Sortable/SortableManager.js +19 -0
  543. package/dist/esm/Sortable/constants.js +1 -0
  544. package/dist/esm/Sortable/index.js +47 -0
  545. package/dist/esm/Spinner/Spinner.js +65 -0
  546. package/dist/esm/Spinner/index.js +2 -0
  547. package/dist/esm/StackView/StackView.js +88 -0
  548. package/dist/esm/StackView/index.js +2 -0
  549. package/dist/esm/StepperField/StepperField.js +70 -0
  550. package/dist/esm/StepperField/index.js +2 -0
  551. package/dist/esm/StepperProgress/Context.js +3 -0
  552. package/dist/esm/StepperProgress/Step.js +74 -0
  553. package/dist/esm/StepperProgress/StepperProgress.js +34 -0
  554. package/dist/esm/StepperProgress/index.js +4 -0
  555. package/dist/esm/Summary/Summary.js +29 -0
  556. package/dist/esm/Summary/index.js +2 -0
  557. package/dist/esm/Tab/Tab.js +66 -0
  558. package/dist/esm/Tab/index.js +2 -0
  559. package/dist/esm/TabNav/Tab.js +93 -0
  560. package/dist/esm/TabNav/TabNav.js +42 -0
  561. package/dist/esm/TabNav/TabNav.test.js +45 -0
  562. package/dist/esm/TabNav/index.js +2 -0
  563. package/dist/esm/Table/AnimateScroll.js +83 -0
  564. package/dist/esm/Table/AvatarCell.js +31 -0
  565. package/dist/esm/Table/Body.js +23 -0
  566. package/dist/esm/Table/BodyCell.js +14 -0
  567. package/dist/esm/Table/BodyInnerCell.js +23 -0
  568. package/dist/esm/Table/BodyRow.js +56 -0
  569. package/dist/esm/Table/CheckboxCell.js +29 -0
  570. package/dist/esm/Table/ColumnPicker.js +61 -0
  571. package/dist/esm/Table/DateCell.js +11 -0
  572. package/dist/esm/Table/DragCell.js +37 -0
  573. package/dist/esm/Table/DragHandle.js +15 -0
  574. package/dist/esm/Table/Header.js +34 -0
  575. package/dist/esm/Table/HeaderCell.js +16 -0
  576. package/dist/esm/Table/HeaderInnerCell.js +20 -0
  577. package/dist/esm/Table/HeaderRow.js +14 -0
  578. package/dist/esm/Table/NavigationArrow.js +66 -0
  579. package/dist/esm/Table/ScrollShadow.js +37 -0
  580. package/dist/esm/Table/SubRowToggleCell.js +36 -0
  581. package/dist/esm/Table/Table.js +679 -0
  582. package/dist/esm/Table/TableBase.js +162 -0
  583. package/dist/esm/Table/TableContainer.js +15 -0
  584. package/dist/esm/Table/TableWrapper.js +12 -0
  585. package/dist/esm/Table/index.js +2 -0
  586. package/dist/esm/Tabs/Tab.js +50 -0
  587. package/dist/esm/Tabs/TabList.js +61 -0
  588. package/dist/esm/Tabs/TabPanel.js +20 -0
  589. package/dist/esm/Tabs/TabPanels.js +21 -0
  590. package/dist/esm/Tabs/Tabs.js +89 -0
  591. package/dist/esm/Tabs/index.js +10 -0
  592. package/dist/esm/Text/Text.js +85 -0
  593. package/dist/esm/Text/index.js +2 -0
  594. package/dist/esm/TextArea/TextArea.js +19 -0
  595. package/dist/esm/TextArea/index.js +2 -0
  596. package/dist/esm/ThemeProvider/ThemeProvider.js +113 -0
  597. package/dist/esm/ThemeProvider/index.js +2 -0
  598. package/dist/esm/ThemeProvider/styles.js +39 -0
  599. package/dist/esm/TileView/TileView.js +54 -0
  600. package/dist/esm/TileView/index.js +2 -0
  601. package/dist/esm/TimeField/TimeField.js +316 -0
  602. package/dist/esm/TimeField/TimeField.test.js +384 -0
  603. package/dist/esm/TimeField/index.js +2 -0
  604. package/dist/esm/TimeField/utils.js +40 -0
  605. package/dist/esm/ToggleSwitch/ToggleSwitch.js +83 -0
  606. package/dist/esm/ToggleSwitch/ToggleSwitch.test.js +136 -0
  607. package/dist/esm/ToggleSwitch/index.js +2 -0
  608. package/dist/esm/TokenInput/DefaultToken.js +31 -0
  609. package/dist/esm/TokenInput/TokenInput.js +251 -0
  610. package/dist/esm/TokenInput/default-renders.js +42 -0
  611. package/dist/esm/TokenInput/index.js +2 -0
  612. package/dist/esm/Toolbar/Action.js +17 -0
  613. package/dist/esm/Toolbar/Toolbar.js +99 -0
  614. package/dist/esm/Toolbar/index.js +2 -0
  615. package/dist/esm/Tooltip/Tooltip.js +196 -0
  616. package/dist/esm/Tooltip/Tooltip.test.js +160 -0
  617. package/dist/esm/Tooltip/index.js +2 -0
  618. package/dist/esm/VariantProvider/VariantProvider.js +18 -0
  619. package/dist/esm/VariantProvider/index.js +1 -0
  620. package/dist/esm/Wizard/Step.js +23 -0
  621. package/dist/esm/Wizard/Wizard.js +170 -0
  622. package/dist/esm/Wizard/WizardContext.js +3 -0
  623. package/dist/esm/Wizard/index.js +4 -0
  624. package/dist/esm/WrapView/WrapView.js +26 -0
  625. package/dist/esm/WrapView/index.js +2 -0
  626. package/dist/esm/designTokens/index.js +78 -0
  627. package/dist/esm/hooks/index.js +8 -0
  628. package/dist/esm/hooks/use-accessibility-violation.js +69 -0
  629. package/dist/esm/hooks/use-document-event.js +33 -0
  630. package/dist/esm/hooks/use-focus.js +24 -0
  631. package/dist/esm/hooks/use-hover.js +18 -0
  632. package/dist/esm/hooks/use-id.js +20 -0
  633. package/dist/esm/hooks/use-keyboard-shortcuts.js +29 -0
  634. package/dist/esm/hooks/use-measure.js +113 -0
  635. package/dist/esm/hooks/use-media-query.js +41 -0
  636. package/dist/esm/hooks/use-roving-index.js +53 -0
  637. package/dist/esm/hooks/useConstant.js +15 -0
  638. package/dist/esm/index.d.js +116 -0
  639. package/dist/esm/index.js +89 -0
  640. package/dist/esm/server.js +13 -0
  641. package/dist/esm/system/box-sizes.js +57 -0
  642. package/dist/esm/system/button-themes.js +281 -0
  643. package/dist/esm/system/colors/colors.js +118 -0
  644. package/dist/esm/system/colors/index.js +2 -0
  645. package/dist/esm/system/colors/utils.js +184 -0
  646. package/dist/esm/system/css.js +6 -0
  647. package/dist/esm/system/cxs.js +101 -0
  648. package/dist/esm/system/default-theme.js +68 -0
  649. package/dist/esm/system/index.js +17 -0
  650. package/dist/esm/system/parse-styles.js +47 -0
  651. package/dist/esm/system/plugins/border.js +85 -0
  652. package/dist/esm/system/plugins/color.js +40 -0
  653. package/dist/esm/system/plugins/elevation.js +14 -0
  654. package/dist/esm/system/plugins/flex.js +75 -0
  655. package/dist/esm/system/plugins/grid.js +44 -0
  656. package/dist/esm/system/plugins/index.js +13 -0
  657. package/dist/esm/system/plugins/misc.js +25 -0
  658. package/dist/esm/system/plugins/position.js +40 -0
  659. package/dist/esm/system/plugins/size.js +31 -0
  660. package/dist/esm/system/plugins/space.js +103 -0
  661. package/dist/esm/system/plugins/stroke.js +38 -0
  662. package/dist/esm/system/plugins/transform.js +39 -0
  663. package/dist/esm/system/plugins/typography.js +15 -0
  664. package/dist/esm/system/split-styles.js +110 -0
  665. package/dist/esm/system/style-names.js +5 -0
  666. package/dist/esm/system/use-css.js +10 -0
  667. package/dist/esm/system/utils.js +149 -0
  668. package/dist/esm/utils.js +824 -0
  669. package/dist/esm/vendor/react-measure/Measure.js +158 -0
  670. package/dist/esm/vendor/react-measure/Viewport.js +169 -0
  671. package/dist/esm/vendor/react-measure/index.js +2 -0
  672. package/dist/esm/vendor/react-measure/utils.js +68 -0
  673. package/dist/types/ActionsDropdown/ActionsDropdown.d.ts +14 -1
  674. package/dist/types/ActionsDropdown/index.d.ts +0 -1
  675. package/dist/types/Alert/Alert.d.ts +2 -1
  676. package/dist/types/Alert/Alert.test.d.ts +0 -1
  677. package/dist/types/Alert/index.d.ts +0 -1
  678. package/dist/types/Avatar/Avatar.d.ts +12 -1
  679. package/dist/types/Badge/Badge.d.ts +28 -1
  680. package/dist/types/Badge/Status.d.ts +15 -1
  681. package/dist/types/Box/Box.d.ts +52 -1
  682. package/dist/types/Box/index.d.ts +0 -1
  683. package/dist/types/Button/Button.d.ts +59 -1
  684. package/dist/types/Button/Button.test.d.ts +0 -1
  685. package/dist/types/Button/Input.d.ts +12 -1
  686. package/dist/types/Button/index.d.ts +0 -1
  687. package/dist/types/Calendar/Calendar.d.ts +33 -1
  688. package/dist/types/Card/Card.d.ts +2 -1
  689. package/dist/types/Card/Section.d.ts +1 -1
  690. package/dist/types/Card/index.d.ts +0 -1
  691. package/dist/types/Checkbox/Checkbox.d.ts +35 -1
  692. package/dist/types/CheckboxGroup/CheckboxGroup.d.ts +9 -1
  693. package/dist/types/CheckboxGroup/CheckboxGroupContext.d.ts +0 -1
  694. package/dist/types/ChurchCenterStatus/ChurchCenterStatus.d.ts +41 -1
  695. package/dist/types/ChurchCenterStatus/index.d.ts +0 -1
  696. package/dist/types/Collapse/Collapse.test.d.ts +0 -1
  697. package/dist/types/Combobox/Combobox.d.ts +9 -1
  698. package/dist/types/Combobox/ComboboxInput.d.ts +0 -1
  699. package/dist/types/DateField/DateField.d.ts +33 -1
  700. package/dist/types/DateField/parse.d.ts +9 -1
  701. package/dist/types/DateField/parse.test.d.ts +0 -1
  702. package/dist/types/DateField/useArrowKeysToNavigateCalendar.d.ts +0 -1
  703. package/dist/types/DateField/useEditableDate.d.ts +12 -1
  704. package/dist/types/Dialog/Dialog.d.ts +58 -0
  705. package/dist/types/Dialog/Dialog.test.d.ts +1 -0
  706. package/dist/types/Dialog/index.d.ts +2 -0
  707. package/dist/types/Divider/Divider.d.ts +15 -1
  708. package/dist/types/Divider/index.d.ts +0 -1
  709. package/dist/types/Dropdown/Dropdown.test.d.ts +0 -1
  710. package/dist/types/EditActions/EditActions.d.ts +3 -1
  711. package/dist/types/Field/Field.d.ts +14 -1
  712. package/dist/types/FieldSet/FieldSet.d.ts +18 -1
  713. package/dist/types/FilterLayout/FilterLayout.d.ts +5 -1
  714. package/dist/types/FilterLayout/index.d.ts +0 -1
  715. package/dist/types/GridView/GridView.d.ts +17 -1
  716. package/dist/types/GridView/index.d.ts +0 -1
  717. package/dist/types/Group/Group.d.ts +15 -1
  718. package/dist/types/Group/index.d.ts +0 -1
  719. package/dist/types/Heading/Heading.d.ts +3 -1
  720. package/dist/types/HeadingUppercase/HeadingUppercase.d.ts +0 -1
  721. package/dist/types/Highlight/Highlight.d.ts +15 -1
  722. package/dist/types/Icon/Icon.d.ts +4 -1
  723. package/dist/types/Link/Link.test.d.ts +1 -0
  724. package/dist/types/Logo/Logo.d.ts +2 -1
  725. package/dist/types/Modal/Modal.d.ts +13 -1
  726. package/dist/types/Modal/Modal.test.d.ts +0 -1
  727. package/dist/types/NumberField/NumberField.d.ts +40 -1
  728. package/dist/types/NumberField/NumberField.test.d.ts +0 -1
  729. package/dist/types/Pagination/Pagination.d.ts +24 -1
  730. package/dist/types/Popover/Popover.d.ts +84 -1
  731. package/dist/types/Popover/Popover.test.d.ts +0 -1
  732. package/dist/types/Popover/index.d.ts +0 -1
  733. package/dist/types/Popover/rewireTabOrder.d.ts +0 -1
  734. package/dist/types/Popover/utils.d.ts +0 -1
  735. package/dist/types/Portal/Portal.d.ts +6 -1
  736. package/dist/types/Portal/index.d.ts +0 -1
  737. package/dist/types/Progress/Progress.d.ts +6 -1
  738. package/dist/types/Radio/Radio.d.ts +30 -1
  739. package/dist/types/Scrim/Scrim.d.ts +1 -1
  740. package/dist/types/Scrim/index.d.ts +0 -1
  741. package/dist/types/Select/Select.test.d.ts +0 -1
  742. package/dist/types/Spinner/Spinner.d.ts +15 -1
  743. package/dist/types/Spinner/index.d.ts +0 -1
  744. package/dist/types/StackView/StackView.d.ts +21 -1
  745. package/dist/types/StackView/index.d.ts +0 -1
  746. package/dist/types/StepperField/StepperField.d.ts +15 -1
  747. package/dist/types/Summary/Summary.d.ts +12 -1
  748. package/dist/types/Tab/Tab.d.ts +5 -1
  749. package/dist/types/Tab/index.d.ts +0 -1
  750. package/dist/types/TabNav/Tab.d.ts +25 -0
  751. package/dist/types/TabNav/TabNav.d.ts +13 -0
  752. package/dist/types/TabNav/TabNav.test.d.ts +1 -0
  753. package/dist/types/TabNav/index.d.ts +2 -0
  754. package/dist/types/Text/Text.d.ts +37 -1
  755. package/dist/types/Text/index.d.ts +0 -1
  756. package/dist/types/TextArea/TextArea.d.ts +1 -1
  757. package/dist/types/ThemeProvider/ThemeProvider.d.ts +0 -2
  758. package/dist/types/ThemeProvider/index.d.ts +0 -1
  759. package/dist/types/ThemeProvider/styles.d.ts +0 -1
  760. package/dist/types/TileView/TileView.d.ts +8 -1
  761. package/dist/types/TileView/index.d.ts +0 -1
  762. package/dist/types/TimeField/TimeField.d.ts +17 -1
  763. package/dist/types/TimeField/TimeField.test.d.ts +0 -1
  764. package/dist/types/ToggleSwitch/ToggleSwitch.d.ts +7 -1
  765. package/dist/types/ToggleSwitch/ToggleSwitch.test.d.ts +0 -1
  766. package/dist/types/ToggleSwitch/index.d.ts +0 -1
  767. package/dist/types/Tooltip/Tooltip.test.d.ts +0 -1
  768. package/dist/types/Wizard/Wizard.d.ts +34 -1
  769. package/dist/types/WrapView/WrapView.d.ts +1 -1
  770. package/dist/types/WrapView/index.d.ts +0 -1
  771. package/dist/types/designTokens/index.d.ts +40 -1
  772. package/dist/types/hooks/use-accessibility-violation.d.ts +8 -2
  773. package/dist/types/hooks/useConstant.d.ts +0 -1
  774. package/dist/types/index.d.ts +426 -85
  775. package/dist/types/system/default-theme.d.ts +0 -1
  776. package/dist/types/system/style-names.d.ts +0 -1
  777. package/package.json +13 -14
  778. package/src/ActionsDropdown/ActionsDropdown.mdx +69 -0
  779. package/src/ActionsDropdown/ActionsDropdown.tsx +180 -0
  780. package/src/ActionsDropdown/index.ts +2 -0
  781. package/src/Alert/Alert.mdx +15 -0
  782. package/src/Alert/Alert.test.tsx +9 -0
  783. package/src/Alert/Alert.tsx +41 -0
  784. package/src/Alert/index.ts +2 -0
  785. package/src/Avatar/Avatar.mdx +96 -0
  786. package/src/Avatar/Avatar.tsx +65 -0
  787. package/src/Avatar/index.js +2 -0
  788. package/src/Badge/Badge.mdx +63 -0
  789. package/src/Badge/Badge.tsx +197 -0
  790. package/src/Badge/Status.mdx +34 -0
  791. package/src/Badge/Status.tsx +90 -0
  792. package/src/Badge/index.js +4 -0
  793. package/src/Box/Box.mdx +15 -0
  794. package/src/Box/Box.tsx +77 -0
  795. package/src/Box/index.ts +2 -0
  796. package/src/Button/Button.mdx +133 -0
  797. package/src/Button/Button.test.tsx +101 -0
  798. package/src/Button/Button.tsx +430 -0
  799. package/src/Button/Input.mdx +170 -0
  800. package/src/Button/Input.tsx +194 -0
  801. package/src/Button/index.ts +2 -0
  802. package/src/Calendar/Calendar.mdx +129 -0
  803. package/src/Calendar/Calendar.tsx +517 -0
  804. package/src/Calendar/Day.js +162 -0
  805. package/src/Calendar/Day.mdx +6 -0
  806. package/src/Calendar/index.js +2 -0
  807. package/src/Calendar/utils.js +115 -0
  808. package/src/Card/Card.mdx +55 -0
  809. package/src/Card/Card.tsx +82 -0
  810. package/src/Card/Section.mdx +19 -0
  811. package/src/Card/Section.tsx +25 -0
  812. package/src/Card/index.ts +2 -0
  813. package/src/Checkbox/Checkbox.mdx +41 -0
  814. package/src/Checkbox/Checkbox.tsx +251 -0
  815. package/src/Checkbox/index.js +2 -0
  816. package/src/CheckboxCard/CheckboxCard.js +77 -0
  817. package/src/CheckboxCard/CheckboxCard.mdx +28 -0
  818. package/src/CheckboxCard/index.js +2 -0
  819. package/src/CheckboxGroup/CheckboxGroup.mdx +28 -0
  820. package/src/CheckboxGroup/CheckboxGroup.tsx +70 -0
  821. package/src/CheckboxGroup/CheckboxGroupContext.tsx +13 -0
  822. package/src/CheckboxGroup/index.js +2 -0
  823. package/src/ChurchCenterStatus/ChurchCenterStatus.mdx +124 -0
  824. package/src/ChurchCenterStatus/ChurchCenterStatus.tsx +200 -0
  825. package/src/ChurchCenterStatus/index.tsx +2 -0
  826. package/src/Collapse/Collapse.js +123 -0
  827. package/src/Collapse/Collapse.mdx +26 -0
  828. package/src/Collapse/Collapse.test.tsx +42 -0
  829. package/src/Collapse/index.js +2 -0
  830. package/src/ColumnView/ColumnView.js +65 -0
  831. package/src/ColumnView/ColumnView.mdx +40 -0
  832. package/src/ColumnView/index.js +2 -0
  833. package/src/Combobox/Combobox.mdx +179 -0
  834. package/src/Combobox/Combobox.test.js +90 -0
  835. package/src/Combobox/Combobox.tsx +40 -0
  836. package/src/Combobox/ComboboxInput.tsx +169 -0
  837. package/src/Combobox/ComboboxItem.js +33 -0
  838. package/src/Combobox/ComboboxItems.js +99 -0
  839. package/src/Combobox/ComboboxPopover.js +262 -0
  840. package/src/Combobox/index.js +10 -0
  841. package/src/DataTable/DataTable.js +572 -0
  842. package/src/DataTable/DataTable.mdx +513 -0
  843. package/src/DataTable/DataTable.test.js +95 -0
  844. package/src/DataTable/components/BodyRow.js +37 -0
  845. package/src/DataTable/components/BodyRows.js +125 -0
  846. package/src/DataTable/components/BodySubRows.js +99 -0
  847. package/src/DataTable/components/CheckboxCell.js +111 -0
  848. package/src/DataTable/components/ColumnPicker.js +51 -0
  849. package/src/DataTable/components/HeaderCell.js +83 -0
  850. package/src/DataTable/components/Icon.js +51 -0
  851. package/src/DataTable/components/index.js +4 -0
  852. package/src/DataTable/hooks/index.js +6 -0
  853. package/src/DataTable/hooks/useCollapsibleRows.js +97 -0
  854. package/src/DataTable/hooks/useColumnSort.js +62 -0
  855. package/src/DataTable/hooks/useColumnWidths.js +86 -0
  856. package/src/DataTable/hooks/useHoverFocus.js +16 -0
  857. package/src/DataTable/hooks/useRefManager.js +21 -0
  858. package/src/DataTable/hooks/useScrollShadows.js +82 -0
  859. package/src/DataTable/hooks/useScrollSync.js +55 -0
  860. package/src/DataTable/hooks/useVariants.js +13 -0
  861. package/src/DataTable/index.js +15 -0
  862. package/src/DataTable/utils/getCell.js +9 -0
  863. package/src/DataTable/utils/getParsedColumns.js +142 -0
  864. package/src/DataTable/utils/getRowLinkProps.js +5 -0
  865. package/src/DataTable/utils/index.js +4 -0
  866. package/src/DataTable/utils/variants.js +146 -0
  867. package/src/DateField/DateField.mdx +34 -0
  868. package/src/DateField/DateField.tsx +239 -0
  869. package/src/DateField/index.js +2 -0
  870. package/src/DateField/parse.test.ts +76 -0
  871. package/src/DateField/parse.ts +92 -0
  872. package/src/DateField/useArrowKeysToNavigateCalendar.ts +59 -0
  873. package/src/DateField/useEditableDate.ts +81 -0
  874. package/src/Dialog/Dialog.mdx +41 -0
  875. package/src/Dialog/Dialog.test.tsx +221 -0
  876. package/src/Dialog/Dialog.tsx +168 -0
  877. package/src/Dialog/index.ts +2 -0
  878. package/src/Divider/Divider.mdx +43 -0
  879. package/src/Divider/Divider.tsx +51 -0
  880. package/src/Divider/index.ts +2 -0
  881. package/src/DragDrop/DragDrop.js +216 -0
  882. package/src/DragDrop/DragDrop.mdx +218 -0
  883. package/src/DragDrop/index.js +2 -0
  884. package/src/Drawer/Drawer.js +96 -0
  885. package/src/Drawer/Drawer.mdx +51 -0
  886. package/src/Drawer/index.js +2 -0
  887. package/src/Dropdown/Dropdown.js +322 -0
  888. package/src/Dropdown/Dropdown.mdx +202 -0
  889. package/src/Dropdown/Dropdown.test.tsx +133 -0
  890. package/src/Dropdown/Item.js +39 -0
  891. package/src/Dropdown/Link.js +39 -0
  892. package/src/Dropdown/index.js +2 -0
  893. package/src/EditActions/EditActions.mdx +145 -0
  894. package/src/EditActions/EditActions.tsx +84 -0
  895. package/src/EditActions/index.js +2 -0
  896. package/src/Field/Field.mdx +39 -0
  897. package/src/Field/Field.tsx +148 -0
  898. package/src/Field/index.js +2 -0
  899. package/src/FieldSet/FieldSet.mdx +26 -0
  900. package/src/FieldSet/FieldSet.tsx +85 -0
  901. package/src/FieldSet/index.js +2 -0
  902. package/src/FilterLayout/FilterLayout.mdx +34 -0
  903. package/src/FilterLayout/FilterLayout.tsx +99 -0
  904. package/src/FilterLayout/index.ts +2 -0
  905. package/src/FocusGroup/FocusGroup.js +93 -0
  906. package/src/FocusGroup/index.js +2 -0
  907. package/src/Form/Form.js +189 -0
  908. package/src/Form/Form.mdx +154 -0
  909. package/src/Form/index.js +2 -0
  910. package/src/GridView/GridView.mdx +56 -0
  911. package/src/GridView/GridView.tsx +150 -0
  912. package/src/GridView/index.ts +2 -0
  913. package/src/Group/Group.mdx +79 -0
  914. package/src/Group/Group.tsx +63 -0
  915. package/src/Group/index.ts +2 -0
  916. package/src/Heading/Heading.mdx +18 -0
  917. package/src/Heading/Heading.tsx +30 -0
  918. package/src/Heading/index.js +2 -0
  919. package/src/HeadingUppercase/HeadingUppercase.mdx +10 -0
  920. package/src/HeadingUppercase/HeadingUppercase.tsx +33 -0
  921. package/src/HeadingUppercase/index.js +2 -0
  922. package/src/HelperDrawer/HelperDrawer.js +65 -0
  923. package/src/HelperDrawer/HelperDrawer.mdx +19 -0
  924. package/src/HelperDrawer/index.js +2 -0
  925. package/src/Highlight/Highlight.mdx +16 -0
  926. package/src/Highlight/Highlight.tsx +69 -0
  927. package/src/Highlight/index.js +2 -0
  928. package/src/Highlight/utils.js +51 -0
  929. package/src/Icon/Icon.mdx +112 -0
  930. package/src/Icon/Icon.tsx +59 -0
  931. package/src/Icon/Path.js +22 -0
  932. package/src/Icon/Path.mdx +34 -0
  933. package/src/Icon/Status.js +50 -0
  934. package/src/Icon/Status.mdx +17 -0
  935. package/src/Icon/index.js +6 -0
  936. package/src/Input/Inline.js +64 -0
  937. package/src/Input/Inline.mdx +45 -0
  938. package/src/Input/Input.js +222 -0
  939. package/src/Input/Input.mdx +29 -0
  940. package/src/Input/InputBox.js +448 -0
  941. package/src/Input/InputBox.mdx +16 -0
  942. package/src/Input/InputContext.js +3 -0
  943. package/src/Input/InputField.js +340 -0
  944. package/src/Input/InputField.mdx +11 -0
  945. package/src/Input/InputLabel.js +68 -0
  946. package/src/Input/InputLabel.mdx +21 -0
  947. package/src/Input/index.js +10 -0
  948. package/src/Input/utils.js +10 -0
  949. package/src/ItemList/ItemList.js +238 -0
  950. package/src/ItemList/ItemListContext.js +3 -0
  951. package/src/ItemList/ItemListController.js +34 -0
  952. package/src/ItemList/ItemListItem.js +88 -0
  953. package/src/ItemList/index.js +5 -0
  954. package/src/ItemList/utils.js +58 -0
  955. package/src/Link/Inline.js +32 -0
  956. package/src/Link/Link.js +90 -0
  957. package/src/Link/Link.mdx +32 -0
  958. package/src/Link/Link.test.tsx +38 -0
  959. package/src/Link/index.js +4 -0
  960. package/src/LinkList/LinkList.js +31 -0
  961. package/src/LinkList/LinkList.mdx +30 -0
  962. package/src/LinkList/index.js +2 -0
  963. package/src/List/List.js +75 -0
  964. package/src/List/List.mdx +42 -0
  965. package/src/List/ListItem.js +41 -0
  966. package/src/List/index.js +2 -0
  967. package/src/Logo/Logo.mdx +19 -0
  968. package/src/Logo/Logo.tsx +120 -0
  969. package/src/Logo/index.js +2 -0
  970. package/src/Menu/Heading.js +23 -0
  971. package/src/Menu/Heading.mdx +20 -0
  972. package/src/Menu/Item.js +126 -0
  973. package/src/Menu/Item.mdx +18 -0
  974. package/src/Menu/Menu.js +29 -0
  975. package/src/Menu/Menu.mdx +42 -0
  976. package/src/Menu/index.js +2 -0
  977. package/src/Modal/Modal.mdx +60 -0
  978. package/src/Modal/Modal.test.tsx +113 -0
  979. package/src/Modal/Modal.tsx +87 -0
  980. package/src/Modal/index.js +2 -0
  981. package/src/NumberField/NumberField.mdx +75 -0
  982. package/src/NumberField/NumberField.test.tsx +262 -0
  983. package/src/NumberField/NumberField.tsx +358 -0
  984. package/src/NumberField/index.js +2 -0
  985. package/src/Page/Page.mdx +164 -0
  986. package/src/Page/PageActions.js +20 -0
  987. package/src/Page/PageBody.js +44 -0
  988. package/src/Page/PageButton.js +11 -0
  989. package/src/Page/PageDropdown.js +11 -0
  990. package/src/Page/PageHeader.js +37 -0
  991. package/src/Page/PageTab.js +23 -0
  992. package/src/Page/PageTabList.js +15 -0
  993. package/src/Page/PageTitle.js +19 -0
  994. package/src/Page/PageToolbar.js +41 -0
  995. package/src/Page/index.js +21 -0
  996. package/src/PagerView/PagerView.js +223 -0
  997. package/src/PagerView/PagerView.mdx +200 -0
  998. package/src/PagerView/index.js +2 -0
  999. package/src/Pagination/Pagination.mdx +19 -0
  1000. package/src/Pagination/Pagination.tsx +201 -0
  1001. package/src/Pagination/index.js +2 -0
  1002. package/src/Popover/Popover.mdx +66 -0
  1003. package/src/Popover/Popover.test.tsx +62 -0
  1004. package/src/Popover/Popover.tsx +271 -0
  1005. package/src/Popover/index.ts +2 -0
  1006. package/src/Popover/rewireTabOrder.ts +106 -0
  1007. package/src/Popover/utils.ts +63 -0
  1008. package/src/Portal/Portal.tsx +159 -0
  1009. package/src/Portal/index.ts +2 -0
  1010. package/src/Progress/Progress.mdx +23 -0
  1011. package/src/Progress/Progress.tsx +49 -0
  1012. package/src/Progress/index.js +2 -0
  1013. package/src/Radio/Radio.mdx +38 -0
  1014. package/src/Radio/Radio.tsx +192 -0
  1015. package/src/Radio/index.js +2 -0
  1016. package/src/RangeSlider/RangeSlider.js +253 -0
  1017. package/src/RangeSlider/RangeSlider.mdx +56 -0
  1018. package/src/RangeSlider/index.js +2 -0
  1019. package/src/ScreenReader/ScreenReader.js +36 -0
  1020. package/src/ScreenReader/ScreenReader.mdx +15 -0
  1021. package/src/ScreenReader/index.js +2 -0
  1022. package/src/Scrim/Scrim.mdx +32 -0
  1023. package/src/Scrim/Scrim.tsx +40 -0
  1024. package/src/Scrim/index.ts +2 -0
  1025. package/src/Section/Section.js +55 -0
  1026. package/src/Section/Section.mdx +103 -0
  1027. package/src/Section/index.js +2 -0
  1028. package/src/SegmentedControl/SegmentedControl.js +119 -0
  1029. package/src/SegmentedControl/SegmentedControl.mdx +72 -0
  1030. package/src/SegmentedControl/index.js +2 -0
  1031. package/src/SegmentedTabs/SegmentedTabs.js +108 -0
  1032. package/src/SegmentedTabs/SegmentedTabs.mdx +74 -0
  1033. package/src/SegmentedTabs/index.js +2 -0
  1034. package/src/Select/Context.js +3 -0
  1035. package/src/Select/Inline.js +52 -0
  1036. package/src/Select/Inline.mdx +27 -0
  1037. package/src/Select/Option.js +84 -0
  1038. package/src/Select/Option.mdx +30 -0
  1039. package/src/Select/OptionGroup.js +19 -0
  1040. package/src/Select/OptionGroup.mdx +25 -0
  1041. package/src/Select/Select.js +626 -0
  1042. package/src/Select/Select.mdx +81 -0
  1043. package/src/Select/Select.test.tsx +112 -0
  1044. package/src/Select/Value.js +22 -0
  1045. package/src/Select/Value.mdx +67 -0
  1046. package/src/Select/constants.js +3 -0
  1047. package/src/Select/index.js +12 -0
  1048. package/src/Select/utils.js +108 -0
  1049. package/src/Sidebar/Sidebar.js +51 -0
  1050. package/src/Sidebar/Sidebar.mdx +28 -0
  1051. package/src/Sidebar/SidebarItem.js +34 -0
  1052. package/src/Sidebar/SidebarList.js +20 -0
  1053. package/src/Sidebar/index.js +2 -0
  1054. package/src/Sortable/Sortable.mdx +100 -0
  1055. package/src/Sortable/SortableEmpty.js +39 -0
  1056. package/src/Sortable/SortableItem.js +57 -0
  1057. package/src/Sortable/SortableList.js +115 -0
  1058. package/src/Sortable/SortableManager.js +20 -0
  1059. package/src/Sortable/constants.js +1 -0
  1060. package/src/Sortable/index.js +32 -0
  1061. package/src/Spinner/Spinner.mdx +50 -0
  1062. package/src/Spinner/Spinner.tsx +101 -0
  1063. package/src/Spinner/index.tsx +2 -0
  1064. package/src/StackView/StackView.mdx +155 -0
  1065. package/src/StackView/StackView.tsx +126 -0
  1066. package/src/StackView/index.ts +2 -0
  1067. package/src/StepperField/StepperField.mdx +21 -0
  1068. package/src/StepperField/StepperField.tsx +78 -0
  1069. package/src/StepperField/index.js +2 -0
  1070. package/src/StepperProgress/Context.js +3 -0
  1071. package/src/StepperProgress/Step.js +84 -0
  1072. package/src/StepperProgress/StepperProgress.js +45 -0
  1073. package/src/StepperProgress/StepperProgress.mdx +61 -0
  1074. package/src/StepperProgress/index.js +4 -0
  1075. package/src/Summary/Summary.mdx +26 -0
  1076. package/src/Summary/Summary.tsx +46 -0
  1077. package/src/Summary/index.js +2 -0
  1078. package/src/Tab/Tab.mdx +22 -0
  1079. package/src/Tab/Tab.tsx +80 -0
  1080. package/src/Tab/index.ts +2 -0
  1081. package/src/TabNav/Tab.mdx +7 -0
  1082. package/src/TabNav/Tab.tsx +139 -0
  1083. package/src/TabNav/TabNav.mdx +97 -0
  1084. package/src/TabNav/TabNav.test.tsx +40 -0
  1085. package/src/TabNav/TabNav.tsx +65 -0
  1086. package/src/TabNav/index.ts +2 -0
  1087. package/src/Table/AnimateScroll.js +58 -0
  1088. package/src/Table/AvatarCell.js +28 -0
  1089. package/src/Table/Body.js +24 -0
  1090. package/src/Table/BodyCell.js +15 -0
  1091. package/src/Table/BodyInnerCell.js +26 -0
  1092. package/src/Table/BodyRow.js +55 -0
  1093. package/src/Table/CheckboxCell.js +25 -0
  1094. package/src/Table/ColumnPicker.js +51 -0
  1095. package/src/Table/DateCell.js +12 -0
  1096. package/src/Table/DragCell.js +29 -0
  1097. package/src/Table/DragHandle.js +9 -0
  1098. package/src/Table/Header.js +26 -0
  1099. package/src/Table/HeaderCell.js +17 -0
  1100. package/src/Table/HeaderInnerCell.js +18 -0
  1101. package/src/Table/HeaderRow.js +15 -0
  1102. package/src/Table/NavigationArrow.js +75 -0
  1103. package/src/Table/ScrollShadow.js +33 -0
  1104. package/src/Table/SubRowToggleCell.js +38 -0
  1105. package/src/Table/Table.js +971 -0
  1106. package/src/Table/Table.mdx +281 -0
  1107. package/src/Table/TableBase.js +166 -0
  1108. package/src/Table/TableContainer.js +16 -0
  1109. package/src/Table/TableWrapper.js +7 -0
  1110. package/src/Table/index.js +2 -0
  1111. package/src/Tabs/Tab.js +51 -0
  1112. package/src/Tabs/TabList.js +67 -0
  1113. package/src/Tabs/TabPanel.js +22 -0
  1114. package/src/Tabs/TabPanels.js +25 -0
  1115. package/src/Tabs/Tabs.js +112 -0
  1116. package/src/Tabs/Tabs.mdx +49 -0
  1117. package/src/Tabs/index.js +10 -0
  1118. package/src/Text/Text.mdx +20 -0
  1119. package/src/Text/Text.tsx +133 -0
  1120. package/src/Text/index.ts +2 -0
  1121. package/src/TextArea/TextArea.mdx +13 -0
  1122. package/src/TextArea/TextArea.tsx +26 -0
  1123. package/src/TextArea/index.js +2 -0
  1124. package/src/ThemeProvider/ThemeProvider.tsx +113 -0
  1125. package/src/ThemeProvider/index.ts +2 -0
  1126. package/src/ThemeProvider/styles.ts +96 -0
  1127. package/src/TileView/TileView.mdx +56 -0
  1128. package/src/TileView/TileView.tsx +72 -0
  1129. package/src/TileView/index.ts +2 -0
  1130. package/src/TimeField/TimeField.mdx +95 -0
  1131. package/src/TimeField/TimeField.test.tsx +281 -0
  1132. package/src/TimeField/TimeField.tsx +344 -0
  1133. package/src/TimeField/index.js +2 -0
  1134. package/src/TimeField/utils.js +44 -0
  1135. package/src/ToggleSwitch/ToggleSwitch.mdx +56 -0
  1136. package/src/ToggleSwitch/ToggleSwitch.test.tsx +135 -0
  1137. package/src/ToggleSwitch/ToggleSwitch.tsx +108 -0
  1138. package/src/ToggleSwitch/index.ts +2 -0
  1139. package/src/TokenInput/DefaultToken.js +36 -0
  1140. package/src/TokenInput/TokenInput.js +257 -0
  1141. package/src/TokenInput/TokenInput.mdx +103 -0
  1142. package/src/TokenInput/default-renders.js +47 -0
  1143. package/src/TokenInput/index.js +2 -0
  1144. package/src/Toolbar/Action.js +16 -0
  1145. package/src/Toolbar/Toolbar.js +140 -0
  1146. package/src/Toolbar/Toolbar.mdx +47 -0
  1147. package/src/Toolbar/index.js +2 -0
  1148. package/src/Tooltip/Tooltip.js +275 -0
  1149. package/src/Tooltip/Tooltip.mdx +79 -0
  1150. package/src/Tooltip/Tooltip.test.tsx +136 -0
  1151. package/src/Tooltip/index.js +2 -0
  1152. package/src/VariantProvider/VariantProvider.js +15 -0
  1153. package/src/VariantProvider/index.js +1 -0
  1154. package/src/Wizard/Step.js +11 -0
  1155. package/src/Wizard/Wizard.mdx +105 -0
  1156. package/src/Wizard/Wizard.tsx +231 -0
  1157. package/src/Wizard/WizardContext.js +3 -0
  1158. package/src/Wizard/index.js +4 -0
  1159. package/src/WrapView/WrapView.mdx +73 -0
  1160. package/src/WrapView/WrapView.tsx +33 -0
  1161. package/src/WrapView/index.ts +2 -0
  1162. package/src/designTokens/index.ts +80 -0
  1163. package/src/hooks/__tests__/use-roving-index.js +58 -0
  1164. package/src/hooks/index.js +8 -0
  1165. package/src/hooks/use-accessibility-violation.tsx +61 -0
  1166. package/src/hooks/use-document-event.js +34 -0
  1167. package/src/hooks/use-focus.js +17 -0
  1168. package/src/hooks/use-hover.js +12 -0
  1169. package/src/hooks/use-id.js +19 -0
  1170. package/src/hooks/use-keyboard-shortcuts.js +26 -0
  1171. package/src/hooks/use-measure.js +120 -0
  1172. package/src/hooks/use-media-query.js +43 -0
  1173. package/src/hooks/use-roving-index.js +59 -0
  1174. package/src/hooks/useConstant.ts +17 -0
  1175. package/src/index.d.ts +426 -0
  1176. package/src/index.js +97 -0
  1177. package/src/server.js +16 -0
  1178. package/src/system/README.md +120 -0
  1179. package/src/system/box-sizes.js +54 -0
  1180. package/src/system/button-themes.js +173 -0
  1181. package/src/system/colors/colors.js +218 -0
  1182. package/src/system/colors/index.js +8 -0
  1183. package/src/system/colors/utils.js +191 -0
  1184. package/src/system/css.js +3 -0
  1185. package/src/system/cxs.js +82 -0
  1186. package/src/system/cxs.test.js +126 -0
  1187. package/src/system/default-theme.ts +53 -0
  1188. package/src/system/index.js +36 -0
  1189. package/src/system/parse-styles.js +49 -0
  1190. package/src/system/plugins/border.js +100 -0
  1191. package/src/system/plugins/color.js +60 -0
  1192. package/src/system/plugins/elevation.js +8 -0
  1193. package/src/system/plugins/flex.js +88 -0
  1194. package/src/system/plugins/grid.js +41 -0
  1195. package/src/system/plugins/index.js +27 -0
  1196. package/src/system/plugins/misc.js +21 -0
  1197. package/src/system/plugins/position.js +49 -0
  1198. package/src/system/plugins/size.js +37 -0
  1199. package/src/system/plugins/space.js +133 -0
  1200. package/src/system/plugins/stroke.js +48 -0
  1201. package/src/system/plugins/transform.js +27 -0
  1202. package/src/system/plugins/typography.js +12 -0
  1203. package/src/system/split-styles.js +109 -0
  1204. package/src/system/style-names.ts +278 -0
  1205. package/src/system/use-css.js +12 -0
  1206. package/src/system/utils.js +144 -0
  1207. package/src/utils.js +808 -0
  1208. package/src/utils.test.js +29 -0
  1209. package/src/vendor/react-measure/Measure.js +115 -0
  1210. package/src/vendor/react-measure/Viewport.js +154 -0
  1211. package/src/vendor/react-measure/index.js +2 -0
  1212. package/src/vendor/react-measure/utils.js +89 -0
  1213. package/dist/index.es.js +0 -25760
  1214. package/dist/index.umd.js +0 -552
  1215. package/dist/types/ActionsDropdown/ActionsDropdown.d.ts.map +0 -1
  1216. package/dist/types/ActionsDropdown/index.d.ts.map +0 -1
  1217. package/dist/types/Alert/Alert.d.ts.map +0 -1
  1218. package/dist/types/Alert/Alert.test.d.ts.map +0 -1
  1219. package/dist/types/Alert/index.d.ts.map +0 -1
  1220. package/dist/types/Avatar/Avatar.d.ts.map +0 -1
  1221. package/dist/types/Badge/Badge.d.ts.map +0 -1
  1222. package/dist/types/Badge/Status.d.ts.map +0 -1
  1223. package/dist/types/Box/Box.d.ts.map +0 -1
  1224. package/dist/types/Box/index.d.ts.map +0 -1
  1225. package/dist/types/Button/Button.d.ts.map +0 -1
  1226. package/dist/types/Button/Button.test.d.ts.map +0 -1
  1227. package/dist/types/Button/Input.d.ts.map +0 -1
  1228. package/dist/types/Button/index.d.ts.map +0 -1
  1229. package/dist/types/Calendar/Calendar.d.ts.map +0 -1
  1230. package/dist/types/Calendar/Day.d.ts +0 -18
  1231. package/dist/types/Calendar/Day.d.ts.map +0 -1
  1232. package/dist/types/Card/Card.d.ts.map +0 -1
  1233. package/dist/types/Card/Section.d.ts.map +0 -1
  1234. package/dist/types/Card/index.d.ts.map +0 -1
  1235. package/dist/types/Checkbox/Checkbox.d.ts.map +0 -1
  1236. package/dist/types/CheckboxGroup/CheckboxGroup.d.ts.map +0 -1
  1237. package/dist/types/CheckboxGroup/CheckboxGroupContext.d.ts.map +0 -1
  1238. package/dist/types/ChurchCenterStatus/ChurchCenterStatus.d.ts.map +0 -1
  1239. package/dist/types/ChurchCenterStatus/index.d.ts.map +0 -1
  1240. package/dist/types/Collapse/Collapse.test.d.ts.map +0 -1
  1241. package/dist/types/Combobox/Combobox.d.ts.map +0 -1
  1242. package/dist/types/Combobox/ComboboxInput.d.ts.map +0 -1
  1243. package/dist/types/Combobox/ComboboxPopover.d.ts +0 -31
  1244. package/dist/types/Combobox/ComboboxPopover.d.ts.map +0 -1
  1245. package/dist/types/DateField/DateField.d.ts.map +0 -1
  1246. package/dist/types/DateField/parse.d.ts.map +0 -1
  1247. package/dist/types/DateField/parse.test.d.ts.map +0 -1
  1248. package/dist/types/DateField/useArrowKeysToNavigateCalendar.d.ts.map +0 -1
  1249. package/dist/types/DateField/useEditableDate.d.ts.map +0 -1
  1250. package/dist/types/Divider/Divider.d.ts.map +0 -1
  1251. package/dist/types/Divider/index.d.ts.map +0 -1
  1252. package/dist/types/Dropdown/Dropdown.test.d.ts.map +0 -1
  1253. package/dist/types/EditActions/EditActions.d.ts.map +0 -1
  1254. package/dist/types/Field/Field.d.ts.map +0 -1
  1255. package/dist/types/FieldSet/FieldSet.d.ts.map +0 -1
  1256. package/dist/types/FilterLayout/FilterLayout.d.ts.map +0 -1
  1257. package/dist/types/FilterLayout/index.d.ts.map +0 -1
  1258. package/dist/types/GridView/GridView.d.ts.map +0 -1
  1259. package/dist/types/GridView/index.d.ts.map +0 -1
  1260. package/dist/types/Group/Group.d.ts.map +0 -1
  1261. package/dist/types/Group/index.d.ts.map +0 -1
  1262. package/dist/types/Heading/Heading.d.ts.map +0 -1
  1263. package/dist/types/HeadingUppercase/HeadingUppercase.d.ts.map +0 -1
  1264. package/dist/types/Highlight/Highlight.d.ts.map +0 -1
  1265. package/dist/types/Icon/Icon.d.ts.map +0 -1
  1266. package/dist/types/Logo/Logo.d.ts.map +0 -1
  1267. package/dist/types/Menu/Heading.d.ts +0 -9
  1268. package/dist/types/Menu/Heading.d.ts.map +0 -1
  1269. package/dist/types/Menu/Item.d.ts +0 -16
  1270. package/dist/types/Menu/Item.d.ts.map +0 -1
  1271. package/dist/types/Modal/Modal.d.ts.map +0 -1
  1272. package/dist/types/Modal/Modal.test.d.ts.map +0 -1
  1273. package/dist/types/NumberField/NumberField.d.ts.map +0 -1
  1274. package/dist/types/NumberField/NumberField.test.d.ts.map +0 -1
  1275. package/dist/types/Pagination/Pagination.d.ts.map +0 -1
  1276. package/dist/types/Popover/Popover.d.ts.map +0 -1
  1277. package/dist/types/Popover/Popover.test.d.ts.map +0 -1
  1278. package/dist/types/Popover/index.d.ts.map +0 -1
  1279. package/dist/types/Popover/rewireTabOrder.d.ts.map +0 -1
  1280. package/dist/types/Popover/utils.d.ts.map +0 -1
  1281. package/dist/types/Portal/Portal.d.ts.map +0 -1
  1282. package/dist/types/Portal/index.d.ts.map +0 -1
  1283. package/dist/types/Progress/Progress.d.ts.map +0 -1
  1284. package/dist/types/Radio/Radio.d.ts.map +0 -1
  1285. package/dist/types/Scrim/Scrim.d.ts.map +0 -1
  1286. package/dist/types/Scrim/index.d.ts.map +0 -1
  1287. package/dist/types/Select/Select.test.d.ts.map +0 -1
  1288. package/dist/types/Spinner/Spinner.d.ts.map +0 -1
  1289. package/dist/types/Spinner/index.d.ts.map +0 -1
  1290. package/dist/types/StackView/StackView.d.ts.map +0 -1
  1291. package/dist/types/StackView/index.d.ts.map +0 -1
  1292. package/dist/types/StepperField/StepperField.d.ts.map +0 -1
  1293. package/dist/types/Summary/Summary.d.ts.map +0 -1
  1294. package/dist/types/Tab/Tab.d.ts.map +0 -1
  1295. package/dist/types/Tab/index.d.ts.map +0 -1
  1296. package/dist/types/Text/Text.d.ts.map +0 -1
  1297. package/dist/types/Text/index.d.ts.map +0 -1
  1298. package/dist/types/TextArea/TextArea.d.ts.map +0 -1
  1299. package/dist/types/ThemeProvider/ThemeProvider.d.ts.map +0 -1
  1300. package/dist/types/ThemeProvider/index.d.ts.map +0 -1
  1301. package/dist/types/ThemeProvider/styles.d.ts.map +0 -1
  1302. package/dist/types/TileView/TileView.d.ts.map +0 -1
  1303. package/dist/types/TileView/index.d.ts.map +0 -1
  1304. package/dist/types/TimeField/TimeField.d.ts.map +0 -1
  1305. package/dist/types/TimeField/TimeField.test.d.ts.map +0 -1
  1306. package/dist/types/ToggleSwitch/ToggleSwitch.d.ts.map +0 -1
  1307. package/dist/types/ToggleSwitch/ToggleSwitch.test.d.ts.map +0 -1
  1308. package/dist/types/ToggleSwitch/index.d.ts.map +0 -1
  1309. package/dist/types/Toolbar/Toolbar.d.ts +0 -21
  1310. package/dist/types/Toolbar/Toolbar.d.ts.map +0 -1
  1311. package/dist/types/Tooltip/Tooltip.test.d.ts.map +0 -1
  1312. package/dist/types/Wizard/Wizard.d.ts.map +0 -1
  1313. package/dist/types/WrapView/WrapView.d.ts.map +0 -1
  1314. package/dist/types/WrapView/index.d.ts.map +0 -1
  1315. package/dist/types/designTokens/index.d.ts.map +0 -1
  1316. package/dist/types/hooks/use-accessibility-violation.d.ts.map +0 -1
  1317. package/dist/types/hooks/useConstant.d.ts.map +0 -1
  1318. package/dist/types/index.d.ts.map +0 -1
  1319. package/dist/types/system/colors/colors.d.ts +0 -113
  1320. package/dist/types/system/colors/colors.d.ts.map +0 -1
  1321. package/dist/types/system/default-theme.d.ts.map +0 -1
  1322. package/dist/types/system/style-names.d.ts.map +0 -1
  1323. package/dist/types/system/utils.d.ts +0 -30
  1324. package/dist/types/system/utils.d.ts.map +0 -1
  1325. package/dist/types/types.d.ts +0 -373
  1326. package/dist/types/types.d.ts.map +0 -1
@@ -0,0 +1,75 @@
1
+ ---
2
+ title: NumberField
3
+ category: Forms
4
+ summary: Number stepper input used to collect numeric information from users.
5
+ ---
6
+
7
+ ```jsx live
8
+ render(() => {
9
+ const [value, setValue] = React.useState(0)
10
+ return (
11
+ <Input.InputBox>
12
+ <NumberField value={value} onChange={(value) => setValue(value)} />
13
+ </Input.InputBox>
14
+ )
15
+ })
16
+ ```
17
+
18
+ ### With Controls
19
+ ```jsx live
20
+ render(() => {
21
+ const [value, setValue] = React.useState(0)
22
+ return (
23
+ <Input.InputBox>
24
+ <NumberField value={value} onChange={(value) => setValue(value)} hasControls={true} />
25
+ </Input.InputBox>
26
+ )
27
+ })
28
+ ```
29
+
30
+ ### Inline
31
+ ```jsx live
32
+ render(() => {
33
+ const [month, setMonth] = React.useState(4)
34
+ const [day, setDay] = React.useState(24)
35
+ const [year, setYear] = React.useState(2022)
36
+ return (
37
+ <StackView axis="horizontal" alignment="center">
38
+ <NumberField
39
+ as={Input.Inline}
40
+ moveFocusOnMax
41
+ fontSize={1}
42
+ pad={2}
43
+ min={1}
44
+ max={12}
45
+ value={month}
46
+ onChange={(month) => setMonth(month)}
47
+ />
48
+ <Text fontSize={1} marginHorizontal={0.5}>
49
+ /
50
+ </Text>
51
+ <NumberField
52
+ as={Input.Inline}
53
+ moveFocusOnMax
54
+ fontSize={1}
55
+ pad={2}
56
+ min={1}
57
+ max={31}
58
+ value={day}
59
+ onChange={(day) => setDay(day)}
60
+ />
61
+ <Text fontSize={1} marginHorizontal={0.5}>
62
+ /
63
+ </Text>
64
+ <NumberField
65
+ as={Input.Inline}
66
+ fontSize={1}
67
+ pad={4}
68
+ min={0}
69
+ value={year}
70
+ onChange={(year) => setYear(year)}
71
+ />
72
+ </StackView>
73
+ )
74
+ })
75
+ ```
@@ -0,0 +1,262 @@
1
+ import React, { useState } from 'react'
2
+ import { render, screen } from '@testing-library/react'
3
+ import '@testing-library/jest-dom/extend-expect'
4
+ import userEvent from '@testing-library/user-event'
5
+ import NumberField from './NumberField'
6
+
7
+ describe('value', () => {
8
+ const TestApp = ({ value: initialValue, ...props }) => {
9
+ const [value, setValue] = useState(initialValue)
10
+ const defaultProps = {
11
+ pad: 0,
12
+ highlightOnInteraction: false,
13
+ placeholder: '',
14
+ autoWidth: false,
15
+ ...props,
16
+ }
17
+ return (
18
+ <NumberField
19
+ data-testid="test"
20
+ value={value}
21
+ onChange={setValue}
22
+ {...defaultProps}
23
+ />
24
+ )
25
+ }
26
+ const setup = (props) => {
27
+ const { getByTestId } = render(<TestApp {...props} />)
28
+ return getByTestId('test')
29
+ }
30
+
31
+ it('renders', () => {
32
+ const numberField = setup({ value: 5 })
33
+ expect(numberField).toHaveValue('5')
34
+ })
35
+
36
+ it('pads if asked to', () => {
37
+ const numberField = setup({ value: 5, pad: 2 })
38
+ expect(numberField).toHaveValue('05')
39
+ })
40
+
41
+ it('uses placeholder when empty', () => {
42
+ const placeholder = 'pick something!'
43
+ const numberField = setup({ placeholder })
44
+ expect(numberField).toHaveAttribute('placeholder', placeholder)
45
+ })
46
+
47
+ describe('min', () => {
48
+ it('is used if typed value is lower after blur', () => {
49
+ const numberField = setup({ value: 2, min: 1 })
50
+ userEvent.type(numberField, '{backspace}0')
51
+ userEvent.tab()
52
+ expect(numberField).toHaveValue('1')
53
+ })
54
+
55
+ it('prevents arrow down from going below', () => {
56
+ const numberField = setup({ value: 1, min: 1 })
57
+ userEvent.type(numberField, '{arrowdown}')
58
+ expect(numberField).toHaveValue('1')
59
+ })
60
+ })
61
+
62
+ describe('max', () => {
63
+ it('is used if typed value is higher after blur', () => {
64
+ const numberField = setup({ value: 0, max: 1 })
65
+ userEvent.type(numberField, '2')
66
+ userEvent.tab()
67
+ expect(numberField).toHaveValue('1')
68
+ })
69
+
70
+ it('prevents arrow up from going above', () => {
71
+ const numberField = setup({ value: 1, max: 1 })
72
+ userEvent.type(numberField, '{arrowup}')
73
+ expect(numberField).toHaveValue('1')
74
+ })
75
+ })
76
+
77
+ describe('pad', () => {
78
+ it('add appropriate pad', () => {
79
+ const numberField = setup({ value: 0, pad: 2 })
80
+ userEvent.type(numberField, '12{backspace}')
81
+ expect(numberField).toHaveValue('01')
82
+ })
83
+ })
84
+ })
85
+
86
+ describe('moveFocusOnMax', () => {
87
+ const TestApp = (props) => {
88
+ const [value, setValue] = useState(0)
89
+
90
+ return (
91
+ <>
92
+ <NumberField
93
+ {...props}
94
+ data-testid="test-a"
95
+ value={value}
96
+ onChange={setValue}
97
+ />
98
+ <input data-testid="test-b" />
99
+ </>
100
+ )
101
+ }
102
+
103
+ const setup = () => {
104
+ const props = { max: 12, pad: 2, moveFocusOnMax: true }
105
+ const { getByTestId } = render(<TestApp {...props} />)
106
+ return [getByTestId('test-a'), getByTestId('test-b')]
107
+ }
108
+
109
+ it('moves focus when any further input would exceed max', () => {
110
+ const [numberField, nextTabbable] = setup()
111
+
112
+ userEvent.type(numberField, '2')
113
+ jest.runAllTimers()
114
+ expect(nextTabbable).toHaveFocus()
115
+ })
116
+
117
+ it('does not move focus when some further input is possible without exceeding max', () => {
118
+ const [numberField, nextTabbable] = setup()
119
+
120
+ userEvent.type(numberField, '1') // (10, 11, 12) are still possible
121
+ jest.runAllTimers()
122
+ expect(numberField).toHaveFocus()
123
+ })
124
+ })
125
+
126
+ describe('ignoredKeys', () => {
127
+ const TestApp = (props) => {
128
+ const [value, setValue] = useState(1)
129
+
130
+ return (
131
+ <NumberField
132
+ {...props}
133
+ data-testid="test"
134
+ value={value}
135
+ onChange={setValue}
136
+ />
137
+ )
138
+ }
139
+
140
+ const setup = () => {
141
+ const props = { ignoredKeys: ['ArrowUp', 'ArrowDown'] }
142
+ const { getByTestId } = render(<TestApp {...props} />)
143
+ return getByTestId('test')
144
+ }
145
+
146
+ it('prevents specified keys from changing values', () => {
147
+ const numberField = setup()
148
+
149
+ userEvent.type(numberField, '{arrowup}')
150
+ jest.runAllTimers()
151
+ expect(numberField).toHaveValue('1')
152
+
153
+ userEvent.type(numberField, '{arrowdown}')
154
+ jest.runAllTimers()
155
+ expect(numberField).toHaveValue('1')
156
+ })
157
+
158
+ it('allows other keys from change the value', () => {
159
+ const numberField = setup()
160
+
161
+ userEvent.type(numberField, '2')
162
+ jest.runAllTimers()
163
+ expect(numberField).toHaveValue('12')
164
+ })
165
+ })
166
+
167
+ describe('use buttons to increment/decrement value', () => {
168
+ const TestApp = (props) => {
169
+ const [value, setValue] = useState(1)
170
+
171
+ return (
172
+ <NumberField
173
+ {...props}
174
+ data-testid="test"
175
+ hasControls={true}
176
+ onChange={setValue}
177
+ value={value}
178
+ />
179
+ )
180
+ }
181
+
182
+ it('user input: pointer', () => {
183
+ const { container } = render(<TestApp step={1} />)
184
+ const input = container.querySelector('input')
185
+ const decrementButton = container.querySelector(
186
+ '[aria-label="Decrement by 1"]'
187
+ )
188
+ const incrementButton = container.querySelector(
189
+ '[aria-label="Increment by 1"]'
190
+ )
191
+
192
+ expect(decrementButton).toBeInTheDocument()
193
+ expect(incrementButton).toBeInTheDocument()
194
+ expect(input).toHaveValue('1')
195
+
196
+ userEvent.click(incrementButton)
197
+ expect(input).toHaveValue('2')
198
+
199
+ userEvent.click(incrementButton)
200
+ expect(input).toHaveValue('3')
201
+
202
+ userEvent.click(decrementButton)
203
+ expect(input).toHaveValue('2')
204
+
205
+ userEvent.click(decrementButton)
206
+ expect(input).toHaveValue('1')
207
+ })
208
+
209
+ it('user input: keyboard', () => {
210
+ const { container } = render(<TestApp step={1} />)
211
+ const input = container.querySelector('input')
212
+ const decrementButton = container.querySelector(
213
+ '[aria-label="Decrement by 1"]'
214
+ )
215
+ const incrementButton = container.querySelector(
216
+ '[aria-label="Increment by 1"]'
217
+ )
218
+
219
+ expect(decrementButton).toBeInTheDocument()
220
+ expect(incrementButton).toBeInTheDocument()
221
+ expect(input).toHaveValue('1')
222
+
223
+ userEvent.tab() // focus on input
224
+ userEvent.tab() // focus on "increment button"
225
+ userEvent.keyboard('{enter}')
226
+ expect(input).toHaveValue('2')
227
+
228
+ userEvent.keyboard('{enter}')
229
+ expect(input).toHaveValue('3')
230
+
231
+ userEvent.tab() // focus on "decrement button"
232
+ userEvent.keyboard('{enter}')
233
+ expect(input).toHaveValue('2')
234
+ })
235
+
236
+ it('user input: pointer w/ custom step', () => {
237
+ const { container } = render(<TestApp step={5} />)
238
+ const input = container.querySelector('input')
239
+ const decrementButton = container.querySelector(
240
+ '[aria-label="Decrement by 5"]'
241
+ )
242
+ const incrementButton = container.querySelector(
243
+ '[aria-label="Increment by 5"]'
244
+ )
245
+
246
+ expect(decrementButton).toBeInTheDocument()
247
+ expect(incrementButton).toBeInTheDocument()
248
+ expect(input).toHaveValue('1')
249
+
250
+ userEvent.click(incrementButton)
251
+ expect(input).toHaveValue('6')
252
+
253
+ userEvent.click(incrementButton)
254
+ expect(input).toHaveValue('11')
255
+
256
+ userEvent.click(decrementButton)
257
+ expect(input).toHaveValue('6')
258
+
259
+ userEvent.click(decrementButton)
260
+ expect(input).toHaveValue('1')
261
+ })
262
+ })
@@ -0,0 +1,358 @@
1
+ import React, { createElement, Component } from 'react'
2
+
3
+ import InputField from '../Input/InputField'
4
+ import StackView from '../StackView'
5
+ import Button from '../Button'
6
+ import { padNumber, getTabbableSiblings } from '../utils'
7
+
8
+ type NumberFieldProps = {
9
+ /**
10
+ * Render custom component or HTML element tag. (Defaults to a [InputField](/input.inputfield) component.). */
11
+ as?: any
12
+
13
+ /**
14
+ * Add controls to increment/decrement the value
15
+ */
16
+ hasControls?: boolean
17
+
18
+ /**
19
+ * An array of keys to ignore when pushed.
20
+ * ex: ["ArrowUp", "ArrowDown"].
21
+ */
22
+ ignoredKeys: string[]
23
+
24
+ /**
25
+ * Maximum number that can be entered.
26
+ */
27
+ max: number
28
+
29
+ /**
30
+ * Minimum number that can be entered.
31
+ */
32
+ min: number
33
+
34
+ /**
35
+ * Called when the input's onInput is called with a valid value
36
+ * or when the arrow keys are used to increment/decrement the value.
37
+ * Please note traditional onInput/onChange events are not supported
38
+ * since this component takes control of them.
39
+ */
40
+ onChange: (value: string) => void
41
+
42
+ /**
43
+ * Maps to the input's `onBlur` prop.
44
+ */
45
+ onBlur?: (event: React.FocusEvent<HTMLInputElement>) => void
46
+
47
+ onInput?: (event: React.FormEvent<HTMLInputElement>) => void
48
+
49
+ onKeyDown?: Function
50
+
51
+ /**
52
+ * The amount of 0s to pad the value with.
53
+ */
54
+ pad: number
55
+
56
+ /**
57
+ * Forces the input text to stay fully selected while interacting with it.
58
+ */
59
+ highlightOnInteraction: boolean
60
+
61
+ /**
62
+ * String to display when value is empty.
63
+ */
64
+ placeholder: string
65
+
66
+ /**
67
+ * The amount to step up/down from the value when using the arrow keys
68
+ * defaults to `1`
69
+ */
70
+ step: number
71
+
72
+ /**
73
+ * The value of the input.
74
+ */
75
+ value: number
76
+
77
+ autoWidth: boolean
78
+ moveFocusOnMax: boolean
79
+ }
80
+
81
+ const MIN_VALUE = -Infinity
82
+ const MAX_VALUE = Infinity
83
+ const ACCEPTED_KEYS = [
84
+ 'Backspace',
85
+ 'Delete',
86
+ 'Tab',
87
+ 'Enter',
88
+ 'Home',
89
+ 'End',
90
+ 'ArrowLeft',
91
+ 'ArrowRight',
92
+ '-',
93
+ '.',
94
+ ]
95
+
96
+ function getPadStringSize(pad) {
97
+ let str = ''
98
+ for (let i = 0; i < pad; i++) {
99
+ str += '0'
100
+ }
101
+ return str
102
+ }
103
+
104
+ function isNotAcceptedNumberKey(event) {
105
+ return (
106
+ !event.metaKey &&
107
+ event.key !== 'v' &&
108
+ isNaN(parseInt(event.key, 10)) &&
109
+ ACCEPTED_KEYS.indexOf(event.key) === -1
110
+ )
111
+ }
112
+
113
+ class NumberField extends Component<NumberFieldProps> {
114
+ static defaultProps = {
115
+ as: InputField,
116
+ hasControls: false,
117
+ ignoredKeys: [],
118
+ min: MIN_VALUE,
119
+ max: MAX_VALUE,
120
+ step: 1,
121
+ moveFocusOnMax: false,
122
+ }
123
+
124
+ firstTouch = true
125
+
126
+ getParsedValues = (value) => {
127
+ return {
128
+ value: Number.parseFloat(value),
129
+ // @ts-ignore Argument of type 'number' is not assignable to parameter of type 'string'.ts(2345)
130
+ minValue: Number.parseFloat(this.props.min),
131
+ // @ts-ignore Argument of type 'number' is not assignable to parameter of type 'string'.ts(2345)
132
+ maxValue: Number.parseFloat(this.props.max),
133
+ }
134
+ }
135
+
136
+ clampValue = (valueToCheck) => {
137
+ const { value, minValue } = this.getParsedValues(valueToCheck)
138
+ return isNaN(value) ? (minValue === MIN_VALUE ? 0 : minValue) : value
139
+ }
140
+
141
+ isValueValid = (valueToCheck) => {
142
+ const { value, minValue, maxValue } = this.getParsedValues(valueToCheck)
143
+ return value >= minValue && value <= maxValue
144
+ }
145
+
146
+ changeIfValid = (value) => {
147
+ if (this.isValueValid(value)) {
148
+ this.props.onChange(value)
149
+ }
150
+ }
151
+
152
+ handleBlur = (event) => {
153
+ const { minValue, maxValue } = this.getParsedValues(event.target.value)
154
+ let value = Number.parseFloat(event.target.value)
155
+
156
+ if (value < minValue) {
157
+ this.props.onChange(minValue.toString())
158
+ } else if (value > maxValue) {
159
+ this.props.onChange(maxValue.toString())
160
+ } else if (isNaN(value)) {
161
+ value = this.clampValue(value)
162
+ this.props.onChange(value.toString())
163
+ }
164
+ if (this.props.onBlur) {
165
+ this.props.onBlur(event)
166
+ }
167
+ this.firstTouch = true
168
+ }
169
+
170
+ stepValue = (baseValue, step) => {
171
+ const increment = step
172
+ const nextValue = this.clampValue(baseValue + increment)
173
+ const parsedValue = Number.parseFloat(
174
+ baseValue.toString().indexOf('.') > -1
175
+ ? nextValue.toFixed(2)
176
+ : nextValue.toString()
177
+ )
178
+ if (this.isValueValid(parsedValue)) {
179
+ // @ts-ignore Argument of type 'number' is not assignable to parameter of type 'string'.ts(2345)
180
+ this.props.onChange(parsedValue)
181
+ }
182
+ }
183
+
184
+ incrementValue = (baseValue) => this.stepValue(baseValue, this.props.step)
185
+
186
+ decrementValue = (baseValue) => this.stepValue(baseValue, -this.props.step)
187
+
188
+ handleKeyDown = (event) => {
189
+ if (this.props.ignoredKeys.includes(event.key)) {
190
+ return
191
+ }
192
+ const { pad } = this.props
193
+ const { value } = this.getParsedValues(event.target.value)
194
+ if (
195
+ isNotAcceptedNumberKey(event) ||
196
+ (pad && (event.key === 'ArrowLeft' || event.key === 'ArrowRight'))
197
+ ) {
198
+ event.preventDefault()
199
+ }
200
+ if (event.key === 'ArrowUp') {
201
+ this.incrementValue(value)
202
+ } else if (event.key === 'ArrowDown') {
203
+ this.decrementValue(value)
204
+ }
205
+ if (this.props.onKeyDown) {
206
+ this.props.onKeyDown(event)
207
+ }
208
+ }
209
+
210
+ handleInput = (event) => {
211
+ const { maxValue } = this.getParsedValues(event.target.value)
212
+ if (this.props.pad) {
213
+ const deleteKeyPressed = event.target.value === ''
214
+ const targetValue = deleteKeyPressed
215
+ ? event.target.value
216
+ : parseFloat(event.target.value)
217
+
218
+ if (deleteKeyPressed) {
219
+ const nextValue = `${this.props.value}`.slice(0, -1)
220
+ this.props.onChange(padNumber(nextValue, this.props.pad))
221
+ } else {
222
+ let nextValue = this.clampValue(targetValue)
223
+ const paddedValue = parseFloat(`${this.props.value}${targetValue}`)
224
+ if (
225
+ !this.firstTouch &&
226
+ !isNaN(targetValue) &&
227
+ this.isValueValid(paddedValue)
228
+ ) {
229
+ nextValue = paddedValue
230
+ }
231
+ this.firstTouch = false
232
+
233
+ if (this.props.moveFocusOnMax && nextValue / maxValue > 0.1) {
234
+ const { next } = getTabbableSiblings(event.target)
235
+ if (next) {
236
+ setTimeout(() => next.focus())
237
+ }
238
+ }
239
+
240
+ this.changeIfValid(nextValue)
241
+ }
242
+ } else {
243
+ this.props.onChange(event.target.value)
244
+ }
245
+ }
246
+
247
+ getAutoWidthValue(value) {
248
+ const { autoWidth, pad, placeholder } = this.props
249
+ const isValueEmpty = value === ''
250
+ return (
251
+ autoWidth ||
252
+ (pad && isValueEmpty
253
+ ? getPadStringSize(pad)
254
+ : isValueEmpty && placeholder !== undefined
255
+ ? placeholder
256
+ : value)
257
+ )
258
+ }
259
+
260
+ renderInput(restProps) {
261
+ const { as, highlightOnInteraction, pad, value } = this.props
262
+ const parsed = this.getParsedValues(value)
263
+ let numberValue = value === null ? '' : value
264
+
265
+ if (pad && numberValue !== '') {
266
+ numberValue = padNumber(numberValue, pad)
267
+ }
268
+
269
+ if (parsed.minValue !== MIN_VALUE) {
270
+ restProps.min = this.props.min
271
+ }
272
+
273
+ if (parsed.maxValue !== MAX_VALUE) {
274
+ restProps.max = this.props.max
275
+ }
276
+
277
+ if (this.props.autoWidth !== false) {
278
+ restProps.autoWidth = this.getAutoWidthValue(numberValue)
279
+ if (restProps.autoWidth === undefined) {
280
+ restProps.autoWidth = true
281
+ }
282
+ }
283
+
284
+ return createElement(as, {
285
+ ...restProps,
286
+ textOverflow: undefined,
287
+ autoComplete: 'off',
288
+ value: numberValue,
289
+ highlightOnInteraction: highlightOnInteraction || pad,
290
+ onBlur: this.handleBlur,
291
+ onInput: this.handleInput,
292
+ onKeyDown: this.handleKeyDown,
293
+ })
294
+ }
295
+
296
+ renderInputWithControls(restProps) {
297
+ const inputElement = this.renderInput(restProps)
298
+
299
+ if (this.props.hasControls) {
300
+ return (
301
+ <>
302
+ {inputElement}
303
+ <StackView marginRight={-1} marginLeft={1}>
304
+ <Button
305
+ icon={{ name: 'general.upCaret' }}
306
+ hover={{ backgroundColor: 'grey-1' }}
307
+ minHeight={1}
308
+ onClick={() => this.incrementValue(this.props.value)}
309
+ paddingVertical={0.25}
310
+ // @ts-ignore Type 'string' is not assignable to type 'never'.ts(2322)
311
+ size="xs"
312
+ title={`Increment by ${this.props.step}`}
313
+ variant="naked"
314
+ />
315
+ <Button
316
+ icon={{ name: 'general.downCaret' }}
317
+ hover={{ backgroundColor: 'grey-1' }}
318
+ minHeight={1}
319
+ onClick={() => this.decrementValue(this.props.value)}
320
+ paddingVertical={0.25}
321
+ // @ts-ignore Type 'string' is not assignable to type 'never'.ts(2322)
322
+ size="xs"
323
+ title={`Decrement by ${this.props.step}`}
324
+ variant="naked"
325
+ />
326
+ </StackView>
327
+ </>
328
+ )
329
+ }
330
+ return inputElement
331
+ }
332
+
333
+ render() {
334
+ const {
335
+ autoWidth,
336
+ as,
337
+ hasControls,
338
+ highlightOnInteraction,
339
+ ignoredKeys,
340
+ min,
341
+ max,
342
+ moveFocusOnMax,
343
+ onChange,
344
+ onBlur,
345
+ onInput,
346
+ onKeyDown,
347
+ pad,
348
+ value,
349
+ ...restProps
350
+ } = this.props
351
+
352
+ return this.props.hasControls
353
+ ? this.renderInputWithControls(restProps)
354
+ : this.renderInput(restProps)
355
+ }
356
+ }
357
+
358
+ export default NumberField
@@ -0,0 +1,2 @@
1
+ import NumberField from './NumberField'
2
+ export default NumberField