@planningcenter/tapestry-react 0.0.1-alpha.0

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 (1078) hide show
  1. package/README.md +7 -0
  2. package/dist/cjs/ActionsDropdown/ActionsDropdown.js +117 -0
  3. package/dist/cjs/ActionsDropdown/index.js +15 -0
  4. package/dist/cjs/Alert/Alert.js +37 -0
  5. package/dist/cjs/Alert/Alert.test.js +20 -0
  6. package/dist/cjs/Alert/index.js +15 -0
  7. package/dist/cjs/Avatar/Avatar.js +55 -0
  8. package/dist/cjs/Avatar/index.js +11 -0
  9. package/dist/cjs/Badge/Badge.js +122 -0
  10. package/dist/cjs/Badge/Status.js +114 -0
  11. package/dist/cjs/Badge/index.js +14 -0
  12. package/dist/cjs/Box/Box.js +46 -0
  13. package/dist/cjs/Box/index.js +15 -0
  14. package/dist/cjs/Button/Button.js +274 -0
  15. package/dist/cjs/Button/Button.test.js +59 -0
  16. package/dist/cjs/Button/Input.js +180 -0
  17. package/dist/cjs/Button/index.js +15 -0
  18. package/dist/cjs/Calendar/Calendar.js +376 -0
  19. package/dist/cjs/Calendar/Day.js +103 -0
  20. package/dist/cjs/Calendar/index.js +11 -0
  21. package/dist/cjs/Calendar/utils.js +104 -0
  22. package/dist/cjs/Card/Card.js +57 -0
  23. package/dist/cjs/Card/index.js +15 -0
  24. package/dist/cjs/Checkbox/Checkbox.js +225 -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 +71 -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 +131 -0
  32. package/dist/cjs/ChurchCenterStatus/index.js +15 -0
  33. package/dist/cjs/Collapse/Collapse.js +123 -0
  34. package/dist/cjs/Collapse/index.js +11 -0
  35. package/dist/cjs/ColumnView/ColumnView.js +63 -0
  36. package/dist/cjs/ColumnView/index.js +11 -0
  37. package/dist/cjs/Combobox/Combobox.js +62 -0
  38. package/dist/cjs/Combobox/ComboboxInput.js +171 -0
  39. package/dist/cjs/Combobox/ComboboxItem.js +72 -0
  40. package/dist/cjs/Combobox/ComboboxItems.js +107 -0
  41. package/dist/cjs/Combobox/ComboboxPopover.js +250 -0
  42. package/dist/cjs/Combobox/index.js +11 -0
  43. package/dist/cjs/DataTable/DataTable.js +271 -0
  44. package/dist/cjs/DataTable/components/BodyRow.js +58 -0
  45. package/dist/cjs/DataTable/components/BodyRows.js +131 -0
  46. package/dist/cjs/DataTable/components/BodySubRows.js +104 -0
  47. package/dist/cjs/DataTable/components/CheckboxCell.js +116 -0
  48. package/dist/cjs/DataTable/components/ColumnPicker.js +74 -0
  49. package/dist/cjs/DataTable/components/HeaderCell.js +88 -0
  50. package/dist/cjs/DataTable/components/Icon.js +70 -0
  51. package/dist/cjs/DataTable/components/index.js +22 -0
  52. package/dist/cjs/DataTable/hooks/index.js +42 -0
  53. package/dist/cjs/DataTable/hooks/useCollapsibleRows.js +127 -0
  54. package/dist/cjs/DataTable/hooks/useColumnSort.js +100 -0
  55. package/dist/cjs/DataTable/hooks/useColumnWidths.js +113 -0
  56. package/dist/cjs/DataTable/hooks/useHoverFocus.js +33 -0
  57. package/dist/cjs/DataTable/hooks/useRefManager.js +28 -0
  58. package/dist/cjs/DataTable/hooks/useScrollShadows.js +106 -0
  59. package/dist/cjs/DataTable/hooks/useScrollSync.js +52 -0
  60. package/dist/cjs/DataTable/hooks/useVariants.js +15 -0
  61. package/dist/cjs/DataTable/index.js +29 -0
  62. package/dist/cjs/DataTable/utils/getCell.js +24 -0
  63. package/dist/cjs/DataTable/utils/getParsedColumns.js +158 -0
  64. package/dist/cjs/DataTable/utils/getRowLinkProps.js +16 -0
  65. package/dist/cjs/DataTable/utils/index.js +22 -0
  66. package/dist/cjs/DataTable/utils/variants.js +176 -0
  67. package/dist/cjs/DateField/DateField.js +169 -0
  68. package/dist/cjs/DateField/index.js +11 -0
  69. package/dist/cjs/Divider/Divider.js +44 -0
  70. package/dist/cjs/Divider/index.js +15 -0
  71. package/dist/cjs/DragDrop/DragDrop.js +226 -0
  72. package/dist/cjs/DragDrop/index.js +11 -0
  73. package/dist/cjs/Drawer/Drawer.js +99 -0
  74. package/dist/cjs/Drawer/index.js +11 -0
  75. package/dist/cjs/Dropdown/Dropdown.js +295 -0
  76. package/dist/cjs/Dropdown/Dropdown.test.js +35 -0
  77. package/dist/cjs/Dropdown/Item.js +74 -0
  78. package/dist/cjs/Dropdown/Link.js +85 -0
  79. package/dist/cjs/Dropdown/index.js +11 -0
  80. package/dist/cjs/EditActions/EditActions.js +94 -0
  81. package/dist/cjs/EditActions/index.js +11 -0
  82. package/dist/cjs/Field/Field.js +130 -0
  83. package/dist/cjs/Field/index.js +11 -0
  84. package/dist/cjs/FieldSet/FieldSet.js +49 -0
  85. package/dist/cjs/FieldSet/index.js +11 -0
  86. package/dist/cjs/FilterLayout/FilterLayout.js +95 -0
  87. package/dist/cjs/FilterLayout/index.js +15 -0
  88. package/dist/cjs/FocusGroup/FocusGroup.js +127 -0
  89. package/dist/cjs/FocusGroup/index.js +11 -0
  90. package/dist/cjs/Form/Form.js +188 -0
  91. package/dist/cjs/Form/index.js +11 -0
  92. package/dist/cjs/GridView/GridView.js +109 -0
  93. package/dist/cjs/GridView/index.js +15 -0
  94. package/dist/cjs/Group/Group.js +48 -0
  95. package/dist/cjs/Group/index.js +15 -0
  96. package/dist/cjs/Heading/Heading.js +33 -0
  97. package/dist/cjs/Heading/index.js +11 -0
  98. package/dist/cjs/HeadingUppercase/HeadingUppercase.js +35 -0
  99. package/dist/cjs/HeadingUppercase/index.js +11 -0
  100. package/dist/cjs/HelperDrawer/HelperDrawer.js +91 -0
  101. package/dist/cjs/HelperDrawer/index.js +11 -0
  102. package/dist/cjs/Highlight/Highlight.js +47 -0
  103. package/dist/cjs/Highlight/index.js +11 -0
  104. package/dist/cjs/Highlight/utils.js +52 -0
  105. package/dist/cjs/Icon/Icon.js +59 -0
  106. package/dist/cjs/Icon/Path.js +33 -0
  107. package/dist/cjs/Icon/Status.js +51 -0
  108. package/dist/cjs/Icon/index.js +17 -0
  109. package/dist/cjs/Input/Inline.js +59 -0
  110. package/dist/cjs/Input/Input.js +130 -0
  111. package/dist/cjs/Input/InputBox.js +350 -0
  112. package/dist/cjs/Input/InputContext.js +10 -0
  113. package/dist/cjs/Input/InputField.js +290 -0
  114. package/dist/cjs/Input/InputLabel.js +93 -0
  115. package/dist/cjs/Input/index.js +23 -0
  116. package/dist/cjs/Input/utils.js +13 -0
  117. package/dist/cjs/ItemList/ItemList.js +262 -0
  118. package/dist/cjs/ItemList/ItemListContext.js +10 -0
  119. package/dist/cjs/ItemList/ItemListController.js +67 -0
  120. package/dist/cjs/ItemList/ItemListItem.js +100 -0
  121. package/dist/cjs/ItemList/index.js +17 -0
  122. package/dist/cjs/ItemList/utils.js +73 -0
  123. package/dist/cjs/Link/Inline.js +50 -0
  124. package/dist/cjs/Link/Link.js +76 -0
  125. package/dist/cjs/Link/index.js +14 -0
  126. package/dist/cjs/LinkList/LinkList.js +41 -0
  127. package/dist/cjs/LinkList/index.js +11 -0
  128. package/dist/cjs/List/List.js +63 -0
  129. package/dist/cjs/List/ListItem.js +52 -0
  130. package/dist/cjs/List/index.js +11 -0
  131. package/dist/cjs/Logo/Logo.js +63 -0
  132. package/dist/cjs/Logo/index.js +11 -0
  133. package/dist/cjs/Menu/Heading.js +26 -0
  134. package/dist/cjs/Menu/Item.js +90 -0
  135. package/dist/cjs/Menu/Menu.js +30 -0
  136. package/dist/cjs/Menu/index.js +11 -0
  137. package/dist/cjs/Modal/Modal.js +65 -0
  138. package/dist/cjs/Modal/index.js +11 -0
  139. package/dist/cjs/NumberField/NumberField.js +244 -0
  140. package/dist/cjs/NumberField/NumberField.test.js +220 -0
  141. package/dist/cjs/NumberField/index.js +11 -0
  142. package/dist/cjs/Page/PageActions.js +22 -0
  143. package/dist/cjs/Page/PageBody.js +56 -0
  144. package/dist/cjs/Page/PageButton.js +24 -0
  145. package/dist/cjs/Page/PageDropdown.js +25 -0
  146. package/dist/cjs/Page/PageHeader.js +48 -0
  147. package/dist/cjs/Page/PageTab.js +21 -0
  148. package/dist/cjs/Page/PageTabList.js +26 -0
  149. package/dist/cjs/Page/PageTitle.js +25 -0
  150. package/dist/cjs/Page/PageToolbar.js +23 -0
  151. package/dist/cjs/Page/index.js +41 -0
  152. package/dist/cjs/PagerView/PagerView.js +230 -0
  153. package/dist/cjs/PagerView/index.js +11 -0
  154. package/dist/cjs/Pagination/Pagination.js +148 -0
  155. package/dist/cjs/Pagination/index.js +11 -0
  156. package/dist/cjs/Popover/Popover.js +214 -0
  157. package/dist/cjs/Popover/index.js +15 -0
  158. package/dist/cjs/Popover/rewireTabOrder.js +123 -0
  159. package/dist/cjs/Popover/utils.js +72 -0
  160. package/dist/cjs/Portal/Portal.js +166 -0
  161. package/dist/cjs/Portal/index.js +15 -0
  162. package/dist/cjs/Progress/Progress.js +45 -0
  163. package/dist/cjs/Progress/index.js +11 -0
  164. package/dist/cjs/Radio/Radio.js +158 -0
  165. package/dist/cjs/Radio/index.js +11 -0
  166. package/dist/cjs/RangeSlider/RangeSlider.js +224 -0
  167. package/dist/cjs/RangeSlider/index.js +11 -0
  168. package/dist/cjs/ScreenReader/ScreenReader.js +38 -0
  169. package/dist/cjs/ScreenReader/index.js +11 -0
  170. package/dist/cjs/Scrim/Scrim.js +36 -0
  171. package/dist/cjs/Scrim/index.js +15 -0
  172. package/dist/cjs/Section/Section.js +48 -0
  173. package/dist/cjs/Section/index.js +11 -0
  174. package/dist/cjs/SegmentedControl/SegmentedControl.js +140 -0
  175. package/dist/cjs/SegmentedControl/index.js +11 -0
  176. package/dist/cjs/SegmentedTabs/SegmentedTabs.js +149 -0
  177. package/dist/cjs/SegmentedTabs/index.js +11 -0
  178. package/dist/cjs/Select/Context.js +10 -0
  179. package/dist/cjs/Select/Inline.js +51 -0
  180. package/dist/cjs/Select/Option.js +103 -0
  181. package/dist/cjs/Select/OptionGroup.js +34 -0
  182. package/dist/cjs/Select/Select.js +542 -0
  183. package/dist/cjs/Select/Value.js +27 -0
  184. package/dist/cjs/Select/constants.js +10 -0
  185. package/dist/cjs/Select/index.js +26 -0
  186. package/dist/cjs/Select/utils.js +129 -0
  187. package/dist/cjs/Sidebar/Sidebar.js +55 -0
  188. package/dist/cjs/Sidebar/SidebarItem.js +53 -0
  189. package/dist/cjs/Sidebar/SidebarList.js +27 -0
  190. package/dist/cjs/Sidebar/index.js +11 -0
  191. package/dist/cjs/Sortable/SortableEmpty.js +42 -0
  192. package/dist/cjs/Sortable/SortableItem.js +57 -0
  193. package/dist/cjs/Sortable/SortableList.js +106 -0
  194. package/dist/cjs/Sortable/SortableManager.js +31 -0
  195. package/dist/cjs/Sortable/constants.js +6 -0
  196. package/dist/cjs/Sortable/index.js +57 -0
  197. package/dist/cjs/Spinner/Spinner.js +79 -0
  198. package/dist/cjs/Spinner/index.js +15 -0
  199. package/dist/cjs/StackView/StackView.js +105 -0
  200. package/dist/cjs/StackView/index.js +15 -0
  201. package/dist/cjs/StepperField/StepperField.js +78 -0
  202. package/dist/cjs/StepperField/index.js +11 -0
  203. package/dist/cjs/StepperProgress/Context.js +10 -0
  204. package/dist/cjs/StepperProgress/Step.js +87 -0
  205. package/dist/cjs/StepperProgress/StepperProgress.js +45 -0
  206. package/dist/cjs/StepperProgress/index.js +14 -0
  207. package/dist/cjs/Summary/Summary.js +41 -0
  208. package/dist/cjs/Summary/index.js +11 -0
  209. package/dist/cjs/Tab/Tab.js +77 -0
  210. package/dist/cjs/Tab/index.js +15 -0
  211. package/dist/cjs/Table/AnimateScroll.js +88 -0
  212. package/dist/cjs/Table/AvatarCell.js +44 -0
  213. package/dist/cjs/Table/Body.js +33 -0
  214. package/dist/cjs/Table/BodyCell.js +24 -0
  215. package/dist/cjs/Table/BodyInnerCell.js +34 -0
  216. package/dist/cjs/Table/BodyRow.js +70 -0
  217. package/dist/cjs/Table/CheckboxCell.js +40 -0
  218. package/dist/cjs/Table/ColumnPicker.js +73 -0
  219. package/dist/cjs/Table/DateCell.js +21 -0
  220. package/dist/cjs/Table/DragCell.js +47 -0
  221. package/dist/cjs/Table/DragHandle.js +22 -0
  222. package/dist/cjs/Table/Header.js +44 -0
  223. package/dist/cjs/Table/HeaderCell.js +26 -0
  224. package/dist/cjs/Table/HeaderInnerCell.js +30 -0
  225. package/dist/cjs/Table/HeaderRow.js +24 -0
  226. package/dist/cjs/Table/NavigationArrow.js +78 -0
  227. package/dist/cjs/Table/ScrollShadow.js +47 -0
  228. package/dist/cjs/Table/SubRowToggleCell.js +47 -0
  229. package/dist/cjs/Table/Table.js +697 -0
  230. package/dist/cjs/Table/TableBase.js +180 -0
  231. package/dist/cjs/Table/TableContainer.js +25 -0
  232. package/dist/cjs/Table/TableWrapper.js +22 -0
  233. package/dist/cjs/Table/index.js +11 -0
  234. package/dist/cjs/Tabs/Tab.js +59 -0
  235. package/dist/cjs/Tabs/TabList.js +92 -0
  236. package/dist/cjs/Tabs/TabPanel.js +28 -0
  237. package/dist/cjs/Tabs/TabPanels.js +49 -0
  238. package/dist/cjs/Tabs/Tabs.js +140 -0
  239. package/dist/cjs/Tabs/index.js +11 -0
  240. package/dist/cjs/Text/Text.js +101 -0
  241. package/dist/cjs/Text/index.js +15 -0
  242. package/dist/cjs/TextArea/TextArea.js +24 -0
  243. package/dist/cjs/TextArea/index.js +11 -0
  244. package/dist/cjs/ThemeProvider/ThemeProvider.js +121 -0
  245. package/dist/cjs/ThemeProvider/index.js +15 -0
  246. package/dist/cjs/ThemeProvider/styles.js +40 -0
  247. package/dist/cjs/TileView/TileView.js +66 -0
  248. package/dist/cjs/TileView/index.js +15 -0
  249. package/dist/cjs/TimeField/TimeField.js +239 -0
  250. package/dist/cjs/TimeField/TimeField.test.js +273 -0
  251. package/dist/cjs/TimeField/index.js +11 -0
  252. package/dist/cjs/TimeField/utils.js +61 -0
  253. package/dist/cjs/TokenInput/DefaultToken.js +42 -0
  254. package/dist/cjs/TokenInput/TokenInput.js +257 -0
  255. package/dist/cjs/TokenInput/default-renders.js +54 -0
  256. package/dist/cjs/TokenInput/index.js +11 -0
  257. package/dist/cjs/Toolbar/Action.js +27 -0
  258. package/dist/cjs/Toolbar/Toolbar.js +112 -0
  259. package/dist/cjs/Toolbar/index.js +11 -0
  260. package/dist/cjs/Tooltip/Tooltip.js +232 -0
  261. package/dist/cjs/Tooltip/index.js +11 -0
  262. package/dist/cjs/VariantProvider/VariantProvider.js +31 -0
  263. package/dist/cjs/VariantProvider/index.js +9 -0
  264. package/dist/cjs/Wizard/Step.js +33 -0
  265. package/dist/cjs/Wizard/Wizard.js +238 -0
  266. package/dist/cjs/Wizard/WizardContext.js +10 -0
  267. package/dist/cjs/Wizard/index.js +11 -0
  268. package/dist/cjs/WrapView/WrapView.js +62 -0
  269. package/dist/cjs/WrapView/index.js +15 -0
  270. package/dist/cjs/hooks/index.js +32 -0
  271. package/dist/cjs/hooks/use-accessibility-violation.js +79 -0
  272. package/dist/cjs/hooks/use-document-event.js +38 -0
  273. package/dist/cjs/hooks/use-focus.js +29 -0
  274. package/dist/cjs/hooks/use-hover.js +24 -0
  275. package/dist/cjs/hooks/use-id.js +26 -0
  276. package/dist/cjs/hooks/use-keyboard-shortcuts.js +38 -0
  277. package/dist/cjs/hooks/use-measure.js +125 -0
  278. package/dist/cjs/hooks/use-roving-index.js +58 -0
  279. package/dist/cjs/icons.js +126 -0
  280. package/dist/cjs/index.d.js +354 -0
  281. package/dist/cjs/index.js +340 -0
  282. package/dist/cjs/server.js +27 -0
  283. package/dist/cjs/system/box-sizes.js +61 -0
  284. package/dist/cjs/system/button-themes.js +286 -0
  285. package/dist/cjs/system/colors/colors.js +107 -0
  286. package/dist/cjs/system/colors/index.js +18 -0
  287. package/dist/cjs/system/colors/utils.js +211 -0
  288. package/dist/cjs/system/css.js +14 -0
  289. package/dist/cjs/system/cxs.js +106 -0
  290. package/dist/cjs/system/default-theme.js +72 -0
  291. package/dist/cjs/system/index.js +90 -0
  292. package/dist/cjs/system/parse-styles.js +61 -0
  293. package/dist/cjs/system/plugins/border.js +93 -0
  294. package/dist/cjs/system/plugins/color.js +47 -0
  295. package/dist/cjs/system/plugins/elevation.js +22 -0
  296. package/dist/cjs/system/plugins/flex.js +84 -0
  297. package/dist/cjs/system/plugins/grid.js +52 -0
  298. package/dist/cjs/system/plugins/index.js +33 -0
  299. package/dist/cjs/system/plugins/misc.js +34 -0
  300. package/dist/cjs/system/plugins/position.js +49 -0
  301. package/dist/cjs/system/plugins/size.js +39 -0
  302. package/dist/cjs/system/plugins/space.js +112 -0
  303. package/dist/cjs/system/plugins/stroke.js +48 -0
  304. package/dist/cjs/system/plugins/transform.js +46 -0
  305. package/dist/cjs/system/plugins/typography.js +23 -0
  306. package/dist/cjs/system/split-styles.js +119 -0
  307. package/dist/cjs/system/style-names.js +14 -0
  308. package/dist/cjs/system/use-css.js +21 -0
  309. package/dist/cjs/system/utils.js +184 -0
  310. package/dist/cjs/utils.js +870 -0
  311. package/dist/cjs/vendor/react-measure/Measure.js +158 -0
  312. package/dist/cjs/vendor/react-measure/Viewport.js +172 -0
  313. package/dist/cjs/vendor/react-measure/index.js +14 -0
  314. package/dist/cjs/vendor/react-measure/utils.js +89 -0
  315. package/dist/esm/ActionsDropdown/ActionsDropdown.js +111 -0
  316. package/dist/esm/ActionsDropdown/index.js +2 -0
  317. package/dist/esm/Alert/Alert.js +22 -0
  318. package/dist/esm/Alert/Alert.test.js +13 -0
  319. package/dist/esm/Alert/index.js +2 -0
  320. package/dist/esm/Avatar/Avatar.js +42 -0
  321. package/dist/esm/Avatar/index.js +2 -0
  322. package/dist/esm/Badge/Badge.js +105 -0
  323. package/dist/esm/Badge/Status.js +98 -0
  324. package/dist/esm/Badge/index.js +4 -0
  325. package/dist/esm/Box/Box.js +35 -0
  326. package/dist/esm/Box/index.js +2 -0
  327. package/dist/esm/Button/Button.js +258 -0
  328. package/dist/esm/Button/Button.test.js +53 -0
  329. package/dist/esm/Button/Input.js +163 -0
  330. package/dist/esm/Button/index.js +2 -0
  331. package/dist/esm/Calendar/Calendar.js +349 -0
  332. package/dist/esm/Calendar/Day.js +92 -0
  333. package/dist/esm/Calendar/index.js +2 -0
  334. package/dist/esm/Calendar/utils.js +80 -0
  335. package/dist/esm/Card/Card.js +44 -0
  336. package/dist/esm/Card/index.js +2 -0
  337. package/dist/esm/Checkbox/Checkbox.js +204 -0
  338. package/dist/esm/Checkbox/index.js +2 -0
  339. package/dist/esm/CheckboxCard/CheckboxCard.js +60 -0
  340. package/dist/esm/CheckboxCard/index.js +2 -0
  341. package/dist/esm/CheckboxGroup/CheckboxGroup.js +58 -0
  342. package/dist/esm/CheckboxGroup/CheckboxGroupContext.js +3 -0
  343. package/dist/esm/CheckboxGroup/index.js +2 -0
  344. package/dist/esm/ChurchCenterStatus/ChurchCenterStatus.js +127 -0
  345. package/dist/esm/ChurchCenterStatus/index.js +2 -0
  346. package/dist/esm/Collapse/Collapse.js +112 -0
  347. package/dist/esm/Collapse/index.js +2 -0
  348. package/dist/esm/ColumnView/ColumnView.js +49 -0
  349. package/dist/esm/ColumnView/index.js +2 -0
  350. package/dist/esm/Combobox/Combobox.js +48 -0
  351. package/dist/esm/Combobox/ComboboxInput.js +160 -0
  352. package/dist/esm/Combobox/ComboboxItem.js +58 -0
  353. package/dist/esm/Combobox/ComboboxItems.js +89 -0
  354. package/dist/esm/Combobox/ComboboxPopover.js +243 -0
  355. package/dist/esm/Combobox/index.js +2 -0
  356. package/dist/esm/DataTable/DataTable.js +247 -0
  357. package/dist/esm/DataTable/components/BodyRow.js +49 -0
  358. package/dist/esm/DataTable/components/BodyRows.js +114 -0
  359. package/dist/esm/DataTable/components/BodySubRows.js +90 -0
  360. package/dist/esm/DataTable/components/CheckboxCell.js +104 -0
  361. package/dist/esm/DataTable/components/ColumnPicker.js +62 -0
  362. package/dist/esm/DataTable/components/HeaderCell.js +75 -0
  363. package/dist/esm/DataTable/components/Icon.js +61 -0
  364. package/dist/esm/DataTable/components/index.js +4 -0
  365. package/dist/esm/DataTable/hooks/index.js +6 -0
  366. package/dist/esm/DataTable/hooks/useCollapsibleRows.js +107 -0
  367. package/dist/esm/DataTable/hooks/useColumnSort.js +85 -0
  368. package/dist/esm/DataTable/hooks/useColumnWidths.js +104 -0
  369. package/dist/esm/DataTable/hooks/useHoverFocus.js +27 -0
  370. package/dist/esm/DataTable/hooks/useRefManager.js +22 -0
  371. package/dist/esm/DataTable/hooks/useScrollShadows.js +94 -0
  372. package/dist/esm/DataTable/hooks/useScrollSync.js +46 -0
  373. package/dist/esm/DataTable/hooks/useVariants.js +9 -0
  374. package/dist/esm/DataTable/index.js +14 -0
  375. package/dist/esm/DataTable/utils/getCell.js +18 -0
  376. package/dist/esm/DataTable/utils/getParsedColumns.js +144 -0
  377. package/dist/esm/DataTable/utils/getRowLinkProps.js +10 -0
  378. package/dist/esm/DataTable/utils/index.js +4 -0
  379. package/dist/esm/DataTable/utils/variants.js +167 -0
  380. package/dist/esm/DateField/DateField.js +158 -0
  381. package/dist/esm/DateField/index.js +2 -0
  382. package/dist/esm/Divider/Divider.js +35 -0
  383. package/dist/esm/Divider/index.js +2 -0
  384. package/dist/esm/DragDrop/DragDrop.js +213 -0
  385. package/dist/esm/DragDrop/index.js +2 -0
  386. package/dist/esm/Drawer/Drawer.js +87 -0
  387. package/dist/esm/Drawer/index.js +2 -0
  388. package/dist/esm/Dropdown/Dropdown.js +282 -0
  389. package/dist/esm/Dropdown/Dropdown.test.js +26 -0
  390. package/dist/esm/Dropdown/Item.js +58 -0
  391. package/dist/esm/Dropdown/Link.js +67 -0
  392. package/dist/esm/Dropdown/index.js +2 -0
  393. package/dist/esm/EditActions/EditActions.js +79 -0
  394. package/dist/esm/EditActions/index.js +2 -0
  395. package/dist/esm/Field/Field.js +114 -0
  396. package/dist/esm/Field/index.js +2 -0
  397. package/dist/esm/FieldSet/FieldSet.js +36 -0
  398. package/dist/esm/FieldSet/index.js +2 -0
  399. package/dist/esm/FilterLayout/FilterLayout.js +82 -0
  400. package/dist/esm/FilterLayout/index.js +2 -0
  401. package/dist/esm/FocusGroup/FocusGroup.js +121 -0
  402. package/dist/esm/FocusGroup/index.js +2 -0
  403. package/dist/esm/Form/Form.js +184 -0
  404. package/dist/esm/Form/index.js +2 -0
  405. package/dist/esm/GridView/GridView.js +98 -0
  406. package/dist/esm/GridView/index.js +2 -0
  407. package/dist/esm/Group/Group.js +36 -0
  408. package/dist/esm/Group/index.js +2 -0
  409. package/dist/esm/Heading/Heading.js +22 -0
  410. package/dist/esm/Heading/index.js +2 -0
  411. package/dist/esm/HeadingUppercase/HeadingUppercase.js +24 -0
  412. package/dist/esm/HeadingUppercase/index.js +2 -0
  413. package/dist/esm/HelperDrawer/HelperDrawer.js +78 -0
  414. package/dist/esm/HelperDrawer/index.js +2 -0
  415. package/dist/esm/Highlight/Highlight.js +36 -0
  416. package/dist/esm/Highlight/index.js +2 -0
  417. package/dist/esm/Highlight/utils.js +46 -0
  418. package/dist/esm/Icon/Icon.js +47 -0
  419. package/dist/esm/Icon/Path.js +22 -0
  420. package/dist/esm/Icon/Status.js +39 -0
  421. package/dist/esm/Icon/index.js +6 -0
  422. package/dist/esm/Input/Inline.js +49 -0
  423. package/dist/esm/Input/Input.js +116 -0
  424. package/dist/esm/Input/InputBox.js +339 -0
  425. package/dist/esm/Input/InputContext.js +3 -0
  426. package/dist/esm/Input/InputField.js +281 -0
  427. package/dist/esm/Input/InputLabel.js +79 -0
  428. package/dist/esm/Input/index.js +10 -0
  429. package/dist/esm/Input/utils.js +5 -0
  430. package/dist/esm/ItemList/ItemList.js +272 -0
  431. package/dist/esm/ItemList/ItemListContext.js +3 -0
  432. package/dist/esm/ItemList/ItemListController.js +56 -0
  433. package/dist/esm/ItemList/ItemListItem.js +91 -0
  434. package/dist/esm/ItemList/index.js +4 -0
  435. package/dist/esm/ItemList/utils.js +55 -0
  436. package/dist/esm/Link/Inline.js +40 -0
  437. package/dist/esm/Link/Link.js +66 -0
  438. package/dist/esm/Link/index.js +4 -0
  439. package/dist/esm/LinkList/LinkList.js +31 -0
  440. package/dist/esm/LinkList/index.js +2 -0
  441. package/dist/esm/List/List.js +51 -0
  442. package/dist/esm/List/ListItem.js +39 -0
  443. package/dist/esm/List/index.js +2 -0
  444. package/dist/esm/Logo/Logo.js +51 -0
  445. package/dist/esm/Logo/index.js +2 -0
  446. package/dist/esm/Menu/Heading.js +16 -0
  447. package/dist/esm/Menu/Item.js +77 -0
  448. package/dist/esm/Menu/Menu.js +18 -0
  449. package/dist/esm/Menu/index.js +2 -0
  450. package/dist/esm/Modal/Modal.js +50 -0
  451. package/dist/esm/Modal/index.js +2 -0
  452. package/dist/esm/NumberField/NumberField.js +241 -0
  453. package/dist/esm/NumberField/NumberField.test.js +190 -0
  454. package/dist/esm/NumberField/index.js +2 -0
  455. package/dist/esm/Page/PageActions.js +12 -0
  456. package/dist/esm/Page/PageBody.js +43 -0
  457. package/dist/esm/Page/PageButton.js +13 -0
  458. package/dist/esm/Page/PageDropdown.js +14 -0
  459. package/dist/esm/Page/PageHeader.js +34 -0
  460. package/dist/esm/Page/PageTab.js +11 -0
  461. package/dist/esm/Page/PageTabList.js +14 -0
  462. package/dist/esm/Page/PageTitle.js +14 -0
  463. package/dist/esm/Page/PageToolbar.js +14 -0
  464. package/dist/esm/Page/index.js +10 -0
  465. package/dist/esm/PagerView/PagerView.js +209 -0
  466. package/dist/esm/PagerView/index.js +2 -0
  467. package/dist/esm/Pagination/Pagination.js +131 -0
  468. package/dist/esm/Pagination/index.js +2 -0
  469. package/dist/esm/Popover/Popover.js +197 -0
  470. package/dist/esm/Popover/index.js +2 -0
  471. package/dist/esm/Popover/rewireTabOrder.js +122 -0
  472. package/dist/esm/Popover/utils.js +62 -0
  473. package/dist/esm/Portal/Portal.js +158 -0
  474. package/dist/esm/Portal/index.js +2 -0
  475. package/dist/esm/Progress/Progress.js +35 -0
  476. package/dist/esm/Progress/index.js +2 -0
  477. package/dist/esm/Radio/Radio.js +139 -0
  478. package/dist/esm/Radio/index.js +2 -0
  479. package/dist/esm/RangeSlider/RangeSlider.js +210 -0
  480. package/dist/esm/RangeSlider/index.js +2 -0
  481. package/dist/esm/ScreenReader/ScreenReader.js +28 -0
  482. package/dist/esm/ScreenReader/index.js +2 -0
  483. package/dist/esm/Scrim/Scrim.js +24 -0
  484. package/dist/esm/Scrim/index.js +2 -0
  485. package/dist/esm/Section/Section.js +36 -0
  486. package/dist/esm/Section/index.js +2 -0
  487. package/dist/esm/SegmentedControl/SegmentedControl.js +129 -0
  488. package/dist/esm/SegmentedControl/index.js +2 -0
  489. package/dist/esm/SegmentedTabs/SegmentedTabs.js +137 -0
  490. package/dist/esm/SegmentedTabs/index.js +2 -0
  491. package/dist/esm/Select/Context.js +3 -0
  492. package/dist/esm/Select/Inline.js +41 -0
  493. package/dist/esm/Select/Option.js +88 -0
  494. package/dist/esm/Select/OptionGroup.js +24 -0
  495. package/dist/esm/Select/Select.js +535 -0
  496. package/dist/esm/Select/Value.js +17 -0
  497. package/dist/esm/Select/constants.js +3 -0
  498. package/dist/esm/Select/index.js +12 -0
  499. package/dist/esm/Select/utils.js +106 -0
  500. package/dist/esm/Sidebar/Sidebar.js +39 -0
  501. package/dist/esm/Sidebar/SidebarItem.js +44 -0
  502. package/dist/esm/Sidebar/SidebarList.js +17 -0
  503. package/dist/esm/Sidebar/index.js +2 -0
  504. package/dist/esm/Sortable/SortableEmpty.js +31 -0
  505. package/dist/esm/Sortable/SortableItem.js +43 -0
  506. package/dist/esm/Sortable/SortableList.js +85 -0
  507. package/dist/esm/Sortable/SortableManager.js +19 -0
  508. package/dist/esm/Sortable/constants.js +1 -0
  509. package/dist/esm/Sortable/index.js +47 -0
  510. package/dist/esm/Spinner/Spinner.js +65 -0
  511. package/dist/esm/Spinner/index.js +2 -0
  512. package/dist/esm/StackView/StackView.js +91 -0
  513. package/dist/esm/StackView/index.js +2 -0
  514. package/dist/esm/StepperField/StepperField.js +64 -0
  515. package/dist/esm/StepperField/index.js +2 -0
  516. package/dist/esm/StepperProgress/Context.js +3 -0
  517. package/dist/esm/StepperProgress/Step.js +74 -0
  518. package/dist/esm/StepperProgress/StepperProgress.js +31 -0
  519. package/dist/esm/StepperProgress/index.js +4 -0
  520. package/dist/esm/Summary/Summary.js +29 -0
  521. package/dist/esm/Summary/index.js +2 -0
  522. package/dist/esm/Tab/Tab.js +66 -0
  523. package/dist/esm/Tab/index.js +2 -0
  524. package/dist/esm/Table/AnimateScroll.js +83 -0
  525. package/dist/esm/Table/AvatarCell.js +31 -0
  526. package/dist/esm/Table/Body.js +23 -0
  527. package/dist/esm/Table/BodyCell.js +14 -0
  528. package/dist/esm/Table/BodyInnerCell.js +23 -0
  529. package/dist/esm/Table/BodyRow.js +56 -0
  530. package/dist/esm/Table/CheckboxCell.js +29 -0
  531. package/dist/esm/Table/ColumnPicker.js +61 -0
  532. package/dist/esm/Table/DateCell.js +11 -0
  533. package/dist/esm/Table/DragCell.js +37 -0
  534. package/dist/esm/Table/DragHandle.js +15 -0
  535. package/dist/esm/Table/Header.js +34 -0
  536. package/dist/esm/Table/HeaderCell.js +16 -0
  537. package/dist/esm/Table/HeaderInnerCell.js +20 -0
  538. package/dist/esm/Table/HeaderRow.js +14 -0
  539. package/dist/esm/Table/NavigationArrow.js +66 -0
  540. package/dist/esm/Table/ScrollShadow.js +37 -0
  541. package/dist/esm/Table/SubRowToggleCell.js +36 -0
  542. package/dist/esm/Table/Table.js +679 -0
  543. package/dist/esm/Table/TableBase.js +162 -0
  544. package/dist/esm/Table/TableContainer.js +15 -0
  545. package/dist/esm/Table/TableWrapper.js +12 -0
  546. package/dist/esm/Table/index.js +2 -0
  547. package/dist/esm/Tabs/Tab.js +47 -0
  548. package/dist/esm/Tabs/TabList.js +78 -0
  549. package/dist/esm/Tabs/TabPanel.js +18 -0
  550. package/dist/esm/Tabs/TabPanels.js +35 -0
  551. package/dist/esm/Tabs/Tabs.js +133 -0
  552. package/dist/esm/Tabs/index.js +2 -0
  553. package/dist/esm/Text/Text.js +87 -0
  554. package/dist/esm/Text/index.js +2 -0
  555. package/dist/esm/TextArea/TextArea.js +14 -0
  556. package/dist/esm/TextArea/index.js +2 -0
  557. package/dist/esm/ThemeProvider/ThemeProvider.js +96 -0
  558. package/dist/esm/ThemeProvider/index.js +2 -0
  559. package/dist/esm/ThemeProvider/styles.js +29 -0
  560. package/dist/esm/TileView/TileView.js +54 -0
  561. package/dist/esm/TileView/index.js +2 -0
  562. package/dist/esm/TimeField/TimeField.js +237 -0
  563. package/dist/esm/TimeField/TimeField.test.js +241 -0
  564. package/dist/esm/TimeField/index.js +2 -0
  565. package/dist/esm/TimeField/utils.js +40 -0
  566. package/dist/esm/TokenInput/DefaultToken.js +31 -0
  567. package/dist/esm/TokenInput/TokenInput.js +251 -0
  568. package/dist/esm/TokenInput/default-renders.js +42 -0
  569. package/dist/esm/TokenInput/index.js +2 -0
  570. package/dist/esm/Toolbar/Action.js +17 -0
  571. package/dist/esm/Toolbar/Toolbar.js +98 -0
  572. package/dist/esm/Toolbar/index.js +2 -0
  573. package/dist/esm/Tooltip/Tooltip.js +230 -0
  574. package/dist/esm/Tooltip/index.js +2 -0
  575. package/dist/esm/VariantProvider/VariantProvider.js +18 -0
  576. package/dist/esm/VariantProvider/index.js +1 -0
  577. package/dist/esm/Wizard/Step.js +23 -0
  578. package/dist/esm/Wizard/Wizard.js +226 -0
  579. package/dist/esm/Wizard/WizardContext.js +3 -0
  580. package/dist/esm/Wizard/index.js +2 -0
  581. package/dist/esm/WrapView/WrapView.js +52 -0
  582. package/dist/esm/WrapView/index.js +2 -0
  583. package/dist/esm/hooks/index.js +7 -0
  584. package/dist/esm/hooks/use-accessibility-violation.js +69 -0
  585. package/dist/esm/hooks/use-document-event.js +33 -0
  586. package/dist/esm/hooks/use-focus.js +24 -0
  587. package/dist/esm/hooks/use-hover.js +18 -0
  588. package/dist/esm/hooks/use-id.js +20 -0
  589. package/dist/esm/hooks/use-keyboard-shortcuts.js +29 -0
  590. package/dist/esm/hooks/use-measure.js +113 -0
  591. package/dist/esm/hooks/use-roving-index.js +53 -0
  592. package/dist/esm/icons.js +121 -0
  593. package/dist/esm/index.d.js +78 -0
  594. package/dist/esm/index.js +86 -0
  595. package/dist/esm/server.js +13 -0
  596. package/dist/esm/system/box-sizes.js +54 -0
  597. package/dist/esm/system/button-themes.js +281 -0
  598. package/dist/esm/system/colors/colors.js +97 -0
  599. package/dist/esm/system/colors/index.js +2 -0
  600. package/dist/esm/system/colors/utils.js +183 -0
  601. package/dist/esm/system/css.js +6 -0
  602. package/dist/esm/system/cxs.js +101 -0
  603. package/dist/esm/system/default-theme.js +60 -0
  604. package/dist/esm/system/index.js +17 -0
  605. package/dist/esm/system/parse-styles.js +47 -0
  606. package/dist/esm/system/plugins/border.js +85 -0
  607. package/dist/esm/system/plugins/color.js +38 -0
  608. package/dist/esm/system/plugins/elevation.js +14 -0
  609. package/dist/esm/system/plugins/flex.js +75 -0
  610. package/dist/esm/system/plugins/grid.js +44 -0
  611. package/dist/esm/system/plugins/index.js +13 -0
  612. package/dist/esm/system/plugins/misc.js +25 -0
  613. package/dist/esm/system/plugins/position.js +40 -0
  614. package/dist/esm/system/plugins/size.js +31 -0
  615. package/dist/esm/system/plugins/space.js +103 -0
  616. package/dist/esm/system/plugins/stroke.js +38 -0
  617. package/dist/esm/system/plugins/transform.js +39 -0
  618. package/dist/esm/system/plugins/typography.js +15 -0
  619. package/dist/esm/system/split-styles.js +110 -0
  620. package/dist/esm/system/style-names.js +5 -0
  621. package/dist/esm/system/use-css.js +10 -0
  622. package/dist/esm/system/utils.js +144 -0
  623. package/dist/esm/utils.js +824 -0
  624. package/dist/esm/vendor/react-measure/Measure.js +156 -0
  625. package/dist/esm/vendor/react-measure/Viewport.js +169 -0
  626. package/dist/esm/vendor/react-measure/index.js +2 -0
  627. package/dist/esm/vendor/react-measure/utils.js +68 -0
  628. package/dist/types/ActionsDropdown/ActionsDropdown.d.ts +35 -0
  629. package/dist/types/ActionsDropdown/index.d.ts +2 -0
  630. package/dist/types/Alert/Alert.d.ts +10 -0
  631. package/dist/types/Alert/Alert.test.d.ts +1 -0
  632. package/dist/types/Alert/index.d.ts +2 -0
  633. package/dist/types/Box/Box.d.ts +26 -0
  634. package/dist/types/Box/index.d.ts +2 -0
  635. package/dist/types/Button/Button.d.ts +108 -0
  636. package/dist/types/Button/Button.test.d.ts +1 -0
  637. package/dist/types/Button/Input.d.ts +30 -0
  638. package/dist/types/Button/index.d.ts +2 -0
  639. package/dist/types/Card/Card.d.ts +12 -0
  640. package/dist/types/Card/index.d.ts +2 -0
  641. package/dist/types/ChurchCenterStatus/ChurchCenterStatus.d.ts +45 -0
  642. package/dist/types/ChurchCenterStatus/index.d.ts +2 -0
  643. package/dist/types/Divider/Divider.d.ts +24 -0
  644. package/dist/types/Divider/index.d.ts +2 -0
  645. package/dist/types/Dropdown/Dropdown.test.d.ts +1 -0
  646. package/dist/types/FilterLayout/FilterLayout.d.ts +14 -0
  647. package/dist/types/FilterLayout/index.d.ts +2 -0
  648. package/dist/types/GridView/GridView.d.ts +26 -0
  649. package/dist/types/GridView/index.d.ts +2 -0
  650. package/dist/types/Group/Group.d.ts +20 -0
  651. package/dist/types/Group/index.d.ts +2 -0
  652. package/dist/types/NumberField/NumberField.test.d.ts +1 -0
  653. package/dist/types/Popover/Popover.d.ts +115 -0
  654. package/dist/types/Popover/index.d.ts +2 -0
  655. package/dist/types/Popover/rewireTabOrder.d.ts +2 -0
  656. package/dist/types/Popover/utils.d.ts +49 -0
  657. package/dist/types/Portal/Portal.d.ts +34 -0
  658. package/dist/types/Portal/index.d.ts +2 -0
  659. package/dist/types/Scrim/Scrim.d.ts +3 -0
  660. package/dist/types/Scrim/index.d.ts +2 -0
  661. package/dist/types/Spinner/Spinner.d.ts +24 -0
  662. package/dist/types/Spinner/index.d.ts +2 -0
  663. package/dist/types/StackView/StackView.d.ts +28 -0
  664. package/dist/types/StackView/index.d.ts +2 -0
  665. package/dist/types/Tab/Tab.d.ts +16 -0
  666. package/dist/types/Tab/index.d.ts +2 -0
  667. package/dist/types/Text/Text.d.ts +44 -0
  668. package/dist/types/Text/index.d.ts +2 -0
  669. package/dist/types/ThemeProvider/ThemeProvider.d.ts +24 -0
  670. package/dist/types/ThemeProvider/index.d.ts +2 -0
  671. package/dist/types/ThemeProvider/styles.d.ts +3 -0
  672. package/dist/types/TileView/TileView.d.ts +13 -0
  673. package/dist/types/TileView/index.d.ts +2 -0
  674. package/dist/types/TimeField/TimeField.test.d.ts +1 -0
  675. package/dist/types/WrapView/WrapView.d.ts +9 -0
  676. package/dist/types/WrapView/index.d.ts +2 -0
  677. package/dist/types/hooks/use-accessibility-violation.d.ts +34 -0
  678. package/dist/types/index.d.ts +340 -0
  679. package/dist/types/system/default-theme.d.ts +3 -0
  680. package/dist/types/system/style-names.d.ts +8 -0
  681. package/package.json +122 -0
  682. package/src/ActionsDropdown/ActionsDropdown.mdx +69 -0
  683. package/src/ActionsDropdown/ActionsDropdown.tsx +179 -0
  684. package/src/ActionsDropdown/index.ts +2 -0
  685. package/src/Alert/Alert.mdx +14 -0
  686. package/src/Alert/Alert.test.tsx +9 -0
  687. package/src/Alert/Alert.tsx +36 -0
  688. package/src/Alert/index.ts +2 -0
  689. package/src/Avatar/Avatar.js +53 -0
  690. package/src/Avatar/Avatar.mdx +95 -0
  691. package/src/Avatar/index.js +2 -0
  692. package/src/Badge/Badge.js +155 -0
  693. package/src/Badge/Badge.mdx +60 -0
  694. package/src/Badge/Status.js +101 -0
  695. package/src/Badge/Status.mdx +32 -0
  696. package/src/Badge/index.js +4 -0
  697. package/src/Box/Box.mdx +14 -0
  698. package/src/Box/Box.tsx +56 -0
  699. package/src/Box/index.ts +2 -0
  700. package/src/Button/Button.mdx +130 -0
  701. package/src/Button/Button.test.tsx +33 -0
  702. package/src/Button/Button.tsx +340 -0
  703. package/src/Button/Input.mdx +169 -0
  704. package/src/Button/Input.tsx +192 -0
  705. package/src/Button/index.ts +2 -0
  706. package/src/Calendar/Calendar.js +463 -0
  707. package/src/Calendar/Calendar.mdx +127 -0
  708. package/src/Calendar/Day.js +108 -0
  709. package/src/Calendar/index.js +2 -0
  710. package/src/Calendar/utils.js +115 -0
  711. package/src/Card/Card.mdx +63 -0
  712. package/src/Card/Card.tsx +63 -0
  713. package/src/Card/index.ts +2 -0
  714. package/src/Checkbox/Checkbox.js +258 -0
  715. package/src/Checkbox/Checkbox.mdx +40 -0
  716. package/src/Checkbox/index.js +2 -0
  717. package/src/CheckboxCard/CheckboxCard.js +52 -0
  718. package/src/CheckboxCard/CheckboxCard.mdx +27 -0
  719. package/src/CheckboxCard/index.js +2 -0
  720. package/src/CheckboxGroup/CheckboxGroup.js +56 -0
  721. package/src/CheckboxGroup/CheckboxGroup.mdx +27 -0
  722. package/src/CheckboxGroup/CheckboxGroupContext.js +3 -0
  723. package/src/CheckboxGroup/index.js +2 -0
  724. package/src/ChurchCenterStatus/ChurchCenterStatus.mdx +105 -0
  725. package/src/ChurchCenterStatus/ChurchCenterStatus.tsx +168 -0
  726. package/src/ChurchCenterStatus/index.tsx +2 -0
  727. package/src/Collapse/Collapse.js +118 -0
  728. package/src/Collapse/Collapse.mdx +26 -0
  729. package/src/Collapse/index.js +2 -0
  730. package/src/ColumnView/ColumnView.js +61 -0
  731. package/src/ColumnView/ColumnView.mdx +39 -0
  732. package/src/ColumnView/index.js +2 -0
  733. package/src/Combobox/Combobox.js +39 -0
  734. package/src/Combobox/Combobox.mdx +177 -0
  735. package/src/Combobox/Combobox.test.js +90 -0
  736. package/src/Combobox/ComboboxInput.js +136 -0
  737. package/src/Combobox/ComboboxItem.js +33 -0
  738. package/src/Combobox/ComboboxItems.js +121 -0
  739. package/src/Combobox/ComboboxPopover.js +232 -0
  740. package/src/Combobox/index.js +2 -0
  741. package/src/DataTable/DataTable.js +523 -0
  742. package/src/DataTable/DataTable.mdx +513 -0
  743. package/src/DataTable/DataTable.test.js +95 -0
  744. package/src/DataTable/components/BodyRow.js +37 -0
  745. package/src/DataTable/components/BodyRows.js +122 -0
  746. package/src/DataTable/components/BodySubRows.js +99 -0
  747. package/src/DataTable/components/CheckboxCell.js +111 -0
  748. package/src/DataTable/components/ColumnPicker.js +51 -0
  749. package/src/DataTable/components/HeaderCell.js +83 -0
  750. package/src/DataTable/components/Icon.js +51 -0
  751. package/src/DataTable/components/index.js +4 -0
  752. package/src/DataTable/hooks/index.js +6 -0
  753. package/src/DataTable/hooks/useCollapsibleRows.js +97 -0
  754. package/src/DataTable/hooks/useColumnSort.js +62 -0
  755. package/src/DataTable/hooks/useColumnWidths.js +86 -0
  756. package/src/DataTable/hooks/useHoverFocus.js +16 -0
  757. package/src/DataTable/hooks/useRefManager.js +21 -0
  758. package/src/DataTable/hooks/useScrollShadows.js +82 -0
  759. package/src/DataTable/hooks/useScrollSync.js +55 -0
  760. package/src/DataTable/hooks/useVariants.js +13 -0
  761. package/src/DataTable/index.js +15 -0
  762. package/src/DataTable/utils/getCell.js +9 -0
  763. package/src/DataTable/utils/getParsedColumns.js +142 -0
  764. package/src/DataTable/utils/getRowLinkProps.js +5 -0
  765. package/src/DataTable/utils/index.js +4 -0
  766. package/src/DataTable/utils/variants.js +146 -0
  767. package/src/DateField/DateField.js +172 -0
  768. package/src/DateField/DateField.mdx +17 -0
  769. package/src/DateField/index.js +2 -0
  770. package/src/Divider/Divider.mdx +42 -0
  771. package/src/Divider/Divider.tsx +51 -0
  772. package/src/Divider/index.ts +2 -0
  773. package/src/DragDrop/DragDrop.js +211 -0
  774. package/src/DragDrop/DragDrop.mdx +204 -0
  775. package/src/DragDrop/index.js +2 -0
  776. package/src/Drawer/Drawer.js +93 -0
  777. package/src/Drawer/Drawer.mdx +49 -0
  778. package/src/Drawer/index.js +2 -0
  779. package/src/Dropdown/Dropdown.js +262 -0
  780. package/src/Dropdown/Dropdown.mdx +201 -0
  781. package/src/Dropdown/Dropdown.test.tsx +22 -0
  782. package/src/Dropdown/Item.js +39 -0
  783. package/src/Dropdown/Link.js +43 -0
  784. package/src/Dropdown/index.js +2 -0
  785. package/src/EditActions/EditActions.js +61 -0
  786. package/src/EditActions/EditActions.mdx +143 -0
  787. package/src/EditActions/index.js +2 -0
  788. package/src/Field/Field.js +141 -0
  789. package/src/Field/Field.mdx +37 -0
  790. package/src/Field/index.js +2 -0
  791. package/src/FieldSet/FieldSet.js +57 -0
  792. package/src/FieldSet/FieldSet.mdx +24 -0
  793. package/src/FieldSet/index.js +2 -0
  794. package/src/FilterLayout/FilterLayout.mdx +33 -0
  795. package/src/FilterLayout/FilterLayout.tsx +93 -0
  796. package/src/FilterLayout/index.ts +2 -0
  797. package/src/FocusGroup/FocusGroup.js +93 -0
  798. package/src/FocusGroup/index.js +2 -0
  799. package/src/Form/Form.js +189 -0
  800. package/src/Form/Form.mdx +152 -0
  801. package/src/Form/index.js +2 -0
  802. package/src/GridView/GridView.mdx +55 -0
  803. package/src/GridView/GridView.tsx +131 -0
  804. package/src/GridView/index.ts +2 -0
  805. package/src/Group/Group.mdx +78 -0
  806. package/src/Group/Group.tsx +52 -0
  807. package/src/Group/index.ts +2 -0
  808. package/src/Heading/Heading.js +27 -0
  809. package/src/Heading/Heading.mdx +17 -0
  810. package/src/Heading/index.js +2 -0
  811. package/src/HeadingUppercase/HeadingUppercase.js +26 -0
  812. package/src/HeadingUppercase/HeadingUppercase.mdx +8 -0
  813. package/src/HeadingUppercase/index.js +2 -0
  814. package/src/HelperDrawer/HelperDrawer.js +57 -0
  815. package/src/HelperDrawer/HelperDrawer.mdx +18 -0
  816. package/src/HelperDrawer/index.js +2 -0
  817. package/src/Highlight/Highlight.js +63 -0
  818. package/src/Highlight/Highlight.mdx +14 -0
  819. package/src/Highlight/index.js +2 -0
  820. package/src/Highlight/utils.js +51 -0
  821. package/src/Icon/Icon.js +58 -0
  822. package/src/Icon/Icon.mdx +78 -0
  823. package/src/Icon/Path.js +20 -0
  824. package/src/Icon/Status.js +41 -0
  825. package/src/Icon/index.js +6 -0
  826. package/src/Input/Inline.js +53 -0
  827. package/src/Input/Inline.mdx +43 -0
  828. package/src/Input/Input.js +97 -0
  829. package/src/Input/Input.mdx +33 -0
  830. package/src/Input/InputBox.js +407 -0
  831. package/src/Input/InputBox.mdx +14 -0
  832. package/src/Input/InputContext.js +3 -0
  833. package/src/Input/InputField.js +308 -0
  834. package/src/Input/InputField.mdx +9 -0
  835. package/src/Input/InputLabel.js +65 -0
  836. package/src/Input/InputLabel.mdx +18 -0
  837. package/src/Input/index.js +10 -0
  838. package/src/Input/utils.js +10 -0
  839. package/src/ItemList/ItemList.js +238 -0
  840. package/src/ItemList/ItemListContext.js +3 -0
  841. package/src/ItemList/ItemListController.js +34 -0
  842. package/src/ItemList/ItemListItem.js +88 -0
  843. package/src/ItemList/index.js +5 -0
  844. package/src/ItemList/utils.js +58 -0
  845. package/src/Link/Inline.js +32 -0
  846. package/src/Link/Link.js +73 -0
  847. package/src/Link/Link.mdx +31 -0
  848. package/src/Link/index.js +4 -0
  849. package/src/LinkList/LinkList.js +25 -0
  850. package/src/LinkList/LinkList.mdx +29 -0
  851. package/src/LinkList/index.js +2 -0
  852. package/src/List/List.js +51 -0
  853. package/src/List/List.mdx +41 -0
  854. package/src/List/ListItem.js +41 -0
  855. package/src/List/index.js +2 -0
  856. package/src/Logo/Logo.js +112 -0
  857. package/src/Logo/Logo.mdx +18 -0
  858. package/src/Logo/index.js +2 -0
  859. package/src/Menu/Heading.js +13 -0
  860. package/src/Menu/Item.js +99 -0
  861. package/src/Menu/Menu.js +23 -0
  862. package/src/Menu/Menu.mdx +40 -0
  863. package/src/Menu/index.js +2 -0
  864. package/src/Modal/Modal.js +77 -0
  865. package/src/Modal/Modal.mdx +58 -0
  866. package/src/Modal/index.js +2 -0
  867. package/src/NumberField/NumberField.js +255 -0
  868. package/src/NumberField/NumberField.mdx +62 -0
  869. package/src/NumberField/NumberField.test.tsx +137 -0
  870. package/src/NumberField/index.js +2 -0
  871. package/src/Page/Page.mdx +109 -0
  872. package/src/Page/PageActions.js +9 -0
  873. package/src/Page/PageBody.js +44 -0
  874. package/src/Page/PageButton.js +11 -0
  875. package/src/Page/PageDropdown.js +11 -0
  876. package/src/Page/PageHeader.js +43 -0
  877. package/src/Page/PageTab.js +9 -0
  878. package/src/Page/PageTabList.js +13 -0
  879. package/src/Page/PageTitle.js +11 -0
  880. package/src/Page/PageToolbar.js +18 -0
  881. package/src/Page/index.js +21 -0
  882. package/src/PagerView/PagerView.js +222 -0
  883. package/src/PagerView/PagerView.mdx +199 -0
  884. package/src/PagerView/index.js +2 -0
  885. package/src/Pagination/Pagination.js +145 -0
  886. package/src/Pagination/Pagination.mdx +18 -0
  887. package/src/Pagination/index.js +2 -0
  888. package/src/Popover/Popover.mdx +65 -0
  889. package/src/Popover/Popover.tsx +262 -0
  890. package/src/Popover/index.ts +2 -0
  891. package/src/Popover/rewireTabOrder.ts +124 -0
  892. package/src/Popover/utils.ts +62 -0
  893. package/src/Portal/Portal.tsx +142 -0
  894. package/src/Portal/index.ts +2 -0
  895. package/src/Progress/Progress.js +45 -0
  896. package/src/Progress/Progress.mdx +21 -0
  897. package/src/Progress/index.js +2 -0
  898. package/src/Radio/Radio.js +186 -0
  899. package/src/Radio/Radio.mdx +37 -0
  900. package/src/Radio/index.js +2 -0
  901. package/src/RangeSlider/RangeSlider.js +244 -0
  902. package/src/RangeSlider/RangeSlider.mdx +54 -0
  903. package/src/RangeSlider/index.js +2 -0
  904. package/src/ScreenReader/ScreenReader.js +31 -0
  905. package/src/ScreenReader/ScreenReader.mdx +14 -0
  906. package/src/ScreenReader/index.js +2 -0
  907. package/src/Scrim/Scrim.mdx +30 -0
  908. package/src/Scrim/Scrim.tsx +29 -0
  909. package/src/Scrim/index.ts +2 -0
  910. package/src/Section/Section.js +43 -0
  911. package/src/Section/Section.mdx +101 -0
  912. package/src/Section/index.js +2 -0
  913. package/src/SegmentedControl/SegmentedControl.js +123 -0
  914. package/src/SegmentedControl/SegmentedControl.mdx +70 -0
  915. package/src/SegmentedControl/index.js +2 -0
  916. package/src/SegmentedTabs/SegmentedTabs.js +126 -0
  917. package/src/SegmentedTabs/SegmentedTabs.mdx +72 -0
  918. package/src/SegmentedTabs/index.js +2 -0
  919. package/src/Select/Context.js +3 -0
  920. package/src/Select/Inline.js +32 -0
  921. package/src/Select/Option.js +84 -0
  922. package/src/Select/OptionGroup.js +13 -0
  923. package/src/Select/Select.js +554 -0
  924. package/src/Select/Select.mdx +177 -0
  925. package/src/Select/Value.js +20 -0
  926. package/src/Select/constants.js +3 -0
  927. package/src/Select/index.js +12 -0
  928. package/src/Select/utils.js +108 -0
  929. package/src/Sidebar/Sidebar.js +42 -0
  930. package/src/Sidebar/Sidebar.mdx +28 -0
  931. package/src/Sidebar/SidebarItem.js +34 -0
  932. package/src/Sidebar/SidebarList.js +20 -0
  933. package/src/Sidebar/index.js +2 -0
  934. package/src/Sortable/Sortable.mdx +100 -0
  935. package/src/Sortable/SortableEmpty.js +39 -0
  936. package/src/Sortable/SortableItem.js +57 -0
  937. package/src/Sortable/SortableList.js +115 -0
  938. package/src/Sortable/SortableManager.js +20 -0
  939. package/src/Sortable/constants.js +1 -0
  940. package/src/Sortable/index.js +32 -0
  941. package/src/Spinner/Spinner.mdx +48 -0
  942. package/src/Spinner/Spinner.tsx +100 -0
  943. package/src/Spinner/index.tsx +2 -0
  944. package/src/StackView/StackView.mdx +139 -0
  945. package/src/StackView/StackView.tsx +109 -0
  946. package/src/StackView/index.ts +2 -0
  947. package/src/StepperField/StepperField.js +48 -0
  948. package/src/StepperField/StepperField.mdx +20 -0
  949. package/src/StepperField/index.js +2 -0
  950. package/src/StepperProgress/Context.js +3 -0
  951. package/src/StepperProgress/Step.js +84 -0
  952. package/src/StepperProgress/StepperProgress.js +46 -0
  953. package/src/StepperProgress/StepperProgress.mdx +59 -0
  954. package/src/StepperProgress/index.js +4 -0
  955. package/src/Summary/Summary.js +42 -0
  956. package/src/Summary/Summary.mdx +25 -0
  957. package/src/Summary/index.js +2 -0
  958. package/src/Tab/Tab.mdx +21 -0
  959. package/src/Tab/Tab.tsx +80 -0
  960. package/src/Tab/index.ts +2 -0
  961. package/src/Table/AnimateScroll.js +58 -0
  962. package/src/Table/AvatarCell.js +28 -0
  963. package/src/Table/Body.js +24 -0
  964. package/src/Table/BodyCell.js +15 -0
  965. package/src/Table/BodyInnerCell.js +26 -0
  966. package/src/Table/BodyRow.js +55 -0
  967. package/src/Table/CheckboxCell.js +25 -0
  968. package/src/Table/ColumnPicker.js +51 -0
  969. package/src/Table/DateCell.js +12 -0
  970. package/src/Table/DragCell.js +29 -0
  971. package/src/Table/DragHandle.js +9 -0
  972. package/src/Table/Header.js +26 -0
  973. package/src/Table/HeaderCell.js +17 -0
  974. package/src/Table/HeaderInnerCell.js +18 -0
  975. package/src/Table/HeaderRow.js +15 -0
  976. package/src/Table/NavigationArrow.js +75 -0
  977. package/src/Table/ScrollShadow.js +33 -0
  978. package/src/Table/SubRowToggleCell.js +38 -0
  979. package/src/Table/Table.js +971 -0
  980. package/src/Table/Table.mdx +281 -0
  981. package/src/Table/TableBase.js +166 -0
  982. package/src/Table/TableContainer.js +16 -0
  983. package/src/Table/TableWrapper.js +7 -0
  984. package/src/Table/index.js +2 -0
  985. package/src/Tabs/Tab.js +48 -0
  986. package/src/Tabs/TabList.js +73 -0
  987. package/src/Tabs/TabPanel.js +21 -0
  988. package/src/Tabs/TabPanels.js +26 -0
  989. package/src/Tabs/Tabs.js +128 -0
  990. package/src/Tabs/Tabs.mdx +49 -0
  991. package/src/Tabs/index.js +2 -0
  992. package/src/Text/Text.mdx +18 -0
  993. package/src/Text/Text.tsx +124 -0
  994. package/src/Text/index.ts +2 -0
  995. package/src/TextArea/TextArea.js +17 -0
  996. package/src/TextArea/TextArea.mdx +12 -0
  997. package/src/TextArea/index.js +2 -0
  998. package/src/ThemeProvider/ThemeProvider.tsx +99 -0
  999. package/src/ThemeProvider/index.ts +2 -0
  1000. package/src/ThemeProvider/styles.ts +64 -0
  1001. package/src/TileView/TileView.mdx +55 -0
  1002. package/src/TileView/TileView.tsx +58 -0
  1003. package/src/TileView/index.ts +2 -0
  1004. package/src/TimeField/TimeField.js +245 -0
  1005. package/src/TimeField/TimeField.mdx +94 -0
  1006. package/src/TimeField/TimeField.test.tsx +161 -0
  1007. package/src/TimeField/index.js +2 -0
  1008. package/src/TimeField/utils.js +44 -0
  1009. package/src/TokenInput/DefaultToken.js +36 -0
  1010. package/src/TokenInput/TokenInput.js +251 -0
  1011. package/src/TokenInput/TokenInput.mdx +102 -0
  1012. package/src/TokenInput/default-renders.js +47 -0
  1013. package/src/TokenInput/index.js +2 -0
  1014. package/src/Toolbar/Action.js +16 -0
  1015. package/src/Toolbar/Toolbar.js +139 -0
  1016. package/src/Toolbar/Toolbar.mdx +46 -0
  1017. package/src/Toolbar/index.js +2 -0
  1018. package/src/Tooltip/Tooltip.js +247 -0
  1019. package/src/Tooltip/Tooltip.mdx +77 -0
  1020. package/src/Tooltip/index.js +2 -0
  1021. package/src/VariantProvider/VariantProvider.js +15 -0
  1022. package/src/VariantProvider/index.js +1 -0
  1023. package/src/Wizard/Step.js +11 -0
  1024. package/src/Wizard/Wizard.js +253 -0
  1025. package/src/Wizard/Wizard.mdx +99 -0
  1026. package/src/Wizard/WizardContext.js +3 -0
  1027. package/src/Wizard/index.js +2 -0
  1028. package/src/WrapView/WrapView.mdx +72 -0
  1029. package/src/WrapView/WrapView.tsx +55 -0
  1030. package/src/WrapView/index.ts +2 -0
  1031. package/src/hooks/__tests__/use-roving-index.js +58 -0
  1032. package/src/hooks/index.js +7 -0
  1033. package/src/hooks/use-accessibility-violation.tsx +61 -0
  1034. package/src/hooks/use-document-event.js +34 -0
  1035. package/src/hooks/use-focus.js +17 -0
  1036. package/src/hooks/use-hover.js +12 -0
  1037. package/src/hooks/use-id.js +19 -0
  1038. package/src/hooks/use-keyboard-shortcuts.js +26 -0
  1039. package/src/hooks/use-measure.js +120 -0
  1040. package/src/hooks/use-roving-index.js +59 -0
  1041. package/src/icons.js +121 -0
  1042. package/src/index.d.ts +340 -0
  1043. package/src/index.js +94 -0
  1044. package/src/server.js +16 -0
  1045. package/src/system/README.md +120 -0
  1046. package/src/system/box-sizes.js +51 -0
  1047. package/src/system/button-themes.js +173 -0
  1048. package/src/system/colors/colors.js +195 -0
  1049. package/src/system/colors/index.js +8 -0
  1050. package/src/system/colors/utils.js +190 -0
  1051. package/src/system/css.js +3 -0
  1052. package/src/system/cxs.js +82 -0
  1053. package/src/system/cxs.test.js +126 -0
  1054. package/src/system/default-theme.ts +44 -0
  1055. package/src/system/index.js +36 -0
  1056. package/src/system/parse-styles.js +49 -0
  1057. package/src/system/plugins/border.js +100 -0
  1058. package/src/system/plugins/color.js +57 -0
  1059. package/src/system/plugins/elevation.js +8 -0
  1060. package/src/system/plugins/flex.js +88 -0
  1061. package/src/system/plugins/grid.js +41 -0
  1062. package/src/system/plugins/index.js +27 -0
  1063. package/src/system/plugins/misc.js +21 -0
  1064. package/src/system/plugins/position.js +49 -0
  1065. package/src/system/plugins/size.js +37 -0
  1066. package/src/system/plugins/space.js +133 -0
  1067. package/src/system/plugins/stroke.js +48 -0
  1068. package/src/system/plugins/transform.js +27 -0
  1069. package/src/system/plugins/typography.js +12 -0
  1070. package/src/system/split-styles.js +107 -0
  1071. package/src/system/style-names.ts +277 -0
  1072. package/src/system/use-css.js +12 -0
  1073. package/src/system/utils.js +138 -0
  1074. package/src/utils.js +808 -0
  1075. package/src/vendor/react-measure/Measure.js +115 -0
  1076. package/src/vendor/react-measure/Viewport.js +154 -0
  1077. package/src/vendor/react-measure/index.js +2 -0
  1078. package/src/vendor/react-measure/utils.js +89 -0
