bootstrap-rn 0.3.5 → 0.4.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 (839) hide show
  1. package/lib/commonjs/Context.js +1 -1
  2. package/lib/commonjs/Context.js.map +1 -1
  3. package/lib/commonjs/Provider.js +8 -4
  4. package/lib/commonjs/Provider.js.map +1 -1
  5. package/lib/commonjs/components/Body.js +9 -6
  6. package/lib/commonjs/components/Body.js.map +1 -1
  7. package/lib/commonjs/components/Caret.js +5 -4
  8. package/lib/commonjs/components/Caret.js.map +1 -1
  9. package/lib/commonjs/components/Heading.js +7 -5
  10. package/lib/commonjs/components/Heading.js.map +1 -1
  11. package/lib/commonjs/components/Image.js +5 -4
  12. package/lib/commonjs/components/Image.js.map +1 -1
  13. package/lib/commonjs/components/ImageBackground.js +5 -4
  14. package/lib/commonjs/components/ImageBackground.js.map +1 -1
  15. package/lib/commonjs/components/Label.js +7 -5
  16. package/lib/commonjs/components/Label.js.map +1 -1
  17. package/lib/commonjs/components/Link.js +8 -5
  18. package/lib/commonjs/components/Link.js.map +1 -1
  19. package/lib/commonjs/components/Pressable.js +21 -11
  20. package/lib/commonjs/components/Pressable.js.map +1 -1
  21. package/lib/commonjs/components/ScrollView.js +10 -7
  22. package/lib/commonjs/components/ScrollView.js.map +1 -1
  23. package/lib/commonjs/components/Text.js +9 -7
  24. package/lib/commonjs/components/Text.js.map +1 -1
  25. package/lib/commonjs/components/TextInput.js +5 -4
  26. package/lib/commonjs/components/TextInput.js.map +1 -1
  27. package/lib/commonjs/components/View.js +10 -7
  28. package/lib/commonjs/components/View.js.map +1 -1
  29. package/lib/commonjs/components/alert/Alert.js +7 -5
  30. package/lib/commonjs/components/alert/Alert.js.map +1 -1
  31. package/lib/commonjs/components/badge/Badge.js +10 -7
  32. package/lib/commonjs/components/badge/Badge.js.map +1 -1
  33. package/lib/commonjs/components/breadcrumb/Breadcrumb.js +7 -5
  34. package/lib/commonjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  35. package/lib/commonjs/components/breadcrumb/BreadcrumbItem.js +14 -11
  36. package/lib/commonjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  37. package/lib/commonjs/components/button-group/ButtonGroup.js +10 -7
  38. package/lib/commonjs/components/button-group/ButtonGroup.js.map +1 -1
  39. package/lib/commonjs/components/button-group/ButtonGroupContext.js +1 -1
  40. package/lib/commonjs/components/button-group/ButtonGroupContext.js.map +1 -1
  41. package/lib/commonjs/components/button-group/ButtonToolbar.js +7 -5
  42. package/lib/commonjs/components/button-group/ButtonToolbar.js.map +1 -1
  43. package/lib/commonjs/components/buttons/Button.js +7 -5
  44. package/lib/commonjs/components/buttons/Button.js.map +1 -1
  45. package/lib/commonjs/components/card/Card.js +7 -5
  46. package/lib/commonjs/components/card/Card.js.map +1 -1
  47. package/lib/commonjs/components/card/CardBody.js +7 -5
  48. package/lib/commonjs/components/card/CardBody.js.map +1 -1
  49. package/lib/commonjs/components/card/CardFooter.js +7 -5
  50. package/lib/commonjs/components/card/CardFooter.js.map +1 -1
  51. package/lib/commonjs/components/card/CardHeader.js +7 -5
  52. package/lib/commonjs/components/card/CardHeader.js.map +1 -1
  53. package/lib/commonjs/components/close/CloseButton.js +8 -5
  54. package/lib/commonjs/components/close/CloseButton.js.map +1 -1
  55. package/lib/commonjs/components/collapse/Collapse.js +7 -5
  56. package/lib/commonjs/components/collapse/Collapse.js.map +1 -1
  57. package/lib/commonjs/components/collapse/CollapseProvider.js +6 -4
  58. package/lib/commonjs/components/collapse/CollapseProvider.js.map +1 -1
  59. package/lib/commonjs/components/collapse/useCollapse.js +1 -1
  60. package/lib/commonjs/components/collapse/useCollapse.js.map +1 -1
  61. package/lib/commonjs/components/collapse/useToggleCollapse.js +1 -1
  62. package/lib/commonjs/components/collapse/useToggleCollapse.js.map +1 -1
  63. package/lib/commonjs/components/containers/Container.js +5 -4
  64. package/lib/commonjs/components/containers/Container.js.map +1 -1
  65. package/lib/commonjs/components/dropdown/Dropdown.js +10 -7
  66. package/lib/commonjs/components/dropdown/Dropdown.js.map +1 -1
  67. package/lib/commonjs/components/dropdown/DropdownDivider.js +5 -4
  68. package/lib/commonjs/components/dropdown/DropdownDivider.js.map +1 -1
  69. package/lib/commonjs/components/dropdown/DropdownHeader.js +11 -8
  70. package/lib/commonjs/components/dropdown/DropdownHeader.js.map +1 -1
  71. package/lib/commonjs/components/dropdown/DropdownItem.js +7 -5
  72. package/lib/commonjs/components/dropdown/DropdownItem.js.map +1 -1
  73. package/lib/commonjs/components/dropdown/DropdownItemText.js +10 -7
  74. package/lib/commonjs/components/dropdown/DropdownItemText.js.map +1 -1
  75. package/lib/commonjs/components/dropdown/DropdownMenu.js +50 -38
  76. package/lib/commonjs/components/dropdown/DropdownMenu.js.map +1 -1
  77. package/lib/commonjs/components/dropdown/DropdownToggle.js +1 -1
  78. package/lib/commonjs/components/dropdown/DropdownToggle.js.map +1 -1
  79. package/lib/commonjs/components/dropdown/useDismissDropdown.js +1 -1
  80. package/lib/commonjs/components/dropdown/useDismissDropdown.js.map +1 -1
  81. package/lib/commonjs/components/dropdown/useDropdown.js +1 -1
  82. package/lib/commonjs/components/dropdown/useDropdown.js.map +1 -1
  83. package/lib/commonjs/components/dropdown/useToggleDropdown.js +1 -1
  84. package/lib/commonjs/components/dropdown/useToggleDropdown.js.map +1 -1
  85. package/lib/commonjs/components/forms/Checkbox.js +5 -4
  86. package/lib/commonjs/components/forms/Checkbox.js.map +1 -1
  87. package/lib/commonjs/components/forms/Feedback.js +7 -5
  88. package/lib/commonjs/components/forms/Feedback.js.map +1 -1
  89. package/lib/commonjs/components/forms/FormCheck.js +10 -7
  90. package/lib/commonjs/components/forms/FormCheck.js.map +1 -1
  91. package/lib/commonjs/components/forms/FormCheckContext.js +1 -1
  92. package/lib/commonjs/components/forms/FormCheckContext.js.map +1 -1
  93. package/lib/commonjs/components/forms/FormCheckInput.js +5 -4
  94. package/lib/commonjs/components/forms/FormCheckInput.js.map +1 -1
  95. package/lib/commonjs/components/forms/FormCheckLabel.js +7 -5
  96. package/lib/commonjs/components/forms/FormCheckLabel.js.map +1 -1
  97. package/lib/commonjs/components/forms/FormLabel.js +7 -5
  98. package/lib/commonjs/components/forms/FormLabel.js.map +1 -1
  99. package/lib/commonjs/components/forms/FormText.js +10 -7
  100. package/lib/commonjs/components/forms/FormText.js.map +1 -1
  101. package/lib/commonjs/components/forms/Input.js +5 -4
  102. package/lib/commonjs/components/forms/Input.js.map +1 -1
  103. package/lib/commonjs/components/forms/Picker.js +27 -24
  104. package/lib/commonjs/components/forms/Picker.js.map +1 -1
  105. package/lib/commonjs/components/forms/PickerContext.js +1 -1
  106. package/lib/commonjs/components/forms/PickerContext.js.map +1 -1
  107. package/lib/commonjs/components/forms/PickerItem.js +3 -2
  108. package/lib/commonjs/components/forms/PickerItem.js.map +1 -1
  109. package/lib/commonjs/components/forms/Radio.js +5 -4
  110. package/lib/commonjs/components/forms/Radio.js.map +1 -1
  111. package/lib/commonjs/components/forms/RadioContext.js +1 -1
  112. package/lib/commonjs/components/forms/RadioContext.js.map +1 -1
  113. package/lib/commonjs/components/forms/RadioGroup.js +10 -7
  114. package/lib/commonjs/components/forms/RadioGroup.js.map +1 -1
  115. package/lib/commonjs/components/forms/Switch.js +5 -4
  116. package/lib/commonjs/components/forms/Switch.js.map +1 -1
  117. package/lib/commonjs/components/forms/internals/FormCheckInputNative.js +6 -4
  118. package/lib/commonjs/components/forms/internals/FormCheckInputNative.js.map +1 -1
  119. package/lib/commonjs/components/forms/internals/FormCheckInputWeb.js +3 -2
  120. package/lib/commonjs/components/forms/internals/FormCheckInputWeb.js.map +1 -1
  121. package/lib/commonjs/components/forms/internals/PickerNative.js +47 -36
  122. package/lib/commonjs/components/forms/internals/PickerNative.js.map +1 -1
  123. package/lib/commonjs/components/forms/internals/PickerNativeContext.js +1 -1
  124. package/lib/commonjs/components/forms/internals/PickerNativeContext.js.map +1 -1
  125. package/lib/commonjs/components/forms/internals/PickerNativeItem.js +8 -5
  126. package/lib/commonjs/components/forms/internals/PickerNativeItem.js.map +1 -1
  127. package/lib/commonjs/components/forms/internals/PickerWeb.js +15 -11
  128. package/lib/commonjs/components/forms/internals/PickerWeb.js.map +1 -1
  129. package/lib/commonjs/components/forms/internals/PickerWebContext.js +1 -1
  130. package/lib/commonjs/components/forms/internals/PickerWebContext.js.map +1 -1
  131. package/lib/commonjs/components/forms/internals/PickerWebItem.js +3 -2
  132. package/lib/commonjs/components/forms/internals/PickerWebItem.js.map +1 -1
  133. package/lib/commonjs/components/grid/Col.js +7 -5
  134. package/lib/commonjs/components/grid/Col.js.map +1 -1
  135. package/lib/commonjs/components/grid/Row.js +7 -5
  136. package/lib/commonjs/components/grid/Row.js.map +1 -1
  137. package/lib/commonjs/components/helpers/BackdropHandler.js +3 -2
  138. package/lib/commonjs/components/helpers/BackdropHandler.js.map +1 -1
  139. package/lib/commonjs/components/helpers/ListContext.js +1 -1
  140. package/lib/commonjs/components/helpers/ListContext.js.map +1 -1
  141. package/lib/commonjs/components/helpers/Overlay.js +12 -3
  142. package/lib/commonjs/components/helpers/Overlay.js.map +1 -1
  143. package/lib/commonjs/components/list-group/ListGroup.js +10 -7
  144. package/lib/commonjs/components/list-group/ListGroup.js.map +1 -1
  145. package/lib/commonjs/components/list-group/ListGroupContext.js +1 -1
  146. package/lib/commonjs/components/list-group/ListGroupContext.js.map +1 -1
  147. package/lib/commonjs/components/list-group/ListGroupItem.js +7 -5
  148. package/lib/commonjs/components/list-group/ListGroupItem.js.map +1 -1
  149. package/lib/commonjs/components/list-group/ListGroupItemAction.js +7 -5
  150. package/lib/commonjs/components/list-group/ListGroupItemAction.js.map +1 -1
  151. package/lib/commonjs/components/modal/Modal.js +41 -32
  152. package/lib/commonjs/components/modal/Modal.js.map +1 -1
  153. package/lib/commonjs/components/modal/ModalBody.js +8 -6
  154. package/lib/commonjs/components/modal/ModalBody.js.map +1 -1
  155. package/lib/commonjs/components/modal/ModalContext.js +1 -1
  156. package/lib/commonjs/components/modal/ModalContext.js.map +1 -1
  157. package/lib/commonjs/components/modal/ModalFooter.js +7 -5
  158. package/lib/commonjs/components/modal/ModalFooter.js.map +1 -1
  159. package/lib/commonjs/components/modal/ModalHeader.js +7 -5
  160. package/lib/commonjs/components/modal/ModalHeader.js.map +1 -1
  161. package/lib/commonjs/components/modal/ModalTitle.js +8 -7
  162. package/lib/commonjs/components/modal/ModalTitle.js.map +1 -1
  163. package/lib/commonjs/components/modal/useModal.js +1 -1
  164. package/lib/commonjs/components/modal/useModal.js.map +1 -1
  165. package/lib/commonjs/components/nav/Nav.js +10 -7
  166. package/lib/commonjs/components/nav/Nav.js.map +1 -1
  167. package/lib/commonjs/components/nav/NavLink.js +7 -5
  168. package/lib/commonjs/components/nav/NavLink.js.map +1 -1
  169. package/lib/commonjs/components/nav/Tab.js +1 -1
  170. package/lib/commonjs/components/nav/Tab.js.map +1 -1
  171. package/lib/commonjs/components/nav/TabContent.js +5 -4
  172. package/lib/commonjs/components/nav/TabContent.js.map +1 -1
  173. package/lib/commonjs/components/nav/TabPane.js +5 -4
  174. package/lib/commonjs/components/nav/TabPane.js.map +1 -1
  175. package/lib/commonjs/components/nav/TabProvider.js +6 -4
  176. package/lib/commonjs/components/nav/TabProvider.js.map +1 -1
  177. package/lib/commonjs/components/nav/useTabbable.js +1 -1
  178. package/lib/commonjs/components/nav/useTabbable.js.map +1 -1
  179. package/lib/commonjs/components/nav/useToggleTab.js +1 -1
  180. package/lib/commonjs/components/nav/useToggleTab.js.map +1 -1
  181. package/lib/commonjs/components/navbar/Navbar.js +10 -7
  182. package/lib/commonjs/components/navbar/Navbar.js.map +1 -1
  183. package/lib/commonjs/components/navbar/NavbarBrand.js +7 -5
  184. package/lib/commonjs/components/navbar/NavbarBrand.js.map +1 -1
  185. package/lib/commonjs/components/navbar/NavbarCollapse.js +7 -5
  186. package/lib/commonjs/components/navbar/NavbarCollapse.js.map +1 -1
  187. package/lib/commonjs/components/navbar/NavbarText.js +10 -7
  188. package/lib/commonjs/components/navbar/NavbarText.js.map +1 -1
  189. package/lib/commonjs/components/navbar/NavbarToggler.js +10 -7
  190. package/lib/commonjs/components/navbar/NavbarToggler.js.map +1 -1
  191. package/lib/commonjs/components/navbar/useDismissNavbar.js +1 -1
  192. package/lib/commonjs/components/navbar/useDismissNavbar.js.map +1 -1
  193. package/lib/commonjs/components/navbar/useNavbar.js +1 -1
  194. package/lib/commonjs/components/navbar/useNavbar.js.map +1 -1
  195. package/lib/commonjs/components/navbar/useToggleNavbar.js +1 -1
  196. package/lib/commonjs/components/navbar/useToggleNavbar.js.map +1 -1
  197. package/lib/commonjs/components/offcanvas/Offcanvas.js +42 -31
  198. package/lib/commonjs/components/offcanvas/Offcanvas.js.map +1 -1
  199. package/lib/commonjs/components/offcanvas/OffcanvasBody.js +7 -5
  200. package/lib/commonjs/components/offcanvas/OffcanvasBody.js.map +1 -1
  201. package/lib/commonjs/components/offcanvas/OffcanvasContext.js +1 -1
  202. package/lib/commonjs/components/offcanvas/OffcanvasContext.js.map +1 -1
  203. package/lib/commonjs/components/offcanvas/OffcanvasHeader.js +7 -5
  204. package/lib/commonjs/components/offcanvas/OffcanvasHeader.js.map +1 -1
  205. package/lib/commonjs/components/offcanvas/OffcanvasTitle.js +8 -7
  206. package/lib/commonjs/components/offcanvas/OffcanvasTitle.js.map +1 -1
  207. package/lib/commonjs/components/offcanvas/useOffcanvas.js +1 -1
  208. package/lib/commonjs/components/offcanvas/useOffcanvas.js.map +1 -1
  209. package/lib/commonjs/components/pagination/Pagination.js +7 -5
  210. package/lib/commonjs/components/pagination/Pagination.js.map +1 -1
  211. package/lib/commonjs/components/pagination/PaginationItem.js +7 -5
  212. package/lib/commonjs/components/pagination/PaginationItem.js.map +1 -1
  213. package/lib/commonjs/components/placeholders/Placeholders.js +7 -5
  214. package/lib/commonjs/components/placeholders/Placeholders.js.map +1 -1
  215. package/lib/commonjs/components/popover/Popover.js +10 -7
  216. package/lib/commonjs/components/popover/Popover.js.map +1 -1
  217. package/lib/commonjs/components/popover/PopoverArrow.js +11 -9
  218. package/lib/commonjs/components/popover/PopoverArrow.js.map +1 -1
  219. package/lib/commonjs/components/popover/PopoverBody.js +7 -5
  220. package/lib/commonjs/components/popover/PopoverBody.js.map +1 -1
  221. package/lib/commonjs/components/popover/PopoverContext.js +1 -1
  222. package/lib/commonjs/components/popover/PopoverContext.js.map +1 -1
  223. package/lib/commonjs/components/popover/PopoverHeader.js +11 -8
  224. package/lib/commonjs/components/popover/PopoverHeader.js.map +1 -1
  225. package/lib/commonjs/components/popover/injectPopover.js +41 -25
  226. package/lib/commonjs/components/popover/injectPopover.js.map +1 -1
  227. package/lib/commonjs/components/progress/Progress.js +10 -7
  228. package/lib/commonjs/components/progress/Progress.js.map +1 -1
  229. package/lib/commonjs/components/progress/ProgressBar.js +10 -7
  230. package/lib/commonjs/components/progress/ProgressBar.js.map +1 -1
  231. package/lib/commonjs/components/progress/ProgressContext.js +1 -1
  232. package/lib/commonjs/components/progress/ProgressContext.js.map +1 -1
  233. package/lib/commonjs/components/spinners/Spinner.js +5 -4
  234. package/lib/commonjs/components/spinners/Spinner.js.map +1 -1
  235. package/lib/commonjs/components/toasts/Toast.js +7 -5
  236. package/lib/commonjs/components/toasts/Toast.js.map +1 -1
  237. package/lib/commonjs/components/toasts/ToastBody.js +7 -5
  238. package/lib/commonjs/components/toasts/ToastBody.js.map +1 -1
  239. package/lib/commonjs/components/toasts/ToastContainer.js +10 -7
  240. package/lib/commonjs/components/toasts/ToastContainer.js.map +1 -1
  241. package/lib/commonjs/components/toasts/ToastContainerContext.js +1 -1
  242. package/lib/commonjs/components/toasts/ToastContainerContext.js.map +1 -1
  243. package/lib/commonjs/components/toasts/ToastHeader.js +7 -5
  244. package/lib/commonjs/components/toasts/ToastHeader.js.map +1 -1
  245. package/lib/commonjs/components/tooltip/Tooltip.js +10 -7
  246. package/lib/commonjs/components/tooltip/Tooltip.js.map +1 -1
  247. package/lib/commonjs/components/tooltip/TooltipArrow.js +9 -7
  248. package/lib/commonjs/components/tooltip/TooltipArrow.js.map +1 -1
  249. package/lib/commonjs/components/tooltip/TooltipContext.js +1 -1
  250. package/lib/commonjs/components/tooltip/TooltipContext.js.map +1 -1
  251. package/lib/commonjs/components/tooltip/TooltipInner.js +10 -7
  252. package/lib/commonjs/components/tooltip/TooltipInner.js.map +1 -1
  253. package/lib/commonjs/components/tooltip/injectTooltip.js +38 -24
  254. package/lib/commonjs/components/tooltip/injectTooltip.js.map +1 -1
  255. package/lib/commonjs/components/type/Blockquote.js +7 -5
  256. package/lib/commonjs/components/type/Blockquote.js.map +1 -1
  257. package/lib/commonjs/components/type/Code.js +7 -5
  258. package/lib/commonjs/components/type/Code.js.map +1 -1
  259. package/lib/commonjs/components/type/DisplayHeading.js +7 -5
  260. package/lib/commonjs/components/type/DisplayHeading.js.map +1 -1
  261. package/lib/commonjs/components/type/Paragraph.js +7 -5
  262. package/lib/commonjs/components/type/Paragraph.js.map +1 -1
  263. package/lib/commonjs/hooks/useAction.js.map +1 -1
  264. package/lib/commonjs/hooks/useBackground.js.map +1 -1
  265. package/lib/commonjs/hooks/useBackground.native.js +12 -9
  266. package/lib/commonjs/hooks/useBackground.native.js.map +1 -1
  267. package/lib/commonjs/hooks/useFixedElement.js +1 -1
  268. package/lib/commonjs/hooks/useFixedElement.js.map +1 -1
  269. package/lib/commonjs/hooks/useForcedContext.js +1 -1
  270. package/lib/commonjs/hooks/useForcedContext.js.map +1 -1
  271. package/lib/commonjs/hooks/useIdentifier.js +1 -1
  272. package/lib/commonjs/hooks/useIdentifier.js.map +1 -1
  273. package/lib/commonjs/hooks/useList.js +12 -9
  274. package/lib/commonjs/hooks/useList.js.map +1 -1
  275. package/lib/commonjs/hooks/useMedia.js +1 -1
  276. package/lib/commonjs/hooks/useMedia.js.map +1 -1
  277. package/lib/commonjs/hooks/useModifier.js +1 -1
  278. package/lib/commonjs/hooks/useModifier.js.map +1 -1
  279. package/lib/commonjs/hooks/useScrollbarEffects.js.map +1 -1
  280. package/lib/commonjs/hooks/useStyle.js +1 -1
  281. package/lib/commonjs/hooks/useStyle.js.map +1 -1
  282. package/lib/commonjs/hooks/useTrigger.js +1 -1
  283. package/lib/commonjs/hooks/useTrigger.js.map +1 -1
  284. package/lib/commonjs/hooks/useViewport.js +1 -1
  285. package/lib/commonjs/hooks/useViewport.js.map +1 -1
  286. package/lib/commonjs/index.js +1 -1
  287. package/lib/commonjs/index.js.map +1 -1
  288. package/lib/commonjs/package.json +1 -0
  289. package/lib/commonjs/style/TextStyleContext.js +1 -1
  290. package/lib/commonjs/style/TextStyleContext.js.map +1 -1
  291. package/lib/commonjs/style/TextStyleProvider.js +6 -4
  292. package/lib/commonjs/style/TextStyleProvider.js.map +1 -1
  293. package/lib/commonjs/style/createStyle.js +1 -1
  294. package/lib/commonjs/style/createStyle.js.map +1 -1
  295. package/lib/commonjs/style/css.js +1 -1
  296. package/lib/commonjs/style/css.js.map +1 -1
  297. package/lib/commonjs/style/functions.js +1 -1
  298. package/lib/commonjs/style/functions.js.map +1 -1
  299. package/lib/commonjs/style/makeTheme.js +1 -1
  300. package/lib/commonjs/style/makeTheme.js.map +1 -1
  301. package/lib/commonjs/style/makeUtilities.js +1 -1
  302. package/lib/commonjs/style/makeUtilities.js.map +1 -1
  303. package/lib/commonjs/style/math.js +1 -1
  304. package/lib/commonjs/style/math.js.map +1 -1
  305. package/lib/commonjs/style/parse/InputStream.js.map +1 -1
  306. package/lib/commonjs/style/parse/index.js +1 -1
  307. package/lib/commonjs/style/parse/index.js.map +1 -1
  308. package/lib/commonjs/style/parse/parseBlock.js +1 -1
  309. package/lib/commonjs/style/parse/parseBlock.js.map +1 -1
  310. package/lib/commonjs/style/parse/rules/declaration.js +1 -1
  311. package/lib/commonjs/style/parse/rules/declaration.js.map +1 -1
  312. package/lib/commonjs/style/parse/rules/directive.js +1 -1
  313. package/lib/commonjs/style/parse/rules/directive.js.map +1 -1
  314. package/lib/commonjs/style/parse/rules/selector.js +1 -1
  315. package/lib/commonjs/style/parse/rules/selector.js.map +1 -1
  316. package/lib/commonjs/style/parse/rules/variable.js +1 -1
  317. package/lib/commonjs/style/parse/rules/variable.js.map +1 -1
  318. package/lib/commonjs/style/transform/formula.js.map +1 -1
  319. package/lib/commonjs/style/transform/index.js +21 -2
  320. package/lib/commonjs/style/transform/index.js.map +1 -1
  321. package/lib/commonjs/style/transform/rem.js.map +1 -1
  322. package/lib/commonjs/style/types/RgbaValue.js.map +1 -1
  323. package/lib/commonjs/style/types/UnitValue.js.map +1 -1
  324. package/lib/commonjs/theme/breakpoints.js.map +1 -1
  325. package/lib/commonjs/theme/functions.js +1 -1
  326. package/lib/commonjs/theme/functions.js.map +1 -1
  327. package/lib/commonjs/theme/maps.js.map +1 -1
  328. package/lib/commonjs/theme/utilities.js.map +1 -1
  329. package/lib/commonjs/theme/variables.js +1 -1
  330. package/lib/commonjs/theme/variables.js.map +1 -1
  331. package/lib/commonjs/utils.d.ts +1 -2
  332. package/lib/commonjs/utils.js +0 -1
  333. package/lib/commonjs/utils.js.map +1 -1
  334. package/lib/module/Context.js +2 -0
  335. package/lib/module/Context.js.map +1 -1
  336. package/lib/module/Provider.js +9 -3
  337. package/lib/module/Provider.js.map +1 -1
  338. package/lib/module/components/Body.js +10 -5
  339. package/lib/module/components/Body.js.map +1 -1
  340. package/lib/module/components/Caret.js +6 -3
  341. package/lib/module/components/Caret.js.map +1 -1
  342. package/lib/module/components/Heading.js +8 -4
  343. package/lib/module/components/Heading.js.map +1 -1
  344. package/lib/module/components/Image.js +6 -3
  345. package/lib/module/components/Image.js.map +1 -1
  346. package/lib/module/components/ImageBackground.js +6 -3
  347. package/lib/module/components/ImageBackground.js.map +1 -1
  348. package/lib/module/components/Label.js +8 -4
  349. package/lib/module/components/Label.js.map +1 -1
  350. package/lib/module/components/Link.js +9 -5
  351. package/lib/module/components/Link.js.map +1 -1
  352. package/lib/module/components/Pressable.js +22 -10
  353. package/lib/module/components/Pressable.js.map +1 -1
  354. package/lib/module/components/ScrollView.js +11 -6
  355. package/lib/module/components/ScrollView.js.map +1 -1
  356. package/lib/module/components/Text.js +10 -6
  357. package/lib/module/components/Text.js.map +1 -1
  358. package/lib/module/components/TextInput.js +6 -3
  359. package/lib/module/components/TextInput.js.map +1 -1
  360. package/lib/module/components/View.js +11 -6
  361. package/lib/module/components/View.js.map +1 -1
  362. package/lib/module/components/alert/Alert.js +8 -4
  363. package/lib/module/components/alert/Alert.js.map +1 -1
  364. package/lib/module/components/badge/Badge.js +11 -6
  365. package/lib/module/components/badge/Badge.js.map +1 -1
  366. package/lib/module/components/breadcrumb/Breadcrumb.js +8 -4
  367. package/lib/module/components/breadcrumb/Breadcrumb.js.map +1 -1
  368. package/lib/module/components/breadcrumb/BreadcrumbItem.js +15 -10
  369. package/lib/module/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  370. package/lib/module/components/button-group/ButtonGroup.js +11 -6
  371. package/lib/module/components/button-group/ButtonGroup.js.map +1 -1
  372. package/lib/module/components/button-group/ButtonGroupContext.js +2 -0
  373. package/lib/module/components/button-group/ButtonGroupContext.js.map +1 -1
  374. package/lib/module/components/button-group/ButtonToolbar.js +8 -4
  375. package/lib/module/components/button-group/ButtonToolbar.js.map +1 -1
  376. package/lib/module/components/buttons/Button.js +8 -4
  377. package/lib/module/components/buttons/Button.js.map +1 -1
  378. package/lib/module/components/buttons/useToggleButton.js +2 -0
  379. package/lib/module/components/buttons/useToggleButton.js.map +1 -1
  380. package/lib/module/components/card/Card.js +8 -4
  381. package/lib/module/components/card/Card.js.map +1 -1
  382. package/lib/module/components/card/CardBody.js +8 -4
  383. package/lib/module/components/card/CardBody.js.map +1 -1
  384. package/lib/module/components/card/CardFooter.js +8 -4
  385. package/lib/module/components/card/CardFooter.js.map +1 -1
  386. package/lib/module/components/card/CardHeader.js +8 -4
  387. package/lib/module/components/card/CardHeader.js.map +1 -1
  388. package/lib/module/components/close/CloseButton.js +9 -4
  389. package/lib/module/components/close/CloseButton.js.map +1 -1
  390. package/lib/module/components/collapse/Collapse.js +8 -4
  391. package/lib/module/components/collapse/Collapse.js.map +1 -1
  392. package/lib/module/components/collapse/CollapseContext.js +2 -0
  393. package/lib/module/components/collapse/CollapseContext.js.map +1 -1
  394. package/lib/module/components/collapse/CollapseProvider.js +7 -3
  395. package/lib/module/components/collapse/CollapseProvider.js.map +1 -1
  396. package/lib/module/components/collapse/useCollapse.js +2 -0
  397. package/lib/module/components/collapse/useCollapse.js.map +1 -1
  398. package/lib/module/components/collapse/useToggleCollapse.js +2 -0
  399. package/lib/module/components/collapse/useToggleCollapse.js.map +1 -1
  400. package/lib/module/components/containers/Container.js +6 -3
  401. package/lib/module/components/containers/Container.js.map +1 -1
  402. package/lib/module/components/dropdown/Dropdown.js +11 -6
  403. package/lib/module/components/dropdown/Dropdown.js.map +1 -1
  404. package/lib/module/components/dropdown/DropdownContext.js +2 -0
  405. package/lib/module/components/dropdown/DropdownContext.js.map +1 -1
  406. package/lib/module/components/dropdown/DropdownDivider.js +6 -3
  407. package/lib/module/components/dropdown/DropdownDivider.js.map +1 -1
  408. package/lib/module/components/dropdown/DropdownHeader.js +12 -7
  409. package/lib/module/components/dropdown/DropdownHeader.js.map +1 -1
  410. package/lib/module/components/dropdown/DropdownItem.js +8 -4
  411. package/lib/module/components/dropdown/DropdownItem.js.map +1 -1
  412. package/lib/module/components/dropdown/DropdownItemText.js +11 -6
  413. package/lib/module/components/dropdown/DropdownItemText.js.map +1 -1
  414. package/lib/module/components/dropdown/DropdownMenu.js +51 -37
  415. package/lib/module/components/dropdown/DropdownMenu.js.map +1 -1
  416. package/lib/module/components/dropdown/DropdownToggle.js +2 -0
  417. package/lib/module/components/dropdown/DropdownToggle.js.map +1 -1
  418. package/lib/module/components/dropdown/useDismissDropdown.js +2 -0
  419. package/lib/module/components/dropdown/useDismissDropdown.js.map +1 -1
  420. package/lib/module/components/dropdown/useDropdown.js +2 -0
  421. package/lib/module/components/dropdown/useDropdown.js.map +1 -1
  422. package/lib/module/components/dropdown/useToggleDropdown.js +2 -0
  423. package/lib/module/components/dropdown/useToggleDropdown.js.map +1 -1
  424. package/lib/module/components/forms/Checkbox.js +6 -3
  425. package/lib/module/components/forms/Checkbox.js.map +1 -1
  426. package/lib/module/components/forms/Feedback.js +8 -4
  427. package/lib/module/components/forms/Feedback.js.map +1 -1
  428. package/lib/module/components/forms/FormCheck.js +11 -6
  429. package/lib/module/components/forms/FormCheck.js.map +1 -1
  430. package/lib/module/components/forms/FormCheckContext.js +2 -0
  431. package/lib/module/components/forms/FormCheckContext.js.map +1 -1
  432. package/lib/module/components/forms/FormCheckInput.js +6 -3
  433. package/lib/module/components/forms/FormCheckInput.js.map +1 -1
  434. package/lib/module/components/forms/FormCheckLabel.js +8 -4
  435. package/lib/module/components/forms/FormCheckLabel.js.map +1 -1
  436. package/lib/module/components/forms/FormLabel.js +8 -4
  437. package/lib/module/components/forms/FormLabel.js.map +1 -1
  438. package/lib/module/components/forms/FormText.js +11 -6
  439. package/lib/module/components/forms/FormText.js.map +1 -1
  440. package/lib/module/components/forms/Input.js +6 -3
  441. package/lib/module/components/forms/Input.js.map +1 -1
  442. package/lib/module/components/forms/Picker.js +28 -23
  443. package/lib/module/components/forms/Picker.js.map +1 -1
  444. package/lib/module/components/forms/PickerContext.js +2 -0
  445. package/lib/module/components/forms/PickerContext.js.map +1 -1
  446. package/lib/module/components/forms/PickerItem.js +4 -1
  447. package/lib/module/components/forms/PickerItem.js.map +1 -1
  448. package/lib/module/components/forms/Radio.js +6 -3
  449. package/lib/module/components/forms/Radio.js.map +1 -1
  450. package/lib/module/components/forms/RadioContext.js +2 -0
  451. package/lib/module/components/forms/RadioContext.js.map +1 -1
  452. package/lib/module/components/forms/RadioGroup.js +11 -6
  453. package/lib/module/components/forms/RadioGroup.js.map +1 -1
  454. package/lib/module/components/forms/Switch.js +6 -3
  455. package/lib/module/components/forms/Switch.js.map +1 -1
  456. package/lib/module/components/forms/internals/FormCheckInputNative.js +7 -3
  457. package/lib/module/components/forms/internals/FormCheckInputNative.js.map +1 -1
  458. package/lib/module/components/forms/internals/FormCheckInputWeb.js +4 -1
  459. package/lib/module/components/forms/internals/FormCheckInputWeb.js.map +1 -1
  460. package/lib/module/components/forms/internals/PickerNative.js +48 -35
  461. package/lib/module/components/forms/internals/PickerNative.js.map +1 -1
  462. package/lib/module/components/forms/internals/PickerNativeContext.js +2 -0
  463. package/lib/module/components/forms/internals/PickerNativeContext.js.map +1 -1
  464. package/lib/module/components/forms/internals/PickerNativeItem.js +9 -4
  465. package/lib/module/components/forms/internals/PickerNativeItem.js.map +1 -1
  466. package/lib/module/components/forms/internals/PickerWeb.js +16 -10
  467. package/lib/module/components/forms/internals/PickerWeb.js.map +1 -1
  468. package/lib/module/components/forms/internals/PickerWebContext.js +2 -0
  469. package/lib/module/components/forms/internals/PickerWebContext.js.map +1 -1
  470. package/lib/module/components/forms/internals/PickerWebItem.js +4 -1
  471. package/lib/module/components/forms/internals/PickerWebItem.js.map +1 -1
  472. package/lib/module/components/grid/Col.js +8 -4
  473. package/lib/module/components/grid/Col.js.map +1 -1
  474. package/lib/module/components/grid/Row.js +8 -4
  475. package/lib/module/components/grid/Row.js.map +1 -1
  476. package/lib/module/components/helpers/BackdropHandler.js +4 -1
  477. package/lib/module/components/helpers/BackdropHandler.js.map +1 -1
  478. package/lib/module/components/helpers/ListContext.js +2 -0
  479. package/lib/module/components/helpers/ListContext.js.map +1 -1
  480. package/lib/module/components/helpers/Overlay.js +14 -3
  481. package/lib/module/components/helpers/Overlay.js.map +1 -1
  482. package/lib/module/components/list-group/ListGroup.js +11 -6
  483. package/lib/module/components/list-group/ListGroup.js.map +1 -1
  484. package/lib/module/components/list-group/ListGroupContext.js +2 -0
  485. package/lib/module/components/list-group/ListGroupContext.js.map +1 -1
  486. package/lib/module/components/list-group/ListGroupItem.js +8 -4
  487. package/lib/module/components/list-group/ListGroupItem.js.map +1 -1
  488. package/lib/module/components/list-group/ListGroupItemAction.js +8 -4
  489. package/lib/module/components/list-group/ListGroupItemAction.js.map +1 -1
  490. package/lib/module/components/modal/Modal.js +42 -31
  491. package/lib/module/components/modal/Modal.js.map +1 -1
  492. package/lib/module/components/modal/ModalBody.js +9 -5
  493. package/lib/module/components/modal/ModalBody.js.map +1 -1
  494. package/lib/module/components/modal/ModalContext.js +2 -0
  495. package/lib/module/components/modal/ModalContext.js.map +1 -1
  496. package/lib/module/components/modal/ModalFooter.js +8 -4
  497. package/lib/module/components/modal/ModalFooter.js.map +1 -1
  498. package/lib/module/components/modal/ModalHeader.js +8 -4
  499. package/lib/module/components/modal/ModalHeader.js.map +1 -1
  500. package/lib/module/components/modal/ModalTitle.js +9 -6
  501. package/lib/module/components/modal/ModalTitle.js.map +1 -1
  502. package/lib/module/components/modal/useModal.js +2 -0
  503. package/lib/module/components/modal/useModal.js.map +1 -1
  504. package/lib/module/components/nav/Nav.js +11 -6
  505. package/lib/module/components/nav/Nav.js.map +1 -1
  506. package/lib/module/components/nav/NavContext.js +2 -0
  507. package/lib/module/components/nav/NavContext.js.map +1 -1
  508. package/lib/module/components/nav/NavLink.js +8 -4
  509. package/lib/module/components/nav/NavLink.js.map +1 -1
  510. package/lib/module/components/nav/Tab.js +2 -0
  511. package/lib/module/components/nav/Tab.js.map +1 -1
  512. package/lib/module/components/nav/TabContent.js +6 -3
  513. package/lib/module/components/nav/TabContent.js.map +1 -1
  514. package/lib/module/components/nav/TabContext.js +2 -0
  515. package/lib/module/components/nav/TabContext.js.map +1 -1
  516. package/lib/module/components/nav/TabPane.js +6 -3
  517. package/lib/module/components/nav/TabPane.js.map +1 -1
  518. package/lib/module/components/nav/TabProvider.js +7 -3
  519. package/lib/module/components/nav/TabProvider.js.map +1 -1
  520. package/lib/module/components/nav/useTabbable.js +2 -0
  521. package/lib/module/components/nav/useTabbable.js.map +1 -1
  522. package/lib/module/components/nav/useToggleTab.js +2 -0
  523. package/lib/module/components/nav/useToggleTab.js.map +1 -1
  524. package/lib/module/components/navbar/Navbar.js +11 -6
  525. package/lib/module/components/navbar/Navbar.js.map +1 -1
  526. package/lib/module/components/navbar/NavbarBrand.js +8 -4
  527. package/lib/module/components/navbar/NavbarBrand.js.map +1 -1
  528. package/lib/module/components/navbar/NavbarCollapse.js +8 -4
  529. package/lib/module/components/navbar/NavbarCollapse.js.map +1 -1
  530. package/lib/module/components/navbar/NavbarContext.js +2 -0
  531. package/lib/module/components/navbar/NavbarContext.js.map +1 -1
  532. package/lib/module/components/navbar/NavbarText.js +11 -6
  533. package/lib/module/components/navbar/NavbarText.js.map +1 -1
  534. package/lib/module/components/navbar/NavbarToggler.js +11 -6
  535. package/lib/module/components/navbar/NavbarToggler.js.map +1 -1
  536. package/lib/module/components/navbar/useDismissNavbar.js +2 -0
  537. package/lib/module/components/navbar/useDismissNavbar.js.map +1 -1
  538. package/lib/module/components/navbar/useNavbar.js +2 -0
  539. package/lib/module/components/navbar/useNavbar.js.map +1 -1
  540. package/lib/module/components/navbar/useToggleNavbar.js +2 -0
  541. package/lib/module/components/navbar/useToggleNavbar.js.map +1 -1
  542. package/lib/module/components/offcanvas/Offcanvas.js +43 -30
  543. package/lib/module/components/offcanvas/Offcanvas.js.map +1 -1
  544. package/lib/module/components/offcanvas/OffcanvasBody.js +8 -4
  545. package/lib/module/components/offcanvas/OffcanvasBody.js.map +1 -1
  546. package/lib/module/components/offcanvas/OffcanvasContext.js +2 -0
  547. package/lib/module/components/offcanvas/OffcanvasContext.js.map +1 -1
  548. package/lib/module/components/offcanvas/OffcanvasHeader.js +8 -4
  549. package/lib/module/components/offcanvas/OffcanvasHeader.js.map +1 -1
  550. package/lib/module/components/offcanvas/OffcanvasTitle.js +9 -6
  551. package/lib/module/components/offcanvas/OffcanvasTitle.js.map +1 -1
  552. package/lib/module/components/offcanvas/useOffcanvas.js +2 -0
  553. package/lib/module/components/offcanvas/useOffcanvas.js.map +1 -1
  554. package/lib/module/components/pagination/Pagination.js +8 -4
  555. package/lib/module/components/pagination/Pagination.js.map +1 -1
  556. package/lib/module/components/pagination/PaginationItem.js +8 -4
  557. package/lib/module/components/pagination/PaginationItem.js.map +1 -1
  558. package/lib/module/components/placeholders/Placeholders.js +8 -4
  559. package/lib/module/components/placeholders/Placeholders.js.map +1 -1
  560. package/lib/module/components/popover/Popover.js +11 -6
  561. package/lib/module/components/popover/Popover.js.map +1 -1
  562. package/lib/module/components/popover/PopoverArrow.js +12 -8
  563. package/lib/module/components/popover/PopoverArrow.js.map +1 -1
  564. package/lib/module/components/popover/PopoverBody.js +8 -4
  565. package/lib/module/components/popover/PopoverBody.js.map +1 -1
  566. package/lib/module/components/popover/PopoverContext.js +2 -0
  567. package/lib/module/components/popover/PopoverContext.js.map +1 -1
  568. package/lib/module/components/popover/PopoverHeader.js +12 -7
  569. package/lib/module/components/popover/PopoverHeader.js.map +1 -1
  570. package/lib/module/components/popover/injectPopover.js +42 -24
  571. package/lib/module/components/popover/injectPopover.js.map +1 -1
  572. package/lib/module/components/progress/Progress.js +11 -6
  573. package/lib/module/components/progress/Progress.js.map +1 -1
  574. package/lib/module/components/progress/ProgressBar.js +11 -6
  575. package/lib/module/components/progress/ProgressBar.js.map +1 -1
  576. package/lib/module/components/progress/ProgressContext.js +2 -0
  577. package/lib/module/components/progress/ProgressContext.js.map +1 -1
  578. package/lib/module/components/progress/useProgress.js +2 -0
  579. package/lib/module/components/progress/useProgress.js.map +1 -1
  580. package/lib/module/components/spinners/Spinner.js +6 -3
  581. package/lib/module/components/spinners/Spinner.js.map +1 -1
  582. package/lib/module/components/toasts/Toast.js +8 -4
  583. package/lib/module/components/toasts/Toast.js.map +1 -1
  584. package/lib/module/components/toasts/ToastBody.js +8 -4
  585. package/lib/module/components/toasts/ToastBody.js.map +1 -1
  586. package/lib/module/components/toasts/ToastContainer.js +11 -6
  587. package/lib/module/components/toasts/ToastContainer.js.map +1 -1
  588. package/lib/module/components/toasts/ToastContainerContext.js +2 -0
  589. package/lib/module/components/toasts/ToastContainerContext.js.map +1 -1
  590. package/lib/module/components/toasts/ToastHeader.js +8 -4
  591. package/lib/module/components/toasts/ToastHeader.js.map +1 -1
  592. package/lib/module/components/tooltip/Tooltip.js +11 -6
  593. package/lib/module/components/tooltip/Tooltip.js.map +1 -1
  594. package/lib/module/components/tooltip/TooltipArrow.js +10 -6
  595. package/lib/module/components/tooltip/TooltipArrow.js.map +1 -1
  596. package/lib/module/components/tooltip/TooltipContext.js +2 -0
  597. package/lib/module/components/tooltip/TooltipContext.js.map +1 -1
  598. package/lib/module/components/tooltip/TooltipInner.js +11 -6
  599. package/lib/module/components/tooltip/TooltipInner.js.map +1 -1
  600. package/lib/module/components/tooltip/injectTooltip.js +39 -23
  601. package/lib/module/components/tooltip/injectTooltip.js.map +1 -1
  602. package/lib/module/components/type/Blockquote.js +8 -4
  603. package/lib/module/components/type/Blockquote.js.map +1 -1
  604. package/lib/module/components/type/Code.js +8 -4
  605. package/lib/module/components/type/Code.js.map +1 -1
  606. package/lib/module/components/type/DisplayHeading.js +8 -4
  607. package/lib/module/components/type/DisplayHeading.js.map +1 -1
  608. package/lib/module/components/type/Paragraph.js +8 -4
  609. package/lib/module/components/type/Paragraph.js.map +1 -1
  610. package/lib/module/hooks/useAction.js +2 -0
  611. package/lib/module/hooks/useAction.js.map +1 -1
  612. package/lib/module/hooks/useBackground.js +2 -0
  613. package/lib/module/hooks/useBackground.js.map +1 -1
  614. package/lib/module/hooks/useBackground.native.js +13 -8
  615. package/lib/module/hooks/useBackground.native.js.map +1 -1
  616. package/lib/module/hooks/useControlledState.js +2 -0
  617. package/lib/module/hooks/useControlledState.js.map +1 -1
  618. package/lib/module/hooks/useFixedElement.js +2 -0
  619. package/lib/module/hooks/useFixedElement.js.map +1 -1
  620. package/lib/module/hooks/useForcedContext.js +2 -0
  621. package/lib/module/hooks/useForcedContext.js.map +1 -1
  622. package/lib/module/hooks/useIdentifier.js +2 -0
  623. package/lib/module/hooks/useIdentifier.js.map +1 -1
  624. package/lib/module/hooks/useInteractionState.js +2 -0
  625. package/lib/module/hooks/useInteractionState.js.map +1 -1
  626. package/lib/module/hooks/useList.js +13 -8
  627. package/lib/module/hooks/useList.js.map +1 -1
  628. package/lib/module/hooks/useMedia.js +2 -0
  629. package/lib/module/hooks/useMedia.js.map +1 -1
  630. package/lib/module/hooks/useModifier.js +2 -0
  631. package/lib/module/hooks/useModifier.js.map +1 -1
  632. package/lib/module/hooks/useScrollbarEffects.js +2 -0
  633. package/lib/module/hooks/useScrollbarEffects.js.map +1 -1
  634. package/lib/module/hooks/useStyle.js +2 -0
  635. package/lib/module/hooks/useStyle.js.map +1 -1
  636. package/lib/module/hooks/useTrigger.js +2 -0
  637. package/lib/module/hooks/useTrigger.js.map +1 -1
  638. package/lib/module/hooks/useViewport.js +2 -0
  639. package/lib/module/hooks/useViewport.js.map +1 -1
  640. package/lib/module/index.js +2 -0
  641. package/lib/module/index.js.map +1 -1
  642. package/lib/module/package.json +1 -0
  643. package/lib/module/style/StyleSheet.js +2 -0
  644. package/lib/module/style/StyleSheet.js.map +1 -1
  645. package/lib/module/style/TextStyleContext.js +2 -0
  646. package/lib/module/style/TextStyleContext.js.map +1 -1
  647. package/lib/module/style/TextStyleProvider.js +7 -3
  648. package/lib/module/style/TextStyleProvider.js.map +1 -1
  649. package/lib/module/style/createStyle.js +2 -0
  650. package/lib/module/style/createStyle.js.map +1 -1
  651. package/lib/module/style/css.js +2 -0
  652. package/lib/module/style/css.js.map +1 -1
  653. package/lib/module/style/functions.js +2 -0
  654. package/lib/module/style/functions.js.map +1 -1
  655. package/lib/module/style/makeTheme.js +2 -0
  656. package/lib/module/style/makeTheme.js.map +1 -1
  657. package/lib/module/style/makeUtilities.js +2 -0
  658. package/lib/module/style/makeUtilities.js.map +1 -1
  659. package/lib/module/style/math.js +2 -0
  660. package/lib/module/style/math.js.map +1 -1
  661. package/lib/module/style/mixins/mediaBreakpointBetween.js +2 -0
  662. package/lib/module/style/mixins/mediaBreakpointBetween.js.map +1 -1
  663. package/lib/module/style/mixins/mediaBreakpointDown.js +2 -0
  664. package/lib/module/style/mixins/mediaBreakpointDown.js.map +1 -1
  665. package/lib/module/style/mixins/mediaBreakpointOnly.js +2 -0
  666. package/lib/module/style/mixins/mediaBreakpointOnly.js.map +1 -1
  667. package/lib/module/style/mixins/mediaBreakpointUp.js +2 -0
  668. package/lib/module/style/mixins/mediaBreakpointUp.js.map +1 -1
  669. package/lib/module/style/mixins/platform.js +2 -0
  670. package/lib/module/style/mixins/platform.js.map +1 -1
  671. package/lib/module/style/parse/InputStream.js +2 -0
  672. package/lib/module/style/parse/InputStream.js.map +1 -1
  673. package/lib/module/style/parse/index.js +2 -0
  674. package/lib/module/style/parse/index.js.map +1 -1
  675. package/lib/module/style/parse/isIdent.js +2 -0
  676. package/lib/module/style/parse/isIdent.js.map +1 -1
  677. package/lib/module/style/parse/isWhitespace.js +2 -0
  678. package/lib/module/style/parse/isWhitespace.js.map +1 -1
  679. package/lib/module/style/parse/parseBlock.js +2 -0
  680. package/lib/module/style/parse/parseBlock.js.map +1 -1
  681. package/lib/module/style/parse/rules/comment.js +2 -0
  682. package/lib/module/style/parse/rules/comment.js.map +1 -1
  683. package/lib/module/style/parse/rules/declaration.js +2 -0
  684. package/lib/module/style/parse/rules/declaration.js.map +1 -1
  685. package/lib/module/style/parse/rules/directive.js +2 -0
  686. package/lib/module/style/parse/rules/directive.js.map +1 -1
  687. package/lib/module/style/parse/rules/selector.js +2 -0
  688. package/lib/module/style/parse/rules/selector.js.map +1 -1
  689. package/lib/module/style/parse/rules/variable.js +2 -0
  690. package/lib/module/style/parse/rules/variable.js.map +1 -1
  691. package/lib/module/style/transform/formula.js +2 -0
  692. package/lib/module/style/transform/formula.js.map +1 -1
  693. package/lib/module/style/transform/index.js +22 -1
  694. package/lib/module/style/transform/index.js.map +1 -1
  695. package/lib/module/style/transform/properties/backgroundPosition.js +2 -0
  696. package/lib/module/style/transform/properties/backgroundPosition.js.map +1 -1
  697. package/lib/module/style/transform/properties/backgroundPositionX.js +2 -0
  698. package/lib/module/style/transform/properties/backgroundPositionX.js.map +1 -1
  699. package/lib/module/style/transform/properties/backgroundPositionY.js +2 -0
  700. package/lib/module/style/transform/properties/backgroundPositionY.js.map +1 -1
  701. package/lib/module/style/transform/properties/backgroundSize.js +2 -0
  702. package/lib/module/style/transform/properties/backgroundSize.js.map +1 -1
  703. package/lib/module/style/transform/rem.js +2 -0
  704. package/lib/module/style/transform/rem.js.map +1 -1
  705. package/lib/module/style/transform/rgba.js +2 -0
  706. package/lib/module/style/transform/rgba.js.map +1 -1
  707. package/lib/module/style/types/RgbaValue.js +2 -0
  708. package/lib/module/style/types/RgbaValue.js.map +1 -1
  709. package/lib/module/style/types/UnitValue.js +2 -0
  710. package/lib/module/style/types/UnitValue.js.map +1 -1
  711. package/lib/module/theme/breakpoints.js +2 -0
  712. package/lib/module/theme/breakpoints.js.map +1 -1
  713. package/lib/module/theme/functions.js +2 -0
  714. package/lib/module/theme/functions.js.map +1 -1
  715. package/lib/module/theme/maps.js +2 -0
  716. package/lib/module/theme/maps.js.map +1 -1
  717. package/lib/module/theme/proxies.js +2 -0
  718. package/lib/module/theme/proxies.js.map +1 -1
  719. package/lib/module/theme/utilities.js +2 -0
  720. package/lib/module/theme/utilities.js.map +1 -1
  721. package/lib/module/theme/variables.js +2 -0
  722. package/lib/module/theme/variables.js.map +1 -1
  723. package/lib/module/types.js +2 -0
  724. package/lib/module/utils.d.ts +1 -2
  725. package/lib/module/utils.js +2 -1
  726. package/lib/module/utils.js.map +1 -1
  727. package/lib/types/components/Pressable.d.ts +1 -1
  728. package/lib/types/components/Pressable.d.ts.map +1 -1
  729. package/lib/types/components/View.d.ts.map +1 -1
  730. package/lib/types/components/collapse/CollapseContext.d.ts +0 -1
  731. package/lib/types/components/collapse/CollapseContext.d.ts.map +1 -1
  732. package/lib/types/components/collapse/useCollapse.d.ts +0 -1
  733. package/lib/types/components/collapse/useCollapse.d.ts.map +1 -1
  734. package/lib/types/components/dropdown/DropdownContext.d.ts +1 -2
  735. package/lib/types/components/dropdown/DropdownContext.d.ts.map +1 -1
  736. package/lib/types/components/dropdown/DropdownToggle.d.ts +2 -2
  737. package/lib/types/components/dropdown/DropdownToggle.d.ts.map +1 -1
  738. package/lib/types/components/dropdown/useDropdown.d.ts +1 -2
  739. package/lib/types/components/dropdown/useDropdown.d.ts.map +1 -1
  740. package/lib/types/components/dropdown/useToggleDropdown.d.ts +1 -2
  741. package/lib/types/components/dropdown/useToggleDropdown.d.ts.map +1 -1
  742. package/lib/types/components/forms/Picker.d.ts +7 -6
  743. package/lib/types/components/forms/Picker.d.ts.map +1 -1
  744. package/lib/types/components/forms/PickerItem.d.ts +1 -1
  745. package/lib/types/components/forms/PickerItem.d.ts.map +1 -1
  746. package/lib/types/components/forms/Radio.d.ts +1 -1
  747. package/lib/types/components/forms/Radio.d.ts.map +1 -1
  748. package/lib/types/components/forms/RadioContext.d.ts +2 -2
  749. package/lib/types/components/forms/RadioContext.d.ts.map +1 -1
  750. package/lib/types/components/forms/RadioGroup.d.ts +2 -2
  751. package/lib/types/components/forms/RadioGroup.d.ts.map +1 -1
  752. package/lib/types/components/forms/internals/PickerNative.d.ts.map +1 -1
  753. package/lib/types/components/forms/internals/PickerNativeContext.d.ts +2 -2
  754. package/lib/types/components/forms/internals/PickerNativeContext.d.ts.map +1 -1
  755. package/lib/types/components/forms/internals/PickerNativeItem.d.ts +1 -1
  756. package/lib/types/components/forms/internals/PickerNativeItem.d.ts.map +1 -1
  757. package/lib/types/components/forms/internals/PickerWebItem.d.ts +1 -1
  758. package/lib/types/components/forms/internals/PickerWebItem.d.ts.map +1 -1
  759. package/lib/types/components/helpers/BackdropHandler.d.ts +2 -2
  760. package/lib/types/components/helpers/BackdropHandler.d.ts.map +1 -1
  761. package/lib/types/components/helpers/Overlay.d.ts +6 -6
  762. package/lib/types/components/helpers/Overlay.d.ts.map +1 -1
  763. package/lib/types/components/modal/Modal.d.ts +3 -4
  764. package/lib/types/components/modal/Modal.d.ts.map +1 -1
  765. package/lib/types/components/modal/ModalBody.d.ts +3 -6
  766. package/lib/types/components/modal/ModalBody.d.ts.map +1 -1
  767. package/lib/types/components/nav/NavContext.d.ts +0 -1
  768. package/lib/types/components/nav/NavContext.d.ts.map +1 -1
  769. package/lib/types/components/nav/Tab.d.ts +0 -1
  770. package/lib/types/components/nav/Tab.d.ts.map +1 -1
  771. package/lib/types/components/nav/TabContext.d.ts +0 -1
  772. package/lib/types/components/nav/TabContext.d.ts.map +1 -1
  773. package/lib/types/components/navbar/NavbarContext.d.ts +0 -1
  774. package/lib/types/components/navbar/NavbarContext.d.ts.map +1 -1
  775. package/lib/types/components/navbar/useNavbar.d.ts +0 -1
  776. package/lib/types/components/navbar/useNavbar.d.ts.map +1 -1
  777. package/lib/types/components/offcanvas/OffcanvasBody.d.ts +3 -4
  778. package/lib/types/components/offcanvas/OffcanvasBody.d.ts.map +1 -1
  779. package/lib/types/hooks/useAction.d.ts +3 -4
  780. package/lib/types/hooks/useAction.d.ts.map +1 -1
  781. package/lib/types/hooks/useBackground.d.ts.map +1 -1
  782. package/lib/types/hooks/useBackground.native.d.ts +1 -1
  783. package/lib/types/hooks/useFixedElement.d.ts +1 -2
  784. package/lib/types/hooks/useFixedElement.d.ts.map +1 -1
  785. package/lib/types/hooks/useInteractionState.d.ts.map +1 -1
  786. package/lib/types/hooks/useList.d.ts +1 -1
  787. package/lib/types/hooks/useList.d.ts.map +1 -1
  788. package/lib/types/hooks/useMedia.d.ts.map +1 -1
  789. package/lib/types/hooks/useModifier.d.ts +0 -1
  790. package/lib/types/hooks/useModifier.d.ts.map +1 -1
  791. package/lib/types/hooks/useScrollbarEffects.d.ts +1 -1
  792. package/lib/types/hooks/useScrollbarEffects.d.ts.map +1 -1
  793. package/lib/types/hooks/useTrigger.d.ts +2 -2
  794. package/lib/types/hooks/useTrigger.d.ts.map +1 -1
  795. package/lib/types/style/StyleSheet.d.ts +1 -1
  796. package/lib/types/style/StyleSheet.d.ts.map +1 -1
  797. package/lib/types/style/createStyle.d.ts +1 -1
  798. package/lib/types/style/css.d.ts +1 -1
  799. package/lib/types/style/makeUtilities.d.ts +6 -2
  800. package/lib/types/style/makeUtilities.d.ts.map +1 -1
  801. package/lib/types/style/parse/index.d.ts.map +1 -1
  802. package/lib/types/style/parse/rules/declaration.d.ts.map +1 -1
  803. package/lib/types/style/parse/rules/directive.d.ts.map +1 -1
  804. package/lib/types/style/parse/rules/selector.d.ts.map +1 -1
  805. package/lib/types/style/parse/rules/variable.d.ts.map +1 -1
  806. package/lib/types/style/transform/index.d.ts.map +1 -1
  807. package/lib/types/theme/functions.d.ts.map +1 -1
  808. package/lib/types/theme/maps.d.ts +60 -60
  809. package/lib/types/theme/proxies.d.ts +312 -312
  810. package/lib/types/theme/variables.d.ts +1 -1
  811. package/lib/types/utils.d.ts +1 -2
  812. package/lib/types/utils.d.ts.map +1 -1
  813. package/package.json +6 -6
  814. package/src/components/Image.tsx +1 -1
  815. package/src/components/View.tsx +55 -57
  816. package/src/components/dropdown/DropdownContext.ts +21 -21
  817. package/src/components/dropdown/DropdownToggle.ts +18 -18
  818. package/src/components/forms/Picker.tsx +193 -191
  819. package/src/components/forms/PickerItem.tsx +32 -32
  820. package/src/components/forms/Radio.tsx +37 -37
  821. package/src/components/forms/RadioContext.ts +13 -13
  822. package/src/components/forms/RadioGroup.tsx +42 -40
  823. package/src/components/forms/internals/PickerNative.tsx +196 -195
  824. package/src/components/forms/internals/PickerNativeContext.ts +14 -14
  825. package/src/components/forms/internals/PickerNativeItem.tsx +59 -59
  826. package/src/components/forms/internals/PickerWebItem.tsx +36 -36
  827. package/src/components/helpers/BackdropHandler.tsx +143 -143
  828. package/src/components/helpers/Overlay.tsx +92 -79
  829. package/src/components/modal/Modal.tsx +82 -81
  830. package/src/components/modal/ModalBody.tsx +52 -56
  831. package/src/components/offcanvas/OffcanvasBody.tsx +64 -66
  832. package/src/hooks/useAction.ts +78 -78
  833. package/src/hooks/useBackground.native.tsx +202 -202
  834. package/src/hooks/{useBackground.ts → useBackground.tsx} +123 -118
  835. package/src/hooks/useList.tsx +59 -56
  836. package/src/hooks/useScrollbarEffects.ts +94 -92
  837. package/src/style/makeUtilities.ts +79 -76
  838. package/src/style/transform/index.ts +245 -218
  839. package/src/utils.ts +92 -95
