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,391 @@
1
+ import * as React from 'react';
2
+ import {
3
+ ColorValue,
4
+ GestureResponderEvent,
5
+ I18nManager,
6
+ NativeSyntheticEvent,
7
+ StyleProp,
8
+ StyleSheet,
9
+ TextStyle,
10
+ TextLayoutEventData,
11
+ View,
12
+ ViewProps,
13
+ ViewStyle,
14
+ PressableAndroidRippleConfig,
15
+ } from 'react-native';
16
+
17
+ import { ListAccordionGroupContext } from './ListAccordionGroup';
18
+ import type { Style } from './utils';
19
+ import { getAccordionColors, getLeftStyles } from './utils';
20
+ import { useInternalTheme } from '../../core/theming';
21
+ import type { ThemeProp } from '../../types';
22
+ import MaterialCommunityIcon from '../MaterialCommunityIcon';
23
+ import TouchableRipple from '../TouchableRipple/TouchableRipple';
24
+ import Text from '../Typography/Text';
25
+
26
+ export type Props = {
27
+ /**
28
+ * Title text for the list accordion.
29
+ */
30
+ title: React.ReactNode;
31
+ /**
32
+ * Description text for the list accordion.
33
+ */
34
+ description?: React.ReactNode;
35
+ /**
36
+ * Callback which returns a React element to display on the left side.
37
+ */
38
+ left?: (props: { color: string; style: Style }) => React.ReactNode;
39
+ /**
40
+ * Callback which returns a React element to display on the right side.
41
+ */
42
+ right?: (props: { isExpanded: boolean }) => React.ReactNode;
43
+ /**
44
+ * Whether the accordion is expanded
45
+ * If this prop is provided, the accordion will behave as a "controlled component".
46
+ * You'll need to update this prop when you want to toggle the component or on `onPress`.
47
+ */
48
+ expanded?: boolean;
49
+ /**
50
+ * Function to execute on press.
51
+ */
52
+ onPress?: (e: GestureResponderEvent) => void;
53
+ /**
54
+ * Function to execute on long press.
55
+ */
56
+ onLongPress?: (e: GestureResponderEvent) => void;
57
+ /**
58
+ * The number of milliseconds a user must touch the element before executing `onLongPress`.
59
+ */
60
+ delayLongPress?: number;
61
+ /**
62
+ * Content of the section.
63
+ */
64
+ children: React.ReactNode;
65
+ /**
66
+ * @optional
67
+ */
68
+ theme?: ThemeProp;
69
+ /**
70
+ * Type of background drawabale to display the feedback (Android).
71
+ * https://reactnative.dev/docs/pressable#rippleconfig
72
+ */
73
+ background?: PressableAndroidRippleConfig;
74
+ /**
75
+ * Style that is passed to the wrapping TouchableRipple element.
76
+ */
77
+ style?: StyleProp<ViewStyle>;
78
+ /**
79
+ * Style that is passed to Title element.
80
+ */
81
+ titleStyle?: StyleProp<TextStyle>;
82
+ /**
83
+ * Style that is passed to Description element.
84
+ */
85
+ descriptionStyle?: StyleProp<TextStyle>;
86
+ /**
87
+ * Color of the ripple effect.
88
+ */
89
+ rippleColor?: ColorValue;
90
+ /**
91
+ * Truncate Title text such that the total number of lines does not
92
+ * exceed this number.
93
+ */
94
+ titleNumberOfLines?: number;
95
+ /**
96
+ * Truncate Description text such that the total number of lines does not
97
+ * exceed this number.
98
+ */
99
+ descriptionNumberOfLines?: number;
100
+ /**
101
+ * Specifies the largest possible scale a title font can reach.
102
+ */
103
+ titleMaxFontSizeMultiplier?: number;
104
+ /**
105
+ * Specifies the largest possible scale a description font can reach.
106
+ */
107
+ descriptionMaxFontSizeMultiplier?: number;
108
+ /**
109
+ * Id is used for distinguishing specific accordion when using List.AccordionGroup. Property is required when using List.AccordionGroup and has no impact on behavior when using standalone List.Accordion.
110
+ */
111
+ id?: string | number;
112
+ /**
113
+ * TestID used for testing purposes
114
+ */
115
+ testID?: string;
116
+ /**
117
+ * Accessibility label for the TouchableRipple. This is read by the screen reader when the user taps the touchable.
118
+ */
119
+ accessibilityLabel?: string;
120
+ /**
121
+ * `pointerEvents` passed to the `View` container
122
+ */
123
+ pointerEvents?: ViewProps['pointerEvents'];
124
+ };
125
+
126
+ /**
127
+ * A component used to display an expandable list item.
128
+ *
129
+ * ## Usage
130
+ * ```js
131
+ * import * as React from 'react';
132
+ * import { List } from 'react-native-paper';
133
+ *
134
+ * const MyComponent = () => {
135
+ * const [expanded, setExpanded] = React.useState(true);
136
+ *
137
+ * const handlePress = () => setExpanded(!expanded);
138
+ *
139
+ * return (
140
+ * <List.Section title="Accordions">
141
+ * <List.Accordion
142
+ * title="Uncontrolled Accordion"
143
+ * left={props => <List.Icon {...props} icon="folder" />}>
144
+ * <List.Item title="First item" />
145
+ * <List.Item title="Second item" />
146
+ * </List.Accordion>
147
+ *
148
+ * <List.Accordion
149
+ * title="Controlled Accordion"
150
+ * left={props => <List.Icon {...props} icon="folder" />}
151
+ * expanded={expanded}
152
+ * onPress={handlePress}>
153
+ * <List.Item title="First item" />
154
+ * <List.Item title="Second item" />
155
+ * </List.Accordion>
156
+ * </List.Section>
157
+ * );
158
+ * };
159
+ *
160
+ * export default MyComponent;
161
+ * ```
162
+ */
163
+ const ListAccordion = ({
164
+ left,
165
+ right,
166
+ title,
167
+ description,
168
+ children,
169
+ theme: themeOverrides,
170
+ titleStyle,
171
+ descriptionStyle,
172
+ titleNumberOfLines = 1,
173
+ descriptionNumberOfLines = 2,
174
+ rippleColor: customRippleColor,
175
+ style,
176
+ id,
177
+ testID,
178
+ background,
179
+ onPress,
180
+ onLongPress,
181
+ delayLongPress,
182
+ expanded: expandedProp,
183
+ accessibilityLabel,
184
+ pointerEvents = 'none',
185
+ titleMaxFontSizeMultiplier,
186
+ descriptionMaxFontSizeMultiplier,
187
+ }: Props) => {
188
+ const theme = useInternalTheme(themeOverrides);
189
+ const [expanded, setExpanded] = React.useState<boolean>(
190
+ expandedProp || false
191
+ );
192
+ const [alignToTop, setAlignToTop] = React.useState(false);
193
+
194
+ const onDescriptionTextLayout = (
195
+ event: NativeSyntheticEvent<TextLayoutEventData>
196
+ ) => {
197
+ if (!theme.isV3) {
198
+ return;
199
+ }
200
+ const { nativeEvent } = event;
201
+ setAlignToTop(nativeEvent.lines.length >= 2);
202
+ };
203
+
204
+ const handlePressAction = (e: GestureResponderEvent) => {
205
+ onPress?.(e);
206
+
207
+ if (expandedProp === undefined) {
208
+ // Only update state of the `expanded` prop was not passed
209
+ // If it was passed, the component will act as a controlled component
210
+ setExpanded((expanded) => !expanded);
211
+ }
212
+ };
213
+
214
+ const expandedInternal = expandedProp !== undefined ? expandedProp : expanded;
215
+
216
+ const groupContext = React.useContext(ListAccordionGroupContext);
217
+ if (groupContext !== null && (id === undefined || id === null || id === '')) {
218
+ throw new Error(
219
+ 'List.Accordion is used inside a List.AccordionGroup without specifying an id prop.'
220
+ );
221
+ }
222
+ const isExpanded = groupContext
223
+ ? groupContext.expandedId === id
224
+ : expandedInternal;
225
+
226
+ const { titleColor, descriptionColor, titleTextColor, rippleColor } =
227
+ getAccordionColors({
228
+ theme,
229
+ isExpanded,
230
+ customRippleColor,
231
+ });
232
+
233
+ const handlePress =
234
+ groupContext && id !== undefined
235
+ ? () => groupContext.onAccordionPress(id)
236
+ : handlePressAction;
237
+ return (
238
+ <View>
239
+ <View style={{ backgroundColor: theme?.colors?.background }}>
240
+ <TouchableRipple
241
+ style={[theme.isV3 ? styles.containerV3 : styles.container, style]}
242
+ onPress={handlePress}
243
+ onLongPress={onLongPress}
244
+ delayLongPress={delayLongPress}
245
+ rippleColor={rippleColor}
246
+ accessibilityRole="button"
247
+ accessibilityState={{ expanded: isExpanded }}
248
+ accessibilityLabel={accessibilityLabel}
249
+ testID={testID}
250
+ theme={theme}
251
+ background={background}
252
+ borderless
253
+ >
254
+ <View
255
+ style={theme.isV3 ? styles.rowV3 : styles.row}
256
+ pointerEvents={pointerEvents}
257
+ >
258
+ {left
259
+ ? left({
260
+ color: isExpanded ? theme.colors?.primary : descriptionColor,
261
+ style: getLeftStyles(alignToTop, description, theme.isV3),
262
+ })
263
+ : null}
264
+ <View
265
+ style={[theme.isV3 ? styles.itemV3 : styles.item, styles.content]}
266
+ >
267
+ <Text
268
+ selectable={false}
269
+ numberOfLines={titleNumberOfLines}
270
+ style={[
271
+ styles.title,
272
+ {
273
+ color: titleTextColor,
274
+ },
275
+ titleStyle,
276
+ ]}
277
+ maxFontSizeMultiplier={titleMaxFontSizeMultiplier}
278
+ >
279
+ {title}
280
+ </Text>
281
+ {description ? (
282
+ <Text
283
+ selectable={false}
284
+ numberOfLines={descriptionNumberOfLines}
285
+ style={[
286
+ styles.description,
287
+ {
288
+ color: descriptionColor,
289
+ },
290
+ descriptionStyle,
291
+ ]}
292
+ onTextLayout={onDescriptionTextLayout}
293
+ maxFontSizeMultiplier={descriptionMaxFontSizeMultiplier}
294
+ >
295
+ {description}
296
+ </Text>
297
+ ) : null}
298
+ </View>
299
+ <View
300
+ style={[styles.item, description ? styles.multiline : undefined]}
301
+ >
302
+ {right ? (
303
+ right({
304
+ isExpanded: isExpanded,
305
+ })
306
+ ) : (
307
+ <MaterialCommunityIcon
308
+ name={isExpanded ? 'chevron-up' : 'chevron-down'}
309
+ color={theme.isV3 ? descriptionColor : titleColor}
310
+ size={24}
311
+ direction={I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'}
312
+ />
313
+ )}
314
+ </View>
315
+ </View>
316
+ </TouchableRipple>
317
+ </View>
318
+
319
+ {isExpanded
320
+ ? React.Children.map(children, (child) => {
321
+ if (
322
+ left &&
323
+ React.isValidElement(child) &&
324
+ !child.props.left &&
325
+ !child.props.right
326
+ ) {
327
+ return React.cloneElement(child as React.ReactElement<any>, {
328
+ style: [
329
+ theme.isV3 ? styles.childV3 : styles.child,
330
+ child.props.style,
331
+ ],
332
+ theme,
333
+ });
334
+ }
335
+
336
+ return child;
337
+ })
338
+ : null}
339
+ </View>
340
+ );
341
+ };
342
+
343
+ ListAccordion.displayName = 'List.Accordion';
344
+
345
+ const styles = StyleSheet.create({
346
+ container: {
347
+ padding: 8,
348
+ },
349
+ containerV3: {
350
+ paddingVertical: 8,
351
+ paddingRight: 24,
352
+ },
353
+ row: {
354
+ flexDirection: 'row',
355
+ alignItems: 'center',
356
+ },
357
+ rowV3: {
358
+ flexDirection: 'row',
359
+ marginVertical: 6,
360
+ },
361
+ multiline: {
362
+ height: 40,
363
+ alignItems: 'center',
364
+ justifyContent: 'center',
365
+ },
366
+ title: {
367
+ fontSize: 16,
368
+ },
369
+ description: {
370
+ fontSize: 14,
371
+ },
372
+ item: {
373
+ marginVertical: 6,
374
+ paddingLeft: 8,
375
+ },
376
+ itemV3: {
377
+ paddingLeft: 16,
378
+ },
379
+ child: {
380
+ paddingLeft: 64,
381
+ },
382
+ childV3: {
383
+ paddingLeft: 40,
384
+ },
385
+ content: {
386
+ flex: 1,
387
+ justifyContent: 'center',
388
+ },
389
+ });
390
+
391
+ export default ListAccordion;
@@ -0,0 +1,88 @@
1
+ import * as React from 'react';
2
+
3
+ export type Props = {
4
+ /**
5
+ * Function to execute on selection change.
6
+ */
7
+ onAccordionPress?: (expandedId: string | number) => void;
8
+ /**
9
+ * Id of the currently expanded list accordion
10
+ */
11
+ expandedId?: string | number;
12
+ /**
13
+ * React elements containing list accordions
14
+ */
15
+ children: React.ReactNode;
16
+ };
17
+
18
+ export type ListAccordionGroupContextType = {
19
+ expandedId: string | number | undefined;
20
+ onAccordionPress: (expandedId: string | number) => void;
21
+ } | null;
22
+
23
+ export const ListAccordionGroupContext =
24
+ React.createContext<ListAccordionGroupContextType>(null);
25
+
26
+ /**
27
+ * List.AccordionGroup allows to control a group of List Accordions. `id` prop for List.Accordion is required in order for group to work.
28
+ * List.AccordionGroup can be a controlled or uncontrolled component. The example shows the uncontrolled version.
29
+ * At most one Accordion can be expanded at a given time.
30
+ *
31
+ * ## Usage
32
+ * ```js
33
+ * import * as React from 'react';
34
+ * import { View, Text } from 'react-native';
35
+ * import { List } from 'react-native-paper';
36
+ *
37
+ * const MyComponent = () => (
38
+ * <List.AccordionGroup>
39
+ * <List.Accordion title="Accordion 1" id="1">
40
+ * <List.Item title="Item 1" />
41
+ * </List.Accordion>
42
+ * <List.Accordion title="Accordion 2" id="2">
43
+ * <List.Item title="Item 2" />
44
+ * </List.Accordion>
45
+ * <View>
46
+ * <Text>
47
+ * List.Accordion can be wrapped because implementation uses React.Context.
48
+ * </Text>
49
+ * <List.Accordion title="Accordion 3" id="3">
50
+ * <List.Item title="Item 3" />
51
+ * </List.Accordion>
52
+ * </View>
53
+ * </List.AccordionGroup>
54
+ * );
55
+ *
56
+ * export default MyComponent;
57
+ *```
58
+ */
59
+ const ListAccordionGroup = ({
60
+ expandedId: expandedIdProp,
61
+ onAccordionPress,
62
+ children,
63
+ }: Props) => {
64
+ const [expandedId, setExpandedId] = React.useState<
65
+ string | number | undefined
66
+ >(undefined);
67
+
68
+ const onAccordionPressDefault = (newExpandedId: string | number) => {
69
+ setExpandedId((currentExpandedId) =>
70
+ currentExpandedId === newExpandedId ? undefined : newExpandedId
71
+ );
72
+ };
73
+
74
+ return (
75
+ <ListAccordionGroupContext.Provider
76
+ value={{
77
+ expandedId: expandedIdProp || expandedId, // component can be controlled or uncontrolled
78
+ onAccordionPress: onAccordionPress || onAccordionPressDefault,
79
+ }}
80
+ >
81
+ {children}
82
+ </ListAccordionGroupContext.Provider>
83
+ );
84
+ };
85
+
86
+ ListAccordionGroup.displayName = 'List.AccordionGroup';
87
+
88
+ export default ListAccordionGroup;
@@ -0,0 +1,79 @@
1
+ import * as React from 'react';
2
+ import { View, ViewStyle, StyleSheet, StyleProp } from 'react-native';
3
+
4
+ import { useInternalTheme } from '../../core/theming';
5
+ import type { ThemeProp } from '../../types';
6
+ import Icon, { IconSource } from '../Icon';
7
+
8
+ export type Props = {
9
+ /**
10
+ * Icon to show.
11
+ */
12
+ icon: IconSource;
13
+ /**
14
+ * Color for the icon.
15
+ */
16
+ color?: string;
17
+ style?: StyleProp<ViewStyle>;
18
+ /**
19
+ * @optional
20
+ */
21
+ theme?: ThemeProp;
22
+ };
23
+
24
+ const ICON_SIZE = 24;
25
+
26
+ /**
27
+ * A component to show an icon in a list item.
28
+ *
29
+ * ## Usage
30
+ * ```js
31
+ * import * as React from 'react';
32
+ * import { List, MD3Colors } from 'react-native-paper';
33
+ *
34
+ * const MyComponent = () => (
35
+ * <>
36
+ * <List.Icon color={MD3Colors.tertiary70} icon="folder" />
37
+ * <List.Icon color={MD3Colors.tertiary70} icon="equal" />
38
+ * <List.Icon color={MD3Colors.tertiary70} icon="calendar" />
39
+ * </>
40
+ * );
41
+ *
42
+ * export default MyComponent;
43
+ * ```
44
+ */
45
+ const ListIcon = ({
46
+ icon,
47
+ color: iconColor,
48
+ style,
49
+ theme: themeOverrides,
50
+ }: Props) => {
51
+ const theme = useInternalTheme(themeOverrides);
52
+
53
+ return (
54
+ <View
55
+ style={[theme.isV3 ? styles.itemV3 : styles.item, style]}
56
+ pointerEvents="box-none"
57
+ >
58
+ <Icon source={icon} size={ICON_SIZE} color={iconColor} theme={theme} />
59
+ </View>
60
+ );
61
+ };
62
+
63
+ const styles = StyleSheet.create({
64
+ item: {
65
+ margin: 8,
66
+ height: 40,
67
+ width: 40,
68
+ alignItems: 'center',
69
+ justifyContent: 'center',
70
+ },
71
+ itemV3: {
72
+ alignItems: 'center',
73
+ justifyContent: 'center',
74
+ },
75
+ });
76
+
77
+ ListIcon.displayName = 'List.Icon';
78
+
79
+ export default ListIcon;
@@ -0,0 +1,89 @@
1
+ import * as React from 'react';
2
+ import {
3
+ StyleSheet,
4
+ StyleProp,
5
+ Image,
6
+ ImageSourcePropType,
7
+ ImageStyle,
8
+ } from 'react-native';
9
+
10
+ import { useInternalTheme } from '../../core/theming';
11
+ import type { ThemeProp } from '../../types';
12
+
13
+ export type Props = {
14
+ source: ImageSourcePropType;
15
+ variant?: 'image' | 'video';
16
+ style?: StyleProp<ImageStyle>;
17
+ /**
18
+ * @optional
19
+ */
20
+ theme?: ThemeProp;
21
+ };
22
+
23
+ /**
24
+ * A component to show image in a list item.
25
+ *
26
+ * ## Usage
27
+ * ```js
28
+ * import * as React from 'react';
29
+ * import { List, MD3Colors } from 'react-native-paper';
30
+ *
31
+ * const MyComponent = () => (
32
+ * <>
33
+ * <List.Image variant="image" source={{uri: 'https://www.someurl.com/apple'}} />
34
+ * <List.Image variant="video" source={require('../../some-apple.png')} />
35
+ * </>
36
+ * );
37
+ *
38
+ * export default MyComponent;
39
+ * ```
40
+ */
41
+ const ListImage = ({
42
+ style,
43
+ source,
44
+ variant = 'image',
45
+ theme: themeOverrides,
46
+ }: Props) => {
47
+ const theme = useInternalTheme(themeOverrides);
48
+ const getStyles = () => {
49
+ if (variant === 'video') {
50
+ if (!theme.isV3) {
51
+ return [style, styles.video];
52
+ }
53
+
54
+ return [style, styles.videoV3];
55
+ }
56
+
57
+ return [style, styles.image];
58
+ };
59
+
60
+ return (
61
+ <Image
62
+ style={getStyles()}
63
+ source={source}
64
+ accessibilityIgnoresInvertColors
65
+ testID="list-image"
66
+ />
67
+ );
68
+ };
69
+
70
+ const styles = StyleSheet.create({
71
+ image: {
72
+ width: 56,
73
+ height: 56,
74
+ },
75
+ video: {
76
+ width: 100,
77
+ height: 64,
78
+ marginLeft: 0,
79
+ },
80
+ videoV3: {
81
+ width: 114,
82
+ height: 64,
83
+ marginLeft: 0,
84
+ },
85
+ });
86
+
87
+ ListImage.displayName = 'List.Image';
88
+
89
+ export default ListImage;