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

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,643 @@
1
+ import * as React from 'react';
2
+ import {
3
+ Animated,
4
+ ColorValue,
5
+ EasingFunction,
6
+ Platform,
7
+ StyleProp,
8
+ StyleSheet,
9
+ View,
10
+ ViewStyle,
11
+ } from 'react-native';
12
+
13
+ import useLatestCallback from 'use-latest-callback';
14
+
15
+ import BottomNavigationBar from './BottomNavigationBar';
16
+ import BottomNavigationRouteScreen from './BottomNavigationRouteScreen';
17
+ import { useInternalTheme } from '../../core/theming';
18
+ import type { ThemeProp } from '../../types';
19
+ import useAnimatedValueArray from '../../utils/useAnimatedValueArray';
20
+ import type { IconSource } from '../Icon';
21
+ import { Props as TouchableRippleProps } from '../TouchableRipple/TouchableRipple';
22
+
23
+ export type BaseRoute = {
24
+ key: string;
25
+ title?: string;
26
+ focusedIcon?: IconSource;
27
+ unfocusedIcon?: IconSource;
28
+ badge?: string | number | boolean;
29
+ /**
30
+ * @deprecated In v5.x works only with theme version 2.
31
+ */
32
+ color?: string;
33
+ accessibilityLabel?: string;
34
+ testID?: string;
35
+ lazy?: boolean;
36
+ };
37
+
38
+ type NavigationState<Route extends BaseRoute> = {
39
+ index: number;
40
+ routes: Route[];
41
+ };
42
+
43
+ type TabPressEvent = {
44
+ defaultPrevented: boolean;
45
+ preventDefault(): void;
46
+ };
47
+
48
+ type TouchableProps<Route extends BaseRoute> = TouchableRippleProps & {
49
+ key: string;
50
+ route: Route;
51
+ children: React.ReactNode;
52
+ borderless?: boolean;
53
+ centered?: boolean;
54
+ rippleColor?: ColorValue;
55
+ };
56
+
57
+ export type Props<Route extends BaseRoute> = {
58
+ /**
59
+ * Whether the shifting style is used, the active tab icon shifts up to show the label and the inactive tabs won't have a label.
60
+ *
61
+ * By default, this is `false` with theme version 3 and `true` when you have more than 3 tabs.
62
+ * Pass `shifting={false}` to explicitly disable this animation, or `shifting={true}` to always use this animation.
63
+ * Note that you need at least 2 tabs be able to run this animation.
64
+ */
65
+ shifting?: boolean;
66
+ /**
67
+ * Whether to show labels in tabs. When `false`, only icons will be displayed.
68
+ */
69
+ labeled?: boolean;
70
+ /**
71
+ * Whether tabs should be spread across the entire width.
72
+ */
73
+ compact?: boolean;
74
+ /**
75
+ * State for the bottom navigation. The state should contain the following properties:
76
+ *
77
+ * - `index`: a number representing the index of the active route in the `routes` array
78
+ * - `routes`: an array containing a list of route objects used for rendering the tabs
79
+ *
80
+ * Each route object should contain the following properties:
81
+ *
82
+ * - `key`: a unique key to identify the route (required)
83
+ * - `title`: title of the route to use as the tab label
84
+ * - `focusedIcon`: icon to use as the focused tab icon, can be a string, an image source or a react component @renamed Renamed from 'icon' to 'focusedIcon' in v5.x
85
+ * - `unfocusedIcon`: icon to use as the unfocused tab icon, can be a string, an image source or a react component @supported Available in v5.x with theme version 3
86
+ * - `color`: color to use as background color for shifting bottom navigation @deprecatedProperty In v5.x works only with theme version 2.
87
+ * - `badge`: badge to show on the tab icon, can be `true` to show a dot, `string` or `number` to show text.
88
+ * - `accessibilityLabel`: accessibility label for the tab button
89
+ * - `testID`: test id for the tab button
90
+ *
91
+ * Example:
92
+ *
93
+ * ```js
94
+ * {
95
+ * index: 1,
96
+ * routes: [
97
+ * { key: 'music', title: 'Favorites', focusedIcon: 'heart', unfocusedIcon: 'heart-outline'},
98
+ * { key: 'albums', title: 'Albums', focusedIcon: 'album' },
99
+ * { key: 'recents', title: 'Recents', focusedIcon: 'history' },
100
+ * { key: 'notifications', title: 'Notifications', focusedIcon: 'bell', unfocusedIcon: 'bell-outline' },
101
+ * ]
102
+ * }
103
+ * ```
104
+ *
105
+ * `BottomNavigation` is a controlled component, which means the `index` needs to be updated via the `onIndexChange` callback.
106
+ */
107
+ navigationState: NavigationState<Route>;
108
+ /**
109
+ * Callback which is called on tab change, receives the index of the new tab as argument.
110
+ * The navigation state needs to be updated when it's called, otherwise the change is dropped.
111
+ */
112
+ onIndexChange: (index: number) => void;
113
+ /**
114
+ * Callback which returns a react element to render as the page for the tab. Receives an object containing the route as the argument:
115
+ *
116
+ * ```js
117
+ * renderScene = ({ route, jumpTo }) => {
118
+ * switch (route.key) {
119
+ * case 'music':
120
+ * return <MusicRoute jumpTo={jumpTo} />;
121
+ * case 'albums':
122
+ * return <AlbumsRoute jumpTo={jumpTo} />;
123
+ * }
124
+ * }
125
+ * ```
126
+ *
127
+ * Pages are lazily rendered, which means that a page will be rendered the first time you navigate to it.
128
+ * After initial render, all the pages stay rendered to preserve their state.
129
+ *
130
+ * You need to make sure that your individual routes implement a `shouldComponentUpdate` to improve the performance.
131
+ * To make it easier to specify the components, you can use the `SceneMap` helper:
132
+ *
133
+ * ```js
134
+ * renderScene = BottomNavigation.SceneMap({
135
+ * music: MusicRoute,
136
+ * albums: AlbumsRoute,
137
+ * });
138
+ * ```
139
+ *
140
+ * Specifying the components this way is easier and takes care of implementing a `shouldComponentUpdate` method.
141
+ * Each component will receive the current route and a `jumpTo` method as it's props.
142
+ * The `jumpTo` method can be used to navigate to other tabs programmatically:
143
+ *
144
+ * ```js
145
+ * this.props.jumpTo('albums')
146
+ * ```
147
+ */
148
+ renderScene: (props: {
149
+ route: Route;
150
+ jumpTo: (key: string) => void;
151
+ }) => React.ReactNode | null;
152
+ /**
153
+ * Callback which returns a React Element to be used as tab icon.
154
+ */
155
+ renderIcon?: (props: {
156
+ route: Route;
157
+ focused: boolean;
158
+ color: string;
159
+ }) => React.ReactNode;
160
+ /**
161
+ * Callback which React Element to be used as tab label.
162
+ */
163
+ renderLabel?: (props: {
164
+ route: Route;
165
+ focused: boolean;
166
+ color: string;
167
+ }) => React.ReactNode;
168
+ /**
169
+ * Callback which returns a React element to be used as the touchable for the tab item.
170
+ * Renders a `TouchableRipple` on Android and `Pressable` on iOS.
171
+ */
172
+ renderTouchable?: (props: TouchableProps<Route>) => React.ReactNode;
173
+ /**
174
+ * Get accessibility label for the tab button. This is read by the screen reader when the user taps the tab.
175
+ * Uses `route.accessibilityLabel` by default.
176
+ */
177
+ getAccessibilityLabel?: (props: { route: Route }) => string | undefined;
178
+ /**
179
+ * Get badge for the tab, uses `route.badge` by default.
180
+ */
181
+ getBadge?: (props: { route: Route }) => boolean | number | string | undefined;
182
+ /**
183
+ * Get color for the tab, uses `route.color` by default.
184
+ */
185
+ getColor?: (props: { route: Route }) => string | undefined;
186
+ /**
187
+ * Get label text for the tab, uses `route.title` by default. Use `renderLabel` to replace label component.
188
+ */
189
+ getLabelText?: (props: { route: Route }) => string | undefined;
190
+ /**
191
+ * Get lazy for the current screen. Uses true by default.
192
+ */
193
+ getLazy?: (props: { route: Route }) => boolean | undefined;
194
+ /**
195
+ * Get the id to locate this tab button in tests, uses `route.testID` by default.
196
+ */
197
+ getTestID?: (props: { route: Route }) => string | undefined;
198
+ /**
199
+ * Function to execute on tab press. It receives the route for the pressed tab, useful for things like scroll to top.
200
+ */
201
+ onTabPress?: (props: { route: Route } & TabPressEvent) => void;
202
+ /**
203
+ * Function to execute on tab long press. It receives the route for the pressed tab, useful for things like custom action when longed pressed.
204
+ */
205
+ onTabLongPress?: (props: { route: Route } & TabPressEvent) => void;
206
+ /**
207
+ * Custom color for icon and label in the active tab.
208
+ */
209
+ activeColor?: string;
210
+ /**
211
+ * Custom color for icon and label in the inactive tab.
212
+ */
213
+ inactiveColor?: string;
214
+ /**
215
+ * Whether animation is enabled for scenes transitions in `shifting` mode.
216
+ * By default, the scenes cross-fade during tab change when `shifting` is enabled.
217
+ * Specify `sceneAnimationEnabled` as `false` to disable the animation.
218
+ */
219
+ sceneAnimationEnabled?: boolean;
220
+ /**
221
+ * The scene animation effect. Specify `'shifting'` for a different effect.
222
+ * By default, 'opacity' will be used.
223
+ */
224
+ sceneAnimationType?: 'opacity' | 'shifting';
225
+ /**
226
+ * The scene animation Easing.
227
+ */
228
+ sceneAnimationEasing?: EasingFunction | undefined;
229
+ /**
230
+ * Whether the bottom navigation bar is hidden when keyboard is shown.
231
+ * On Android, this works best when [`windowSoftInputMode`](https://developer.android.com/guide/topics/manifest/activity-element#wsoft) is set to `adjustResize`.
232
+ */
233
+ keyboardHidesNavigationBar?: boolean;
234
+ /**
235
+ * Safe area insets for the tab bar. This can be used to avoid elements like the navigation bar on Android and bottom safe area on iOS.
236
+ * The bottom insets for iOS is added by default. You can override the behavior with this option.
237
+ */
238
+ safeAreaInsets?: {
239
+ top?: number;
240
+ right?: number;
241
+ bottom?: number;
242
+ left?: number;
243
+ };
244
+ /**
245
+ * Style for the bottom navigation bar. You can pass a custom background color here:
246
+ *
247
+ * ```js
248
+ * barStyle={{ backgroundColor: '#694fad' }}
249
+ * ```
250
+ */
251
+ barStyle?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
252
+ /**
253
+ * Specifies the largest possible scale a label font can reach.
254
+ */
255
+ labelMaxFontSizeMultiplier?: number;
256
+ style?: StyleProp<ViewStyle>;
257
+ activeIndicatorStyle?: StyleProp<ViewStyle>;
258
+ /**
259
+ * @optional
260
+ */
261
+ theme?: ThemeProp;
262
+ /**
263
+ * TestID used for testing purposes
264
+ */
265
+ testID?: string;
266
+ };
267
+
268
+ const FAR_FAR_AWAY = Platform.OS === 'web' ? 0 : 9999;
269
+
270
+ const SceneComponent = React.memo(({ component, ...rest }: any) =>
271
+ React.createElement(component, rest)
272
+ );
273
+
274
+ /**
275
+ * BottomNavigation provides quick navigation between top-level views of an app with a bottom navigation bar.
276
+ * It is primarily designed for use on mobile. If you want to use the navigation bar only see [`BottomNavigation.Bar`](BottomNavigationBar).
277
+ *
278
+ * By default BottomNavigation uses primary color as a background, in dark theme with `adaptive` mode it will use surface colour instead.
279
+ * See [Dark Theme](https://callstack.github.io/react-native-paper/docs/guides/theming#dark-theme) for more information.
280
+ *
281
+ * ## Usage
282
+ * ```js
283
+ * import * as React from 'react';
284
+ * import { BottomNavigation, Text } from 'react-native-paper';
285
+ *
286
+ * const MusicRoute = () => <Text>Music</Text>;
287
+ *
288
+ * const AlbumsRoute = () => <Text>Albums</Text>;
289
+ *
290
+ * const RecentsRoute = () => <Text>Recents</Text>;
291
+ *
292
+ * const NotificationsRoute = () => <Text>Notifications</Text>;
293
+ *
294
+ * const MyComponent = () => {
295
+ * const [index, setIndex] = React.useState(0);
296
+ * const [routes] = React.useState([
297
+ * { key: 'music', title: 'Favorites', focusedIcon: 'heart', unfocusedIcon: 'heart-outline'},
298
+ * { key: 'albums', title: 'Albums', focusedIcon: 'album' },
299
+ * { key: 'recents', title: 'Recents', focusedIcon: 'history' },
300
+ * { key: 'notifications', title: 'Notifications', focusedIcon: 'bell', unfocusedIcon: 'bell-outline' },
301
+ * ]);
302
+ *
303
+ * const renderScene = BottomNavigation.SceneMap({
304
+ * music: MusicRoute,
305
+ * albums: AlbumsRoute,
306
+ * recents: RecentsRoute,
307
+ * notifications: NotificationsRoute,
308
+ * });
309
+ *
310
+ * return (
311
+ * <BottomNavigation
312
+ * navigationState={{ index, routes }}
313
+ * onIndexChange={setIndex}
314
+ * renderScene={renderScene}
315
+ * />
316
+ * );
317
+ * };
318
+ *
319
+ * export default MyComponent;
320
+ * ```
321
+ */
322
+ const BottomNavigation = <Route extends BaseRoute>({
323
+ navigationState,
324
+ renderScene,
325
+ renderIcon,
326
+ renderLabel,
327
+ renderTouchable,
328
+ getLabelText,
329
+ getBadge,
330
+ getColor,
331
+ getAccessibilityLabel,
332
+ getTestID,
333
+ activeColor,
334
+ inactiveColor,
335
+ keyboardHidesNavigationBar = Platform.OS === 'android',
336
+ barStyle,
337
+ labeled = true,
338
+ style,
339
+ activeIndicatorStyle,
340
+ sceneAnimationEnabled = false,
341
+ sceneAnimationType = 'opacity',
342
+ sceneAnimationEasing,
343
+ onTabPress,
344
+ onTabLongPress,
345
+ onIndexChange,
346
+ shifting: shiftingProp,
347
+ safeAreaInsets,
348
+ labelMaxFontSizeMultiplier = 1,
349
+ compact: compactProp,
350
+ testID = 'bottom-navigation',
351
+ theme: themeOverrides,
352
+ getLazy = ({ route }: { route: Route }) => route.lazy,
353
+ }: Props<Route>) => {
354
+ const theme = useInternalTheme(themeOverrides);
355
+ const { scale } = theme.animation;
356
+ const compact = compactProp ?? !theme.isV3;
357
+ let shifting =
358
+ shiftingProp ?? (theme.isV3 ? false : navigationState.routes.length > 3);
359
+
360
+ if (shifting && navigationState.routes.length < 2) {
361
+ shifting = false;
362
+ console.warn(
363
+ 'BottomNavigation needs at least 2 tabs to run shifting animation'
364
+ );
365
+ }
366
+
367
+ const focusedKey = navigationState.routes[navigationState.index].key;
368
+
369
+ /**
370
+ * Active state of individual tab item positions:
371
+ * -1 if they're before the active tab, 0 if they're active, 1 if they're after the active tab
372
+ */
373
+ const tabsPositionAnims = useAnimatedValueArray(
374
+ navigationState.routes.map((_, i) =>
375
+ i === navigationState.index ? 0 : i >= navigationState.index ? 1 : -1
376
+ )
377
+ );
378
+
379
+ /**
380
+ * The top offset for each tab item to position it offscreen.
381
+ * Placing items offscreen helps to save memory usage for inactive screens with removeClippedSubviews.
382
+ * We use animated values for this to prevent unnecessary re-renders.
383
+ */
384
+ const offsetsAnims = useAnimatedValueArray(
385
+ navigationState.routes.map(
386
+ // offscreen === 1, normal === 0
387
+ (_, i) => (i === navigationState.index ? 0 : 1)
388
+ )
389
+ );
390
+
391
+ /**
392
+ * List of loaded tabs, tabs will be loaded when navigated to.
393
+ */
394
+ const [loaded, setLoaded] = React.useState<string[]>([focusedKey]);
395
+
396
+ if (!loaded.includes(focusedKey)) {
397
+ // Set the current tab to be loaded if it was not loaded before
398
+ setLoaded((loaded) => [...loaded, focusedKey]);
399
+ }
400
+
401
+ const animateToIndex = React.useCallback(
402
+ (index: number) => {
403
+ Animated.parallel([
404
+ ...navigationState.routes.map((_, i) =>
405
+ Animated.timing(tabsPositionAnims[i], {
406
+ toValue: i === index ? 0 : i >= index ? 1 : -1,
407
+ duration: theme.isV3 || shifting ? 150 * scale : 0,
408
+ useNativeDriver: true,
409
+ easing: sceneAnimationEasing,
410
+ })
411
+ ),
412
+ ]).start(({ finished }) => {
413
+ if (finished) {
414
+ // Position all inactive screens offscreen to save memory usage
415
+ // Only do it when animation has finished to avoid glitches mid-transition if switching fast
416
+ offsetsAnims.forEach((offset, i) => {
417
+ if (i === index) {
418
+ offset.setValue(0);
419
+ } else {
420
+ offset.setValue(1);
421
+ }
422
+ });
423
+ }
424
+ });
425
+ },
426
+ [
427
+ shifting,
428
+ navigationState.routes,
429
+ offsetsAnims,
430
+ scale,
431
+ tabsPositionAnims,
432
+ sceneAnimationEasing,
433
+ theme,
434
+ ]
435
+ );
436
+
437
+ React.useEffect(() => {
438
+ // Workaround for native animated bug in react-native@^0.57
439
+ // Context: https://github.com/callstack/react-native-paper/pull/637
440
+ animateToIndex(navigationState.index);
441
+ // eslint-disable-next-line react-hooks/exhaustive-deps
442
+ }, []);
443
+
444
+ const prevNavigationState = React.useRef<NavigationState<Route>>();
445
+
446
+ React.useEffect(() => {
447
+ // Reset offsets of previous and current tabs before animation
448
+ offsetsAnims.forEach((offset, i) => {
449
+ if (
450
+ i === navigationState.index ||
451
+ i === prevNavigationState.current?.index
452
+ ) {
453
+ offset.setValue(0);
454
+ }
455
+ });
456
+
457
+ animateToIndex(navigationState.index);
458
+ }, [navigationState.index, animateToIndex, offsetsAnims]);
459
+
460
+ const handleTabPress = useLatestCallback(
461
+ (event: { route: Route } & TabPressEvent) => {
462
+ onTabPress?.(event);
463
+
464
+ if (event.defaultPrevented) {
465
+ return;
466
+ }
467
+
468
+ const index = navigationState.routes.findIndex(
469
+ (route) => event.route.key === route.key
470
+ );
471
+
472
+ if (index !== navigationState.index) {
473
+ prevNavigationState.current = navigationState;
474
+ onIndexChange(index);
475
+ }
476
+ }
477
+ );
478
+
479
+ const jumpTo = useLatestCallback((key: string) => {
480
+ const index = navigationState.routes.findIndex(
481
+ (route) => route.key === key
482
+ );
483
+
484
+ prevNavigationState.current = navigationState;
485
+ onIndexChange(index);
486
+ });
487
+
488
+ const { routes } = navigationState;
489
+ const { colors } = theme;
490
+
491
+ return (
492
+ <View style={[styles.container, style]} testID={testID}>
493
+ <View style={[styles.content, { backgroundColor: colors?.background }]}>
494
+ {routes.map((route, index) => {
495
+ if (getLazy({ route }) !== false && !loaded.includes(route.key)) {
496
+ // Don't render a screen if we've never navigated to it
497
+ return null;
498
+ }
499
+
500
+ const focused = navigationState.index === index;
501
+ const previouslyFocused =
502
+ prevNavigationState.current?.index === index;
503
+ const countAlphaOffscreen =
504
+ sceneAnimationEnabled && (focused || previouslyFocused);
505
+ const renderToHardwareTextureAndroid =
506
+ sceneAnimationEnabled && focused;
507
+
508
+ const opacity = sceneAnimationEnabled
509
+ ? tabsPositionAnims[index].interpolate({
510
+ inputRange: [-1, 0, 1],
511
+ outputRange: [0, 1, 0],
512
+ })
513
+ : focused
514
+ ? 1
515
+ : 0;
516
+
517
+ const offsetTarget = focused ? 0 : FAR_FAR_AWAY;
518
+
519
+ const top = sceneAnimationEnabled
520
+ ? offsetsAnims[index].interpolate({
521
+ inputRange: [0, 1],
522
+ outputRange: [0, offsetTarget],
523
+ })
524
+ : offsetTarget;
525
+
526
+ const left =
527
+ sceneAnimationType === 'shifting'
528
+ ? tabsPositionAnims[index].interpolate({
529
+ inputRange: [-1, 0, 1],
530
+ outputRange: [-50, 0, 50],
531
+ })
532
+ : 0;
533
+
534
+ const zIndex = focused ? 1 : 0;
535
+
536
+ return (
537
+ <BottomNavigationRouteScreen
538
+ key={route.key}
539
+ pointerEvents={focused ? 'auto' : 'none'}
540
+ accessibilityElementsHidden={!focused}
541
+ importantForAccessibility={
542
+ focused ? 'auto' : 'no-hide-descendants'
543
+ }
544
+ index={index}
545
+ visibility={opacity}
546
+ style={[StyleSheet.absoluteFill, { zIndex }]}
547
+ collapsable={false}
548
+ removeClippedSubviews={
549
+ // On iOS, set removeClippedSubviews to true only when not focused
550
+ // This is an workaround for a bug where the clipped view never re-appears
551
+ Platform.OS === 'ios' ? navigationState.index !== index : true
552
+ }
553
+ >
554
+ <Animated.View
555
+ {...(Platform.OS === 'android' && {
556
+ needsOffscreenAlphaCompositing: countAlphaOffscreen,
557
+ })}
558
+ renderToHardwareTextureAndroid={renderToHardwareTextureAndroid}
559
+ style={[
560
+ styles.content,
561
+ {
562
+ opacity,
563
+ transform: [{ translateX: left }, { translateY: top }],
564
+ },
565
+ ]}
566
+ >
567
+ {renderScene({ route, jumpTo })}
568
+ </Animated.View>
569
+ </BottomNavigationRouteScreen>
570
+ );
571
+ })}
572
+ </View>
573
+ <BottomNavigationBar
574
+ navigationState={navigationState}
575
+ renderIcon={renderIcon}
576
+ renderLabel={renderLabel}
577
+ renderTouchable={renderTouchable}
578
+ getLabelText={getLabelText}
579
+ getBadge={getBadge}
580
+ getColor={getColor}
581
+ getAccessibilityLabel={getAccessibilityLabel}
582
+ getTestID={getTestID}
583
+ activeColor={activeColor}
584
+ inactiveColor={inactiveColor}
585
+ keyboardHidesNavigationBar={keyboardHidesNavigationBar}
586
+ style={barStyle}
587
+ activeIndicatorStyle={activeIndicatorStyle}
588
+ labeled={labeled}
589
+ animationEasing={sceneAnimationEasing}
590
+ onTabPress={handleTabPress}
591
+ onTabLongPress={onTabLongPress}
592
+ shifting={shifting}
593
+ safeAreaInsets={safeAreaInsets}
594
+ labelMaxFontSizeMultiplier={labelMaxFontSizeMultiplier}
595
+ compact={compact}
596
+ testID={`${testID}-bar`}
597
+ theme={theme}
598
+ />
599
+ </View>
600
+ );
601
+ };
602
+
603
+ /**
604
+ * Function which takes a map of route keys to components.
605
+ * Pure components are used to minimize re-rendering of the pages.
606
+ * This drastically improves the animation performance.
607
+ */
608
+ BottomNavigation.SceneMap = <Route extends BaseRoute>(scenes: {
609
+ [key: string]: React.ComponentType<{
610
+ route: Route;
611
+ jumpTo: (key: string) => void;
612
+ }>;
613
+ }) => {
614
+ return ({
615
+ route,
616
+ jumpTo,
617
+ }: {
618
+ route: Route;
619
+ jumpTo: (key: string) => void;
620
+ }) => (
621
+ <SceneComponent
622
+ key={route.key}
623
+ component={scenes[route.key ? route.key : '']}
624
+ route={route}
625
+ jumpTo={jumpTo}
626
+ />
627
+ );
628
+ };
629
+
630
+ // @component ./BottomNavigationBar.tsx
631
+ BottomNavigation.Bar = BottomNavigationBar;
632
+
633
+ export default BottomNavigation;
634
+
635
+ const styles = StyleSheet.create({
636
+ container: {
637
+ flex: 1,
638
+ overflow: 'hidden',
639
+ },
640
+ content: {
641
+ flex: 1,
642
+ },
643
+ });