@@ -1,143 +1,143 @@
1
- import React, { useEffect, useMemo, RefObject } from 'react';
2
- import { Platform, findNodeHandle } from 'react-native';
3
- import StyleSheet from '../../style/StyleSheet';
4
- import css from '../../style/css';
5
- import Pressable from '../Pressable';
6
- import { ViewRef } from '../View';
7
-
8
- type BackdropType = boolean | 'static';
9
- type AutoCloseType = boolean | string;
10
-
11
- const styles = StyleSheet.create({
12
- handler: css`
13
- top: 0;
14
- bottom: 0;
15
- left: 0;
16
- right: 0;
17
- position: absolute;
18
- flex-grow: 1;
19
- `,
20
- });
21
-
22
- const initialState = {
23
- waitingForMouseUp: false,
24
- ignoreBackdropClick: false,
25
- };
26
-
27
- interface BackdropHandlerProps {
28
- toggleRef?: RefObject<ViewRef>;
29
- dialogRef: RefObject<ViewRef>;
30
- onClose?: () => void;
31
- autoClose?: AutoCloseType;
32
- backdrop?: BackdropType;
33
- }
34
-
35
- function BackdropHandler(props: BackdropHandlerProps) {
36
- const {
37
- toggleRef,
38
- dialogRef,
39
- onClose: handleClose,
40
- backdrop = true,
41
- autoClose = 'outside',
42
- } = props;
43
-
44
- if (Platform.OS === 'web') {
45
- const state = useMemo(() => initialState, []);
46
-
47
- useEffect(() => {
48
- const toggle = toggleRef
49
- ? // @ts-expect-error web only method for converting to HTMLElement
50
- (findNodeHandle(toggleRef.current) as HTMLElement)
51
- : undefined;
52
- // @ts-expect-error web only method for converting to HTMLElement
53
- const dialog = findNodeHandle(dialogRef.current) as HTMLElement;
54
-
55
- const handleDialogMouseDown = () => {
56
- state.waitingForMouseUp = true;
57
- };
58
-
59
- // Workaround for chrome, because chrome does not fire onMouseDown event
60
- // for dialog when clicking on the <select> menu.
61
- const handleDialogMouseUp = () => {
62
- state.ignoreBackdropClick = true;
63
- };
64
-
65
- const handleDocumentClick = ({ target }: MouseEvent) => {
66
- const isDialogClick =
67
- state.ignoreBackdropClick ||
68
- (dialog && dialog.contains(target as Node));
69
-
70
- if (backdrop === 'static' || autoClose === false) {
71
- return;
72
- }
73
-
74
- // Click outside -> return if autoClose is inside.
75
- if (!isDialogClick && autoClose === 'inside') {
76
- return;
77
- }
78
-
79
- // Click inside / on dialog -> return if autoClose is outside.
80
- if (isDialogClick) {
81
- state.ignoreBackdropClick = false;
82
-
83
- if (autoClose === 'outside') {
84
- return;
85
- }
86
- }
87
-
88
- // Click on toggle -> return always.
89
- if (toggle && (target === toggle || toggle.contains(target as Node))) {
90
- return;
91
- }
92
-
93
- handleClose?.();
94
- };
95
-
96
- const handleDocumentMouseUp = () => {
97
- if (state.waitingForMouseUp) {
98
- state.ignoreBackdropClick = true;
99
- }
100
-
101
- state.waitingForMouseUp = false;
102
- };
103
-
104
- if (dialog) {
105
- dialog.addEventListener('mousedown', handleDialogMouseDown);
106
- dialog.addEventListener('mouseup', handleDialogMouseUp);
107
- }
108
- // See https://github.com/necolas/react-native-web/issues/2115
109
- document.addEventListener('click', handleDocumentClick, true);
110
- document.addEventListener('mouseup', handleDocumentMouseUp, true);
111
-
112
- return () => {
113
- if (dialog) {
114
- dialog.removeEventListener('mousedown', handleDialogMouseDown);
115
- dialog.removeEventListener('mouseup', handleDialogMouseUp);
116
- }
117
- document.removeEventListener('click', handleDocumentClick, true);
118
- document.removeEventListener('mouseup', handleDocumentMouseUp, true);
119
- };
120
- }, [backdrop, autoClose]);
121
-
122
- return null;
123
- }
124
-
125
- if (backdrop !== true) {
126
- return null;
127
- }
128
-
129
- return (
130
- <Pressable
131
- style={styles.handler}
132
- onPress={() => {
133
- handleClose?.();
134
- }}
135
- accessible={false}
136
- importantForAccessibility="no"
137
- />
138
- );
139
- }
140
-
141
- BackdropHandler.displayName = 'BackdropHandler';
142
-
143
- export default BackdropHandler;
1
+ import React, { useEffect, useMemo, RefObject } from 'react';
2
+ import { Platform, findNodeHandle } from 'react-native';
3
+ import StyleSheet from '../../style/StyleSheet';
4
+ import css from '../../style/css';
5
+ import Pressable from '../Pressable';
6
+ import { ViewRef } from '../View';
7
+
8
+ type BackdropType = boolean | 'static';
9
+ type AutoCloseType = boolean | string;
10
+
11
+ const styles = StyleSheet.create({
12
+ handler: css`
13
+ top: 0;
14
+ bottom: 0;
15
+ left: 0;
16
+ right: 0;
17
+ position: absolute;
18
+ flex-grow: 1;
19
+ `,
20
+ });
21
+
22
+ const initialState = {
23
+ waitingForMouseUp: false,
24
+ ignoreBackdropClick: false,
25
+ };
26
+
27
+ interface BackdropHandlerProps {
28
+ toggleRef?: RefObject<ViewRef | null>;
29
+ dialogRef: RefObject<ViewRef | null>;
30
+ onClose?: () => void;
31
+ autoClose?: AutoCloseType;
32
+ backdrop?: BackdropType;
33
+ }
34
+
35
+ function BackdropHandler(props: BackdropHandlerProps) {
36
+ const {
37
+ toggleRef,
38
+ dialogRef,
39
+ onClose: handleClose,
40
+ backdrop = true,
41
+ autoClose = 'outside',
42
+ } = props;
43
+
44
+ if (Platform.OS === 'web') {
45
+ const state = useMemo(() => initialState, []);
46
+
47
+ useEffect(() => {
48
+ const toggle = toggleRef
49
+ ? // @ts-expect-error web only method for converting to HTMLElement
50
+ (findNodeHandle(toggleRef.current) as HTMLElement)
51
+ : undefined;
52
+ // @ts-expect-error web only method for converting to HTMLElement
53
+ const dialog = findNodeHandle(dialogRef.current) as HTMLElement;
54
+
55
+ const handleDialogMouseDown = () => {
56
+ state.waitingForMouseUp = true;
57
+ };
58
+
59
+ // Workaround for chrome, because chrome does not fire onMouseDown event
60
+ // for dialog when clicking on the <select> menu.
61
+ const handleDialogMouseUp = () => {
62
+ state.ignoreBackdropClick = true;
63
+ };
64
+
65
+ const handleDocumentClick = ({ target }: MouseEvent) => {
66
+ const isDialogClick =
67
+ state.ignoreBackdropClick ||
68
+ (dialog && dialog.contains(target as Node));
69
+
70
+ if (backdrop === 'static' || autoClose === false) {
71
+ return;
72
+ }
73
+
74
+ // Click outside -> return if autoClose is inside.
75
+ if (!isDialogClick && autoClose === 'inside') {
76
+ return;
77
+ }
78
+
79
+ // Click inside / on dialog -> return if autoClose is outside.
80
+ if (isDialogClick) {
81
+ state.ignoreBackdropClick = false;
82
+
83
+ if (autoClose === 'outside') {
84
+ return;
85
+ }
86
+ }
87
+
88
+ // Click on toggle -> return always.
89
+ if (toggle && (target === toggle || toggle.contains(target as Node))) {
90
+ return;
91
+ }
92
+
93
+ handleClose?.();
94
+ };
95
+
96
+ const handleDocumentMouseUp = () => {
97
+ if (state.waitingForMouseUp) {
98
+ state.ignoreBackdropClick = true;
99
+ }
100
+
101
+ state.waitingForMouseUp = false;
102
+ };
103
+
104
+ if (dialog) {
105
+ dialog.addEventListener('mousedown', handleDialogMouseDown);
106
+ dialog.addEventListener('mouseup', handleDialogMouseUp);
107
+ }
108
+ // See https://github.com/necolas/react-native-web/issues/2115
109
+ document.addEventListener('click', handleDocumentClick, true);
110
+ document.addEventListener('mouseup', handleDocumentMouseUp, true);
111
+
112
+ return () => {
113
+ if (dialog) {
114
+ dialog.removeEventListener('mousedown', handleDialogMouseDown);
115
+ dialog.removeEventListener('mouseup', handleDialogMouseUp);
116
+ }
117
+ document.removeEventListener('click', handleDocumentClick, true);
118
+ document.removeEventListener('mouseup', handleDocumentMouseUp, true);
119
+ };
120
+ }, [backdrop, autoClose]);
121
+
122
+ return null;
123
+ }
124
+
125
+ if (backdrop !== true) {
126
+ return null;
127
+ }
128
+
129
+ return (
130
+ <Pressable
131
+ style={styles.handler}
132
+ onPress={() => {
133
+ handleClose?.();
134
+ }}
135
+ accessible={false}
136
+ importantForAccessibility="no"
137
+ />
138
+ );
139
+ }
140
+
141
+ BackdropHandler.displayName = 'BackdropHandler';
142
+
143
+ export default BackdropHandler;
@@ -1,79 +1,92 @@
1
- import React, { useRef, ReactNode } from 'react';
2
- import { Platform, StatusBar, ViewStyle } from 'react-native';
3
- import { useOverlayPosition } from '@react-native-aria/overlays';
4
- import type { ViewRef } from '../View';
5
- import type { Placement, PlacementAxis } from '../../types';
6
-
7
- type OverlayReturnType = {
8
- placement: PlacementAxis;
9
- rendered?: boolean;
10
- overlayProps: {
11
- style: ViewStyle;
12
- };
13
- arrowProps: {
14
- style: ViewStyle;
15
- };
16
- };
17
-
18
- interface OverlayProps {
19
- children: (
20
- overlay: OverlayReturnType,
21
- overlayRef: React.RefObject<ViewRef>,
22
- ) => ReactNode;
23
- placement: Placement;
24
- targetRef: React.RefObject<ViewRef>;
25
- offset?: number;
26
- arrowOffset?: number;
27
- visible: boolean;
28
- }
29
-
30
- const Overlay = ({
31
- children,
32
- targetRef,
33
- placement,
34
- offset,
35
- arrowOffset = 0,
36
- visible,
37
- }: OverlayProps) => {
38
- const overlayRef = useRef(null);
39
-
40
- const overlay = useOverlayPosition({
41
- placement,
42
- targetRef,
43
- overlayRef,
44
- offset,
45
- isOpen: visible,
46
- });
47
-
48
- // Remove unnecessary arrow styles and adjust arrow offset.
49
- if (placement === 'top' || placement === 'bottom') {
50
- // @ts-expect-error workaround for correct positioning
51
- delete overlay.arrowProps.style.top;
52
- if (typeof overlay.arrowProps.style.left === 'number') {
53
- overlay.arrowProps.style.left -= arrowOffset;
54
- }
55
- }
56
- if (placement === 'left' || placement === 'right') {
57
- // @ts-expect-error workaround for correct positioning
58
- delete overlay.arrowProps.style.left;
59
- if (typeof overlay.arrowProps.style.top === 'number') {
60
- overlay.arrowProps.style.top -= arrowOffset;
61
- }
62
- }
63
-
64
- // Adjust top value by status bar height on Android
65
- if (Platform.OS === 'android' && StatusBar.currentHeight) {
66
- if (typeof overlay.overlayProps.style.top === 'number') {
67
- overlay.overlayProps.style.top -= StatusBar.currentHeight;
68
- }
69
- if (typeof overlay.arrowProps.style.top === 'number') {
70
- overlay.arrowProps.style.top -= StatusBar.currentHeight;
71
- }
72
- }
73
-
74
- return children(overlay, overlayRef);
75
- };
76
-
77
- Overlay.displayName = 'Overlay';
78
-
79
- export default Overlay;
1
+ import React, { useRef, ReactNode } from 'react';
2
+ import { Platform, StatusBar, ViewStyle } from 'react-native';
3
+ import { useOverlayPosition } from '@react-native-aria/overlays';
4
+ import type { ViewRef } from '../View';
5
+ import type { Placement, PlacementAxis } from '../../types';
6
+
7
+ type OverlayReturnType = {
8
+ placement: PlacementAxis;
9
+ rendered?: boolean;
10
+ overlayProps: {
11
+ style: ViewStyle;
12
+ };
13
+ arrowProps: {
14
+ style: ViewStyle;
15
+ };
16
+ };
17
+
18
+ interface OverlayProps {
19
+ children: (
20
+ overlay: OverlayReturnType,
21
+ overlayRef: React.RefObject<ViewRef | null>,
22
+ ) => ReactNode;
23
+ placement: Placement;
24
+ targetRef: React.RefObject<ViewRef | null>;
25
+ offset?: number;
26
+ arrowOffset?: number;
27
+ visible: boolean;
28
+ }
29
+
30
+ function Overlay({
31
+ children,
32
+ targetRef,
33
+ placement,
34
+ offset,
35
+ arrowOffset = 0,
36
+ visible,
37
+ }: OverlayProps) {
38
+ const overlayRef = useRef(null);
39
+
40
+ const overlay = useOverlayPosition({
41
+ placement,
42
+ targetRef,
43
+ overlayRef,
44
+ offset,
45
+ isOpen: visible,
46
+ });
47
+
48
+ // Remove unnecessary arrow styles and adjust arrow offset.
49
+ if (placement === 'top' || placement === 'bottom') {
50
+ // @ts-expect-error workaround for correct positioning
51
+ delete overlay.arrowProps.style.top;
52
+ if (typeof overlay.arrowProps.style.left === 'number') {
53
+ overlay.arrowProps.style.left -= arrowOffset;
54
+ }
55
+ }
56
+ if (placement === 'left' || placement === 'right') {
57
+ // @ts-expect-error workaround for correct positioning
58
+ delete overlay.arrowProps.style.left;
59
+ if (typeof overlay.arrowProps.style.top === 'number') {
60
+ overlay.arrowProps.style.top -= arrowOffset;
61
+ }
62
+ }
63
+
64
+ // Adjust top value by status bar height on Android
65
+ if (Platform.OS === 'android' && StatusBar.currentHeight) {
66
+ if (typeof overlay.overlayProps.style.top === 'number') {
67
+ overlay.overlayProps.style.top -= StatusBar.currentHeight;
68
+ }
69
+ if (typeof overlay.arrowProps.style.top === 'number') {
70
+ overlay.arrowProps.style.top -= StatusBar.currentHeight;
71
+ }
72
+ }
73
+
74
+ // Workaround for different calculation of height in Android 15
75
+ // https://github.com/facebook/react-native/issues/47080
76
+ if (
77
+ Platform.OS === 'android' &&
78
+ Platform.constants.Version >= 35 &&
79
+ StatusBar.currentHeight
80
+ ) {
81
+ if (typeof overlay.overlayProps.style.bottom === 'number') {
82
+ // Assuming height of bottom bar is 22
83
+ overlay.overlayProps.style.bottom -= StatusBar.currentHeight + 22;
84
+ }
85
+ }
86
+
87
+ return children(overlay, overlayRef);
88
+ }
89
+
90
+ Overlay.displayName = 'Overlay';
91
+
92
+ export default Overlay;
@@ -4,8 +4,8 @@ import { OverlayProvider } from '@react-native-aria/overlays';
4
4
  import StyleSheet from '../../style/StyleSheet';
