@expo/ui 56.0.17 → 56.0.19

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 (434) hide show
  1. package/CHANGELOG.md +36 -0
  2. package/android/build.gradle +2 -2
  3. package/android/src/main/java/expo/modules/ui/DatePickerView.kt +33 -8
  4. package/android/src/main/java/expo/modules/ui/ModalBottomSheetView.kt +14 -0
  5. package/build/community/bottom-sheet/BottomSheet.android.d.ts.map +1 -1
  6. package/build/community/bottom-sheet/BottomSheet.ios.d.ts.map +1 -1
  7. package/build/community/bottom-sheet/scrollContextReset.d.ts +5 -0
  8. package/build/community/bottom-sheet/scrollContextReset.d.ts.map +1 -0
  9. package/build/community/datetime-picker/DateTimePicker.d.ts.map +1 -1
  10. package/build/community/datetime-picker/types.d.ts +2 -2
  11. package/build/community/datetime-picker/types.d.ts.map +1 -1
  12. package/build/community/menu/types.d.ts +2 -2
  13. package/build/community/menu/types.d.ts.map +1 -1
  14. package/build/community/pager-view/PagerView.android.d.ts.map +1 -1
  15. package/build/community/pager-view/types.d.ts +2 -2
  16. package/build/community/pager-view/types.d.ts.map +1 -1
  17. package/build/community/segmented-control/types.d.ts +2 -2
  18. package/build/community/segmented-control/types.d.ts.map +1 -1
  19. package/build/community/slider/types.d.ts +2 -2
  20. package/build/community/slider/types.d.ts.map +1 -1
  21. package/build/jetpack-compose/AlertDialog/index.d.ts +2 -2
  22. package/build/jetpack-compose/AlertDialog/index.d.ts.map +1 -1
  23. package/build/jetpack-compose/AnimatedVisibility/index.d.ts +2 -2
  24. package/build/jetpack-compose/AnimatedVisibility/index.d.ts.map +1 -1
  25. package/build/jetpack-compose/Badge/index.d.ts +2 -2
  26. package/build/jetpack-compose/Badge/index.d.ts.map +1 -1
  27. package/build/jetpack-compose/BadgedBox/index.d.ts +2 -2
  28. package/build/jetpack-compose/BadgedBox/index.d.ts.map +1 -1
  29. package/build/jetpack-compose/BasicAlertDialog/index.d.ts +2 -2
  30. package/build/jetpack-compose/BasicAlertDialog/index.d.ts.map +1 -1
  31. package/build/jetpack-compose/Box/index.d.ts +2 -2
  32. package/build/jetpack-compose/Box/index.d.ts.map +1 -1
  33. package/build/jetpack-compose/Button/index.d.ts +2 -2
  34. package/build/jetpack-compose/Button/index.d.ts.map +1 -1
  35. package/build/jetpack-compose/Card/index.d.ts +6 -6
  36. package/build/jetpack-compose/Card/index.d.ts.map +1 -1
  37. package/build/jetpack-compose/Carousel/index.d.ts +6 -6
  38. package/build/jetpack-compose/Carousel/index.d.ts.map +1 -1
  39. package/build/jetpack-compose/Checkbox/index.d.ts +4 -4
  40. package/build/jetpack-compose/Checkbox/index.d.ts.map +1 -1
  41. package/build/jetpack-compose/Chip/index.d.ts +8 -8
  42. package/build/jetpack-compose/Chip/index.d.ts.map +1 -1
  43. package/build/jetpack-compose/Column/index.d.ts +2 -2
  44. package/build/jetpack-compose/Column/index.d.ts.map +1 -1
  45. package/build/jetpack-compose/DatePicker/index.d.ts +6 -6
  46. package/build/jetpack-compose/DatePicker/index.d.ts.map +1 -1
  47. package/build/jetpack-compose/DockedSearchBar/index.d.ts +2 -2
  48. package/build/jetpack-compose/DockedSearchBar/index.d.ts.map +1 -1
  49. package/build/jetpack-compose/DropdownMenu/DropdownMenuItem.d.ts +2 -2
  50. package/build/jetpack-compose/DropdownMenu/DropdownMenuItem.d.ts.map +1 -1
  51. package/build/jetpack-compose/DropdownMenu/index.d.ts +2 -2
  52. package/build/jetpack-compose/DropdownMenu/index.d.ts.map +1 -1
  53. package/build/jetpack-compose/ExposedDropdownMenuBox/ExposedDropdownMenu.d.ts +2 -2
  54. package/build/jetpack-compose/ExposedDropdownMenuBox/ExposedDropdownMenu.d.ts.map +1 -1
  55. package/build/jetpack-compose/ExposedDropdownMenuBox/index.d.ts +2 -2
  56. package/build/jetpack-compose/ExposedDropdownMenuBox/index.d.ts.map +1 -1
  57. package/build/jetpack-compose/FloatingActionButton/index.d.ts +8 -6
  58. package/build/jetpack-compose/FloatingActionButton/index.d.ts.map +1 -1
  59. package/build/jetpack-compose/FlowRow/index.d.ts +2 -2
  60. package/build/jetpack-compose/FlowRow/index.d.ts.map +1 -1
  61. package/build/jetpack-compose/HorizontalFloatingToolbar/index.d.ts +4 -4
  62. package/build/jetpack-compose/HorizontalFloatingToolbar/index.d.ts.map +1 -1
  63. package/build/jetpack-compose/HorizontalPager/index.d.ts +2 -2
  64. package/build/jetpack-compose/HorizontalPager/index.d.ts.map +1 -1
  65. package/build/jetpack-compose/Host/index.d.ts +2 -2
  66. package/build/jetpack-compose/Host/index.d.ts.map +1 -1
  67. package/build/jetpack-compose/Icon/index.d.ts +2 -2
  68. package/build/jetpack-compose/Icon/index.d.ts.map +1 -1
  69. package/build/jetpack-compose/IconButton/index.d.ts +2 -2
  70. package/build/jetpack-compose/IconButton/index.d.ts.map +1 -1
  71. package/build/jetpack-compose/LazyColumn/index.d.ts +2 -2
  72. package/build/jetpack-compose/LazyColumn/index.d.ts.map +1 -1
  73. package/build/jetpack-compose/LazyRow/index.d.ts +2 -2
  74. package/build/jetpack-compose/LazyRow/index.d.ts.map +1 -1
  75. package/build/jetpack-compose/ListItem/index.d.ts +2 -2
  76. package/build/jetpack-compose/ListItem/index.d.ts.map +1 -1
  77. package/build/jetpack-compose/LoadingIndicator/index.d.ts +2 -2
  78. package/build/jetpack-compose/LoadingIndicator/index.d.ts.map +1 -1
  79. package/build/jetpack-compose/ModalBottomSheet/index.d.ts +8 -2
  80. package/build/jetpack-compose/ModalBottomSheet/index.d.ts.map +1 -1
  81. package/build/jetpack-compose/MultiChoiceSegmentedButtonRow/index.d.ts +2 -2
  82. package/build/jetpack-compose/MultiChoiceSegmentedButtonRow/index.d.ts.map +1 -1
  83. package/build/jetpack-compose/NavigationBar/index.d.ts +4 -4
  84. package/build/jetpack-compose/NavigationBar/index.d.ts.map +1 -1
  85. package/build/jetpack-compose/Progress/index.d.ts +9 -8
  86. package/build/jetpack-compose/Progress/index.d.ts.map +1 -1
  87. package/build/jetpack-compose/PullToRefreshBox/index.d.ts +4 -4
  88. package/build/jetpack-compose/PullToRefreshBox/index.d.ts.map +1 -1
  89. package/build/jetpack-compose/RNHostView/index.d.ts +8 -0
  90. package/build/jetpack-compose/RNHostView/index.d.ts.map +1 -1
  91. package/build/jetpack-compose/RadioButton/index.d.ts +2 -2
  92. package/build/jetpack-compose/RadioButton/index.d.ts.map +1 -1
  93. package/build/jetpack-compose/Row/index.d.ts +2 -2
  94. package/build/jetpack-compose/Row/index.d.ts.map +1 -1
  95. package/build/jetpack-compose/SearchBar/index.d.ts +2 -2
  96. package/build/jetpack-compose/SearchBar/index.d.ts.map +1 -1
  97. package/build/jetpack-compose/SegmentedButton/index.d.ts +2 -2
  98. package/build/jetpack-compose/SegmentedButton/index.d.ts.map +1 -1
  99. package/build/jetpack-compose/Shape/index.d.ts +2 -2
  100. package/build/jetpack-compose/Shape/index.d.ts.map +1 -1
  101. package/build/jetpack-compose/SingleChoiceSegmentedButtonRow/index.d.ts +2 -2
  102. package/build/jetpack-compose/SingleChoiceSegmentedButtonRow/index.d.ts.map +1 -1
  103. package/build/jetpack-compose/Slider/index.d.ts +2 -2
  104. package/build/jetpack-compose/Slider/index.d.ts.map +1 -1
  105. package/build/jetpack-compose/Snackbar/index.d.ts +4 -4
  106. package/build/jetpack-compose/Snackbar/index.d.ts.map +1 -1
  107. package/build/jetpack-compose/Spacer/index.d.ts +2 -2
  108. package/build/jetpack-compose/Spacer/index.d.ts.map +1 -1
  109. package/build/jetpack-compose/Surface/index.d.ts +2 -2
  110. package/build/jetpack-compose/Surface/index.d.ts.map +1 -1
  111. package/build/jetpack-compose/Switch/index.d.ts +2 -2
  112. package/build/jetpack-compose/Switch/index.d.ts.map +1 -1
  113. package/build/jetpack-compose/SyncSwitch/index.d.ts +2 -2
  114. package/build/jetpack-compose/SyncSwitch/index.d.ts.map +1 -1
  115. package/build/jetpack-compose/Text/index.d.ts +2 -2
  116. package/build/jetpack-compose/Text/index.d.ts.map +1 -1
  117. package/build/jetpack-compose/TextField/BasicTextField.d.ts +2 -2
  118. package/build/jetpack-compose/TextField/BasicTextField.d.ts.map +1 -1
  119. package/build/jetpack-compose/TextField/TextField.d.ts +4 -4
  120. package/build/jetpack-compose/TextField/TextField.d.ts.map +1 -1
  121. package/build/jetpack-compose/ToggleButton/index.d.ts +2 -2
  122. package/build/jetpack-compose/ToggleButton/index.d.ts.map +1 -1
  123. package/build/jetpack-compose/Tooltip/index.d.ts +6 -6
  124. package/build/jetpack-compose/Tooltip/index.d.ts.map +1 -1
  125. package/build/swift-ui/AccessoryWidgetBackground/index.d.ts +2 -1
  126. package/build/swift-ui/AccessoryWidgetBackground/index.d.ts.map +1 -1
  127. package/build/swift-ui/Alert/index.d.ts +2 -2
  128. package/build/swift-ui/Alert/index.d.ts.map +1 -1
  129. package/build/swift-ui/BottomSheet/index.d.ts +2 -2
  130. package/build/swift-ui/BottomSheet/index.d.ts.map +1 -1
  131. package/build/swift-ui/Button/index.d.ts +2 -2
  132. package/build/swift-ui/Button/index.d.ts.map +1 -1
  133. package/build/swift-ui/Chart/index.d.ts +2 -2
  134. package/build/swift-ui/Chart/index.d.ts.map +1 -1
  135. package/build/swift-ui/ColorPicker/index.d.ts +2 -2
  136. package/build/swift-ui/ColorPicker/index.d.ts.map +1 -1
  137. package/build/swift-ui/ConfirmationDialog/index.d.ts +2 -2
  138. package/build/swift-ui/ConfirmationDialog/index.d.ts.map +1 -1
  139. package/build/swift-ui/ContextMenu/types.d.ts +4 -4
  140. package/build/swift-ui/ContextMenu/types.d.ts.map +1 -1
  141. package/build/swift-ui/DatePicker/index.d.ts +2 -2
  142. package/build/swift-ui/DatePicker/index.d.ts.map +1 -1
  143. package/build/swift-ui/Divider/index.d.ts +2 -1
  144. package/build/swift-ui/Divider/index.d.ts.map +1 -1
  145. package/build/swift-ui/Gauge/index.d.ts +2 -2
  146. package/build/swift-ui/Gauge/index.d.ts.map +1 -1
  147. package/build/swift-ui/GlassEffectContainer/index.d.ts +2 -2
  148. package/build/swift-ui/GlassEffectContainer/index.d.ts.map +1 -1
  149. package/build/swift-ui/Grid/index.d.ts +2 -2
  150. package/build/swift-ui/Grid/index.d.ts.map +1 -1
  151. package/build/swift-ui/HStack/index.d.ts +2 -2
  152. package/build/swift-ui/HStack/index.d.ts.map +1 -1
  153. package/build/swift-ui/Host/index.d.ts +9 -3
  154. package/build/swift-ui/Host/index.d.ts.map +1 -1
  155. package/build/swift-ui/Label/index.d.ts +2 -2
  156. package/build/swift-ui/Label/index.d.ts.map +1 -1
  157. package/build/swift-ui/LabeledContent/index.d.ts +2 -2
  158. package/build/swift-ui/LabeledContent/index.d.ts.map +1 -1
  159. package/build/swift-ui/LazyHStack/index.d.ts +2 -2
  160. package/build/swift-ui/LazyHStack/index.d.ts.map +1 -1
  161. package/build/swift-ui/LazyVStack/index.d.ts +2 -2
  162. package/build/swift-ui/LazyVStack/index.d.ts.map +1 -1
  163. package/build/swift-ui/Link/index.d.ts +2 -2
  164. package/build/swift-ui/Link/index.d.ts.map +1 -1
  165. package/build/swift-ui/List/ListForEach.d.ts +2 -2
  166. package/build/swift-ui/List/ListForEach.d.ts.map +1 -1
  167. package/build/swift-ui/Mask/index.d.ts +2 -2
  168. package/build/swift-ui/Mask/index.d.ts.map +1 -1
  169. package/build/swift-ui/Menu/types.d.ts +2 -2
  170. package/build/swift-ui/Menu/types.d.ts.map +1 -1
  171. package/build/swift-ui/Namespace.d.ts +2 -2
  172. package/build/swift-ui/Namespace.d.ts.map +1 -1
  173. package/build/swift-ui/Overlay/index.d.ts +2 -2
  174. package/build/swift-ui/Overlay/index.d.ts.map +1 -1
  175. package/build/swift-ui/Popover/index.d.ts +2 -2
  176. package/build/swift-ui/Popover/index.d.ts.map +1 -1
  177. package/build/swift-ui/ProgressView/index.d.ts +2 -2
  178. package/build/swift-ui/ProgressView/index.d.ts.map +1 -1
  179. package/build/swift-ui/RNHostView.d.ts +2 -2
  180. package/build/swift-ui/RNHostView.d.ts.map +1 -1
  181. package/build/swift-ui/ScrollView/index.d.ts +2 -2
  182. package/build/swift-ui/ScrollView/index.d.ts.map +1 -1
  183. package/build/swift-ui/Section/index.d.ts +2 -2
  184. package/build/swift-ui/Section/index.d.ts.map +1 -1
  185. package/build/swift-ui/SecureField/index.d.ts +2 -2
  186. package/build/swift-ui/SecureField/index.d.ts.map +1 -1
  187. package/build/swift-ui/ShareLink/index.d.ts +2 -2
  188. package/build/swift-ui/ShareLink/index.d.ts.map +1 -1
  189. package/build/swift-ui/Slider/index.d.ts +2 -2
  190. package/build/swift-ui/Slider/index.d.ts.map +1 -1
  191. package/build/swift-ui/Stepper/index.d.ts +2 -2
  192. package/build/swift-ui/Stepper/index.d.ts.map +1 -1
  193. package/build/swift-ui/SwipeActions/index.d.ts +4 -4
  194. package/build/swift-ui/SwipeActions/index.d.ts.map +1 -1
  195. package/build/swift-ui/SyncToggle/index.d.ts +2 -2
  196. package/build/swift-ui/SyncToggle/index.d.ts.map +1 -1
  197. package/build/swift-ui/TabView/Tab.d.ts +2 -2
  198. package/build/swift-ui/TabView/Tab.d.ts.map +1 -1
  199. package/build/swift-ui/TabView/index.d.ts +2 -2
  200. package/build/swift-ui/TabView/index.d.ts.map +1 -1
  201. package/build/swift-ui/TextField/index.d.ts +2 -2
  202. package/build/swift-ui/TextField/index.d.ts.map +1 -1
  203. package/build/swift-ui/Toggle/index.d.ts +2 -2
  204. package/build/swift-ui/Toggle/index.d.ts.map +1 -1
  205. package/build/swift-ui/VStack/index.d.ts +2 -2
  206. package/build/swift-ui/VStack/index.d.ts.map +1 -1
  207. package/build/swift-ui/ZStack/index.d.ts +2 -2
  208. package/build/swift-ui/ZStack/index.d.ts.map +1 -1
  209. package/build/swift-ui/modifiers/index.d.ts +60 -2
  210. package/build/swift-ui/modifiers/index.d.ts.map +1 -1
  211. package/build/swift-ui/modifiers/presentationModifiers.d.ts +19 -0
  212. package/build/swift-ui/modifiers/presentationModifiers.d.ts.map +1 -1
  213. package/build/swift-ui/modifiers/widgets.d.ts +7 -0
  214. package/build/swift-ui/modifiers/widgets.d.ts.map +1 -1
  215. package/build/universal/Button/index.d.ts.map +1 -1
  216. package/build/universal/Button/index.ios.d.ts.map +1 -1
  217. package/build/universal/Checkbox/index.d.ts.map +1 -1
  218. package/build/universal/Collapsible/index.d.ts.map +1 -1
  219. package/build/universal/FieldGroup/FieldGroup.d.ts.map +1 -1
  220. package/build/universal/FieldGroup/FieldSection.d.ts.map +1 -1
  221. package/build/universal/FieldGroup/FieldSectionSlots.d.ts.map +1 -1
  222. package/build/universal/FieldGroup/groupChildren.d.ts.map +1 -1
  223. package/build/universal/Host/index.d.ts +1 -2
  224. package/build/universal/Host/index.d.ts.map +1 -1
  225. package/build/universal/Host/types.d.ts +16 -2
  226. package/build/universal/Host/types.d.ts.map +1 -1
  227. package/build/universal/ListItem/ListItem.android.d.ts.map +1 -1
  228. package/build/universal/ListItem/ListItem.ios.d.ts.map +1 -1
  229. package/build/universal/ListItem/types.d.ts +8 -0
  230. package/build/universal/ListItem/types.d.ts.map +1 -1
  231. package/build/universal/Picker/Picker.d.ts.map +1 -1
  232. package/build/universal/Slider/index.d.ts.map +1 -1
  233. package/build/universal/Switch/index.d.ts.map +1 -1
  234. package/build/universal/Text/index.ios.d.ts.map +1 -1
  235. package/build/universal/TextInput/index.d.ts.map +1 -1
  236. package/build/universal/hooks.d.ts +11 -0
  237. package/build/universal/hooks.d.ts.map +1 -1
  238. package/build/universal/keyboardEvent.fx.d.ts +2 -0
  239. package/build/universal/keyboardEvent.fx.d.ts.map +1 -0
  240. package/build/universal/modifierUtils.d.ts +16 -0
  241. package/build/universal/modifierUtils.d.ts.map +1 -0
  242. package/build/universal/transformStyle.android.d.ts +3 -0
  243. package/build/universal/transformStyle.android.d.ts.map +1 -1
  244. package/build/universal/transformStyle.ios.d.ts +3 -0
  245. package/build/universal/transformStyle.ios.d.ts.map +1 -1
  246. package/build/universal/types.d.ts +2 -0
  247. package/build/universal/types.d.ts.map +1 -1
  248. package/build/universal/webUtils.d.ts +66 -0
  249. package/build/universal/webUtils.d.ts.map +1 -0
  250. package/expo-module.config.json +1 -1
  251. package/ios/HostView.swift +15 -0
  252. package/ios/Modifiers/PresentationModifiers.swift +30 -0
  253. package/ios/Modifiers/ViewModifierRegistry.swift +119 -11
  254. package/ios/Modifiers/WidgetModifiers.swift +12 -0
  255. package/ios/RNHostView.swift +5 -0
  256. package/local-maven-repo/expo/modules/ui/expo.modules.ui/{56.0.17/expo.modules.ui-56.0.17-sources.jar → 56.0.19/expo.modules.ui-56.0.19-sources.jar} +0 -0
  257. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19-sources.jar.md5 +1 -0
  258. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19-sources.jar.sha1 +1 -0
  259. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19-sources.jar.sha256 +1 -0
  260. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19-sources.jar.sha512 +1 -0
  261. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.aar +0 -0
  262. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.aar.md5 +1 -0
  263. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.aar.sha1 +1 -0
  264. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.aar.sha256 +1 -0
  265. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.aar.sha512 +1 -0
  266. package/local-maven-repo/expo/modules/ui/expo.modules.ui/{56.0.17/expo.modules.ui-56.0.17.module → 56.0.19/expo.modules.ui-56.0.19.module} +22 -22
  267. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.module.md5 +1 -0
  268. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.module.sha1 +1 -0
  269. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.module.sha256 +1 -0
  270. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.module.sha512 +1 -0
  271. package/local-maven-repo/expo/modules/ui/expo.modules.ui/{56.0.17/expo.modules.ui-56.0.17.pom → 56.0.19/expo.modules.ui-56.0.19.pom} +1 -1
  272. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.pom.md5 +1 -0
  273. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.pom.sha1 +1 -0
  274. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.pom.sha256 +1 -0
  275. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.19/expo.modules.ui-56.0.19.pom.sha512 +1 -0
  276. package/local-maven-repo/expo/modules/ui/expo.modules.ui/maven-metadata.xml +4 -4
  277. package/local-maven-repo/expo/modules/ui/expo.modules.ui/maven-metadata.xml.md5 +1 -1
  278. package/local-maven-repo/expo/modules/ui/expo.modules.ui/maven-metadata.xml.sha1 +1 -1
  279. package/local-maven-repo/expo/modules/ui/expo.modules.ui/maven-metadata.xml.sha256 +1 -1
  280. package/local-maven-repo/expo/modules/ui/expo.modules.ui/maven-metadata.xml.sha512 +1 -1
  281. package/package.json +4 -9
  282. package/plugin/tsconfig.tsbuildinfo +1 -0
  283. package/src/State/index.fx.ts +4 -5
  284. package/src/community/bottom-sheet/BottomSheet.android.tsx +8 -14
  285. package/src/community/bottom-sheet/BottomSheet.ios.tsx +9 -5
  286. package/src/community/bottom-sheet/scrollContextReset.tsx +24 -0
  287. package/src/community/datetime-picker/DateTimePicker.tsx +9 -1
  288. package/src/community/datetime-picker/types.tsx +2 -2
  289. package/src/community/menu/types.tsx +2 -2
  290. package/src/community/pager-view/PagerView.android.tsx +10 -6
  291. package/src/community/pager-view/types.tsx +2 -2
  292. package/src/community/segmented-control/types.tsx +2 -2
  293. package/src/community/slider/types.tsx +2 -2
  294. package/src/jetpack-compose/AlertDialog/index.tsx +2 -2
  295. package/src/jetpack-compose/AnimatedVisibility/index.tsx +2 -2
  296. package/src/jetpack-compose/Badge/index.tsx +2 -2
  297. package/src/jetpack-compose/BadgedBox/index.tsx +2 -2
  298. package/src/jetpack-compose/BasicAlertDialog/index.tsx +2 -2
  299. package/src/jetpack-compose/Box/index.tsx +2 -2
  300. package/src/jetpack-compose/Button/index.tsx +2 -2
  301. package/src/jetpack-compose/Card/index.tsx +6 -6
  302. package/src/jetpack-compose/Carousel/index.tsx +6 -6
  303. package/src/jetpack-compose/Checkbox/index.tsx +4 -4
  304. package/src/jetpack-compose/Chip/index.tsx +8 -8
  305. package/src/jetpack-compose/Column/index.tsx +2 -2
  306. package/src/jetpack-compose/DatePicker/index.tsx +6 -6
  307. package/src/jetpack-compose/DockedSearchBar/index.tsx +2 -2
  308. package/src/jetpack-compose/DropdownMenu/DropdownMenuItem.tsx +2 -2
  309. package/src/jetpack-compose/DropdownMenu/index.tsx +2 -2
  310. package/src/jetpack-compose/ExposedDropdownMenuBox/ExposedDropdownMenu.tsx +2 -2
  311. package/src/jetpack-compose/ExposedDropdownMenuBox/index.tsx +2 -2
  312. package/src/jetpack-compose/FloatingActionButton/index.tsx +6 -6
  313. package/src/jetpack-compose/FlowRow/index.tsx +2 -2
  314. package/src/jetpack-compose/HorizontalFloatingToolbar/index.tsx +4 -4
  315. package/src/jetpack-compose/HorizontalPager/index.tsx +2 -2
  316. package/src/jetpack-compose/Host/index.tsx +2 -2
  317. package/src/jetpack-compose/Icon/index.tsx +2 -2
  318. package/src/jetpack-compose/IconButton/index.tsx +2 -2
  319. package/src/jetpack-compose/LazyColumn/index.tsx +2 -2
  320. package/src/jetpack-compose/LazyRow/index.tsx +2 -2
  321. package/src/jetpack-compose/ListItem/index.tsx +2 -2
  322. package/src/jetpack-compose/LoadingIndicator/index.tsx +2 -2
  323. package/src/jetpack-compose/ModalBottomSheet/index.tsx +9 -2
  324. package/src/jetpack-compose/MultiChoiceSegmentedButtonRow/index.tsx +2 -2
  325. package/src/jetpack-compose/NavigationBar/index.tsx +4 -4
  326. package/src/jetpack-compose/Progress/index.tsx +7 -7
  327. package/src/jetpack-compose/PullToRefreshBox/index.tsx +4 -4
  328. package/src/jetpack-compose/RNHostView/index.tsx +8 -0
  329. package/src/jetpack-compose/RadioButton/index.tsx +2 -2
  330. package/src/jetpack-compose/Row/index.tsx +2 -2
  331. package/src/jetpack-compose/SearchBar/index.tsx +2 -2
  332. package/src/jetpack-compose/SegmentedButton/index.tsx +2 -2
  333. package/src/jetpack-compose/Shape/index.tsx +2 -2
  334. package/src/jetpack-compose/SingleChoiceSegmentedButtonRow/index.tsx +2 -2
  335. package/src/jetpack-compose/Slider/index.tsx +2 -2
  336. package/src/jetpack-compose/Snackbar/index.tsx +4 -4
  337. package/src/jetpack-compose/Spacer/index.tsx +2 -2
  338. package/src/jetpack-compose/Surface/index.tsx +2 -2
  339. package/src/jetpack-compose/Switch/index.tsx +2 -2
  340. package/src/jetpack-compose/SyncSwitch/index.tsx +2 -2
  341. package/src/jetpack-compose/Text/index.tsx +2 -2
  342. package/src/jetpack-compose/TextField/BasicTextField.tsx +2 -2
  343. package/src/jetpack-compose/TextField/TextField.tsx +4 -4
  344. package/src/jetpack-compose/ToggleButton/index.tsx +2 -2
  345. package/src/jetpack-compose/Tooltip/index.tsx +6 -6
  346. package/src/swift-ui/AccessoryWidgetBackground/index.tsx +1 -1
  347. package/src/swift-ui/Alert/index.tsx +2 -2
  348. package/src/swift-ui/BottomSheet/index.tsx +2 -2
  349. package/src/swift-ui/Button/index.tsx +2 -2
  350. package/src/swift-ui/Chart/index.tsx +2 -2
  351. package/src/swift-ui/ColorPicker/index.tsx +2 -2
  352. package/src/swift-ui/ConfirmationDialog/index.tsx +2 -2
  353. package/src/swift-ui/ContextMenu/types.ts +4 -4
  354. package/src/swift-ui/DatePicker/index.tsx +2 -2
  355. package/src/swift-ui/Divider/index.tsx +1 -1
  356. package/src/swift-ui/Gauge/index.tsx +2 -2
  357. package/src/swift-ui/GlassEffectContainer/index.tsx +2 -2
  358. package/src/swift-ui/Grid/index.tsx +2 -2
  359. package/src/swift-ui/HStack/index.tsx +2 -2
  360. package/src/swift-ui/Host/index.tsx +12 -3
  361. package/src/swift-ui/Label/index.tsx +2 -2
  362. package/src/swift-ui/LabeledContent/index.tsx +2 -2
  363. package/src/swift-ui/LazyHStack/index.tsx +2 -2
  364. package/src/swift-ui/LazyVStack/index.tsx +2 -2
  365. package/src/swift-ui/Link/index.tsx +2 -2
  366. package/src/swift-ui/List/ListForEach.tsx +2 -2
  367. package/src/swift-ui/Mask/index.tsx +2 -2
  368. package/src/swift-ui/Menu/types.ts +2 -2
  369. package/src/swift-ui/Namespace.tsx +2 -2
  370. package/src/swift-ui/Overlay/index.tsx +2 -2
  371. package/src/swift-ui/Popover/index.tsx +2 -2
  372. package/src/swift-ui/ProgressView/index.tsx +2 -2
  373. package/src/swift-ui/RNHostView.tsx +2 -2
  374. package/src/swift-ui/ScrollView/index.tsx +2 -2
  375. package/src/swift-ui/Section/index.tsx +2 -2
  376. package/src/swift-ui/SecureField/index.tsx +2 -2
  377. package/src/swift-ui/ShareLink/index.tsx +2 -2
  378. package/src/swift-ui/Slider/index.tsx +2 -2
  379. package/src/swift-ui/Stepper/index.tsx +2 -2
  380. package/src/swift-ui/SwipeActions/index.tsx +4 -4
  381. package/src/swift-ui/SyncToggle/index.tsx +2 -2
  382. package/src/swift-ui/TabView/Tab.tsx +2 -2
  383. package/src/swift-ui/TabView/index.tsx +2 -2
  384. package/src/swift-ui/TextField/index.tsx +2 -2
  385. package/src/swift-ui/Toggle/index.tsx +2 -2
  386. package/src/swift-ui/VStack/index.tsx +2 -2
  387. package/src/swift-ui/ZStack/index.tsx +2 -2
  388. package/src/swift-ui/modifiers/index.ts +82 -1
  389. package/src/swift-ui/modifiers/presentationModifiers.ts +22 -0
  390. package/src/swift-ui/modifiers/widgets.ts +9 -0
  391. package/src/ts-declarations/react-native-web.d.ts +31 -3
  392. package/src/universal/Button/index.ios.tsx +6 -1
  393. package/src/universal/Button/index.tsx +83 -35
  394. package/src/universal/Checkbox/index.tsx +85 -30
  395. package/src/universal/Collapsible/index.tsx +5 -17
  396. package/src/universal/FieldGroup/FieldGroup.tsx +5 -15
  397. package/src/universal/FieldGroup/FieldSection.tsx +14 -31
  398. package/src/universal/FieldGroup/FieldSectionSlots.tsx +3 -0
  399. package/src/universal/FieldGroup/groupChildren.tsx +3 -0
  400. package/src/universal/Host/index.tsx +44 -30
  401. package/src/universal/Host/types.ts +17 -2
  402. package/src/universal/ListItem/ListItem.android.tsx +10 -2
  403. package/src/universal/ListItem/ListItem.ios.tsx +23 -6
  404. package/src/universal/ListItem/types.ts +10 -0
  405. package/src/universal/Picker/Picker.tsx +74 -29
  406. package/src/universal/Slider/index.tsx +90 -9
  407. package/src/universal/Switch/index.android.tsx +2 -2
  408. package/src/universal/Switch/index.tsx +77 -18
  409. package/src/universal/Text/index.ios.tsx +3 -1
  410. package/src/universal/TextInput/index.tsx +49 -13
  411. package/src/universal/hooks.ts +25 -1
  412. package/src/universal/keyboardEvent.fx.ts +28 -0
  413. package/src/universal/modifierUtils.ts +23 -0
  414. package/src/universal/transformStyle.android.ts +9 -1
  415. package/src/universal/transformStyle.ios.ts +9 -1
  416. package/src/universal/types.ts +2 -0
  417. package/src/universal/webUtils.ts +245 -0
  418. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17-sources.jar.md5 +0 -1
  419. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17-sources.jar.sha1 +0 -1
  420. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17-sources.jar.sha256 +0 -1
  421. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17-sources.jar.sha512 +0 -1
  422. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.aar +0 -0
  423. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.aar.md5 +0 -1
  424. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.aar.sha1 +0 -1
  425. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.aar.sha256 +0 -1
  426. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.aar.sha512 +0 -1
  427. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.module.md5 +0 -1
  428. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.module.sha1 +0 -1
  429. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.module.sha256 +0 -1
  430. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.module.sha512 +0 -1
  431. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.pom.md5 +0 -1
  432. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.pom.sha1 +0 -1
  433. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.pom.sha256 +0 -1
  434. package/local-maven-repo/expo/modules/ui/expo.modules.ui/56.0.17/expo.modules.ui-56.0.17.pom.sha512 +0 -1
