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,31 @@
1
+ import React from 'react';
2
+ import { Animated, Platform, View, ViewProps } from 'react-native';
3
+
4
+ interface Props extends ViewProps {
5
+ visibility?: 0 | 1 | Animated.AnimatedInterpolation<number>;
6
+ index: number;
7
+ }
8
+
9
+ class BottomNavigationRouteScreen extends React.Component<Props> {
10
+ render(): JSX.Element {
11
+ const { style, index, children, visibility, ...rest } = this.props;
12
+
13
+ // On Web, the unfocused tab screens can still be clicked since they are transparent, but still there
14
+ // Hiding them with `display: none` makes sure that they won't receive clicks
15
+ // We only set it on Web since on native, react-native-pager-view's breaks due to layout changing
16
+ const display =
17
+ Platform.OS === 'web' ? (visibility === 0 ? 'none' : 'flex') : undefined;
18
+
19
+ return (
20
+ <View
21
+ testID={`RouteScreen: ${index}`}
22
+ style={[style, { display }]}
23
+ {...rest}
24
+ >
25
+ {children}
26
+ </View>
27
+ );
28
+ }
29
+ }
30
+
31
+ export default Animated.createAnimatedComponent(BottomNavigationRouteScreen);
@@ -0,0 +1,70 @@
1
+ import color from 'color';
2
+ import type { InternalTheme } from 'src/types';
3
+
4
+ import type { black, white } from '../../styles/themes/v2/colors';
5
+
6
+ type BaseProps = {
7
+ defaultColor: typeof black | typeof white;
8
+ theme: InternalTheme;
9
+ };
10
+
11
+ export const getActiveTintColor = ({
12
+ activeColor,
13
+ defaultColor,
14
+ theme,
15
+ }: BaseProps & {
16
+ activeColor: string | undefined;
17
+ }) => {
18
+ if (typeof activeColor === 'string') {
19
+ return activeColor;
20
+ }
21
+
22
+ if (theme.isV3) {
23
+ return theme.colors.onSecondaryContainer;
24
+ }
25
+
26
+ return defaultColor;
27
+ };
28
+
29
+ export const getInactiveTintColor = ({
30
+ inactiveColor,
31
+ defaultColor,
32
+ theme,
33
+ }: BaseProps & {
34
+ inactiveColor: string | undefined;
35
+ }) => {
36
+ if (typeof inactiveColor === 'string') {
37
+ return inactiveColor;
38
+ }
39
+
40
+ if (theme.isV3) {
41
+ return theme.colors.onSurfaceVariant;
42
+ }
43
+
44
+ return color(defaultColor).alpha(0.5).rgb().string();
45
+ };
46
+
47
+ export const getLabelColor = ({
48
+ tintColor,
49
+ hasColor,
50
+ focused,
51
+ defaultColor,
52
+ theme,
53
+ }: BaseProps & {
54
+ tintColor: string;
55
+ hasColor: boolean;
56
+ focused: boolean;
57
+ }) => {
58
+ if (hasColor) {
59
+ return tintColor;
60
+ }
61
+
62
+ if (theme.isV3) {
63
+ if (focused) {
64
+ return theme.colors.onSurface;
65
+ }
66
+ return theme.colors.onSurfaceVariant;
67
+ }
68
+
69
+ return defaultColor;
70
+ };
@@ -0,0 +1,503 @@
1
+ import * as React from 'react';
2
+ import {
3
+ AccessibilityRole,
4
+ Animated,
5
+ ColorValue,
6
+ GestureResponderEvent,
7
+ Platform,
8
+ PressableAndroidRippleConfig,
9
+ StyleProp,
10
+ StyleSheet,
11
+ TextStyle,
12
+ View,
13
+ ViewStyle,
14
+ } from 'react-native';
15
+
16
+ import color from 'color';
17
+
18
+ import {
19
+ ButtonMode,
20
+ getButtonColors,
21
+ getButtonTouchableRippleStyle,
22
+ } from './utils';
23
+ import { useInternalTheme } from '../../core/theming';
24
+ import type { $Omit, ThemeProp } from '../../types';
25
+ import { forwardRef } from '../../utils/forwardRef';
26
+ import hasTouchHandler from '../../utils/hasTouchHandler';
27
+ import { splitStyles } from '../../utils/splitStyles';
28
+ import ActivityIndicator from '../ActivityIndicator';
29
+ import Icon, { IconSource } from '../Icon';
30
+ import Surface from '../Surface';
31
+ import TouchableRipple from '../TouchableRipple/TouchableRipple';
32
+ import Text from '../Typography/Text';
33
+
34
+ export type Props = $Omit<React.ComponentProps<typeof Surface>, 'mode'> & {
35
+ /**
36
+ * Mode of the button. You can change the mode to adjust the styling to give it desired emphasis.
37
+ * - `text` - flat button without background or outline, used for the lowest priority actions, especially when presenting multiple options.
38
+ * - `outlined` - button with an outline without background, typically used for important, but not primary action – represents medium emphasis.
39
+ * - `contained` - button with a background color, used for important action, have the most visual impact and high emphasis.
40
+ * - `elevated` - button with a background color and elevation, used when absolutely necessary e.g. button requires visual separation from a patterned background. @supported Available in v5.x with theme version 3
41
+ * - `contained-tonal` - button with a secondary background color, an alternative middle ground between contained and outlined buttons. @supported Available in v5.x with theme version 3
42
+ */
43
+ mode?: 'text' | 'outlined' | 'contained' | 'elevated' | 'contained-tonal';
44
+ /**
45
+ * Whether the color is a dark color. A dark button will render light text and vice-versa. Only applicable for:
46
+ * * `contained` mode for theme version 2
47
+ * * `contained`, `contained-tonal` and `elevated` modes for theme version 3.
48
+ */
49
+ dark?: boolean;
50
+ /**
51
+ * Use a compact look, useful for `text` buttons in a row.
52
+ */
53
+ compact?: boolean;
54
+ /**
55
+ * @deprecated Deprecated in v5.x - use `buttonColor` or `textColor` instead.
56
+ * Custom text color for flat button, or background color for contained button.
57
+ */
58
+ color?: string;
59
+ /**
60
+ * Custom button's background color.
61
+ */
62
+ buttonColor?: string;
63
+ /**
64
+ * Custom button's text color.
65
+ */
66
+ textColor?: string;
67
+ /**
68
+ * Color of the ripple effect.
69
+ */
70
+ rippleColor?: ColorValue;
71
+ /**
72
+ * Whether to show a loading indicator.
73
+ */
74
+ loading?: boolean;
75
+ /**
76
+ * Icon to display for the `Button`.
77
+ */
78
+ icon?: IconSource;
79
+ /**
80
+ * Whether the button is disabled. A disabled button is greyed out and `onPress` is not called on touch.
81
+ */
82
+ disabled?: boolean;
83
+ /**
84
+ * Label text of the button.
85
+ */
86
+ children: React.ReactNode;
87
+ /**
88
+ * Make the label text uppercased. Note that this won't work if you pass React elements as children.
89
+ */
90
+ uppercase?: boolean;
91
+ /**
92
+ * Type of background drawabale to display the feedback (Android).
93
+ * https://reactnative.dev/docs/pressable#rippleconfig
94
+ */
95
+ background?: PressableAndroidRippleConfig;
96
+ /**
97
+ * Accessibility label for the button. This is read by the screen reader when the user taps the button.
98
+ */
99
+ accessibilityLabel?: string;
100
+ /**
101
+ * Accessibility hint for the button. This is read by the screen reader when the user taps the button.
102
+ */
103
+ accessibilityHint?: string;
104
+ /**
105
+ * Accessibility role for the button. The "button" role is set by default.
106
+ */
107
+ accessibilityRole?: AccessibilityRole;
108
+ /**
109
+ * Function to execute on press.
110
+ */
111
+ onPress?: (e: GestureResponderEvent) => void;
112
+ /**
113
+ * Function to execute as soon as the touchable element is pressed and invoked even before onPress.
114
+ */
115
+ onPressIn?: (e: GestureResponderEvent) => void;
116
+ /**
117
+ * Function to execute as soon as the touch is released even before onPress.
118
+ */
119
+ onPressOut?: (e: GestureResponderEvent) => void;
120
+ /**
121
+ * Function to execute on long press.
122
+ */
123
+ onLongPress?: (e: GestureResponderEvent) => void;
124
+ /**
125
+ * The number of milliseconds a user must touch the element before executing `onLongPress`.
126
+ */
127
+ delayLongPress?: number;
128
+ /**
129
+ * Style of button's inner content.
130
+ * Use this prop to apply custom height and width, to set a custom padding or to set the icon on the right with `flexDirection: 'row-reverse'`.
131
+ */
132
+ contentStyle?: StyleProp<ViewStyle>;
133
+ /**
134
+ * Specifies the largest possible scale a text font can reach.
135
+ */
136
+ maxFontSizeMultiplier?: number;
137
+ style?: Animated.WithAnimatedValue<StyleProp<ViewStyle>>;
138
+ /**
139
+ * Style for the button text.
140
+ */
141
+ labelStyle?: StyleProp<TextStyle>;
142
+ /**
143
+ * @optional
144
+ */
145
+ theme?: ThemeProp;
146
+ /**
147
+ * Reference for the touchable
148
+ */
149
+ touchableRef?: React.RefObject<View>;
150
+ /**
151
+ * testID to be used on tests.
152
+ */
153
+ testID?: string;
154
+ };
155
+
156
+ /**
157
+ * A button is component that the user can press to trigger an action.
158
+ *
159
+ * ## Usage
160
+ * ```js
161
+ * import * as React from 'react';
162
+ * import { Button } from 'react-native-paper';
163
+ *
164
+ * const MyComponent = () => (
165
+ * <Button icon="camera" mode="contained" onPress={() => console.log('Pressed')}>
166
+ * Press me
167
+ * </Button>
168
+ * );
169
+ *
170
+ * export default MyComponent;
171
+ * ```
172
+ */
173
+ const Button = (
174
+ {
175
+ disabled,
176
+ compact,
177
+ mode = 'text',
178
+ dark,
179
+ loading,
180
+ icon,
181
+ buttonColor: customButtonColor,
182
+ textColor: customTextColor,
183
+ rippleColor: customRippleColor,
184
+ children,
185
+ accessibilityLabel,
186
+ accessibilityHint,
187
+ accessibilityRole = 'button',
188
+ onPress,
189
+ onPressIn,
190
+ onPressOut,
191
+ onLongPress,
192
+ delayLongPress,
193
+ style,
194
+ theme: themeOverrides,
195
+ uppercase: uppercaseProp,
196
+ contentStyle,
197
+ labelStyle,
198
+ testID = 'button',
199
+ accessible,
200
+ background,
201
+ maxFontSizeMultiplier,
202
+ touchableRef,
203
+ ...rest
204
+ }: Props,
205
+ ref: React.ForwardedRef<View>
206
+ ) => {
207
+ const theme = useInternalTheme(themeOverrides);
208
+ const isMode = React.useCallback(
209
+ (modeToCompare: ButtonMode) => {
210
+ return mode === modeToCompare;
211
+ },
212
+ [mode]
213
+ );
214
+ const { roundness, isV3, animation } = theme;
215
+ const uppercase = uppercaseProp ?? !theme.isV3;
216
+
217
+ const hasPassedTouchHandler = hasTouchHandler({
218
+ onPress,
219
+ onPressIn,
220
+ onPressOut,
221
+ onLongPress,
222
+ });
223
+
224
+ const isElevationEntitled =
225
+ !disabled && (isV3 ? isMode('elevated') : isMode('contained'));
226
+ const initialElevation = isV3 ? 1 : 2;
227
+ const activeElevation = isV3 ? 2 : 8;
228
+
229
+ const { current: elevation } = React.useRef<Animated.Value>(
230
+ new Animated.Value(isElevationEntitled ? initialElevation : 0)
231
+ );
232
+
233
+ React.useEffect(() => {
234
+ // Workaround not to call setValue on Animated.Value, because it breaks styles.
235
+ // https://github.com/callstack/react-native-paper/issues/4559
236
+ Animated.timing(elevation, {
237
+ toValue: isElevationEntitled ? initialElevation : 0,
238
+ duration: 0,
239
+ useNativeDriver: true,
240
+ });
241
+ }, [isElevationEntitled, elevation, initialElevation]);
242
+
243
+ const handlePressIn = (e: GestureResponderEvent) => {
244
+ onPressIn?.(e);
245
+ if (isV3 ? isMode('elevated') : isMode('contained')) {
246
+ const { scale } = animation;
247
+ Animated.timing(elevation, {
248
+ toValue: activeElevation,
249
+ duration: 200 * scale,
250
+ useNativeDriver:
251
+ Platform.OS === 'web' ||
252
+ Platform.constants.reactNativeVersion.minor <= 72,
253
+ }).start();
254
+ }
255
+ };
256
+
257
+ const handlePressOut = (e: GestureResponderEvent) => {
258
+ onPressOut?.(e);
259
+ if (isV3 ? isMode('elevated') : isMode('contained')) {
260
+ const { scale } = animation;
261
+ Animated.timing(elevation, {
262
+ toValue: initialElevation,
263
+ duration: 150 * scale,
264
+ useNativeDriver:
265
+ Platform.OS === 'web' ||
266
+ Platform.constants.reactNativeVersion.minor <= 72,
267
+ }).start();
268
+ }
269
+ };
270
+
271
+ const flattenedStyles = (StyleSheet.flatten(style) || {}) as ViewStyle;
272
+ const [, borderRadiusStyles] = splitStyles(
273
+ flattenedStyles,
274
+ (style) => style.startsWith('border') && style.endsWith('Radius')
275
+ );
276
+
277
+ const borderRadius = (isV3 ? 5 : 1) * roundness;
278
+ const iconSize = isV3 ? 18 : 16;
279
+
280
+ const { backgroundColor, borderColor, textColor, borderWidth } =
281
+ getButtonColors({
282
+ customButtonColor,
283
+ customTextColor,
284
+ theme,
285
+ mode,
286
+ disabled,
287
+ dark,
288
+ });
289
+
290
+ const rippleColor =
291
+ customRippleColor || color(textColor).alpha(0.12).rgb().string();
292
+
293
+ const touchableStyle = {
294
+ ...borderRadiusStyles,
295
+ borderRadius: borderRadiusStyles.borderRadius ?? borderRadius,
296
+ };
297
+
298
+ const buttonStyle = {
299
+ backgroundColor,
300
+ borderColor,
301
+ borderWidth,
302
+ ...touchableStyle,
303
+ };
304
+
305
+ const { color: customLabelColor, fontSize: customLabelSize } =
306
+ StyleSheet.flatten(labelStyle) || {};
307
+
308
+ const font = isV3 ? theme.fonts.labelLarge : theme.fonts.medium;
309
+
310
+ const textStyle = {
311
+ color: textColor,
312
+ ...font,
313
+ };
314
+
315
+ const iconStyle =
316
+ StyleSheet.flatten(contentStyle)?.flexDirection === 'row-reverse'
317
+ ? [
318
+ styles.iconReverse,
319
+ isV3 && styles[`md3IconReverse${compact ? 'Compact' : ''}`],
320
+ isV3 &&
321
+ isMode('text') &&
322
+ styles[`md3IconReverseTextMode${compact ? 'Compact' : ''}`],
323
+ ]
324
+ : [
325
+ styles.icon,
326
+ isV3 && styles[`md3Icon${compact ? 'Compact' : ''}`],
327
+ isV3 &&
328
+ isMode('text') &&
329
+ styles[`md3IconTextMode${compact ? 'Compact' : ''}`],
330
+ ];
331
+
332
+ return (
333
+ <Surface
334
+ {...rest}
335
+ ref={ref}
336
+ testID={`${testID}-container`}
337
+ style={
338
+ [
339
+ styles.button,
340
+ compact && styles.compact,
341
+ buttonStyle,
342
+ style,
343
+ !isV3 && !disabled && { elevation },
344
+ ] as Animated.WithAnimatedValue<StyleProp<ViewStyle>>
345
+ }
346
+ {...(isV3 && { elevation: elevation })}
347
+ >
348
+ <TouchableRipple
349
+ borderless
350
+ background={background}
351
+ onPress={onPress}
352
+ onLongPress={onLongPress}
353
+ onPressIn={hasPassedTouchHandler ? handlePressIn : undefined}
354
+ onPressOut={hasPassedTouchHandler ? handlePressOut : undefined}
355
+ delayLongPress={delayLongPress}
356
+ accessibilityLabel={accessibilityLabel}
357
+ accessibilityHint={accessibilityHint}
358
+ accessibilityRole={accessibilityRole}
359
+ accessibilityState={{ disabled }}
360
+ accessible={accessible}
361
+ disabled={disabled}
362
+ rippleColor={rippleColor}
363
+ style={getButtonTouchableRippleStyle(touchableStyle, borderWidth)}
364
+ testID={testID}
365
+ theme={theme}
366
+ ref={touchableRef}
367
+ >
368
+ <View style={[styles.content, contentStyle]}>
369
+ {icon && loading !== true ? (
370
+ <View style={iconStyle} testID={`${testID}-icon-container`}>
371
+ <Icon
372
+ source={icon}
373
+ size={customLabelSize ?? iconSize}
374
+ color={
375
+ typeof customLabelColor === 'string'
376
+ ? customLabelColor
377
+ : textColor
378
+ }
379
+ />
380
+ </View>
381
+ ) : null}
382
+ {loading ? (
383
+ <ActivityIndicator
384
+ size={customLabelSize ?? iconSize}
385
+ color={
386
+ typeof customLabelColor === 'string'
387
+ ? customLabelColor
388
+ : textColor
389
+ }
390
+ style={iconStyle}
391
+ />
392
+ ) : null}
393
+ <Text
394
+ variant="labelLarge"
395
+ selectable={false}
396
+ numberOfLines={1}
397
+ testID={`${testID}-text`}
398
+ style={[
399
+ styles.label,
400
+ !isV3 && styles.md2Label,
401
+ isV3 &&
402
+ (isMode('text')
403
+ ? icon || loading
404
+ ? styles.md3LabelTextAddons
405
+ : styles.md3LabelText
406
+ : styles.md3Label),
407
+ compact && styles.compactLabel,
408
+ uppercase && styles.uppercaseLabel,
409
+ textStyle,
410
+ labelStyle,
411
+ ]}
412
+ maxFontSizeMultiplier={maxFontSizeMultiplier}
413
+ >
414
+ {children}
415
+ </Text>
416
+ </View>
417
+ </TouchableRipple>
418
+ </Surface>
419
+ );
420
+ };
421
+
422
+ const styles = StyleSheet.create({
423
+ button: {
424
+ minWidth: 64,
425
+ borderStyle: 'solid',
426
+ },
427
+ compact: {
428
+ minWidth: 'auto',
429
+ },
430
+ content: {
431
+ flexDirection: 'row',
432
+ alignItems: 'center',
433
+ justifyContent: 'center',
434
+ },
435
+ icon: {
436
+ marginLeft: 12,
437
+ marginRight: -4,
438
+ },
439
+ iconReverse: {
440
+ marginRight: 12,
441
+ marginLeft: -4,
442
+ },
443
+ /* eslint-disable react-native/no-unused-styles */
444
+ md3Icon: {
445
+ marginLeft: 16,
446
+ marginRight: -16,
447
+ },
448
+ md3IconCompact: {
449
+ marginLeft: 8,
450
+ marginRight: 0,
451
+ },
452
+ md3IconReverse: {
453
+ marginLeft: -16,
454
+ marginRight: 16,
455
+ },
456
+ md3IconReverseCompact: {
457
+ marginLeft: 0,
458
+ marginRight: 8,
459
+ },
460
+ md3IconTextMode: {
461
+ marginLeft: 12,
462
+ marginRight: -8,
463
+ },
464
+ md3IconTextModeCompact: {
465
+ marginLeft: 6,
466
+ marginRight: 0,
467
+ },
468
+ md3IconReverseTextMode: {
469
+ marginLeft: -8,
470
+ marginRight: 12,
471
+ },
472
+ md3IconReverseTextModeCompact: {
473
+ marginLeft: 0,
474
+ marginRight: 6,
475
+ },
476
+ /* eslint-enable react-native/no-unused-styles */
477
+ label: {
478
+ textAlign: 'center',
479
+ marginVertical: 9,
480
+ marginHorizontal: 16,
481
+ },
482
+ md2Label: {
483
+ letterSpacing: 1,
484
+ },
485
+ compactLabel: {
486
+ marginHorizontal: 8,
487
+ },
488
+ uppercaseLabel: {
489
+ textTransform: 'uppercase',
490
+ },
491
+ md3Label: {
492
+ marginVertical: 10,
493
+ marginHorizontal: 24,
494
+ },
495
+ md3LabelText: {
496
+ marginHorizontal: 12,
497
+ },
498
+ md3LabelTextAddons: {
499
+ marginHorizontal: 16,
500
+ },
501
+ });
502
+
503
+ export default forwardRef(Button);