5
5
  import { getStyles } from '../../utils';
6
6
  import css from '../../style/css';
7
- import ScrollView from '../ScrollView';
8
- import View, { ViewProps, ViewRef } from '../View';
7
+ import ScrollView, { ScrollViewRef, ScrollViewProps } from '../ScrollView';
8
+ import View, { ViewRef } from '../View';
9
9
  import BackdropHandler from '../helpers/BackdropHandler';
10
10
  import useModal from './useModal';
11
11
  import ModalContext from './ModalContext';
@@ -15,14 +15,13 @@ import ModalBody from './ModalBody';
15
15
  import ModalFooter from './ModalFooter';
16
16
  import { ExtendedTextStyle, ExtendedViewStyle, StyleProp } from '../../types';
17
17
 
18
- export interface ModalProps extends ViewProps {
18
+ export interface ModalProps extends ScrollViewProps {
19
19
  visible: boolean;
20
20
  size?: 'sm' | 'lg' | 'xl';
21
21
  backdrop?: boolean | 'static';
22
22
  scrollable?: boolean;
23
23
  centered?: boolean;
24
24
  onToggle: () => void;
25
- contentContainerStyle?: StyleProp<ExtendedViewStyle>;
26
25
  dialogStyle?: StyleProp<ExtendedViewStyle>;
27
26
  contentStyle?: StyleProp<ExtendedViewStyle>;
28
27
  dialogTextStyle?: StyleProp<ExtendedTextStyle>;
@@ -135,92 +134,94 @@ const styles = StyleSheet.create({
135
134
  `,
136
135
  });
137
136
 
138
- const Modal = React.forwardRef<ViewRef, ModalProps>((props, ref) => {
139
- const {
140
- children,
141
- visible,
142
- size,
143
- backdrop = true,
144
- scrollable = false,
145
- centered = false,
146
- onToggle: handleToggle,
147
- style,
148
- contentContainerStyle,
149
- dialogStyle,
150
- contentStyle,
151
- textStyle,
152
- dialogTextStyle,
153
- contentTextStyle,
154
- ...elementProps
155
- } = props;
137
+ const Modal = React.forwardRef<ViewRef | ScrollViewRef, ModalProps>(
138
+ (props, ref) => {
139
+ const {
140
+ children,
141
+ visible,
142
+ size,
143
+ backdrop = true,
144
+ scrollable = false,
145
+ centered = false,
146
+ onToggle: handleToggle,
147
+ style,
148
+ contentContainerStyle,
149
+ dialogStyle,
150
+ contentStyle,
151
+ textStyle,
152
+ dialogTextStyle,
153
+ contentTextStyle,
154
+ ...elementProps
155
+ } = props;
156
156
 
157
- const dialogRef = useRef(null);
157
+ const dialogRef = useRef(null);
158
158
 
159
- const modal = useModal(visible, scrollable);
159
+ const modal = useModal(visible, scrollable);
160
160
 
161
- const backdropClasses = getStyles(styles, ['.modal-backdrop']);
162
- const classes = getStyles(styles, ['.modal']);
163
- const dialogClasses = getStyles(styles, [
164
- '.modal-dialog',
165
- size === 'sm' && '.modal-sm',
166
- size === 'lg' && '.modal-lg',
167
- size === 'xl' && '.modal-xl',
168
- scrollable && '.modal-dialog-scrollable',
169
- centered && '.modal-dialog-centered',
170
- ]);
171
- const contentClasses = getStyles(styles, [
172
- '.modal-content',
173
- scrollable && '.modal-dialog-scrollable .modal-content',
174
- ]);
175
- const contentTextClasses = getStyles(styles, ['.modal-content --text']);
161
+ const backdropClasses = getStyles(styles, ['.modal-backdrop']);
162
+ const classes = getStyles(styles, ['.modal']);
163
+ const dialogClasses = getStyles(styles, [
164
+ '.modal-dialog',
165
+ size === 'sm' && '.modal-sm',
166
+ size === 'lg' && '.modal-lg',
167
+ size === 'xl' && '.modal-xl',
168
+ scrollable && '.modal-dialog-scrollable',
169
+ centered && '.modal-dialog-centered',
170
+ ]);
171
+ const contentClasses = getStyles(styles, [
172
+ '.modal-content',
173
+ scrollable && '.modal-dialog-scrollable .modal-content',
174
+ ]);
175
+ const contentTextClasses = getStyles(styles, ['.modal-content --text']);
176
176
 
177
- // If scrollable we use a ScrollView in ModalBody, so we can use a View here.
178
- const FlexView = scrollable ? View : ScrollView;
177
+ // If scrollable we use a ScrollView in ModalBody, so we can use a View here.
178
+ const FlexView = scrollable ? View : ScrollView;
179
179
 
180
- const centeredStyle = centered && {
181
- justifyContent: 'center' as JustifyContentValue,
182
- };
180
+ const centeredStyle = centered && {
181
+ justifyContent: 'center' as JustifyContentValue,
182
+ };
183
183
 
184
- return (
185
- <BaseModal transparent visible={visible} onRequestClose={handleToggle}>
186
- {backdrop && <View style={backdropClasses} />}
187
- <FlexView
188
- {...elementProps}
189
- // @ts-expect-error We need to fix it in the future.
190
- ref={ref}
191
- style={[classes, scrollable && centeredStyle, style]}
192
- textStyle={textStyle}
193
- contentContainerStyle={
194
- scrollable
195
- ? undefined
196
- : [{ flexGrow: 1 }, centeredStyle, contentContainerStyle]
197
- }
198
- >
199
- <BackdropHandler
200
- dialogRef={dialogRef}
201
- onClose={handleToggle}
202
- backdrop={backdrop}
203
- />
204
- <SafeAreaView style={{ flexShrink: 1 }}>
205
- <View
206
- ref={dialogRef}
207
- style={[dialogClasses, dialogStyle]}
208
- textStyle={dialogTextStyle}
209
- >
184
+ return (
185
+ <BaseModal transparent visible={visible} onRequestClose={handleToggle}>
186
+ {backdrop && <View style={backdropClasses} />}
187
+ <FlexView
188
+ {...elementProps}
189
+ // @ts-expect-error Type of ref depends on component.
190
+ ref={ref}
191
+ style={[classes, scrollable && centeredStyle, style]}
192
+ textStyle={textStyle}
193
+ contentContainerStyle={
194
+ scrollable
195
+ ? undefined
196
+ : [{ flexGrow: 1 }, centeredStyle, contentContainerStyle]
197
+ }
198
+ >
199
+ <BackdropHandler
200
+ dialogRef={dialogRef}
201
+ onClose={handleToggle}
202
+ backdrop={backdrop}
203
+ />
204
+ <SafeAreaView style={{ flexShrink: 1 }}>
210
205
  <View
211
- style={[contentClasses, contentStyle]}
212
- textStyle={[contentTextClasses, contentTextStyle]}
206
+ ref={dialogRef}
207
+ style={[dialogClasses, dialogStyle]}
208
+ textStyle={dialogTextStyle}
213
209
  >
214
- <ModalContext.Provider value={modal}>
215
- <OverlayProvider>{children}</OverlayProvider>
216
- </ModalContext.Provider>
210
+ <View
211
+ style={[contentClasses, contentStyle]}
212
+ textStyle={[contentTextClasses, contentTextStyle]}
213
+ >
214
+ <ModalContext.Provider value={modal}>
215
+ <OverlayProvider>{children}</OverlayProvider>
216
+ </ModalContext.Provider>
217
+ </View>
217
218
  </View>
218
- </View>
219
- </SafeAreaView>
220
- </FlexView>
221
- </BaseModal>
222
- );
223
- });
219
+ </SafeAreaView>
220
+ </FlexView>
221
+ </BaseModal>
222
+ );
223
+ },
224
+ );
224
225
 
225
226
  Modal.displayName = 'Modal';
226
227