@@ -98,7 +98,7 @@ export type TimePickerElementColors = {
98
98
  timeSelectorUnselectedContentColor?: ColorValue;
99
99
  };
100
100
 
101
- export type DateTimePickerProps = {
101
+ export interface DateTimePickerProps {
102
102
  /**
103
103
  * The initial date to display on the picker.
104
104
  */
@@ -154,7 +154,7 @@ export type DateTimePickerProps = {
154
154
  * Modifiers for the component.
155
155
  */
156
156
  modifiers?: ModifierConfig[];
157
- };
157
+ }
158
158
 
159
159
  type NativeDatePickerProps = Omit<
160
160
  DateTimePickerProps,
@@ -212,7 +212,7 @@ export function DateTimePicker(props: DateTimePickerProps) {
212
212
 
213
213
  // -- Dialog views (used internally by the compat layer) ---------------------
214
214
 
215
- export type DatePickerDialogProps = {
215
+ export interface DatePickerDialogProps {
216
216
  initialDate?: string | null;
217
217
  variant?: AndroidVariant;
218
218
  showVariantToggle?: boolean;
@@ -223,7 +223,7 @@ export type DatePickerDialogProps = {
223
223
  selectableDates?: { start?: Date; end?: Date };
224
224
  onDateSelected?: (date: Date) => void;
225
225
  onDismissRequest: () => void;
226
- };
226
+ }
227
227
 
228
228
  type NativeDatePickerDialogProps = Omit<
229
229
  DatePickerDialogProps,
@@ -260,7 +260,7 @@ export function DatePickerDialog(props: DatePickerDialogProps) {
260
260
  return <DatePickerDialogNativeView {...nativeProps} />;
261
261
  }
262
262
 
263
- export type TimePickerDialogProps = {
263
+ export interface TimePickerDialogProps {
264
264
  initialDate?: string | null;
265
265
  is24Hour?: boolean;
266
266
  confirmButtonLabel?: string;
@@ -269,7 +269,7 @@ export type TimePickerDialogProps = {
269
269
  elementColors?: DatePickerElementColors & TimePickerElementColors;
270
270
  onDateSelected?: (date: Date) => void;
271
271
  onDismissRequest: () => void;
272
- };
272
+ }
273
273
 
274
274
  type NativeTimePickerDialogProps = Omit<
275
275
  TimePickerDialogProps,
@@ -3,7 +3,7 @@ import { requireNativeView } from 'expo';
3
3
  import { type ExpoModifier, type ViewEvent } from '../../types';
4
4
  import { createViewModifierEventListener } from '../modifiers/utils';
5
5
 
6
- export type DockedSearchBarProps = {
6
+ export interface DockedSearchBarProps {
7
7
  /**
8
8
  * Callback function that is called when the search query changes.
9
9
  */
@@ -18,7 +18,7 @@ export type DockedSearchBarProps = {
18
18
  * The children of the component.
19
19
  */
20
20
  children?: React.ReactNode;
21
- };
21
+ }
22
22
 
23
23
  type PlaceholderProps = {
24
24
  children: React.ReactNode;
@@ -31,7 +31,7 @@ export type DropdownMenuItemElementColors = {
31
31
  /**
32
32
  * Props of the `DropdownMenuItem` component.
33
33
  */
34
- export type DropdownMenuItemProps = {
34
+ export interface DropdownMenuItemProps {
35
35
  /**
36
36
  * Whether the menu item is enabled.
37
37
  * @default true
@@ -53,7 +53,7 @@ export type DropdownMenuItemProps = {
53
53
  * Slot children for text, leading/trailing icons.
54
54
  */
55
55
  children?: React.ReactNode;
56
- };
56
+ }
57
57
 
58
58
  type NativeDropdownMenuItemProps = Omit<DropdownMenuItemProps, 'onClick' | 'children'> &
59
59
  ViewEvent<'onItemPressed', void> & { children?: React.ReactNode };
@@ -19,7 +19,7 @@ const SlotNativeView: React.ComponentType<{
19
19
  /**
20
20
  * Props of the `DropdownMenu` component.
21
21
  */
22
- export type DropdownMenuProps = {
22
+ export interface DropdownMenuProps {
23
23
  /**
24
24
  * The contents of the submenu are used as an anchor for the dropdown menu.
25
25
  * The children will be wrapped in a pressable element, which triggers opening of the dropdown menu.
@@ -51,7 +51,7 @@ export type DropdownMenuProps = {
51
51
  * Modifiers for the component.
52
52
  */
53
53
  modifiers?: ModifierConfig[];
54
- };
54
+ }
55
55
 
56
56
  type NativeMenuProps = {
57
57
  expanded?: boolean;
@@ -13,7 +13,7 @@ const NativeView: React.ComponentType<ExposedDropdownMenuProps> = requireNativeV
13
13
  /**
14
14
  * Props for the `ExposedDropdownMenu` component.
15
15
  */
16
- export type ExposedDropdownMenuProps = {
16
+ export interface ExposedDropdownMenuProps {
17
17
  /**
18
18
  * Whether the dropdown menu is expanded (visible).
19
19
  */
@@ -34,7 +34,7 @@ export type ExposedDropdownMenuProps = {
34
34
  * Children should be `DropdownMenuItem` components.
35
35
  */
36
36
  children?: ReactNode;
37
- };
37
+ }
38
38
 
39
39
  /**
40
40
  * A Material 3 `ExposedDropdownMenu` that displays menu items in a dropdown.
@@ -10,7 +10,7 @@ const NativeView: React.ComponentType<NativeExposedDropdownMenuBoxProps> = requi
10
10
  'ExposedDropdownMenuBoxView'
11
11
  );
12
12
 
13
- export type ExposedDropdownMenuBoxProps = {
13
+ export interface ExposedDropdownMenuBoxProps {
14
14
  /**
15
15
  * Whether the dropdown menu is expanded (visible).
16
16
  */
@@ -28,7 +28,7 @@ export type ExposedDropdownMenuBoxProps = {
28
28
  * and an `ExposedDropdownMenu` with `DropdownMenuItem` children.
29
29
  */
30
30
  children?: ReactNode;
31
- };
31
+ }
32
32
 
33
33
  type NativeExposedDropdownMenuBoxProps = Omit<
34
34
  ExposedDropdownMenuBoxProps,
@@ -16,7 +16,7 @@ type NativeSlotViewProps = {
16
16
  /**
17
17
  * Props shared by all `FloatingActionButton` variants.
18
18
  */
19
- export type FloatingActionButtonProps = {
19
+ export interface FloatingActionButtonProps {
20
20
  /**
21
21
  * Slot-based children (use `.Icon` sub-component).
22
22
  */
@@ -37,24 +37,24 @@ export type FloatingActionButtonProps = {
37
37
  * Modifiers for the component.
38
38
  */
39
39
  modifiers?: ModifierConfig[];
40
- };
40
+ }
41
41
 
42
42
  /**
43
43
  * Props for the `SmallFloatingActionButton` component.
44
44
  * Same as {@link FloatingActionButtonProps}.
45
45
  */
46
- export type SmallFloatingActionButtonProps = FloatingActionButtonProps;
46
+ export interface SmallFloatingActionButtonProps extends FloatingActionButtonProps {}
47
47
 
48
48
  /**
49
49
  * Props for the `LargeFloatingActionButton` component.
50
50
  * Same as {@link FloatingActionButtonProps}.
51
51
  */
52
- export type LargeFloatingActionButtonProps = FloatingActionButtonProps;
52
+ export interface LargeFloatingActionButtonProps extends FloatingActionButtonProps {}
53
53
 
54
54
  /**
55
55
  * Props for the `ExtendedFloatingActionButton` component.
56
56
  */
57
- export type ExtendedFloatingActionButtonProps = FloatingActionButtonProps & {
57
+ export interface ExtendedFloatingActionButtonProps extends FloatingActionButtonProps {
58
58
  /**
59
59
  * Slot-based children (use `.Icon` and `.Text` sub-components).
60
60
  */
@@ -65,7 +65,7 @@ export type ExtendedFloatingActionButtonProps = FloatingActionButtonProps & {
65
65
  * @default true
66
66
  */
67
67
  expanded?: boolean;
68
- };
68
+ }
69
69
 
70
70
  /**
71
71
  * @hidden
@@ -7,7 +7,7 @@ import {
7
7
  transformProps,
8
8
  } from '../layout-types';
9
9
 
10
- export type FlowRowProps = {
10
+ export interface FlowRowProps extends PrimitiveBaseProps {
11
11
  children?: React.ReactNode;
12
12
  /**
13
13
  * Horizontal arrangement of children.
@@ -17,7 +17,7 @@ export type FlowRowProps = {
17
17
  * Vertical arrangement of children.
18
18
  */
19
19
  verticalArrangement?: VerticalArrangement;
20
- } & PrimitiveBaseProps;
20
+ }
21
21
 
22
22
  const FlowRowNativeView: React.ComponentType<FlowRowProps> = requireNativeView(
23
23
  'ExpoUI',
@@ -26,7 +26,7 @@ export type HorizontalFloatingToolbarColors = {
26
26
  fabContentColor?: ColorValue;
27
27
  };
28
28
 
29
- export type HorizontalFloatingToolbarProps = {
29
+ export interface HorizontalFloatingToolbarProps {
30
30
  /**
31
31
  * The variant of the horizontal floating toolbar.
32
32
  * @default 'standard'
@@ -48,9 +48,9 @@ export type HorizontalFloatingToolbarProps = {
48
48
  * Modifiers for the component.
49
49
  */
50
50
  modifiers?: ExpoModifier[];
51
- };
51
+ }
52
52
 
53
- export type HorizontalFloatingToolbarFloatingActionButtonProps = {
53
+ export interface HorizontalFloatingToolbarFloatingActionButtonProps {
54
54
  /**
55
55
  * A callback that is called when the button is pressed.
56
56
  */
@@ -60,7 +60,7 @@ export type HorizontalFloatingToolbarFloatingActionButtonProps = {
60
60
  * The children of the component.
61
61
  */
62
62
  children: React.ReactNode;
63
- };
63
+ }
64
64
 
65
65
  type NativeHorizontalFloatingToolbarProps = HorizontalFloatingToolbarProps & {};
66
66
 
@@ -26,7 +26,7 @@ export type HorizontalPagerHandle = {
26
26
  */
27
27
  export type HorizontalPagerDragInteraction = 'start' | 'stop' | 'cancel';
28
28
 
29
- export type HorizontalPagerProps = {
29
+ export interface HorizontalPagerProps {
30
30
  /**
31
31
  * Imperative handle for programmatic navigation. Mirrors the methods on
32
32
  * Compose's `PagerState`.
@@ -104,7 +104,7 @@ export type HorizontalPagerProps = {
104
104
  * Children to render as pages.
105
105
  */
106
106
  children: React.ReactNode;
107
- };
107
+ }
108
108
 
109
109
  type NativeHorizontalPagerProps = Omit<
110
110
  HorizontalPagerProps,
@@ -12,7 +12,7 @@ import {
12
12
  import { getMaterialColors, HostPaletteContext } from '../colors';
13
13
  import { type PrimitiveBaseProps } from '../layout';
14
14
 
15
- export type HostProps = {
15
+ export interface HostProps extends PrimitiveBaseProps {
16
16
  /**
17
17
  * When true, the host view will update its size in the React Native view tree to match the content's layout from Jetpack Compose.
18
18
  * Can be only set once on mount.
@@ -65,7 +65,7 @@ export type HostProps = {
65
65
  children: React.ReactNode;
66
66
  style?: StyleProp<ViewStyle>;
67
67
  pointerEvents?: 'box-none' | 'none' | 'box-only' | 'auto';
68
- } & PrimitiveBaseProps;
68
+ }
69
69
 
70
70
  type NativeHostProps = Omit<HostProps, 'colorScheme'> & {
71
71
  matchContentsVertical?: boolean;
@@ -9,7 +9,7 @@ import {
9
9
  import type { ModifierConfig } from '../../types';
10
10
  import { createViewModifierEventListener } from '../modifiers/utils';
11
11
 
12
- export type IconProps = {
12
+ export interface IconProps {
13
13
  /**
14
14
  * The source of the icon. Can be a URI string or the result of `require()`.
15
15
  * On Android, supports XML vector drawables loaded via Metro bundler.
@@ -81,7 +81,7 @@ export type IconProps = {
81
81
  * ```
82
82
  */
83
83
  modifiers?: ModifierConfig[];
84
- };
84
+ }
85
85
 
86
86
  /**
87
87
  * @hidden
@@ -15,7 +15,7 @@ export type IconButtonColors = {
15
15
  disabledContentColor?: ColorValue;
16
16
  };
17
17
 
18
- export type IconButtonProps = {
18
+ export interface IconButtonProps {
19
19
  /**
20
20
  * Callback that is called when the icon button is clicked.
21
21
  */
@@ -42,7 +42,7 @@ export type IconButtonProps = {
42
42
  * Content to display inside the icon button.
43
43
  */
44
44
  children: React.ReactNode;
45
- };
45
+ }
46
46
 
47
47
  type NativeIconButtonProps = Omit<IconButtonProps, 'onClick' | 'shape' | 'children'> & {
48
48
  shape?: ShapeRecordProps;
@@ -25,7 +25,7 @@ export type ContentPadding = {
25
25
  bottom?: number;
26
26
  };
27
27
 
28
- export type LazyColumnProps = {
28
+ export interface LazyColumnProps {
29
29
  /**
30
30
  * The content to display inside the lazy column.
31
31
  */
@@ -54,7 +54,7 @@ export type LazyColumnProps = {
54
54
  * Modifiers for the component.
55
55
  */
56
56
  modifiers?: ExpoModifier[];
57
- };
57
+ }
58
58
 
59
59
  type NativeLazyColumnProps = LazyColumnProps;
60
60
  const LazyColumnNativeView: React.ComponentType<NativeLazyColumnProps> = requireNativeView(
@@ -4,7 +4,7 @@ import type { ExpoModifier } from '../../types';
4
4
  import { type ContentPadding } from '../LazyColumn';
5
5
  import { createViewModifierEventListener } from '../modifiers/utils';
6
6
 
7
- export type LazyRowProps = {
7
+ export interface LazyRowProps {
8
8
  /**
9
9
  * The content to display inside the lazy row.
10
10
  */
@@ -33,7 +33,7 @@ export type LazyRowProps = {
33
33
  * Modifiers for the component.
34
34
  */
35
35
  modifiers?: ExpoModifier[];
36
- };
36
+ }
37
37
 
38
38
  type NativeLazyRowProps = LazyRowProps;
39
39
  const LazyRowNativeView: React.ComponentType<NativeLazyRowProps> = requireNativeView(
@@ -16,7 +16,7 @@ export type ListItemColors = {
16
16
  overlineContentColor?: ColorValue;
17
17
  };
18
18
 
19
- export type ListItemProps = {
19
+ export interface ListItemProps {
20
20
  /**
21
21
  * Colors for list item elements.
22
22
  */
@@ -39,7 +39,7 @@ export type ListItemProps = {
39
39
  * Children containing slot sub-components.
40
40
  */
41
41
  children?: React.ReactNode;
42
- };
42
+ }
43
43
 
44
44
  type SlotProps = {
45
45
  slotName: string;
@@ -71,12 +71,12 @@ export const LoadingIndicator = createLoadingIndicatorComponent('LoadingIndicato
71
71
 
72
72
  // region ContainedLoadingIndicator
73
73
 
74
- export type ContainedLoadingIndicatorProps = LoadingIndicatorCommonConfig & {
74
+ export interface ContainedLoadingIndicatorProps extends LoadingIndicatorCommonConfig {
75
75
  /**
76
76
  * Loading indicator's container color
77
77
  */
78
78
  containerColor?: ColorValue;
79
- };
79
+ }
80
80
 
81
81
  /**
82
82
  * A loading indicator that displays loading using morphing shapes inside a container.
@@ -42,7 +42,7 @@ export type ModalBottomSheetProperties = {
42
42
  shouldDismissOnClickOutside?: boolean;
43
43
  };
44
44
 
45
- export type ModalBottomSheetProps = {
45
+ export interface ModalBottomSheetProps {
46
46
  /**
47
47
  * The children of the `ModalBottomSheet` component.
48
48
  * Can include a `ModalBottomSheet.DragHandle` slot for a custom drag handle.
@@ -62,6 +62,12 @@ export type ModalBottomSheetProps = {
62
62
  * @default false
63
63
  */
64
64
  skipPartiallyExpanded?: boolean;
65
+ /**
66
+ * Opens the sheet fully expanded on first composition. Ignored when `skipPartiallyExpanded` is `true`.
67
+ * @default false
68
+ * @platform android
69
+ */
70
+ initialFullyExpanded?: boolean;
65
71
  /**
66
72
  * The background color of the bottom sheet.
67
73
  */
@@ -93,7 +99,7 @@ export type ModalBottomSheetProps = {
93
99
  * Modifiers for the component.
94
100
  */
95
101
  modifiers?: ModifierConfig[];
96
- };
102
+ }
97
103
 
98
104
  type NativeModalBottomSheetProps = Omit<ModalBottomSheetProps, 'onDismissRequest'> & {
99
105
  onDismissRequest: () => void;
@@ -111,6 +117,7 @@ function transformProps(props: ModalBottomSheetProps): NativeModalBottomSheetPro
111
117
  ...(modifiers ? createViewModifierEventListener(modifiers) : undefined),
112
118
  ...restProps,
113
119
  skipPartiallyExpanded: props.skipPartiallyExpanded ?? false,
120
+ initialFullyExpanded: props.initialFullyExpanded ?? false,
114
121
  onDismissRequest: () => {
115
122
  onDismissRequest?.();
116
123
  },
@@ -3,7 +3,7 @@ import { requireNativeView } from 'expo';
3
3
  import { type ModifierConfig } from '../../types';
4
4
  import { createViewModifierEventListener } from '../modifiers/utils';
5
5
 
6
- export type MultiChoiceSegmentedButtonRowProps = {
6
+ export interface MultiChoiceSegmentedButtonRowProps {
7
7
  /**
8
8
  * SegmentedButton children.
9
9
  */
@@ -12,7 +12,7 @@ export type MultiChoiceSegmentedButtonRowProps = {
12
12
  * Modifiers for the component.
13
13
  */
14
14
  modifiers?: ModifierConfig[];
15
- };
15
+ }
16
16
 
17
17
  const MultiChoiceSegmentedButtonRowNativeView: React.ComponentType<MultiChoiceSegmentedButtonRowProps> =
18
18
  requireNativeView('ExpoUI', 'MultiChoiceSegmentedButtonRowView');
@@ -26,7 +26,7 @@ export type NavigationBarItemColors = {
26
26
  disabledTextColor?: ColorValue;
27
27
  };
28
28
 
29
- export type NavigationBarProps = {
29
+ export interface NavigationBarProps {
30
30
  /**
31
31
  * Background color of the navigation bar.
32
32
  * @default NavigationBarDefaults.containerColor
@@ -50,9 +50,9 @@ export type NavigationBarProps = {
50
50
  * Navigation bar items.
51
51
  */
52
52
  children?: React.ReactNode;
53
- };
53
+ }
54
54
 
55
- export type NavigationBarItemProps = {
55
+ export interface NavigationBarItemProps {
56
56
  /**
57
57
  * Whether this item is currently selected.
58
58
  */
@@ -83,7 +83,7 @@ export type NavigationBarItemProps = {
83
83
  * Children containing `Icon`, `SelectedIcon`, and `Label` slots.
84
84
  */
85
85
  children?: React.ReactNode;
86
- };
86
+ }
87
87
 
88
88
  type NativeNavigationBarItemProps = Omit<NavigationBarItemProps, 'onClick'> &
89
89
  ViewEvent<'onButtonPressed', void>;
@@ -72,7 +72,7 @@ export type DrawStopIndicatorConfig = {
72
72
  stopSize?: number;
73
73
  };
74
74
 
75
- export type LinearProgressIndicatorProps = ProgressCommonConfig & {
75
+ export interface LinearProgressIndicatorProps extends ProgressCommonConfig {
76
76
  /**
77
77
  * Stroke cap style for the indicator ends.
78
78
  * @default 'round'
@@ -86,7 +86,7 @@ export type LinearProgressIndicatorProps = ProgressCommonConfig & {
86
86
  * Configuration for the stop indicator dot at the end of the determinate progress track.
87
87
  */
88
88
  drawStopIndicator?: DrawStopIndicatorConfig;
89
- };
89
+ }
90
90
 
91
91
  /**
92
92
  * A linear progress indicator that displays progress in a horizontal bar.
@@ -101,7 +101,7 @@ export const LinearProgressIndicator = createProgressComponent<LinearProgressInd
101
101
 
102
102
  // region CircularProgressIndicator
103
103
 
104
- export type CircularProgressIndicatorProps = ProgressCommonConfig & {
104
+ export interface CircularProgressIndicatorProps extends ProgressCommonConfig {
105
105
  /**
106
106
  * Width of the circular stroke in dp.
107
107
  */
@@ -115,7 +115,7 @@ export type CircularProgressIndicatorProps = ProgressCommonConfig & {
115
115
  * Gap size between the indicator and track in dp.
116
116
  */
117
117
  gapSize?: number;
118
- };
118
+ }
119
119
 
120
120
  /**
121
121
  * A circular progress indicator that displays progress in a circular format.
@@ -130,12 +130,12 @@ export const CircularProgressIndicator = createProgressComponent<CircularProgres
130
130
 
131
131
  // region LinearWavyProgressIndicator
132
132
 
133
- export type LinearWavyProgressIndicatorProps = ProgressCommonConfig & {
133
+ export interface LinearWavyProgressIndicatorProps extends ProgressCommonConfig {
134
134
  /**
135
135
  * Size of the stop indicator in dp at the end of the determinate progress track.
136
136
  */
137
137
  stopSize?: number;
138
- };
138
+ }
139
139
 
140
140
  /**
141
141
  * A linear progress indicator with wavy animation style.
@@ -149,7 +149,7 @@ export const LinearWavyProgressIndicator =
149
149
 
150
150
  // region CircularWavyProgressIndicator
151
151
 
152
- export type CircularWavyProgressIndicatorProps = ProgressCommonConfig;
152
+ export interface CircularWavyProgressIndicatorProps extends ProgressCommonConfig {}
153
153
 
154
154
  /**
155
155
  * A circular progress indicator with wavy animation style.
@@ -8,7 +8,7 @@ import { createViewModifierEventListener } from '../modifiers/utils';
8
8
  /**
9
9
  * Configuration for the loading indicator shown during pull-to-refresh.
10
10
  */
11
- export type PullToRefreshIndicatorProps = {
11
+ export interface PullToRefreshIndicatorProps {
12
12
  /**
13
13
  * Color of the loading indicator spinner.
14
14
  * @default MaterialTheme.colorScheme.primary
@@ -23,9 +23,9 @@ export type PullToRefreshIndicatorProps = {
23
23
  * Modifiers for the loading indicator.
24
24
  */
25
25
  modifiers?: ModifierConfig[];
26
- };
26
+ }
27
27
 
28
- export type PullToRefreshBoxProps = {
28
+ export interface PullToRefreshBoxProps {
29
29
  /**
30
30
  * Whether the content is refreshing.
31
31
  * @default false
@@ -52,7 +52,7 @@ export type PullToRefreshBoxProps = {
52
52
  * The content to refresh.
53
53
  */
54
54
  children: React.ReactNode;
55
- };
55
+ }
56
56
 
57
57
  type NativePullToRefreshBoxProps = Omit<PullToRefreshBoxProps, 'onRefresh'> &
58
58
  ViewEvent<'onRefresh', void>;
@@ -1,5 +1,6 @@
1
1
  import { requireNativeView } from 'expo';
2
2
  import type { ReactElement, ComponentType } from 'react';
3
+ import type { StyleProp, ViewStyle } from 'react-native';
3
4
 
4
5
  import type { ModifierConfig } from '../../types';
5
6
  import type { PrimitiveBaseProps } from '../layout';
@@ -21,6 +22,13 @@ export interface RNHostProps extends PrimitiveBaseProps {
21
22
  * Modifiers for the component.
22
23
  */
23
24
  modifiers?: ModifierConfig[];
25
+ /**
26
+ * Style applied to the host view's React Native shadow node. Useful for
27
+ * controlling its layout position (e.g. `position: 'absolute'`) so the shadow
28
+ * layout matches where the hosting Compose component draws the content —
29
+ * important for `measure()`-based hit-testing such as `Pressable`.
30
+ */
31
+ style?: StyleProp<ViewStyle>;
24
32
  }
25
33
 
26
34
  type NativeRNHostProps = RNHostProps;
@@ -3,7 +3,7 @@ import { requireNativeView } from 'expo';
3
3
  import { type ModifierConfig, type ViewEvent } from '../../types';
4
4
  import { createViewModifierEventListener } from '../modifiers/utils';
5
5
 
6
- export type RadioButtonProps = {
6
+ export interface RadioButtonProps {
7
7
  /**
8
8
  * Whether the radio button is selected.
9
9
  */
@@ -16,7 +16,7 @@ export type RadioButtonProps = {
16
16
  * Modifiers for the component.
17
17
  */
18
18
  modifiers?: ModifierConfig[];
19
- };
19
+ }
20
20
 
21
21
  type NativeRadioButtonProps = Omit<RadioButtonProps, 'onClick'> &
22
22
  ViewEvent<'onButtonPressed', void> & {
@@ -9,7 +9,7 @@ import {
9
9
  transformProps,
10
10
  } from '../layout-types';
11
11
 
12
- export type RowProps = {
12
+ export interface RowProps extends PrimitiveBaseProps {
13
13
  children?: React.ReactNode;
14
14
  /**
15
15
  * Horizontal arrangement of children.
@@ -27,7 +27,7 @@ export type RowProps = {
27
27
  * Vertical alignment of children.
28
28
  */
29
29
  verticalAlignment?: VerticalAlignment;
30
- } & PrimitiveBaseProps;
30
+ }
31
31
 
32
32
  const RowNativeView: React.ComponentType<RowProps> = requireNativeView('ExpoUI', 'RowView');
33
33
 
@@ -3,7 +3,7 @@ import { requireNativeView } from 'expo';
3
3
  import { type ExpoModifier, type ViewEvent } from '../../types';
4
4
  import { createViewModifierEventListener } from '../modifiers/utils';
5
5
 
6
- export type SearchBarProps = {
6
+ export interface SearchBarProps {
7
7
  /**
8
8
  * Callback function that is called when the search text is submitted.
9
9
  */
@@ -18,7 +18,7 @@ export type SearchBarProps = {
18
18
  * The children of the component.
19
19
  */
20
20
  children?: React.ReactNode;
21
- };
21
+ }
22
22
 
23
23
  type PlaceholderProps = {
24
24
  /**
@@ -22,7 +22,7 @@ export type SegmentedButtonColors = {
22
22
  disabledInactiveContainerColor?: ColorValue;
23
23
  };
24
24
 
25
- export type SegmentedButtonProps = {
25
+ export interface SegmentedButtonProps {
26
26
  /**
27
27
  * Whether the button is currently selected (used inside `SingleChoiceSegmentedButtonRow`).
28
28
  */
@@ -56,7 +56,7 @@ export type SegmentedButtonProps = {
56
56
  * Children containing a `Label` slot.
57
57
  */
58
58
  children?: React.ReactNode;
59
- };
59
+ }
60
60
 
61
61
  type NativeSlotViewProps = {
62
62
  slotName: string;