react-native-acoustic-connect-beta 18.0.7 → 18.0.9

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 (327) hide show
  1. package/Examples/SampleUI/.bundle/config +2 -0
  2. package/Examples/SampleUI/.eslintrc.js +4 -0
  3. package/Examples/SampleUI/.prettierrc.js +7 -0
  4. package/Examples/SampleUI/.watchmanconfig +1 -0
  5. package/Examples/SampleUI/App.js +1 -0
  6. package/Examples/SampleUI/Gemfile +10 -0
  7. package/Examples/SampleUI/Gemfile.lock +121 -0
  8. package/Examples/SampleUI/README.md +79 -0
  9. package/Examples/SampleUI/__tests__/App.test.tsx +17 -0
  10. package/Examples/SampleUI/android/app/build.gradle +124 -0
  11. package/Examples/SampleUI/android/app/debug.keystore +0 -0
  12. package/Examples/SampleUI/android/app/proguard-rules.pro +10 -0
  13. package/Examples/SampleUI/android/app/src/debug/AndroidManifest.xml +9 -0
  14. package/Examples/SampleUI/android/app/src/main/AndroidManifest.xml +26 -0
  15. package/Examples/SampleUI/android/app/src/main/java/com/sampleui/MainActivity.kt +23 -0
  16. package/Examples/SampleUI/android/app/src/main/java/com/sampleui/MainApplication.kt +53 -0
  17. package/Examples/SampleUI/android/app/src/main/res/drawable/rn_edit_text_material.xml +37 -0
  18. package/Examples/SampleUI/android/app/src/main/res/mipmap-hdpi/ic_launcher.png +0 -0
  19. package/Examples/SampleUI/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png +0 -0
  20. package/Examples/SampleUI/android/app/src/main/res/mipmap-mdpi/ic_launcher.png +0 -0
  21. package/Examples/SampleUI/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png +0 -0
  22. package/Examples/SampleUI/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png +0 -0
  23. package/Examples/SampleUI/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png +0 -0
  24. package/Examples/SampleUI/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png +0 -0
  25. package/Examples/SampleUI/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png +0 -0
  26. package/Examples/SampleUI/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png +0 -0
  27. package/Examples/SampleUI/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png +0 -0
  28. package/Examples/SampleUI/android/app/src/main/res/values/strings.xml +3 -0
  29. package/Examples/SampleUI/android/app/src/main/res/values/styles.xml +9 -0
  30. package/Examples/SampleUI/android/build.gradle +21 -0
  31. package/Examples/SampleUI/android/gradle/wrapper/gradle-wrapper.jar +0 -0
  32. package/Examples/SampleUI/android/gradle/wrapper/gradle-wrapper.properties +7 -0
  33. package/Examples/SampleUI/android/gradle.properties +39 -0
  34. package/Examples/SampleUI/android/gradlew +252 -0
  35. package/Examples/SampleUI/android/gradlew.bat +94 -0
  36. package/Examples/SampleUI/android/settings.gradle +21 -0
  37. package/Examples/SampleUI/app.json +51 -0
  38. package/Examples/SampleUI/assets/fonts/Abel-Regular.ttf +0 -0
  39. package/Examples/SampleUI/assets/fonts/NotoSans-Regular.ttf +0 -0
  40. package/Examples/SampleUI/assets/images/android-icon.png +0 -0
  41. package/Examples/SampleUI/assets/images/artist-1.jpg +0 -0
  42. package/Examples/SampleUI/assets/images/artist-2.jpg +0 -0
  43. package/Examples/SampleUI/assets/images/avatar.png +0 -0
  44. package/Examples/SampleUI/assets/images/beach.jpg +0 -0
  45. package/Examples/SampleUI/assets/images/bridge.jpg +0 -0
  46. package/Examples/SampleUI/assets/images/chameleon.jpg +0 -0
  47. package/Examples/SampleUI/assets/images/city.jpg +0 -0
  48. package/Examples/SampleUI/assets/images/email-icon.png +0 -0
  49. package/Examples/SampleUI/assets/images/favorite.png +0 -0
  50. package/Examples/SampleUI/assets/images/forest.jpg +0 -0
  51. package/Examples/SampleUI/assets/images/paper-icon.png +0 -0
  52. package/Examples/SampleUI/assets/images/players-2.jpg +0 -0
  53. package/Examples/SampleUI/assets/images/players.jpg +0 -0
  54. package/Examples/SampleUI/assets/images/restaurant-1.jpg +0 -0
  55. package/Examples/SampleUI/assets/images/restaurant-2.jpg +0 -0
  56. package/Examples/SampleUI/assets/images/song-1.jpg +0 -0
  57. package/Examples/SampleUI/assets/images/song-2.jpg +0 -0
  58. package/Examples/SampleUI/assets/images/splash.png +0 -0
  59. package/Examples/SampleUI/assets/images/strawberries.jpg +0 -0
  60. package/Examples/SampleUI/assets/images/wrecked-ship.jpg +0 -0
  61. package/Examples/SampleUI/assets/styles/fonts.css +47 -0
  62. package/Examples/SampleUI/babel.config.js +22 -0
  63. package/Examples/SampleUI/index.js +9 -0
  64. package/Examples/SampleUI/ios/.xcode.env +11 -0
  65. package/Examples/SampleUI/ios/Podfile +58 -0
  66. package/Examples/SampleUI/ios/SampleUI/AppDelegate.h +7 -0
  67. package/Examples/SampleUI/ios/SampleUI/AppDelegate.mm +31 -0
  68. package/Examples/SampleUI/ios/SampleUI/Images.xcassets/AppIcon.appiconset/Contents.json +53 -0
  69. package/Examples/SampleUI/ios/SampleUI/Images.xcassets/Contents.json +6 -0
  70. package/Examples/SampleUI/ios/SampleUI/Info.plist +52 -0
  71. package/Examples/SampleUI/ios/SampleUI/LaunchScreen.storyboard +47 -0
  72. package/Examples/SampleUI/ios/SampleUI/PrivacyInfo.xcprivacy +48 -0
  73. package/Examples/SampleUI/ios/SampleUI/main.m +10 -0
  74. package/Examples/SampleUI/ios/SampleUI.xcodeproj/project.pbxproj +785 -0
  75. package/Examples/SampleUI/ios/SampleUI.xcodeproj/xcshareddata/xcschemes/SampleUI.xcscheme +88 -0
  76. package/Examples/SampleUI/ios/SampleUI.xcworkspace/contents.xcworkspacedata +10 -0
  77. package/Examples/SampleUI/ios/SampleUITests/Info.plist +24 -0
  78. package/Examples/SampleUI/ios/SampleUITests/SampleUITests.m +66 -0
  79. package/Examples/SampleUI/jest.config.js +3 -0
  80. package/Examples/SampleUI/metro.config.js +53 -0
  81. package/Examples/SampleUI/package-lock.json +17033 -0
  82. package/Examples/SampleUI/package.json +62 -0
  83. package/Examples/SampleUI/src/DrawerItems.tsx +322 -0
  84. package/Examples/SampleUI/src/ExampleList.tsx +175 -0
  85. package/Examples/SampleUI/src/Examples/ActivityIndicatorExample.tsx +73 -0
  86. package/Examples/SampleUI/src/Examples/AnimatedFABExample/AnimatedFABExample.tsx +220 -0
  87. package/Examples/SampleUI/src/Examples/AnimatedFABExample/CustomFAB.tsx +70 -0
  88. package/Examples/SampleUI/src/Examples/AnimatedFABExample/CustomFABControls.tsx +146 -0
  89. package/Examples/SampleUI/src/Examples/AnimatedFABExample/index.ts +1 -0
  90. package/Examples/SampleUI/src/Examples/AppbarExample.tsx +263 -0
  91. package/Examples/SampleUI/src/Examples/AvatarExample.tsx +76 -0
  92. package/Examples/SampleUI/src/Examples/BadgeExample.tsx +97 -0
  93. package/Examples/SampleUI/src/Examples/BannerExample.tsx +152 -0
  94. package/Examples/SampleUI/src/Examples/BottomNavigationBarExample.tsx +94 -0
  95. package/Examples/SampleUI/src/Examples/BottomNavigationExample.tsx +205 -0
  96. package/Examples/SampleUI/src/Examples/ButtonExample.tsx +405 -0
  97. package/Examples/SampleUI/src/Examples/CardExample.tsx +245 -0
  98. package/Examples/SampleUI/src/Examples/CheckboxExample.tsx +87 -0
  99. package/Examples/SampleUI/src/Examples/CheckboxItemExample.tsx +72 -0
  100. package/Examples/SampleUI/src/Examples/ChipExample.tsx +432 -0
  101. package/Examples/SampleUI/src/Examples/DataTableExample.tsx +128 -0
  102. package/Examples/SampleUI/src/Examples/DialogExample.tsx +131 -0
  103. package/Examples/SampleUI/src/Examples/Dialogs/DialogTextComponent.tsx +31 -0
  104. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithCustomColors.tsx +57 -0
  105. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithDismissableBackButton.tsx +38 -0
  106. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithIcon.tsx +42 -0
  107. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithLoadingIndicator.tsx +48 -0
  108. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithLongText.tsx +81 -0
  109. package/Examples/SampleUI/src/Examples/Dialogs/DialogWithRadioBtns.tsx +111 -0
  110. package/Examples/SampleUI/src/Examples/Dialogs/UndismissableDialog.tsx +30 -0
  111. package/Examples/SampleUI/src/Examples/Dialogs/index.tsx +7 -0
  112. package/Examples/SampleUI/src/Examples/DividerExample.tsx +30 -0
  113. package/Examples/SampleUI/src/Examples/FABExample.tsx +226 -0
  114. package/Examples/SampleUI/src/Examples/IconButtonExample.tsx +230 -0
  115. package/Examples/SampleUI/src/Examples/IconExample.tsx +50 -0
  116. package/Examples/SampleUI/src/Examples/ListAccordionExample.tsx +65 -0
  117. package/Examples/SampleUI/src/Examples/ListAccordionGroupExample.tsx +80 -0
  118. package/Examples/SampleUI/src/Examples/ListItemExample.tsx +310 -0
  119. package/Examples/SampleUI/src/Examples/ListSectionExample.tsx +159 -0
  120. package/Examples/SampleUI/src/Examples/MaterialBottomTabNavigatorExample.tsx +87 -0
  121. package/Examples/SampleUI/src/Examples/MenuExample.tsx +211 -0
  122. package/Examples/SampleUI/src/Examples/ProgressBarExample.tsx +142 -0
  123. package/Examples/SampleUI/src/Examples/RadioButtonExample.tsx +104 -0
  124. package/Examples/SampleUI/src/Examples/RadioButtonGroupExample.tsx +67 -0
  125. package/Examples/SampleUI/src/Examples/RadioButtonItemExample.tsx +77 -0
  126. package/Examples/SampleUI/src/Examples/SearchbarExample.tsx +249 -0
  127. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonCustomColorCheck.tsx +93 -0
  128. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonDefault.tsx +49 -0
  129. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonDisabled.tsx +47 -0
  130. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonMultiselect.tsx +50 -0
  131. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonMultiselectIcons.tsx +49 -0
  132. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonMultiselectRealCase.tsx +114 -0
  133. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonOnlyIcons.tsx +40 -0
  134. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonOnlyIconsWithCheck.tsx +43 -0
  135. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonRealCase.tsx +97 -0
  136. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonWithDensity.tsx +47 -0
  137. package/Examples/SampleUI/src/Examples/SegmentedButtons/SegmentedButtonWithSelectedCheck.tsx +52 -0
  138. package/Examples/SampleUI/src/Examples/SegmentedButtons/index.ts +9 -0
  139. package/Examples/SampleUI/src/Examples/SegmentedButtonsExample.tsx +57 -0
  140. package/Examples/SampleUI/src/Examples/SnackbarExample.tsx +141 -0
  141. package/Examples/SampleUI/src/Examples/SurfaceExample.tsx +130 -0
  142. package/Examples/SampleUI/src/Examples/SwitchExample.tsx +105 -0
  143. package/Examples/SampleUI/src/Examples/TeamDetails.tsx +291 -0
  144. package/Examples/SampleUI/src/Examples/TeamsList.tsx +57 -0
  145. package/Examples/SampleUI/src/Examples/TextExample.tsx +132 -0
  146. package/Examples/SampleUI/src/Examples/TextInputExample.tsx +914 -0
  147. package/Examples/SampleUI/src/Examples/ThemeExample.tsx +41 -0
  148. package/Examples/SampleUI/src/Examples/ThemingWithReactNavigation.tsx +75 -0
  149. package/Examples/SampleUI/src/Examples/ToggleButtonExample.tsx +128 -0
  150. package/Examples/SampleUI/src/Examples/TooltipExample.tsx +191 -0
  151. package/Examples/SampleUI/src/Examples/TouchableRippleExample.tsx +37 -0
  152. package/Examples/SampleUI/src/RootNavigator.tsx +86 -0
  153. package/Examples/SampleUI/src/ScreenWrapper.tsx +67 -0
  154. package/Examples/SampleUI/src/components/ActivityIndicator.tsx +254 -0
  155. package/Examples/SampleUI/src/components/Appbar/Appbar.tsx +364 -0
  156. package/Examples/SampleUI/src/components/Appbar/AppbarAction.tsx +132 -0
  157. package/Examples/SampleUI/src/components/Appbar/AppbarBackAction.tsx +77 -0
  158. package/Examples/SampleUI/src/components/Appbar/AppbarBackIcon.tsx +52 -0
  159. package/Examples/SampleUI/src/components/Appbar/AppbarContent.tsx +249 -0
  160. package/Examples/SampleUI/src/components/Appbar/AppbarHeader.tsx +174 -0
  161. package/Examples/SampleUI/src/components/Appbar/index.ts +22 -0
  162. package/Examples/SampleUI/src/components/Appbar/utils.ts +188 -0
  163. package/Examples/SampleUI/src/components/Avatar/Avatar.tsx +8 -0
  164. package/Examples/SampleUI/src/components/Avatar/AvatarIcon.tsx +87 -0
  165. package/Examples/SampleUI/src/components/Avatar/AvatarImage.tsx +128 -0
  166. package/Examples/SampleUI/src/components/Avatar/AvatarText.tsx +127 -0
  167. package/Examples/SampleUI/src/components/Badge.tsx +138 -0
  168. package/Examples/SampleUI/src/components/Banner.tsx +302 -0
  169. package/Examples/SampleUI/src/components/BottomNavigation/BottomNavigation.tsx +643 -0
  170. package/Examples/SampleUI/src/components/BottomNavigation/BottomNavigationBar.tsx +1039 -0
  171. package/Examples/SampleUI/src/components/BottomNavigation/BottomNavigationRouteScreen.tsx +31 -0
  172. package/Examples/SampleUI/src/components/BottomNavigation/utils.ts +70 -0
  173. package/Examples/SampleUI/src/components/Button/Button.tsx +503 -0
  174. package/Examples/SampleUI/src/components/Button/utils.tsx +272 -0
  175. package/Examples/SampleUI/src/components/Card/Card.tsx +373 -0
  176. package/Examples/SampleUI/src/components/Card/CardActions.tsx +74 -0
  177. package/Examples/SampleUI/src/components/Card/CardContent.tsx +99 -0
  178. package/Examples/SampleUI/src/components/Card/CardCover.tsx +96 -0
  179. package/Examples/SampleUI/src/components/Card/CardTitle.tsx +236 -0
  180. package/Examples/SampleUI/src/components/Card/utils.tsx +110 -0
  181. package/Examples/SampleUI/src/components/Checkbox/Checkbox.tsx +78 -0
  182. package/Examples/SampleUI/src/components/Checkbox/CheckboxAndroid.tsx +180 -0
  183. package/Examples/SampleUI/src/components/Checkbox/CheckboxIOS.tsx +104 -0
  184. package/Examples/SampleUI/src/components/Checkbox/CheckboxItem.tsx +236 -0
  185. package/Examples/SampleUI/src/components/Checkbox/index.ts +19 -0
  186. package/Examples/SampleUI/src/components/Checkbox/utils.ts +183 -0
  187. package/Examples/SampleUI/src/components/Chip/Chip.tsx +513 -0
  188. package/Examples/SampleUI/src/components/Chip/helpers.tsx +322 -0
  189. package/Examples/SampleUI/src/components/CrossFadeIcon.tsx +140 -0
  190. package/Examples/SampleUI/src/components/DataTable/DataTable.tsx +138 -0
  191. package/Examples/SampleUI/src/components/DataTable/DataTableCell.tsx +132 -0
  192. package/Examples/SampleUI/src/components/DataTable/DataTableHeader.tsx +82 -0
  193. package/Examples/SampleUI/src/components/DataTable/DataTablePagination.tsx +407 -0
  194. package/Examples/SampleUI/src/components/DataTable/DataTableRow.tsx +107 -0
  195. package/Examples/SampleUI/src/components/DataTable/DataTableTitle.tsx +208 -0
  196. package/Examples/SampleUI/src/components/Dialog/Dialog.tsx +191 -0
  197. package/Examples/SampleUI/src/components/Dialog/DialogActions.tsx +94 -0
  198. package/Examples/SampleUI/src/components/Dialog/DialogContent.tsx +54 -0
  199. package/Examples/SampleUI/src/components/Dialog/DialogIcon.tsx +100 -0
  200. package/Examples/SampleUI/src/components/Dialog/DialogScrollArea.tsx +88 -0
  201. package/Examples/SampleUI/src/components/Dialog/DialogTitle.tsx +94 -0
  202. package/Examples/SampleUI/src/components/Divider.tsx +102 -0
  203. package/Examples/SampleUI/src/components/Drawer/Drawer.tsx +8 -0
  204. package/Examples/SampleUI/src/components/Drawer/DrawerCollapsedItem.tsx +282 -0
  205. package/Examples/SampleUI/src/components/Drawer/DrawerItem.tsx +209 -0
  206. package/Examples/SampleUI/src/components/Drawer/DrawerSection.tsx +138 -0
  207. package/Examples/SampleUI/src/components/FAB/AnimatedFAB.tsx +619 -0
  208. package/Examples/SampleUI/src/components/FAB/FAB.tsx +371 -0
  209. package/Examples/SampleUI/src/components/FAB/FABGroup.tsx +532 -0
  210. package/Examples/SampleUI/src/components/FAB/index.ts +13 -0
  211. package/Examples/SampleUI/src/components/FAB/utils.ts +474 -0
  212. package/Examples/SampleUI/src/components/HelperText/HelperText.tsx +168 -0
  213. package/Examples/SampleUI/src/components/HelperText/utils.ts +30 -0
  214. package/Examples/SampleUI/src/components/Icon.tsx +170 -0
  215. package/Examples/SampleUI/src/components/IconButton/IconButton.tsx +234 -0
  216. package/Examples/SampleUI/src/components/IconButton/utils.ts +190 -0
  217. package/Examples/SampleUI/src/components/List/List.tsx +20 -0
  218. package/Examples/SampleUI/src/components/List/ListAccordion.tsx +391 -0
  219. package/Examples/SampleUI/src/components/List/ListAccordionGroup.tsx +88 -0
  220. package/Examples/SampleUI/src/components/List/ListIcon.tsx +79 -0
  221. package/Examples/SampleUI/src/components/List/ListImage.tsx +89 -0
  222. package/Examples/SampleUI/src/components/List/ListItem.tsx +313 -0
  223. package/Examples/SampleUI/src/components/List/ListSection.tsx +87 -0
  224. package/Examples/SampleUI/src/components/List/ListSubheader.tsx +79 -0
  225. package/Examples/SampleUI/src/components/List/utils.ts +113 -0
  226. package/Examples/SampleUI/src/components/MaterialCommunityIcon.tsx +121 -0
  227. package/Examples/SampleUI/src/components/Menu/Menu.tsx +711 -0
  228. package/Examples/SampleUI/src/components/Menu/MenuItem.tsx +257 -0
  229. package/Examples/SampleUI/src/components/Menu/utils.ts +110 -0
  230. package/Examples/SampleUI/src/components/Modal.tsx +245 -0
  231. package/Examples/SampleUI/src/components/Portal/Portal.tsx +69 -0
  232. package/Examples/SampleUI/src/components/Portal/PortalConsumer.tsx +44 -0
  233. package/Examples/SampleUI/src/components/Portal/PortalHost.tsx +143 -0
  234. package/Examples/SampleUI/src/components/Portal/PortalManager.tsx +54 -0
  235. package/Examples/SampleUI/src/components/ProgressBar.tsx +292 -0
  236. package/Examples/SampleUI/src/components/RadioButton/RadioButton.tsx +86 -0
  237. package/Examples/SampleUI/src/components/RadioButton/RadioButtonAndroid.tsx +202 -0
  238. package/Examples/SampleUI/src/components/RadioButton/RadioButtonGroup.tsx +67 -0
  239. package/Examples/SampleUI/src/components/RadioButton/RadioButtonIOS.tsx +130 -0
  240. package/Examples/SampleUI/src/components/RadioButton/RadioButtonItem.tsx +268 -0
  241. package/Examples/SampleUI/src/components/RadioButton/index.ts +22 -0
  242. package/Examples/SampleUI/src/components/RadioButton/utils.ts +37 -0
  243. package/Examples/SampleUI/src/components/Searchbar.tsx +459 -0
  244. package/Examples/SampleUI/src/components/SegmentedButtons/SegmentedButtonItem.tsx +271 -0
  245. package/Examples/SampleUI/src/components/SegmentedButtons/SegmentedButtons.tsx +197 -0
  246. package/Examples/SampleUI/src/components/SegmentedButtons/utils.ts +179 -0
  247. package/Examples/SampleUI/src/components/Snackbar.tsx +430 -0
  248. package/Examples/SampleUI/src/components/Surface.tsx +376 -0
  249. package/Examples/SampleUI/src/components/Switch/Switch.tsx +108 -0
  250. package/Examples/SampleUI/src/components/Switch/utils.ts +113 -0
  251. package/Examples/SampleUI/src/components/TextInput/Addons/Outline.tsx +64 -0
  252. package/Examples/SampleUI/src/components/TextInput/Addons/Underline.tsx +78 -0
  253. package/Examples/SampleUI/src/components/TextInput/Adornment/TextInputAdornment.tsx +208 -0
  254. package/Examples/SampleUI/src/components/TextInput/Adornment/TextInputAffix.tsx +212 -0
  255. package/Examples/SampleUI/src/components/TextInput/Adornment/TextInputIcon.tsx +195 -0
  256. package/Examples/SampleUI/src/components/TextInput/Adornment/enums.tsx +12 -0
  257. package/Examples/SampleUI/src/components/TextInput/Adornment/types.tsx +11 -0
  258. package/Examples/SampleUI/src/components/TextInput/Adornment/utils.ts +48 -0
  259. package/Examples/SampleUI/src/components/TextInput/Label/InputLabel.tsx +217 -0
  260. package/Examples/SampleUI/src/components/TextInput/Label/LabelBackground.tsx +100 -0
  261. package/Examples/SampleUI/src/components/TextInput/TextInput.tsx +572 -0
  262. package/Examples/SampleUI/src/components/TextInput/TextInputFlat.tsx +475 -0
  263. package/Examples/SampleUI/src/components/TextInput/TextInputOutlined.tsx +450 -0
  264. package/Examples/SampleUI/src/components/TextInput/constants.tsx +48 -0
  265. package/Examples/SampleUI/src/components/TextInput/helpers.tsx +612 -0
  266. package/Examples/SampleUI/src/components/TextInput/types.tsx +155 -0
  267. package/Examples/SampleUI/src/components/ToggleButton/ToggleButton.tsx +187 -0
  268. package/Examples/SampleUI/src/components/ToggleButton/ToggleButtonGroup.tsx +72 -0
  269. package/Examples/SampleUI/src/components/ToggleButton/ToggleButtonRow.tsx +107 -0
  270. package/Examples/SampleUI/src/components/ToggleButton/index.ts +16 -0
  271. package/Examples/SampleUI/src/components/ToggleButton/utils.ts +26 -0
  272. package/Examples/SampleUI/src/components/Tooltip/Tooltip.tsx +249 -0
  273. package/Examples/SampleUI/src/components/Tooltip/utils.ts +129 -0
  274. package/Examples/SampleUI/src/components/TouchableRipple/Pressable.tsx +41 -0
  275. package/Examples/SampleUI/src/components/TouchableRipple/TouchableRipple.native.tsx +145 -0
  276. package/Examples/SampleUI/src/components/TouchableRipple/TouchableRipple.tsx +317 -0
  277. package/Examples/SampleUI/src/components/TouchableRipple/utils.ts +66 -0
  278. package/Examples/SampleUI/src/components/Typography/AnimatedText.tsx +107 -0
  279. package/Examples/SampleUI/src/components/Typography/Text.tsx +184 -0
  280. package/Examples/SampleUI/src/components/Typography/types.tsx +5 -0
  281. package/Examples/SampleUI/src/components/Typography/v2/Caption.tsx +50 -0
  282. package/Examples/SampleUI/src/components/Typography/v2/Headline.tsx +52 -0
  283. package/Examples/SampleUI/src/components/Typography/v2/Paragraph.tsx +49 -0
  284. package/Examples/SampleUI/src/components/Typography/v2/StyledText.tsx +56 -0
  285. package/Examples/SampleUI/src/components/Typography/v2/Subheading.tsx +50 -0
  286. package/Examples/SampleUI/src/components/Typography/v2/Text.tsx +62 -0
  287. package/Examples/SampleUI/src/components/Typography/v2/Title.tsx +49 -0
  288. package/Examples/SampleUI/src/components/Typography/v2/index.ts +5 -0
  289. package/Examples/SampleUI/src/core/PaperProvider.tsx +122 -0
  290. package/Examples/SampleUI/src/core/SafeAreaProviderCompat.tsx +65 -0
  291. package/Examples/SampleUI/src/core/settings.tsx +23 -0
  292. package/Examples/SampleUI/src/core/theming.tsx +170 -0
  293. package/Examples/SampleUI/src/index.native.tsx +270 -0
  294. package/Examples/SampleUI/src/index.tsx +226 -0
  295. package/Examples/SampleUI/src/react-navigation/index.tsx +19 -0
  296. package/Examples/SampleUI/src/react-navigation/navigators/createMaterialBottomTabNavigator.tsx +72 -0
  297. package/Examples/SampleUI/src/react-navigation/types.tsx +126 -0
  298. package/Examples/SampleUI/src/react-navigation/views/MaterialBottomTabView.tsx +140 -0
  299. package/Examples/SampleUI/src/styles/__tests__/fonts.test.js +290 -0
  300. package/Examples/SampleUI/src/styles/fonts.tsx +143 -0
  301. package/Examples/SampleUI/src/styles/overlay.tsx +70 -0
  302. package/Examples/SampleUI/src/styles/shadow.tsx +109 -0
  303. package/Examples/SampleUI/src/styles/themes/index.ts +4 -0
  304. package/Examples/SampleUI/src/styles/themes/v2/DarkTheme.tsx +30 -0
  305. package/Examples/SampleUI/src/styles/themes/v2/LightTheme.tsx +30 -0
  306. package/Examples/SampleUI/src/styles/themes/v2/colors.tsx +277 -0
  307. package/Examples/SampleUI/src/styles/themes/v3/DarkTheme.tsx +66 -0
  308. package/Examples/SampleUI/src/styles/themes/v3/LightTheme.tsx +69 -0
  309. package/Examples/SampleUI/src/styles/themes/v3/tokens.tsx +230 -0
  310. package/Examples/SampleUI/src/utils/BackHandler/BackHandler.native.tsx +3 -0
  311. package/Examples/SampleUI/src/utils/BackHandler/BackHandler.tsx +11 -0
  312. package/Examples/SampleUI/src/utils/addEventListener.tsx +56 -0
  313. package/Examples/SampleUI/src/utils/forwardRef.tsx +23 -0
  314. package/Examples/SampleUI/src/utils/getContrastingColor.tsx +15 -0
  315. package/Examples/SampleUI/src/utils/hasTouchHandler.tsx +23 -0
  316. package/Examples/SampleUI/src/utils/roundLayoutSize.ts +2 -0
  317. package/Examples/SampleUI/src/utils/splitStyles.ts +60 -0
  318. package/Examples/SampleUI/src/utils/useAnimatedValue.tsx +9 -0
  319. package/Examples/SampleUI/src/utils/useAnimatedValueArray.tsx +13 -0
  320. package/Examples/SampleUI/src/utils/useIsKeyboardShown.tsx +55 -0
  321. package/Examples/SampleUI/src/utils/useLayout.tsx +29 -0
  322. package/Examples/SampleUI/src/utils/useLazyRef.tsx +11 -0
  323. package/Examples/SampleUI/tsconfig.json +3 -0
  324. package/Examples/SampleUI/utils/index.ts +1426 -0
  325. package/lib/typescript/jslib/TLTRN.d.ts +5 -5
  326. package/lib/typescript/jslib/TLTRN.d.ts.map +1 -1
  327. package/package.json +7 -2