package/src/utils.js ADDED
@@ -0,0 +1,808 @@
1
+ import { Children, cloneElement } from 'react'
2
+ import { tabbable } from 'tabbable'
3
+ import camelToKebabCase from 'camel-to-kebab'
4
+
5
+ /**
6
+ * Returns true if user platform is an iOS device
7
+ * https://stackoverflow.com/a/9039885/1461204
8
+ * @return {Boolean}
9
+ */
10
+ const isIOS =
11
+ typeof window !== 'undefined'
12
+ ? !!navigator.platform && /iPad|iPhone|iPod/.test(navigator.platform)
13
+ : false
14
+
15
+ /**
16
+ * Returns true if user platform supports passive events
17
+ * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support
18
+ * @return {Boolean}
19
+ */
20
+ let supportsPassiveEvents = false
21
+ if (typeof window !== 'undefined') {
22
+ try {
23
+ const options = {
24
+ get passive() {
25
+ supportsPassiveEvents = true
26
+ return true
27
+ },
28
+ }
29
+ window.addEventListener('test', options, options)
30
+ window.removeEventListener('test', options, options)
31
+ } catch (err) {
32
+ supportsPassiveEvents = false
33
+ }
34
+ }
35
+
36
+ /**
37
+ * Used to clone and apply props to children
38
+ * @param {Function} children accepts valid React children
39
+ * @param {Function} callback return the props that should be applied to the cloned child
40
+ * @return {Function} the cloned set of children
41
+ */
42
+ function cloneChildren(children, callback) {
43
+ const childrenArray = Children.toArray(children).filter(
44
+ (child) => child === 0 || Boolean(child)
45
+ )
46
+ const childrenCount = childrenArray.length
47
+ return childrenArray.map((child, index) =>
48
+ typeof child === 'string' || typeof child === 'number'
49
+ ? child
50
+ : cloneElement(
51
+ child,
52
+ callback(child, {
53
+ index,
54
+ childrenCount,
55
+ firstChild: index === 0,
56
+ lastChild: index === Math.max(0, childrenCount - 1),
57
+ isEven: index % 2 === 0,
58
+ isOdd: Math.abs(index % 2) === 1,
59
+ })
60
+ )
61
+ )
62
+ }
63
+
64
+ /**
65
+ * This is intended to be used to compose event handlers
66
+ * @param {Function} internal the internal event handler
67
+ * @param {Function} external the external event handler
68
+ * @return {Function} the event handler to add to an element
69
+ */
70
+ function composeEvents(internal, external) {
71
+ return external
72
+ ? (event, ...args) => {
73
+ internal(event, ...args)
74
+ external(event, ...args)
75
+ }
76
+ : internal
77
+ }
78
+
79
+ /**
80
+ * Similar to composeEvents, but allows an object of events to be composed together
81
+ * @param {Function} internalEvents the internal event handlers
82
+ * @param {Function} externalEvents the external event handlers
83
+ * @return {Function} the event handler to add to an element
84
+ */
85
+ function composeMultipleEvents(internalEvents, externalEvents) {
86
+ return Object.keys(externalEvents).reduce((composedEvents, key) => {
87
+ const internal = internalEvents[key]
88
+ const external = externalEvents[key]
89
+ return {
90
+ ...composedEvents,
91
+ [key]: internal
92
+ ? (event, ...args) => {
93
+ internal(event, ...args)
94
+ external(event, ...args)
95
+ }
96
+ : external,
97
+ }
98
+ }, {})
99
+ }
100
+
101
+ /**
102
+ * Deselects any currently selected text
103
+ */
104
+ function deselectCurrentTextRange() {
105
+ window.getSelection().removeAllRanges()
106
+ }
107
+
108
+ /**
109
+ * Get the closest focusable element
110
+ * @param {HTMLElement} node - the element to start searching from
111
+ * @return {HTMLElement} the closest element that is focusable
112
+ */
113
+ function getClosestFocusableElement(node) {
114
+ if (node instanceof Element) {
115
+ if (node.getAttribute('tabindex') === '-1' || isElementInteractive(node)) {
116
+ return node
117
+ } else {
118
+ return getClosestFocusableElement(node.parentNode)
119
+ }
120
+ } else {
121
+ return document.body
122
+ }
123
+ }
124
+
125
+ /**
126
+ * Get the closest element that scrolls
127
+ * @param {HTMLElement} node - the element to start searching from
128
+ * @return {HTMLElement} the closest parentNode that scrolls
129
+ */
130
+ function getClosestViewport(node, includeHidden) {
131
+ if (node) {
132
+ const { overflow, overflowX, overflowY } = getComputedStyle(node)
133
+ const canScroll = (includeHidden
134
+ ? /(auto|scroll|hidden)/
135
+ : /(auto|scroll)/
136
+ ).test(overflow + overflowX + overflowY)
137
+ if (node === document.body || canScroll) {
138
+ return node
139
+ } else {
140
+ return getClosestViewport(node.parentNode, includeHidden)
141
+ }
142
+ } else {
143
+ return document.body
144
+ }
145
+ }
146
+
147
+ /**
148
+ * Determines which child elements are interactive according to:
149
+ * https://html.spec.whatwg.org/dev/dom.html#interactive-content
150
+ * @param parent The parent element used to determine which children are interactive
151
+ */
152
+ function getInteractiveChildElements(parent) {
153
+ const interactiveElements = []
154
+ parent.querySelectorAll('*').forEach((element) => {
155
+ if (isElementInteractive(element)) {
156
+ interactiveElements.push(element)
157
+ }
158
+ })
159
+ return interactiveElements
160
+ }
161
+
162
+ /**
163
+ * Get element's bounding client rect with an option to get cloned dimensions
164
+ */
165
+
166
+ const getRectObject = (node) => {
167
+ const bounds = node.getBoundingClientRect()
168
+ return {
169
+ width: bounds.width,
170
+ height: bounds.height,
171
+ top: bounds.top,
172
+ right: bounds.right,
173
+ bottom: bounds.bottom,
174
+ left: bounds.left,
175
+ x: bounds.x,
176
+ y: bounds.y,
177
+ }
178
+ }
179
+
180
+ function getRect(node, { clone } = {}) {
181
+ if (clone) {
182
+ const context = document.createElement('div')
183
+ const nodeClone = node.cloneNode(true)
184
+ let rect
185
+ context.appendChild(nodeClone)
186
+ document.body.appendChild(context)
187
+ rect = getRectObject(nodeClone)
188
+ document.body.removeChild(context)
189
+ return rect
190
+ } else {
191
+ return node ? getRectObject(node) : {}
192
+ }
193
+ }
194
+
195
+ /**
196
+ * Get scrollbar width
197
+ */
198
+ let scrollbarWidth
199
+ function getScrollbarWidth() {
200
+ if (scrollbarWidth === undefined) {
201
+ const div = document.createElement('div')
202
+ div.setAttribute(
203
+ 'style',
204
+ `
205
+ width: 100px;
206
+ height: 100px;
207
+ position: absolute;
208
+ opacity: 0;
209
+ overflow: scroll;
210
+ `
211
+ )
212
+ document.body.appendChild(div)
213
+ scrollbarWidth = div.offsetWidth - div.clientWidth
214
+ document.body.removeChild(div)
215
+ }
216
+ return scrollbarWidth
217
+ }
218
+
219
+ /**
220
+ * Returns { previous, next } tabbable siblings
221
+ */
222
+ function getTabbableSiblings(node, _startNode) {
223
+ const tabbables = tabbable(node.parentNode)
224
+ const startNode = _startNode || node
225
+ const startIndex = tabbables.indexOf(startNode)
226
+ const previousTabbable = tabbables[startIndex - 1]
227
+ const nextTabbable = tabbables[startIndex + 1]
228
+ if (node !== document.body && (!previousTabbable || !nextTabbable)) {
229
+ return getTabbableSiblings(node.parentNode, startNode)
230
+ }
231
+ return {
232
+ previous: previousTabbable,
233
+ next: nextTabbable,
234
+ }
235
+ }
236
+
237
+ /**
238
+ * Generates a simple unique ID
239
+ * @return {String} the unique ID
240
+ */
241
+ let idCounter = 1
242
+ function generateId(prefix) {
243
+ return `${prefix}-${idCounter++}`
244
+ }
245
+
246
+ /**
247
+ * Get the width for a single line of text
248
+ * @param {String} text - the string of text to be measured
249
+ * @param {Object|HTMLElement} font - optional font styles or node to pull font styles from
250
+ * @return {Number} the width of the text passed in
251
+ */
252
+ const expando = 'text-width' + new Date().getTime()
253
+ const canvas =
254
+ typeof document === 'undefined' ? null : document.createElement('canvas')
255
+ const context = canvas && canvas.getContext('2d')
256
+ const fontDefaults = {
257
+ fontStyle: 'normal',
258
+ fontVariant: 'normal',
259
+ fontWeight: 'normal',
260
+ fontSize: 'medium',
261
+ fontFamily: 'sans-serif',
262
+ }
263
+
264
+ function getTextWidth(text, font) {
265
+ if (!context) {
266
+ return -1
267
+ }
268
+ if (font instanceof HTMLElement) {
269
+ font = font[expando] || (font[expando] = getComputedStyle(font))
270
+ } else {
271
+ font = { ...fontDefaults, ...font }
272
+ }
273
+ context.font = [
274
+ font.fontStyle,
275
+ font.fontVariant,
276
+ font.fontWeight,
277
+ font.fontSize,
278
+ font.fontFamily,
279
+ ].join(' ')
280
+ return context.measureText(text).width
281
+ }
282
+
283
+ /**
284
+ * Inserts an item in a list at a specific index returning a new array
285
+ */
286
+ function insertAtIndex({ list, index, value }) {
287
+ const nextList = [...list]
288
+ nextList.splice(index, 0, value)
289
+ return nextList
290
+ }
291
+
292
+ /**
293
+ * Determines if a given element is interactive according to:
294
+ * https://html.spec.whatwg.org/dev/dom.html#interactive-content
295
+ * @param element Element that may be interactive (focusable)
296
+ */
297
+ function isTypeOfElementNativelyFocusable(element) {
298
+ const nodeName = element.nodeName.toLowerCase()
299
+ const validInput = nodeName === 'input' && element.type !== 'hidden'
300
+ const validAnchor = nodeName === 'a' && element.hasAttribute('href')
301
+ const validAudioVideo =
302
+ ['audio', 'video'].includes(nodeName) && element.hasAttribute('controls')
303
+ const validImgObject =
304
+ ['img', 'object'].includes(nodeName) && element.hasAttribute('usemap')
305
+ const validNativelyFocusable = [
306
+ 'button',
307
+ 'details',
308
+ 'embed',
309
+ 'iframe',
310
+ 'label',
311
+ 'select',
312
+ 'textarea',
313
+ ].includes(nodeName)
314
+ return (
315
+ validInput ||
316
+ validAnchor ||
317
+ validAudioVideo ||
318
+ validImgObject ||
319
+ validNativelyFocusable
320
+ )
321
+ }
322
+
323
+ function isElementInteractive(element) {
324
+ const hidden =
325
+ element.style.display === 'none' || element.style.visibility === 'hidden'
326
+ const disabled =
327
+ element.hasAttribute('disabled') &&
328
+ element.getAttribute('disabled') !== 'false'
329
+ // If the element is not visible or interactive, fail fast
330
+ if (hidden || disabled) {
331
+ return false
332
+ }
333
+ const hasTabIndex = element.hasAttribute('tabindex')
334
+ const tabIndexNonNegative = Number(element.getAttribute('tabindex')) >= 0
335
+ const tabbableElement = hasTabIndex && tabIndexNonNegative
336
+ const tabbableNativeElement =
337
+ isTypeOfElementNativelyFocusable(element) &&
338
+ (!hasTabIndex || tabIndexNonNegative)
339
+ return tabbableElement || tabbableNativeElement
340
+ }
341
+
342
+ /**
343
+ * Determines if value is an array or not
344
+ */
345
+ function isArray(value) {
346
+ return value && value.constructor === Array
347
+ }
348
+
349
+ /**
350
+ * Determines if value is a function or not
351
+ */
352
+ function isFunction(value) {
353
+ return value && value.constructor === Function
354
+ }
355
+
356
+ /**
357
+ * Determines if a value is present in an array by
358
+ * performing a shallow equal check on each item.
359
+ */
360
+ function isValueInArray(collection, value) {
361
+ let index = -1
362
+ collection.some((v, i) => (shallowEqual(v, value) ? (index = i) : false))
363
+ return index
364
+ }
365
+
366
+ /**
367
+ * Joins React children using a separator.
368
+ */
369
+ function joinChildren(children, separator = ', ') {
370
+ const childrenArray = Children.toArray(children)
371
+ const lastChildIndex = childrenArray.length - 1
372
+ return childrenArray.reduce((result, child, index) => {
373
+ if (child.type === separator.type) {
374
+ const nextResult = [...result]
375
+ nextResult.pop()
376
+ return nextResult.concat(child)
377
+ } else if (index < lastChildIndex) {
378
+ return result.concat([
379
+ child,
380
+ typeof separator === 'string'
381
+ ? separator
382
+ : cloneElement(separator, { key: index + '-separator' }),
383
+ ])
384
+ } else {
385
+ return result.concat(child)
386
+ }
387
+ }, [])
388
+ }
389
+
390
+ /**
391
+ * Lock all scrollbars by disabling mousewheel and locking scrollbars in position
392
+ * Optionally provide an element to allow it to scroll when hovered
393
+ */
394
+ const listenerOptions = supportsPassiveEvents
395
+ ? { capture: true, passive: false }
396
+ : true
397
+ let lockedScrolls = []
398
+
399
+ function lockScroll(node) {
400
+ const scrollCoords = new WeakMap()
401
+ const preventDefault = (event) => event.preventDefault()
402
+ const mouseOver = () =>
403
+ window.removeEventListener('wheel', preventDefault, listenerOptions)
404
+ const mouseOut = () =>
405
+ window.addEventListener('wheel', preventDefault, listenerOptions)
406
+ const mouseDown = (event) => {
407
+ if (event.target !== node) {
408
+ scrollCoords.set(event.target, {
409
+ x: event.target.scrollLeft,
410
+ y: event.target.scrollTop,
411
+ })
412
+ }
413
+ }
414
+ const wheelLock = (event) => {
415
+ const scrollableDistance = node.scrollHeight - node.offsetHeight
416
+ if (
417
+ (event.deltaY > 0 && node.scrollTop >= scrollableDistance) ||
418
+ (event.deltaY < 0 && node.scrollTop <= 0)
419
+ ) {
420
+ event.preventDefault()
421
+ }
422
+ }
423
+ const scrollLock = (event) => {
424
+ const scrollElement =
425
+ event.target === document ? document.documentElement : event.target
426
+ const scrollElementCoords = scrollCoords.get(scrollElement)
427
+ if (scrollElementCoords) {
428
+ scrollElement.scrollLeft = scrollElementCoords.x
429
+ scrollElement.scrollTop = scrollElementCoords.y
430
+ }
431
+ }
432
+ const addListeners = () => {
433
+ if (node) {
434
+ node.addEventListener('mouseover', mouseOver, true)
435
+ node.addEventListener('mouseout', mouseOut, true)
436
+ mouseOut()
437
+ }
438
+ window.addEventListener('mousedown', mouseDown, true)
439
+ window.addEventListener('wheel', wheelLock, listenerOptions)
440
+ window.addEventListener('scroll', scrollLock, true)
441
+ }
442
+ const removeListeners = () => {
443
+ if (node) {
444
+ node.removeEventListener('mouseover', mouseOver, true)
445
+ node.removeEventListener('mouseout', mouseOut, true)
446
+ mouseOver()
447
+ }
448
+ window.removeEventListener('mousedown', mouseDown, true)
449
+ window.removeEventListener('wheel', wheelLock, listenerOptions)
450
+ window.removeEventListener('scroll', scrollLock, true)
451
+ }
452
+ if (lockedScrolls.length > 0) {
453
+ // check if we need to remove any current scroll locks
454
+ lockedScrolls[lockedScrolls.length - 1].removeListeners()
455
+
456
+ // filter any nodes that may be gone from the DOM now
457
+ lockedScrolls = lockedScrolls.filter((lockedScroll) =>
458
+ document.body.contains(lockedScroll.node)
459
+ )
460
+ }
461
+ // store the scroll lock enable/disable methods so we can disable them when
462
+ // new ones are created or enable them when old ones are destroyed
463
+ if (document.body.contains(node)) {
464
+ lockedScrolls.push({
465
+ node,
466
+ addListeners,
467
+ removeListeners,
468
+ })
469
+ addListeners()
470
+ }
471
+ return () => {
472
+ const index = lockedScrolls.findIndex((scroll) => scroll.node === node)
473
+
474
+ if (index > -1) {
475
+ removeListeners()
476
+
477
+ // remove this scroll lock from stored scroll locks
478
+ lockedScrolls.splice(index, 1)
479
+
480
+ // again, filter any nodes that may be gone from the DOM now
481
+ lockedScrolls = lockedScrolls.filter((lockedScroll) => {
482
+ const containsLockedScrollNode = document.body.contains(
483
+ lockedScroll.node
484
+ )
485
+ // as a side effect, make sure to remove listeners from this node
486
+ if (containsLockedScrollNode === false) {
487
+ lockedScroll.removeListeners()
488
+ }
489
+ return containsLockedScrollNode
490
+ })
491
+
492
+ // enable the previous scroll lock if any are left
493
+ if (lockedScrolls.length > 0) {
494
+ lockedScrolls[lockedScrolls.length - 1].addListeners()
495
+ }
496
+ }
497
+ }
498
+ }
499
+
500
+ /**
501
+ * No op function used to stub function props
502
+ */
503
+ function noop() {
504
+ return null
505
+ }
506
+
507
+ /**
508
+ * Pad a number with 0's
509
+ */
510
+ function padNumber(number, size) {
511
+ return Array(Math.max(size - String(number).length + 1, 0)).join(0) + number
512
+ }
513
+
514
+ /**
515
+ * Listen for window visibility and focus/blur changes
516
+ */
517
+ function pageViewChange(callback) {
518
+ if (typeof window !== 'undefined') {
519
+ const handleFocus = () => callback(true)
520
+ const handleBlur = () => callback(false)
521
+ const handleVisibilityChange = () => callback(!document.hidden)
522
+ window.addEventListener('focus', handleFocus)
523
+ window.addEventListener('blur', handleBlur)
524
+ document.addEventListener('visibilitychange', handleVisibilityChange)
525
+ return () => {
526
+ window.removeEventListener('focus', handleFocus)
527
+ window.removeEventListener('blur', handleBlur)
528
+ document.removeEventListener('visibilitychange', handleVisibilityChange)
529
+ }
530
+ } else {
531
+ return () => {}
532
+ }
533
+ }
534
+
535
+ /**
536
+ * Create a range of numbers
537
+ */
538
+ function range(start, stop) {
539
+ const arr = []
540
+ for (let i = start; i < stop; i++) {
541
+ arr.push(i)
542
+ }
543
+ return arr
544
+ }
545
+
546
+ /**
547
+ * Removes an item in a list at a specific index returning a new array
548
+ */
549
+ function removeAtIndex({ list, index }) {
550
+ const nextList = [...list]
551
+ nextList.splice(index, 1)
552
+ return nextList
553
+ }
554
+
555
+ /**
556
+ * Helps with rendering a nested group of data that needs an ordered index.
557
+ */
558
+ function renderIndexedGroup({
559
+ group,
560
+ renderGroup,
561
+ renderEmpty = 'No items found',
562
+ }) {
563
+ return group.length > 0
564
+ ? group.reduce(
565
+ ({ collection, index }, data, dataIndex) => {
566
+ collection.push(renderGroup(data, () => index++))
567
+ return dataIndex === group.length - 1
568
+ ? collection
569
+ : { collection, index }
570
+ },
571
+ { collection: [], index: 0 }
572
+ )
573
+ : renderEmpty
574
+ }
575
+
576
+ /**
577
+ * Reorder a result in an array by its index
578
+ */
579
+ function reorderArray({ list, startIndex, endIndex }) {
580
+ const result = Array.from(list)
581
+ const [removed] = result.splice(startIndex, 1)
582
+ result.splice(endIndex, 0, removed)
583
+ return result
584
+ }
585
+
586
+ /**
587
+ * Shallow compare two items
588
+ */
589
+ function shallowEqual(a, b) {
590
+ return JSON.stringify(a) === JSON.stringify(b)
591
+ }
592
+
593
+ /**
594
+ * Selects the full text range including number inputs
595
+ */
596
+ function selectFullTextRange(node) {
597
+ if (node.type === 'number') {
598
+ node.select()
599
+ } else {
600
+ node.setSelectionRange(0, 9999)
601
+ }
602
+ }
603
+
604
+ /**
605
+ * Stop an event from propagating
606
+ */
607
+ function stopImmediatePropagation(e) {
608
+ e.nativeEvent.stopImmediatePropagation()
609
+ }
610
+
611
+ /**
612
+ * Adds event.stopPropagation() to a component's onClick event.
613
+ * Used to prevent element's onClick from bubbling up the tree.
614
+ */
615
+ function stopPropagationClick(onClick) {
616
+ return (event) => {
617
+ event.stopPropagation()
618
+ if (onClick) {
619
+ onClick(event)
620
+ }
621
+ }
622
+ }
623
+
624
+ /**
625
+ * Simple focus trap that only traps focus when focused on first/last elements.
626
+ * This allows focus traps to work with third-party modals.
627
+ */
628
+ const TAB_KEY = 9
629
+
630
+ function trapFocus(node) {
631
+ function handleKeyDown(event) {
632
+ const tabbables = tabbable(node)
633
+ const [firstTabbable] = tabbables
634
+ const [lastTabbable] = tabbables.reverse()
635
+ if (
636
+ event.shiftKey &&
637
+ event.target === firstTabbable &&
638
+ event.keyCode === TAB_KEY
639
+ ) {
640
+ event.preventDefault()
641
+ lastTabbable.focus()
642
+ }
643
+ if (
644
+ !event.shiftKey &&
645
+ event.target === lastTabbable &&
646
+ event.keyCode === TAB_KEY
647
+ ) {
648
+ event.preventDefault()
649
+ firstTabbable.focus()
650
+ }
651
+ }
652
+ const tabbables = tabbable(node)
653
+ let [currentTabbable] = tabbables
654
+ let currentIndex = 0
655
+
656
+ // skip over HelperDrawer toggles and move to the first interactive element
657
+ while (currentTabbable?.hasAttribute('data-helper-drawer-toggle')) {
658
+ currentTabbable = tabbables[currentIndex++]
659
+ }
660
+
661
+ let lastActiveElement = document.activeElement
662
+ if (currentTabbable) {
663
+ currentTabbable.focus()
664
+ }
665
+
666
+ node.addEventListener('keydown', handleKeyDown)
667
+
668
+ return () => {
669
+ if (lastActiveElement) {
670
+ lastActiveElement.focus()
671
+ }
672
+ node.removeEventListener('keydown', handleKeyDown)
673
+ }
674
+ }
675
+
676
+ /**
677
+ * Utilities to create and manage CSS properties
678
+ */
679
+ const createdCSSProperties = new Set()
680
+
681
+ function createCSSProperty(key, value) {
682
+ if (!createdCSSProperties.has(key)) {
683
+ createdCSSProperties.add(key)
684
+ }
685
+ return `--${camelToKebabCase(key)}-${camelToKebabCase(value)}`
686
+ }
687
+
688
+ function getCSSProperty(key, value) {
689
+ return key && value
690
+ ? `var(--${camelToKebabCase(key)}-${camelToKebabCase(value)})`
691
+ : undefined
692
+ }
693
+
694
+ function objectToCSSProperties(themeKey, props) {
695
+ const properties = {}
696
+ for (let propKey in props) {
697
+ const propValue = props[propKey]
698
+ properties[createCSSProperty(themeKey, propKey)] =
699
+ typeof propValue === 'number'
700
+ ? `${propValue}px`
701
+ : createdCSSProperties.has(propValue)
702
+ ? getCSSProperty(themeKey, propValue)
703
+ : propValue
704
+ }
705
+ return properties
706
+ }
707
+
708
+ function callRef(ref, node) {
709
+ if (ref.current === undefined) {
710
+ if (typeof ref === 'function') {
711
+ ref(node)
712
+ }
713
+ } else {
714
+ ref.current = node
715
+ }
716
+ }
717
+
718
+ function pushProp(
719
+ target,
720
+ key,
721
+ value,
722
+ mergeValue = (nextValue, currentValue) => nextValue
723
+ ) {
724
+ if (key === 'className') {
725
+ target.className = [target.className, value].join(' ').trim()
726
+ } else if (key === 'style') {
727
+ target.style = { ...target.style, ...value }
728
+ } else if (key === 'ref' || key === 'innerRef') {
729
+ const oldRef = target[key]
730
+ target[key] = oldRef
731
+ ? (node) => {
732
+ callRef(oldRef, node)
733
+ callRef(value, node)
734
+ }
735
+ : value
736
+ } else if (typeof value === 'function') {
737
+ const oldFn = target[key]
738
+ target[key] = oldFn
739
+ ? (...args) => {
740
+ oldFn(...args)
741
+ value(...args)
742
+ }
743
+ : value
744
+ } else if (!(key in target)) {
745
+ target[key] = value
746
+ } else {
747
+ target[key] = mergeValue(value, target[key])
748
+ }
749
+ }
750
+
751
+ /**
752
+ * Merges sets of props together:
753
+ * - duplicate `className` props get concatenated
754
+ * - duplicate `style` props get shallow merged (later props have precedence for conflicting rules)
755
+ * - duplicate refs or functions (to be used for event handlers) get called in order from left to right
756
+ * @param propGroup Sets of props to merge together. Later props have precedence.
757
+ */
758
+ function mergeProps(...propGroup) {
759
+ if (propGroup.length === 1) {
760
+ return propGroup[0]
761
+ }
762
+ return propGroup.reduce((mergedProps, props) => {
763
+ for (const key in props) {
764
+ pushProp(mergedProps, key, props[key])
765
+ }
766
+ return mergedProps
767
+ }, {})
768
+ }
769
+
770
+ export {
771
+ cloneChildren,
772
+ composeEvents,
773
+ composeMultipleEvents,
774
+ createCSSProperty,
775
+ deselectCurrentTextRange,
776
+ generateId,
777
+ getCSSProperty,
778
+ getClosestFocusableElement,
779
+ getClosestViewport,
780
+ getInteractiveChildElements,
781
+ getRect,
782
+ getScrollbarWidth,
783
+ getTabbableSiblings,
784
+ getTextWidth,
785
+ insertAtIndex,
786
+ isArray,
787
+ isElementInteractive,
788
+ isFunction,
789
+ isIOS,
790
+ isValueInArray,
791
+ joinChildren,
792
+ lockScroll,
793
+ mergeProps,
794
+ noop,
795
+ objectToCSSProperties,
796
+ padNumber,
797
+ pageViewChange,
798
+ range,
799
+ removeAtIndex,
800
+ renderIndexedGroup,
801
+ reorderArray,
802
+ shallowEqual,
803
+ selectFullTextRange,
804
+ stopImmediatePropagation,
805
+ stopPropagationClick,
806
+ supportsPassiveEvents,
807
+ trapFocus,
808
+ }