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,132 @@
1
+ import * as React from 'react';
2
+ import type {
3
+ Animated,
4
+ ColorValue,
5
+ StyleProp,
6
+ View,
7
+ ViewStyle,
8
+ } from 'react-native';
9
+
10
+ import color from 'color';
11
+ import type { ThemeProp } from 'src/types';
12
+
13
+ import { useInternalTheme } from '../../core/theming';
14
+ import { black } from '../../styles/themes/v2/colors';
15
+ import { forwardRef } from '../../utils/forwardRef';
16
+ import type { IconSource } from '../Icon';
17
+ import IconButton from '../IconButton/IconButton';
18
+
19
+ export type Props = React.ComponentPropsWithoutRef<typeof IconButton> & {
20
+ /**
21
+ * Custom color for action icon.
22
+ */
23
+ color?: string;
24
+ /**
25
+ * Color of the ripple effect.
26
+ */
27
+ rippleColor?: ColorValue;
28
+ /**
29
+ * Name of the icon to show.
30
+ */
31
+ icon: IconSource;
32
+ /**
33
+ * Optional icon size.
34
+ */
35
+ size?: number;
36
+ /**
37
+ * Whether the button is disabled. A disabled button is greyed out and `onPress` is not called on touch.
38
+ */
39
+ disabled?: boolean;
40
+ /**
41
+ * Accessibility label for the button. This is read by the screen reader when the user taps the button.
42
+ */
43
+ accessibilityLabel?: string;
44
+ /**
45
+ * Function to execute on press.
46
+ */
47
+ onPress?: () => void;
48
+ /**
49
+ * @supported Available in v5.x with theme version 3
50
+ *
51
+ * Whether it's the leading button.
52
+ */
53
+ isLeading?: boolean;
54
+ style?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
55
+ ref?: React.RefObject<View>;
56
+ /**
57
+ * @optional
58
+ */
59
+ theme?: ThemeProp;
60
+ };
61
+
62
+ /**
63
+ * A component used to display an action item in the appbar.
64
+ *
65
+ * ## Usage
66
+ * ```js
67
+ * import * as React from 'react';
68
+ * import { Appbar } from 'react-native-paper';
69
+ * import { Platform } from 'react-native';
70
+ *
71
+ * const MORE_ICON = Platform.OS === 'ios' ? 'dots-horizontal' : 'dots-vertical';
72
+ *
73
+ * const MyComponent = () => (
74
+ * <Appbar.Header>
75
+ * <Appbar.Content title="Title" subtitle={'Subtitle'} />
76
+ * <Appbar.Action icon="magnify" onPress={() => {}} />
77
+ * <Appbar.Action icon={MORE_ICON} onPress={() => {}} />
78
+ * </Appbar.Header>
79
+ * );
80
+ *
81
+ * export default MyComponent;
82
+ * ```
83
+ */
84
+ const AppbarAction = forwardRef<View, Props>(
85
+ (
86
+ {
87
+ size = 24,
88
+ color: iconColor,
89
+ icon,
90
+ disabled,
91
+ onPress,
92
+ accessibilityLabel,
93
+ isLeading,
94
+ theme: themeOverrides,
95
+ rippleColor,
96
+ ...rest
97
+ }: Props,
98
+ ref
99
+ ) => {
100
+ const theme = useInternalTheme(themeOverrides);
101
+
102
+ const actionIconColor = iconColor
103
+ ? iconColor
104
+ : theme.isV3
105
+ ? isLeading
106
+ ? theme.colors.onSurface
107
+ : theme.colors.onSurfaceVariant
108
+ : color(black).alpha(0.54).rgb().string();
109
+
110
+ return (
111
+ <IconButton
112
+ size={size}
113
+ onPress={onPress}
114
+ iconColor={actionIconColor}
115
+ icon={icon}
116
+ disabled={disabled}
117
+ accessibilityLabel={accessibilityLabel}
118
+ animated
119
+ ref={ref}
120
+ rippleColor={rippleColor}
121
+ {...rest}
122
+ />
123
+ );
124
+ }
125
+ );
126
+
127
+ AppbarAction.displayName = 'Appbar.Action';
128
+
129
+ export default AppbarAction;
130
+
131
+ // @component-docs ignore-next-line
132
+ export { AppbarAction };
@@ -0,0 +1,77 @@
1
+ import * as React from 'react';
2
+ import type {
3
+ Animated,
4
+ GestureResponderEvent,
5
+ StyleProp,
6
+ View,
7
+ ViewStyle,
8
+ } from 'react-native';
9
+
10
+ import type { $Omit } from './../../types';
11
+ import AppbarAction from './AppbarAction';
12
+ import AppbarBackIcon from './AppbarBackIcon';
13
+ import { forwardRef } from '../../utils/forwardRef';
14
+
15
+ export type Props = $Omit<
16
+ React.ComponentPropsWithoutRef<typeof AppbarAction>,
17
+ 'icon'
18
+ > & {
19
+ /**
20
+ * Custom color for back icon.
21
+ */
22
+ color?: string;
23
+ /**
24
+ * Optional icon size.
25
+ */
26
+ size?: number;
27
+ /**
28
+ * Whether the button is disabled. A disabled button is greyed out and `onPress` is not called on touch.
29
+ */
30
+ disabled?: boolean;
31
+ /**
32
+ * Accessibility label for the button. This is read by the screen reader when the user taps the button.
33
+ */
34
+ accessibilityLabel?: string;
35
+ /**
36
+ * Function to execute on press.
37
+ */
38
+ onPress?: (e: GestureResponderEvent) => void;
39
+ style?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
40
+ ref?: React.RefObject<View>;
41
+ };
42
+
43
+ /**
44
+ * A component used to display a back button in the appbar.
45
+ *
46
+ * ## Usage
47
+ * ```js
48
+ * import * as React from 'react';
49
+ * import { Appbar } from 'react-native-paper';
50
+ *
51
+ * const MyComponent = () => (
52
+ * <Appbar.Header>
53
+ * <Appbar.BackAction onPress={() => {}} />
54
+ * </Appbar.Header>
55
+ * );
56
+ *
57
+ * export default MyComponent;
58
+ * ```
59
+ */
60
+ const AppbarBackAction = forwardRef<View, Props>(
61
+ ({ accessibilityLabel = 'Back', ...rest }: Props, ref) => (
62
+ <AppbarAction
63
+ accessibilityLabel={accessibilityLabel}
64
+ {...rest}
65
+ icon={AppbarBackIcon}
66
+ isLeading
67
+ ref={ref}
68
+ />
69
+ )
70
+ );
71
+
72
+ AppbarBackAction.displayName = 'Appbar.BackAction';
73
+
74
+ export default AppbarBackAction;
75
+
76
+ // @component-docs ignore-next-line
77
+ export { AppbarBackAction };
@@ -0,0 +1,52 @@
1
+ import * as React from 'react';
2
+ import { I18nManager, Image, Platform, StyleSheet, View } from 'react-native';
3
+
4
+ import MaterialCommunityIcon from '../MaterialCommunityIcon';
5
+
6
+ const AppbarBackIcon = ({ size, color }: { size: number; color: string }) => {
7
+ const iosIconSize = size - 3;
8
+
9
+ return Platform.OS === 'ios' ? (
10
+ <View
11
+ style={[
12
+ styles.wrapper,
13
+ {
14
+ width: size,
15
+ height: size,
16
+ transform: [{ scaleX: I18nManager.getConstants().isRTL ? -1 : 1 }],
17
+ },
18
+ ]}
19
+ >
20
+ <Image
21
+ source={require('../../assets/back-chevron.png')}
22
+ style={[
23
+ styles.icon,
24
+ { tintColor: color, width: iosIconSize, height: iosIconSize },
25
+ ]}
26
+ accessibilityIgnoresInvertColors
27
+ />
28
+ </View>
29
+ ) : (
30
+ <MaterialCommunityIcon
31
+ name="arrow-left"
32
+ color={color}
33
+ size={size}
34
+ direction={I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'}
35
+ />
36
+ );
37
+ };
38
+
39
+ const styles = StyleSheet.create({
40
+ wrapper: {
41
+ alignItems: 'center',
42
+ justifyContent: 'center',
43
+ },
44
+ icon: {
45
+ resizeMode: 'contain',
46
+ },
47
+ });
48
+
49
+ export default AppbarBackIcon;
50
+
51
+ // @component-docs ignore-next-line
52
+ export { AppbarBackIcon };
@@ -0,0 +1,249 @@
1
+ import * as React from 'react';
2
+ import {
3
+ AccessibilityRole,
4
+ GestureResponderEvent,
5
+ Platform,
6
+ StyleProp,
7
+ StyleSheet,
8
+ TextStyle,
9
+ Pressable,
10
+ View,
11
+ ViewStyle,
12
+ ViewProps,
13
+ } from 'react-native';
14
+
15
+ import color from 'color';
16
+
17
+ import { modeTextVariant } from './utils';
18
+ import { useInternalTheme } from '../../core/theming';
19
+ import { white } from '../../styles/themes/v2/colors';
20
+ import type { $RemoveChildren, MD3TypescaleKey, ThemeProp } from '../../types';
21
+ import Text, { TextRef } from '../Typography/Text';
22
+
23
+ type TitleString = {
24
+ title: string;
25
+ titleStyle?: StyleProp<TextStyle>;
26
+ };
27
+
28
+ type TitleElement = { title: React.ReactNode; titleStyle?: never };
29
+
30
+ export type Props = $RemoveChildren<typeof View> & {
31
+ // For `title` and `titleStyle` props their types are duplicated due to the generation of documentation.
32
+ // Appropriate type for them are either `TitleString` or `TitleElement`, depends on `title` type.
33
+ /**
34
+ * Text or component for the title.
35
+ */
36
+ title: React.ReactNode;
37
+ /**
38
+ * Style for the title, if `title` is a string.
39
+ */
40
+ titleStyle?: StyleProp<TextStyle>;
41
+ /**
42
+ * Reference for the title.
43
+ */
44
+ titleRef?: React.RefObject<TextRef>;
45
+ /**
46
+ * @deprecated Deprecated in v5.x
47
+ * Text for the subtitle.
48
+ */
49
+ subtitle?: React.ReactNode;
50
+ /**
51
+ * @deprecated Deprecated in v5.x
52
+ * Style for the subtitle.
53
+ */
54
+ subtitleStyle?: StyleProp<TextStyle>;
55
+ /**
56
+ * Function to execute on press.
57
+ */
58
+ onPress?: (e: GestureResponderEvent) => void;
59
+ /**
60
+ * If true, disable all interactions for this component.
61
+ */
62
+ disabled?: boolean;
63
+ /**
64
+ * Custom color for the text.
65
+ */
66
+ color?: string;
67
+ /**
68
+ * Specifies the largest possible scale a title font can reach.
69
+ */
70
+ titleMaxFontSizeMultiplier?: number;
71
+ /**
72
+ * @internal
73
+ */
74
+ mode?: 'small' | 'medium' | 'large' | 'center-aligned';
75
+ style?: StyleProp<ViewStyle>;
76
+ /**
77
+ * @optional
78
+ */
79
+ theme?: ThemeProp;
80
+ /**
81
+ * testID to be used on tests.
82
+ */
83
+ testID?: string;
84
+ } & (TitleString | TitleElement);
85
+
86
+ /**
87
+ * A component used to display a title and optional subtitle in an appbar.
88
+ *
89
+ * ## Usage
90
+ * ```js
91
+ * import * as React from 'react';
92
+ * import { Appbar } from 'react-native-paper';
93
+ *
94
+ * const MyComponent = () => (
95
+ * <Appbar.Header>
96
+ * <Appbar.Content title="Title" />
97
+ * </Appbar.Header>
98
+ * );
99
+ *
100
+ * export default MyComponent;
101
+ * ```
102
+ */
103
+ const AppbarContent = ({
104
+ color: titleColor,
105
+ subtitle,
106
+ subtitleStyle,
107
+ onPress,
108
+ disabled,
109
+ style,
110
+ titleRef,
111
+ titleStyle,
112
+ title,
113
+ titleMaxFontSizeMultiplier,
114
+ mode = 'small',
115
+ theme: themeOverrides,
116
+ testID = 'appbar-content',
117
+ ...rest
118
+ }: Props) => {
119
+ const theme = useInternalTheme(themeOverrides);
120
+ const { isV3, colors } = theme;
121
+
122
+ const titleTextColor = titleColor
123
+ ? titleColor
124
+ : isV3
125
+ ? colors.onSurface
126
+ : white;
127
+
128
+ const subtitleColor = color(titleTextColor).alpha(0.7).rgb().string();
129
+
130
+ const modeContainerStyles = {
131
+ small: styles.v3DefaultContainer,
132
+ medium: styles.v3MediumContainer,
133
+ large: styles.v3LargeContainer,
134
+ 'center-aligned': styles.v3DefaultContainer,
135
+ };
136
+
137
+ const variant = modeTextVariant[mode] as MD3TypescaleKey;
138
+
139
+ const contentWrapperProps = {
140
+ pointerEvents: 'box-none' as ViewProps['pointerEvents'],
141
+ style: [styles.container, isV3 && modeContainerStyles[mode], style],
142
+ testID,
143
+ ...rest,
144
+ };
145
+
146
+ const content = (
147
+ <>
148
+ {typeof title === 'string' ? (
149
+ <Text
150
+ {...(isV3 && { variant })}
151
+ ref={titleRef}
152
+ style={[
153
+ {
154
+ color: titleTextColor,
155
+ ...(isV3
156
+ ? theme.fonts[variant]
157
+ : Platform.OS === 'ios'
158
+ ? theme.fonts.regular
159
+ : theme.fonts.medium),
160
+ },
161
+ !isV3 && styles.title,
162
+ titleStyle,
163
+ ]}
164
+ numberOfLines={1}
165
+ accessible
166
+ accessibilityRole={
167
+ onPress
168
+ ? 'none'
169
+ : Platform.OS === 'web'
170
+ ? ('heading' as 'header')
171
+ : 'header'
172
+ }
173
+ // @ts-expect-error We keep old a11y props for backwards compat with old RN versions
174
+ accessibilityTraits="header"
175
+ testID={`${testID}-title-text`}
176
+ maxFontSizeMultiplier={titleMaxFontSizeMultiplier}
177
+ >
178
+ {title}
179
+ </Text>
180
+ ) : (
181
+ title
182
+ )}
183
+ {!isV3 && subtitle ? (
184
+ <Text
185
+ style={[styles.subtitle, { color: subtitleColor }, subtitleStyle]}
186
+ numberOfLines={1}
187
+ >
188
+ {subtitle}
189
+ </Text>
190
+ ) : null}
191
+ </>
192
+ );
193
+
194
+ if (onPress) {
195
+ return (
196
+ // eslint-disable-next-line react-native-a11y/has-accessibility-props
197
+ <Pressable
198
+ accessibilityRole={touchableRole}
199
+ // @ts-expect-error We keep old a11y props for backwards compat with old RN versions
200
+ accessibilityTraits={touchableRole}
201
+ accessibilityComponentType="button"
202
+ accessbilityState={disabled ? 'disabled' : null}
203
+ onPress={onPress}
204
+ disabled={disabled}
205
+ {...contentWrapperProps}
206
+ >
207
+ {content}
208
+ </Pressable>
209
+ );
210
+ }
211
+
212
+ return <View {...contentWrapperProps}>{content}</View>;
213
+ };
214
+
215
+ AppbarContent.displayName = 'Appbar.Content';
216
+
217
+ const styles = StyleSheet.create({
218
+ container: {
219
+ flex: 1,
220
+ paddingHorizontal: 12,
221
+ },
222
+ v3DefaultContainer: {
223
+ paddingHorizontal: 0,
224
+ },
225
+ v3MediumContainer: {
226
+ paddingHorizontal: 0,
227
+ justifyContent: 'flex-end',
228
+ paddingBottom: 24,
229
+ },
230
+ v3LargeContainer: {
231
+ paddingHorizontal: 0,
232
+ paddingTop: 36,
233
+ justifyContent: 'flex-end',
234
+ paddingBottom: 28,
235
+ },
236
+ title: {
237
+ fontSize: Platform.OS === 'ios' ? 17 : 20,
238
+ },
239
+ subtitle: {
240
+ fontSize: Platform.OS === 'ios' ? 11 : 14,
241
+ },
242
+ });
243
+
244
+ const touchableRole: AccessibilityRole = 'button';
245
+
246
+ export default AppbarContent;
247
+
248
+ // @component-docs ignore-next-line
249
+ export { AppbarContent };
@@ -0,0 +1,174 @@
1
+ import * as React from 'react';
2
+ import {
3
+ Animated,
4
+ ColorValue,
5
+ Platform,
6
+ StyleProp,
7
+ StyleSheet,
8
+ View,
9
+ ViewStyle,
10
+ } from 'react-native';
11
+
12
+ import { useSafeAreaInsets } from 'react-native-safe-area-context';
13
+
14
+ import { Appbar } from './Appbar';
15
+ import {
16
+ DEFAULT_APPBAR_HEIGHT,
17
+ getAppbarBackgroundColor,
18
+ modeAppbarHeight,
19
+ getAppbarBorders,
20
+ } from './utils';
21
+ import { useInternalTheme } from '../../core/theming';
22
+ import shadow from '../../styles/shadow';
23
+ import type { ThemeProp } from '../../types';
24
+
25
+ export type Props = Omit<
26
+ React.ComponentProps<typeof Appbar>,
27
+ 'safeAreaInsets'
28
+ > & {
29
+ /**
30
+ * Whether the background color is a dark color. A dark header will render light text and vice-versa.
31
+ */
32
+ dark?: boolean;
33
+ /**
34
+ * Extra padding to add at the top of header to account for translucent status bar.
35
+ * This is automatically handled on iOS >= 11 including iPhone X using `SafeAreaView`.
36
+ * If you are using Expo, we assume translucent status bar and set a height for status bar automatically.
37
+ * Pass `0` or a custom value to disable the default behaviour, and customize the height.
38
+ */
39
+ statusBarHeight?: number;
40
+ /**
41
+ * Content of the header.
42
+ */
43
+ children: React.ReactNode;
44
+ /**
45
+ * @supported Available in v5.x with theme version 3
46
+ *
47
+ * Mode of the Appbar.
48
+ * - `small` - Appbar with default height (64).
49
+ * - `medium` - Appbar with medium height (112).
50
+ * - `large` - Appbar with large height (152).
51
+ * - `center-aligned` - Appbar with default height and center-aligned title.
52
+ */
53
+ mode?: 'small' | 'medium' | 'large' | 'center-aligned';
54
+ /**
55
+ * @supported Available in v5.x with theme version 3
56
+ * Whether Appbar background should have the elevation along with primary color pigment.
57
+ */
58
+ elevated?: boolean;
59
+ /**
60
+ * @optional
61
+ */
62
+ theme?: ThemeProp;
63
+ style?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
64
+ };
65
+
66
+ /**
67
+ * A component to use as a header at the top of the screen.
68
+ * It can contain the screen title, controls such as navigation buttons, menu button etc.
69
+ *
70
+ * ## Usage
71
+ * ```js
72
+ * import * as React from 'react';
73
+ * import { Appbar } from 'react-native-paper';
74
+ *
75
+ * const MyComponent = () => {
76
+ * const _goBack = () => console.log('Went back');
77
+ *
78
+ * const _handleSearch = () => console.log('Searching');
79
+ *
80
+ * const _handleMore = () => console.log('Shown more');
81
+ *
82
+ * return (
83
+ * <Appbar.Header>
84
+ * <Appbar.BackAction onPress={_goBack} />
85
+ * <Appbar.Content title="Title" />
86
+ * <Appbar.Action icon="magnify" onPress={_handleSearch} />
87
+ * <Appbar.Action icon="dots-vertical" onPress={_handleMore} />
88
+ * </Appbar.Header>
89
+ * );
90
+ * };
91
+ *
92
+ * export default MyComponent;
93
+ * ```
94
+ */
95
+ const AppbarHeader = ({
96
+ // Don't use default props since we check it to know whether we should use SafeAreaView
97
+ statusBarHeight,
98
+ style,
99
+ dark,
100
+ mode = Platform.OS === 'ios' ? 'center-aligned' : 'small',
101
+ elevated = false,
102
+ theme: themeOverrides,
103
+ testID = 'appbar-header',
104
+ ...rest
105
+ }: Props) => {
106
+ const theme = useInternalTheme(themeOverrides);
107
+ const { isV3 } = theme;
108
+
109
+ const flattenedStyle = StyleSheet.flatten(style);
110
+ const {
111
+ height = isV3 ? modeAppbarHeight[mode] : DEFAULT_APPBAR_HEIGHT,
112
+ elevation = isV3 ? (elevated ? 2 : 0) : 4,
113
+ backgroundColor: customBackground,
114
+ zIndex = isV3 && elevated ? 1 : 0,
115
+ ...restStyle
116
+ } = (flattenedStyle || {}) as Exclude<typeof flattenedStyle, number> & {
117
+ height?: number;
118
+ elevation?: number;
119
+ backgroundColor?: ColorValue;
120
+ zIndex?: number;
121
+ };
122
+
123
+ const borderRadius = getAppbarBorders(restStyle);
124
+
125
+ const backgroundColor = getAppbarBackgroundColor(
126
+ theme,
127
+ elevation,
128
+ customBackground,
129
+ elevated
130
+ );
131
+
132
+ const { top, left, right } = useSafeAreaInsets();
133
+
134
+ return (
135
+ <View
136
+ testID={`${testID}-root-layer`}
137
+ style={[
138
+ {
139
+ backgroundColor,
140
+ zIndex,
141
+ elevation,
142
+ paddingTop: statusBarHeight ?? top,
143
+ paddingHorizontal: Math.max(left, right),
144
+ },
145
+ borderRadius,
146
+ shadow(elevation) as ViewStyle,
147
+ ]}
148
+ >
149
+ <Appbar
150
+ testID={testID}
151
+ style={[{ height, backgroundColor }, styles.appbar, restStyle]}
152
+ dark={dark}
153
+ {...(isV3 && {
154
+ mode,
155
+ })}
156
+ {...rest}
157
+ theme={theme}
158
+ />
159
+ </View>
160
+ );
161
+ };
162
+
163
+ AppbarHeader.displayName = 'Appbar.Header';
164
+
165
+ const styles = StyleSheet.create({
166
+ appbar: {
167
+ elevation: 0,
168
+ },
169
+ });
170
+
171
+ export default AppbarHeader;
172
+
173
+ // @component-docs ignore-next-line
174
+ export { AppbarHeader };
@@ -0,0 +1,22 @@
1
+ import AppbarComponent from './Appbar';
2
+ import AppbarAction from './AppbarAction';
3
+ import AppbarBackAction from './AppbarBackAction';
4
+ import AppbarContent from './AppbarContent';
5
+ import AppbarHeader from './AppbarHeader';
6
+
7
+ const Appbar = Object.assign(
8
+ // @component ./Appbar.tsx
9
+ AppbarComponent,
10
+ {
11
+ // @component ./AppbarContent.tsx
12
+ Content: AppbarContent,
13
+ // @component ./AppbarAction.tsx
14
+ Action: AppbarAction,
15
+ // @component ./AppbarBackAction.tsx
16
+ BackAction: AppbarBackAction,
17
+ // @component ./AppbarHeader.tsx
18
+ Header: AppbarHeader,
19
+ }
20
+ );
21
+
22
+ export default Appbar;