@@ -0,0 +1,257 @@
1
+ import * as React from 'react';
2
+ import {
3
+ AccessibilityState,
4
+ ColorValue,
5
+ GestureResponderEvent,
6
+ PressableAndroidRippleConfig,
7
+ StyleProp,
8
+ StyleSheet,
9
+ TextStyle,
10
+ View,
11
+ ViewStyle,
12
+ } from 'react-native';
13
+
14
+ import {
15
+ getContentMaxWidth,
16
+ getMenuItemColor,
17
+ MAX_WIDTH,
18
+ MIN_WIDTH,
19
+ } from './utils';
20
+ import { useInternalTheme } from '../../core/theming';
21
+ import type { ThemeProp } from '../../types';
22
+ import Icon, { IconSource } from '../Icon';
23
+ import TouchableRipple from '../TouchableRipple/TouchableRipple';
24
+ import Text from '../Typography/Text';
25
+
26
+ export type Props = {
27
+ /**
28
+ * Title text for the `MenuItem`.
29
+ */
30
+ title: React.ReactNode;
31
+ /**
32
+ * @renamed Renamed from 'icon' to 'leadingIcon' in v5.x
33
+ *
34
+ * Leading icon to display for the `MenuItem`.
35
+ */
36
+ leadingIcon?: IconSource;
37
+ /**
38
+ * @supported Available in v5.x with theme version 3
39
+ *
40
+ * Trailing icon to display for the `MenuItem`.
41
+ */
42
+ trailingIcon?: IconSource;
43
+ /**
44
+ * Whether the 'item' is disabled. A disabled 'item' is greyed out and `onPress` is not called on touch.
45
+ */
46
+ disabled?: boolean;
47
+ /**
48
+ * @supported Available in v5.x with theme version 3
49
+ *
50
+ * Sets min height with densed layout.
51
+ */
52
+ dense?: boolean;
53
+ /**
54
+ * Type of background drawabale to display the feedback (Android).
55
+ * https://reactnative.dev/docs/pressable#rippleconfig
56
+ */
57
+ background?: PressableAndroidRippleConfig;
58
+ /**
59
+ * Function to execute on press.
60
+ */
61
+ onPress?: (e: GestureResponderEvent) => void;
62
+ /**
63
+ * Specifies the largest possible scale a title font can reach.
64
+ */
65
+ titleMaxFontSizeMultiplier?: number;
66
+ /**
67
+ * @optional
68
+ */
69
+ style?: StyleProp<ViewStyle>;
70
+ contentStyle?: StyleProp<ViewStyle>;
71
+ titleStyle?: StyleProp<TextStyle>;
72
+ /**
73
+ * Color of the ripple effect.
74
+ */
75
+ rippleColor?: ColorValue;
76
+ /**
77
+ * @optional
78
+ */
79
+ theme?: ThemeProp;
80
+ /**
81
+ * TestID used for testing purposes
82
+ */
83
+ testID?: string;
84
+ /**
85
+ * Accessibility label for the Touchable. This is read by the screen reader when the user taps the component.
86
+ */
87
+ accessibilityLabel?: string;
88
+ /**
89
+ * Accessibility state for the Touchable. This is read by the screen reader when the user taps the component.
90
+ */
91
+ accessibilityState?: AccessibilityState;
92
+ };
93
+
94
+ /**
95
+ * A component to show a single list item inside a Menu.
96
+ *
97
+ * ## Usage
98
+ * ```js
99
+ * import * as React from 'react';
100
+ * import { View } from 'react-native';
101
+ * import { Menu } from 'react-native-paper';
102
+ *
103
+ * const MyComponent = () => (
104
+ * <View style={{ flex: 1 }}>
105
+ * <Menu.Item leadingIcon="redo" onPress={() => {}} title="Redo" />
106
+ * <Menu.Item leadingIcon="undo" onPress={() => {}} title="Undo" />
107
+ * <Menu.Item leadingIcon="content-cut" onPress={() => {}} title="Cut" disabled />
108
+ * <Menu.Item leadingIcon="content-copy" onPress={() => {}} title="Copy" disabled />
109
+ * <Menu.Item leadingIcon="content-paste" onPress={() => {}} title="Paste" />
110
+ * </View>
111
+ * );
112
+ *
113
+ * export default MyComponent;
114
+ * ```
115
+ */
116
+ const MenuItem = ({
117
+ leadingIcon,
118
+ trailingIcon,
119
+ dense,
120
+ title,
121
+ disabled,
122
+ background,
123
+ onPress,
124
+ style,
125
+ contentStyle,
126
+ titleStyle,
127
+ rippleColor: customRippleColor,
128
+ testID = 'menu-item',
129
+ accessibilityLabel,
130
+ accessibilityState,
131
+ theme: themeOverrides,
132
+ titleMaxFontSizeMultiplier = 1.5,
133
+ }: Props) => {
134
+ const theme = useInternalTheme(themeOverrides);
135
+ const { titleColor, iconColor, rippleColor } = getMenuItemColor({
136
+ theme,
137
+ disabled,
138
+ customRippleColor,
139
+ });
140
+ const { isV3 } = theme;
141
+
142
+ const containerPadding = isV3 ? 12 : 8;
143
+
144
+ const iconWidth = isV3 ? 24 : 40;
145
+
146
+ const minWidth = MIN_WIDTH - (isV3 ? 12 : 16);
147
+
148
+ const maxWidth = getContentMaxWidth({
149
+ isV3,
150
+ iconWidth,
151
+ leadingIcon,
152
+ trailingIcon,
153
+ });
154
+
155
+ const titleTextStyle = {
156
+ color: titleColor,
157
+ ...(isV3 ? theme.fonts.bodyLarge : {}),
158
+ };
159
+
160
+ const newAccessibilityState = { ...accessibilityState, disabled };
161
+
162
+ return (
163
+ <TouchableRipple
164
+ style={[
165
+ styles.container,
166
+ { paddingHorizontal: containerPadding },
167
+ dense && styles.md3DenseContainer,
168
+ style,
169
+ ]}
170
+ onPress={onPress}
171
+ disabled={disabled}
172
+ testID={testID}
173
+ background={background}
174
+ accessibilityLabel={accessibilityLabel}
175
+ accessibilityRole="menuitem"
176
+ accessibilityState={newAccessibilityState}
177
+ rippleColor={rippleColor}
178
+ >
179
+ <View style={styles.row}>
180
+ {leadingIcon ? (
181
+ <View
182
+ style={[!isV3 && styles.item, { width: iconWidth }]}
183
+ pointerEvents="box-none"
184
+ >
185
+ <Icon source={leadingIcon} size={24} color={iconColor} />
186
+ </View>
187
+ ) : null}
188
+ <View
189
+ style={[
190
+ !isV3 && styles.item,
191
+ styles.content,
192
+ { minWidth, maxWidth },
193
+ isV3 &&
194
+ (leadingIcon
195
+ ? styles.md3LeadingIcon
196
+ : styles.md3WithoutLeadingIcon),
197
+ contentStyle,
198
+ ]}
199
+ pointerEvents="none"
200
+ >
201
+ <Text
202
+ variant="bodyLarge"
203
+ selectable={false}
204
+ numberOfLines={1}
205
+ testID={`${testID}-title`}
206
+ style={[!isV3 && styles.title, titleTextStyle, titleStyle]}
207
+ maxFontSizeMultiplier={titleMaxFontSizeMultiplier}
208
+ >
209
+ {title}
210
+ </Text>
211
+ </View>
212
+ {isV3 && trailingIcon ? (
213
+ <View
214
+ style={[!isV3 && styles.item, { width: iconWidth }]}
215
+ pointerEvents="box-none"
216
+ >
217
+ <Icon source={trailingIcon} size={24} color={iconColor} />
218
+ </View>
219
+ ) : null}
220
+ </View>
221
+ </TouchableRipple>
222
+ );
223
+ };
224
+
225
+ MenuItem.displayName = 'Menu.Item';
226
+
227
+ const styles = StyleSheet.create({
228
+ container: {
229
+ minWidth: MIN_WIDTH,
230
+ maxWidth: MAX_WIDTH,
231
+ height: 48,
232
+ justifyContent: 'center',
233
+ },
234
+ md3DenseContainer: {
235
+ height: 32,
236
+ },
237
+ row: {
238
+ flexDirection: 'row',
239
+ },
240
+ title: {
241
+ fontSize: 16,
242
+ },
243
+ item: {
244
+ marginHorizontal: 8,
245
+ },
246
+ content: {
247
+ justifyContent: 'center',
248
+ },
249
+ md3LeadingIcon: {
250
+ marginLeft: 12,
251
+ },
252
+ md3WithoutLeadingIcon: {
253
+ marginLeft: 4,
254
+ },
255
+ });
256
+
257
+ export default MenuItem;
@@ -0,0 +1,110 @@
1
+ import type { ColorValue } from 'react-native';
2
+
3
+ import color from 'color';
4
+
5
+ import { black, white } from '../../styles/themes/v2/colors';
6
+ import type { InternalTheme } from '../../types';
7
+ import type { IconSource } from '../Icon';
8
+
9
+ export const MIN_WIDTH = 112;
10
+ export const MAX_WIDTH = 280;
11
+
12
+ type ContentProps = {
13
+ isV3: boolean;
14
+ iconWidth: number;
15
+ leadingIcon?: IconSource;
16
+ trailingIcon?: IconSource;
17
+ };
18
+
19
+ type ColorProps = {
20
+ theme: InternalTheme;
21
+ disabled?: boolean;
22
+ customRippleColor?: ColorValue;
23
+ };
24
+
25
+ const getDisabledColor = (theme: InternalTheme) => {
26
+ if (theme.isV3) {
27
+ return theme.colors.onSurfaceDisabled;
28
+ }
29
+
30
+ return color(theme.dark ? white : black)
31
+ .alpha(0.32)
32
+ .rgb()
33
+ .string();
34
+ };
35
+
36
+ const getTitleColor = ({ theme, disabled }: ColorProps) => {
37
+ if (disabled) {
38
+ return getDisabledColor(theme);
39
+ }
40
+
41
+ if (theme.isV3) {
42
+ return theme.colors.onSurface;
43
+ }
44
+
45
+ return color(theme.colors.text).alpha(0.87).rgb().string();
46
+ };
47
+
48
+ const getIconColor = ({ theme, disabled }: ColorProps) => {
49
+ if (disabled) {
50
+ return getDisabledColor(theme);
51
+ }
52
+
53
+ if (theme.isV3) {
54
+ return theme.colors.onSurfaceVariant;
55
+ }
56
+
57
+ return color(theme.colors.text).alpha(0.54).rgb().string();
58
+ };
59
+
60
+ const getRippleColor = ({
61
+ theme,
62
+ customRippleColor,
63
+ }: Omit<ColorProps, 'disabled'>) => {
64
+ if (customRippleColor) {
65
+ return customRippleColor;
66
+ }
67
+
68
+ if (theme.isV3) {
69
+ return color(theme.colors.onSurfaceVariant).alpha(0.12).rgb().string();
70
+ }
71
+
72
+ return undefined;
73
+ };
74
+
75
+ export const getMenuItemColor = ({
76
+ theme,
77
+ disabled,
78
+ customRippleColor,
79
+ }: ColorProps) => {
80
+ return {
81
+ titleColor: getTitleColor({ theme, disabled }),
82
+ iconColor: getIconColor({ theme, disabled }),
83
+ rippleColor: getRippleColor({ theme, customRippleColor }),
84
+ };
85
+ };
86
+
87
+ export const getContentMaxWidth = ({
88
+ isV3,
89
+ iconWidth,
90
+ leadingIcon,
91
+ trailingIcon,
92
+ }: ContentProps) => {
93
+ if (isV3) {
94
+ if (leadingIcon && trailingIcon) {
95
+ return MAX_WIDTH - (2 * iconWidth + 24);
96
+ }
97
+
98
+ if (leadingIcon || trailingIcon) {
99
+ return MAX_WIDTH - (iconWidth + 24);
100
+ }
101
+
102
+ return MAX_WIDTH - 12;
103
+ }
104
+
105
+ if (leadingIcon) {
106
+ return MAX_WIDTH - (iconWidth + 48);
107
+ }
108
+
109
+ return MAX_WIDTH - 16;
110
+ };
@@ -0,0 +1,245 @@
1
+ import * as React from 'react';
2
+ import {
3
+ Animated,
4
+ Easing,
5
+ StyleProp,
6
+ StyleSheet,
7
+ Pressable,
8
+ View,
9
+ ViewStyle,
10
+ } from 'react-native';
11
+
12
+ import { useSafeAreaInsets } from 'react-native-safe-area-context';
13
+ import useLatestCallback from 'use-latest-callback';
14
+
15
+ import Surface from './Surface';
16
+ import { useInternalTheme } from '../core/theming';
17
+ import type { ThemeProp } from '../types';
18
+ import { addEventListener } from '../utils/addEventListener';
19
+ import { BackHandler } from '../utils/BackHandler/BackHandler';
20
+ import useAnimatedValue from '../utils/useAnimatedValue';
21
+
22
+ export type Props = {
23
+ /**
24
+ * Determines whether clicking outside the modal dismisses it.
25
+ */
26
+ dismissable?: boolean;
27
+ /**
28
+ * Determines whether clicking Android hardware back button dismisses the dialog.
29
+ */
30
+ dismissableBackButton?: boolean;
31
+ /**
32
+ * Callback that is called when the user dismisses the modal.
33
+ */
34
+ onDismiss?: () => void;
35
+ /**
36
+ * Accessibility label for the overlay. This is read by the screen reader when the user taps outside the modal.
37
+ */
38
+ overlayAccessibilityLabel?: string;
39
+ /**
40
+ * Determines Whether the modal is visible.
41
+ */
42
+ visible: boolean;
43
+ /**
44
+ * Content of the `Modal`.
45
+ */
46
+ children: React.ReactNode;
47
+ /**
48
+ * Style for the content of the modal
49
+ */
50
+ contentContainerStyle?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
51
+ /**
52
+ * Style for the wrapper of the modal.
53
+ * Use this prop to change the default wrapper style or to override safe area insets with marginTop and marginBottom.
54
+ */
55
+ style?: StyleProp<ViewStyle>;
56
+ /**
57
+ * @optional
58
+ */
59
+ theme?: ThemeProp;
60
+ /**
61
+ * testID to be used on tests.
62
+ */
63
+ testID?: string;
64
+ };
65
+
66
+ const DEFAULT_DURATION = 220;
67
+ const AnimatedPressable = Animated.createAnimatedComponent(Pressable);
68
+
69
+ /**
70
+ * The Modal component is a simple way to present content above an enclosing view.
71
+ * To render the `Modal` above other components, you'll need to wrap it with the [`Portal`](./Portal) component.
72
+ *
73
+ * ## Usage
74
+ * ```js
75
+ * import * as React from 'react';
76
+ * import { Modal, Portal, Text, Button, PaperProvider } from 'react-native-paper';
77
+ *
78
+ * const MyComponent = () => {
79
+ * const [visible, setVisible] = React.useState(false);
80
+ *
81
+ * const showModal = () => setVisible(true);
82
+ * const hideModal = () => setVisible(false);
83
+ * const containerStyle = {backgroundColor: 'white', padding: 20};
84
+ *
85
+ * return (
86
+ * <PaperProvider>
87
+ * <Portal>
88
+ * <Modal visible={visible} onDismiss={hideModal} contentContainerStyle={containerStyle}>
89
+ * <Text>Example Modal. Click outside this area to dismiss.</Text>
90
+ * </Modal>
91
+ * </Portal>
92
+ * <Button style={{marginTop: 30}} onPress={showModal}>
93
+ * Show
94
+ * </Button>
95
+ * </PaperProvider>
96
+ * );
97
+ * };
98
+ *
99
+ * export default MyComponent;
100
+ * ```
101
+ */
102
+ function Modal({
103
+ dismissable = true,
104
+ dismissableBackButton = dismissable,
105
+ visible = false,
106
+ overlayAccessibilityLabel = 'Close modal',
107
+ onDismiss = () => {},
108
+ children,
109
+ contentContainerStyle,
110
+ style,
111
+ theme: themeOverrides,
112
+ testID = 'modal',
113
+ }: Props) {
114
+ const theme = useInternalTheme(themeOverrides);
115
+ const onDismissCallback = useLatestCallback(onDismiss);
116
+ const { scale } = theme.animation;
117
+ const { top, bottom } = useSafeAreaInsets();
118
+ const opacity = useAnimatedValue(visible ? 1 : 0);
119
+ const [visibleInternal, setVisibleInternal] = React.useState(visible);
120
+
121
+ const showModalAnimation = React.useCallback(() => {
122
+ Animated.timing(opacity, {
123
+ toValue: 1,
124
+ duration: scale * DEFAULT_DURATION,
125
+ easing: Easing.out(Easing.cubic),
126
+ useNativeDriver: true,
127
+ }).start();
128
+ }, [opacity, scale]);
129
+
130
+ const hideModalAnimation = React.useCallback(() => {
131
+ Animated.timing(opacity, {
132
+ toValue: 0,
133
+ duration: scale * DEFAULT_DURATION,
134
+ easing: Easing.out(Easing.cubic),
135
+ useNativeDriver: true,
136
+ }).start(({ finished }) => {
137
+ if (!finished) {
138
+ return;
139
+ }
140
+
141
+ setVisibleInternal(false);
142
+ });
143
+ }, [opacity, scale]);
144
+
145
+ React.useEffect(() => {
146
+ if (visibleInternal === visible) {
147
+ return;
148
+ }
149
+
150
+ if (!visibleInternal && visible) {
151
+ setVisibleInternal(true);
152
+ return showModalAnimation();
153
+ }
154
+
155
+ if (visibleInternal && !visible) {
156
+ return hideModalAnimation();
157
+ }
158
+ }, [visible, showModalAnimation, hideModalAnimation, visibleInternal]);
159
+
160
+ React.useEffect(() => {
161
+ if (!visible) {
162
+ return undefined;
163
+ }
164
+
165
+ const onHardwareBackPress = () => {
166
+ if (dismissable || dismissableBackButton) {
167
+ onDismissCallback();
168
+ }
169
+
170
+ return true;
171
+ };
172
+
173
+ const subscription = addEventListener(
174
+ BackHandler,
175
+ 'hardwareBackPress',
176
+ onHardwareBackPress
177
+ );
178
+ return () => subscription.remove();
179
+ }, [dismissable, dismissableBackButton, onDismissCallback, visible]);
180
+
181
+ if (!visibleInternal) {
182
+ return null;
183
+ }
184
+
185
+ return (
186
+ <Animated.View
187
+ pointerEvents={visible ? 'auto' : 'none'}
188
+ accessibilityViewIsModal
189
+ accessibilityLiveRegion="polite"
190
+ style={StyleSheet.absoluteFill}
191
+ onAccessibilityEscape={onDismissCallback}
192
+ testID={testID}
193
+ >
194
+ <AnimatedPressable
195
+ accessibilityLabel={overlayAccessibilityLabel}
196
+ accessibilityRole="button"
197
+ disabled={!dismissable}
198
+ onPress={dismissable ? onDismissCallback : undefined}
199
+ importantForAccessibility="no"
200
+ style={[
201
+ styles.backdrop,
202
+ {
203
+ backgroundColor: theme.colors?.backdrop,
204
+ opacity,
205
+ },
206
+ ]}
207
+ testID={`${testID}-backdrop`}
208
+ />
209
+ <View
210
+ style={[
211
+ styles.wrapper,
212
+ { marginTop: top, marginBottom: bottom },
213
+ style,
214
+ ]}
215
+ pointerEvents="box-none"
216
+ testID={`${testID}-wrapper`}
217
+ >
218
+ <Surface
219
+ testID={`${testID}-surface`}
220
+ theme={theme}
221
+ style={[{ opacity }, styles.content, contentContainerStyle]}
222
+ >
223
+ {children}
224
+ </Surface>
225
+ </View>
226
+ </Animated.View>
227
+ );
228
+ }
229
+
230
+ export default Modal;
231
+
232
+ const styles = StyleSheet.create({
233
+ backdrop: {
234
+ flex: 1,
235
+ },
236
+ wrapper: {
237
+ ...StyleSheet.absoluteFillObject,
238
+ justifyContent: 'center',
239
+ },
240
+ // eslint-disable-next-line react-native/no-color-literals
241
+ content: {
242
+ backgroundColor: 'transparent',
243
+ justifyContent: 'center',
244
+ },
245
+ });
@@ -0,0 +1,69 @@
1
+ import * as React from 'react';
2
+
3
+ import type { InternalTheme } from 'src/types';
4
+
5
+ import PortalConsumer from './PortalConsumer';
6
+ import PortalHost, { PortalContext, PortalMethods } from './PortalHost';
7
+ import {
8
+ Consumer as SettingsConsumer,
9
+ Provider as SettingsProvider,
10
+ } from '../../core/settings';
11
+ import { ThemeProvider, withInternalTheme } from '../../core/theming';
12
+
13
+ export type Props = {
14
+ /**
15
+ * Content of the `Portal`.
16
+ */
17
+ children: React.ReactNode;
18
+ /**
19
+ * @optional
20
+ */
21
+ theme: InternalTheme;
22
+ };
23
+
24
+ /**
25
+ * Portal allows rendering a component at a different place in the parent tree.
26
+ * You can use it to render content which should appear above other elements, similar to `Modal`.
27
+ * It requires a [`Portal.Host`](PortalHost) component to be rendered somewhere in the parent tree.
28
+ * Note that if you're using the `Provider` component, this already includes a `Portal.Host`.
29
+ *
30
+ * ## Usage
31
+ * ```js
32
+ * import * as React from 'react';
33
+ * import { Portal, Text } from 'react-native-paper';
34
+ *
35
+ * const MyComponent = () => (
36
+ * <Portal>
37
+ * <Text>This is rendered at a different place</Text>
38
+ * </Portal>
39
+ * );
40
+ *
41
+ * export default MyComponent;
42
+ * ```
43
+ */
44
+ class Portal extends React.Component<Props> {
45
+ // @component ./PortalHost.tsx
46
+ static Host = PortalHost;
47
+
48
+ render() {
49
+ const { children, theme } = this.props;
50
+
51
+ return (
52
+ <SettingsConsumer>
53
+ {(settings) => (
54
+ <PortalContext.Consumer>
55
+ {(manager) => (
56
+ <PortalConsumer manager={manager as PortalMethods}>
57
+ <SettingsProvider value={settings}>
58
+ <ThemeProvider theme={theme}>{children}</ThemeProvider>
59
+ </SettingsProvider>
60
+ </PortalConsumer>
61
+ )}
62
+ </PortalContext.Consumer>
63
+ )}
64
+ </SettingsConsumer>
65
+ );
66
+ }
67
+ }
68
+
69
+ export default withInternalTheme(Portal);