@draftbit/core 48.4.8-f6d6b8.2 → 48.4.8-fa5021.2

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 (298) hide show
  1. package/lib/typescript/tsconfig.tsbuildinfo +1 -1
  2. package/package.json +3 -3
  3. package/src/Provider.js +10 -0
  4. package/src/Provider.js.map +1 -0
  5. package/src/components/AccordionGroup.js +45 -0
  6. package/src/components/AccordionGroup.js.map +1 -0
  7. package/src/components/ActionSheet/ActionSheet.js +46 -0
  8. package/src/components/ActionSheet/ActionSheet.js.map +1 -0
  9. package/src/components/ActionSheet/ActionSheetCancel.js +7 -0
  10. package/src/components/ActionSheet/ActionSheetCancel.js.map +1 -0
  11. package/src/components/ActionSheet/ActionSheetItem.js +31 -0
  12. package/src/components/ActionSheet/ActionSheetItem.js.map +1 -0
  13. package/src/components/ActionSheet/index.js +4 -0
  14. package/src/components/ActionSheet/index.js.map +1 -0
  15. package/src/components/AspectRatio.js +19 -0
  16. package/src/components/AspectRatio.js.map +1 -0
  17. package/src/components/BottomSheet/BottomSheet.js +72 -0
  18. package/src/components/BottomSheet/BottomSheet.js.map +1 -0
  19. package/src/components/BottomSheet/BottomSheetComponent.js +438 -0
  20. package/src/components/BottomSheet/BottomSheetComponent.js.map +1 -0
  21. package/src/components/BottomSheet/index.js +2 -0
  22. package/src/components/BottomSheet/index.js.map +1 -0
  23. package/src/components/Button.js +121 -0
  24. package/src/components/Button.js.map +1 -0
  25. package/src/components/Checkbox/Checkbox.js +63 -0
  26. package/src/components/Checkbox/Checkbox.js.map +1 -0
  27. package/src/components/Checkbox/CheckboxGroupRow.js +77 -0
  28. package/src/components/Checkbox/CheckboxGroupRow.js.map +1 -0
  29. package/src/components/Checkbox/CheckboxRow.js +78 -0
  30. package/src/components/Checkbox/CheckboxRow.js.map +1 -0
  31. package/src/components/Checkbox/context.js +15 -0
  32. package/src/components/Checkbox/context.js.map +1 -0
  33. package/src/components/Checkbox/index.js +3 -0
  34. package/src/components/Checkbox/index.js.map +1 -0
  35. package/src/components/Config.js +65 -0
  36. package/src/components/Config.js.map +1 -0
  37. package/src/components/DatePicker/DatePicker.js +384 -0
  38. package/src/components/DatePicker/DatePicker.js.map +1 -0
  39. package/src/components/DatePicker/DatePickerComponent.js +14 -0
  40. package/src/components/DatePicker/DatePickerComponent.js.map +1 -0
  41. package/src/components/DatePicker/DatePickerComponent.web.js +31 -0
  42. package/src/components/DatePicker/DatePickerComponent.web.js.map +1 -0
  43. package/src/components/DatePicker/DatePickerComponentType.js +2 -0
  44. package/src/components/DatePicker/DatePickerComponentType.js.map +1 -0
  45. package/src/components/DeckSwiper/DeckSwiper.js +91 -0
  46. package/src/components/DeckSwiper/DeckSwiper.js.map +1 -0
  47. package/src/components/DeckSwiper/DeckSwiperCard.js +21 -0
  48. package/src/components/DeckSwiper/DeckSwiperCard.js.map +1 -0
  49. package/src/components/DeckSwiper/index.js +3 -0
  50. package/src/components/DeckSwiper/index.js.map +1 -0
  51. package/src/components/Divider.js +14 -0
  52. package/src/components/Divider.js.map +1 -0
  53. package/src/components/Elevation.js +21 -0
  54. package/src/components/Elevation.js.map +1 -0
  55. package/src/components/FormRow.js +20 -0
  56. package/src/components/FormRow.js.map +1 -0
  57. package/src/components/IconButton.js +36 -0
  58. package/src/components/IconButton.js.map +1 -0
  59. package/src/components/Image.js +48 -0
  60. package/src/components/Image.js.map +1 -0
  61. package/src/components/Layout/AspectRatio.js +7 -0
  62. package/src/components/Layout/AspectRatio.js.map +1 -0
  63. package/src/components/Layout/Center.js +15 -0
  64. package/src/components/Layout/Center.js.map +1 -0
  65. package/src/components/Layout/Circle.js +16 -0
  66. package/src/components/Layout/Circle.js.map +1 -0
  67. package/src/components/Layout/HStack.js +12 -0
  68. package/src/components/Layout/HStack.js.map +1 -0
  69. package/src/components/Layout/LayoutCommon.js +8 -0
  70. package/src/components/Layout/LayoutCommon.js.map +1 -0
  71. package/src/components/Layout/Spacer.js +15 -0
  72. package/src/components/Layout/Spacer.js.map +1 -0
  73. package/src/components/Layout/Square.js +25 -0
  74. package/src/components/Layout/Square.js.map +1 -0
  75. package/src/components/Layout/VStack.js +12 -0
  76. package/src/components/Layout/VStack.js.map +1 -0
  77. package/src/components/Layout/ZStack.js +20 -0
  78. package/src/components/Layout/ZStack.js.map +1 -0
  79. package/src/components/Layout/index.js +9 -0
  80. package/src/components/Layout/index.js.map +1 -0
  81. package/src/components/Markdown.js +11 -0
  82. package/src/components/Markdown.js.map +1 -0
  83. package/src/components/MediaPlayer/AudioPlayer/AudioPlayerCommon.js +2 -0
  84. package/src/components/MediaPlayer/AudioPlayer/AudioPlayerCommon.js.map +1 -0
  85. package/src/components/MediaPlayer/AudioPlayer/AudioPlayerWithInterface.js +126 -0
  86. package/src/components/MediaPlayer/AudioPlayer/AudioPlayerWithInterface.js.map +1 -0
  87. package/src/components/MediaPlayer/AudioPlayer/HeadlessAudioPlayer.js +93 -0
  88. package/src/components/MediaPlayer/AudioPlayer/HeadlessAudioPlayer.js.map +1 -0
  89. package/src/components/MediaPlayer/AudioPlayer/index.js +15 -0
  90. package/src/components/MediaPlayer/AudioPlayer/index.js.map +1 -0
  91. package/src/components/MediaPlayer/MediaPlaybackWrapper.js +42 -0
  92. package/src/components/MediaPlayer/MediaPlaybackWrapper.js.map +1 -0
  93. package/src/components/MediaPlayer/MediaPlayerCommon.js +24 -0
  94. package/src/components/MediaPlayer/MediaPlayerCommon.js.map +1 -0
  95. package/src/components/MediaPlayer/VideoPlayer/VideoPlayer.js +75 -0
  96. package/src/components/MediaPlayer/VideoPlayer/VideoPlayer.js.map +1 -0
  97. package/src/components/MediaPlayer/VideoPlayer/index.js +2 -0
  98. package/src/components/MediaPlayer/VideoPlayer/index.js.map +1 -0
  99. package/src/components/NumberInput.js +60 -0
  100. package/src/components/NumberInput.js.map +1 -0
  101. package/src/components/Picker/Picker.js +288 -0
  102. package/src/components/Picker/Picker.js.map +1 -0
  103. package/src/components/Picker/PickerComponent.android.js +70 -0
  104. package/src/components/Picker/PickerComponent.android.js.map +1 -0
  105. package/src/components/Picker/PickerComponent.ios.js +80 -0
  106. package/src/components/Picker/PickerComponent.ios.js.map +1 -0
  107. package/src/components/Picker/PickerComponent.web.js +71 -0
  108. package/src/components/Picker/PickerComponent.web.js.map +1 -0
  109. package/src/components/Picker/PickerTypes.js +2 -0
  110. package/src/components/Picker/PickerTypes.js.map +1 -0
  111. package/src/components/PinInput/CustomPinInputCell.js +11 -0
  112. package/src/components/PinInput/CustomPinInputCell.js.map +1 -0
  113. package/src/components/PinInput/PinInput.js +70 -0
  114. package/src/components/PinInput/PinInput.js.map +1 -0
  115. package/src/components/PinInput/PinInputText.js +14 -0
  116. package/src/components/PinInput/PinInputText.js.map +1 -0
  117. package/src/components/PinInput/index.js +4 -0
  118. package/src/components/PinInput/index.js.map +1 -0
  119. package/src/components/Portal/Portal.js +36 -0
  120. package/src/components/Portal/Portal.js.map +1 -0
  121. package/src/components/Portal/PortalConsumer.js +28 -0
  122. package/src/components/Portal/PortalConsumer.js.map +1 -0
  123. package/src/components/Portal/PortalHost.js +108 -0
  124. package/src/components/Portal/PortalHost.js.map +1 -0
  125. package/src/components/Portal/PortalManager.js +33 -0
  126. package/src/components/Portal/PortalManager.js.map +1 -0
  127. package/src/components/Pressable.js +13 -0
  128. package/src/components/Pressable.js.map +1 -0
  129. package/src/components/Progress/CircularProgress/CircularProgress.js +103 -0
  130. package/src/components/Progress/CircularProgress/CircularProgress.js.map +1 -0
  131. package/src/components/Progress/CircularProgress/index.js +14 -0
  132. package/src/components/Progress/CircularProgress/index.js.map +1 -0
  133. package/src/components/Progress/IndeterminateProgress.js +39 -0
  134. package/src/components/Progress/IndeterminateProgress.js.map +1 -0
  135. package/src/components/Progress/LinearProgress/LinearProgress.js +56 -0
  136. package/src/components/Progress/LinearProgress/LinearProgress.js.map +1 -0
  137. package/src/components/Progress/LinearProgress/index.js +14 -0
  138. package/src/components/Progress/LinearProgress/index.js.map +1 -0
  139. package/src/components/Progress/ProgressCommon.js +2 -0
  140. package/src/components/Progress/ProgressCommon.js.map +1 -0
  141. package/src/components/ProgressIndicator.js +28 -0
  142. package/src/components/ProgressIndicator.js.map +1 -0
  143. package/src/components/RadioButton/RadioButton.js +18 -0
  144. package/src/components/RadioButton/RadioButton.js.map +1 -0
  145. package/src/components/RadioButton/RadioButtonGroup.js +44 -0
  146. package/src/components/RadioButton/RadioButtonGroup.js.map +1 -0
  147. package/src/components/RadioButton/RadioButtonRow.js +77 -0
  148. package/src/components/RadioButton/RadioButtonRow.js.map +1 -0
  149. package/src/components/RadioButton/context.js +15 -0
  150. package/src/components/RadioButton/context.js.map +1 -0
  151. package/src/components/RadioButton/index.js +4 -0
  152. package/src/components/RadioButton/index.js.map +1 -0
  153. package/src/components/Row.js +49 -0
  154. package/src/components/Row.js.map +1 -0
  155. package/src/components/SVG.js +14 -0
  156. package/src/components/SVG.js.map +1 -0
  157. package/src/components/ScreenContainer.js +36 -0
  158. package/src/components/ScreenContainer.js.map +1 -0
  159. package/src/components/SectionList/SectionHeader.js +14 -0
  160. package/src/components/SectionList/SectionHeader.js.map +1 -0
  161. package/src/components/SectionList/SectionList.js +101 -0
  162. package/src/components/SectionList/SectionList.js.map +1 -0
  163. package/src/components/SectionList/index.js +3 -0
  164. package/src/components/SectionList/index.js.map +1 -0
  165. package/src/components/Shadow.js +26 -0
  166. package/src/components/Shadow.js.map +1 -0
  167. package/src/components/Slider.js +64 -0
  168. package/src/components/Slider.js.map +1 -0
  169. package/src/components/StarRating.js +51 -0
  170. package/src/components/StarRating.js.map +1 -0
  171. package/src/components/StepIndicator.js +347 -0
  172. package/src/components/StepIndicator.js.map +1 -0
  173. package/src/components/Stepper.js +42 -0
  174. package/src/components/Stepper.js.map +1 -0
  175. package/src/components/Surface.js +33 -0
  176. package/src/components/Surface.js.map +1 -0
  177. package/src/components/SwipeableItem/SwipeableItem.js +119 -0
  178. package/src/components/SwipeableItem/SwipeableItem.js.map +1 -0
  179. package/src/components/SwipeableItem/SwipeableItemButton.js +6 -0
  180. package/src/components/SwipeableItem/SwipeableItemButton.js.map +1 -0
  181. package/src/components/SwipeableItem/SwipeableItemCommon.js +44 -0
  182. package/src/components/SwipeableItem/SwipeableItemCommon.js.map +1 -0
  183. package/src/components/SwipeableItem/SwipeableList.js +29 -0
  184. package/src/components/SwipeableItem/SwipeableList.js.map +1 -0
  185. package/src/components/SwipeableItem/index.js +4 -0
  186. package/src/components/SwipeableItem/index.js.map +1 -0
  187. package/src/components/Swiper/Swiper.js +74 -0
  188. package/src/components/Swiper/Swiper.js.map +1 -0
  189. package/src/components/Swiper/SwiperItem.js +10 -0
  190. package/src/components/Swiper/SwiperItem.js.map +1 -0
  191. package/src/components/Swiper/index.js +3 -0
  192. package/src/components/Swiper/index.js.map +1 -0
  193. package/src/components/Switch.js +57 -0
  194. package/src/components/Switch.js.map +1 -0
  195. package/src/components/TabView/TabView.js +55 -0
  196. package/src/components/TabView/TabView.js.map +1 -0
  197. package/src/components/TabView/TabViewItem.js +12 -0
  198. package/src/components/TabView/TabViewItem.js.map +1 -0
  199. package/src/components/TabView/index.js +3 -0
  200. package/src/components/TabView/index.js.map +1 -0
  201. package/src/components/Table/Table.js +94 -0
  202. package/src/components/Table/Table.js.map +1 -0
  203. package/src/components/Table/TableCell.js +34 -0
  204. package/src/components/Table/TableCell.js.map +1 -0
  205. package/src/components/Table/TableCommon.js +13 -0
  206. package/src/components/Table/TableCommon.js.map +1 -0
  207. package/src/components/Table/TableRow.js +40 -0
  208. package/src/components/Table/TableRow.js.map +1 -0
  209. package/src/components/Table/index.js +4 -0
  210. package/src/components/Table/index.js.map +1 -0
  211. package/src/components/Text.js +34 -0
  212. package/src/components/Text.js.map +1 -0
  213. package/src/components/TextField.js +430 -0
  214. package/src/components/TextField.js.map +1 -0
  215. package/src/components/TextInput.js +15 -0
  216. package/src/components/TextInput.js.map +1 -0
  217. package/src/components/Touchable.js +13 -0
  218. package/src/components/Touchable.js.map +1 -0
  219. package/src/components/Touchable.web.js +3 -0
  220. package/src/components/Touchable.web.js.map +1 -0
  221. package/src/components/Typography.js +37 -0
  222. package/src/components/Typography.js.map +1 -0
  223. package/src/components/YoutubePlayer/YoutubePlayer.js +21 -0
  224. package/src/components/YoutubePlayer/YoutubePlayer.js.map +1 -0
  225. package/src/components/YoutubePlayer/YoutubePlayer.native.js +10 -0
  226. package/src/components/YoutubePlayer/YoutubePlayer.native.js.map +1 -0
  227. package/src/components/YoutubePlayer/YoutubePlayerProps.js +2 -0
  228. package/src/components/YoutubePlayer/YoutubePlayerProps.js.map +1 -0
  229. package/src/components/YoutubePlayer/index.js +2 -0
  230. package/src/components/YoutubePlayer/index.js.map +1 -0
  231. package/src/components/useAuthState.js +35 -0
  232. package/src/components/useAuthState.js.map +1 -0
  233. package/src/constants.js +11 -0
  234. package/src/constants.js.map +1 -0
  235. package/src/deprecated-components/AccordionItem.js +36 -0
  236. package/src/deprecated-components/AccordionItem.js.map +1 -0
  237. package/src/deprecated-components/AnimatedCircularProgress.js +47 -0
  238. package/src/deprecated-components/AnimatedCircularProgress.js.map +1 -0
  239. package/src/deprecated-components/AvatarEdit.js +34 -0
  240. package/src/deprecated-components/AvatarEdit.js.map +1 -0
  241. package/src/deprecated-components/Banner.js +113 -0
  242. package/src/deprecated-components/Banner.js.map +1 -0
  243. package/src/deprecated-components/Card.js +61 -0
  244. package/src/deprecated-components/Card.js.map +1 -0
  245. package/src/deprecated-components/CheckboxGroup.js +25 -0
  246. package/src/deprecated-components/CheckboxGroup.js.map +1 -0
  247. package/src/deprecated-components/CircleImage.js +12 -0
  248. package/src/deprecated-components/CircleImage.js.map +1 -0
  249. package/src/deprecated-components/CircularProgress.js +85 -0
  250. package/src/deprecated-components/CircularProgress.js.map +1 -0
  251. package/src/deprecated-components/Container.js +47 -0
  252. package/src/deprecated-components/Container.js.map +1 -0
  253. package/src/deprecated-components/DeprecatedButton.js +87 -0
  254. package/src/deprecated-components/DeprecatedButton.js.map +1 -0
  255. package/src/deprecated-components/DeprecatedCardWrapper.js +22 -0
  256. package/src/deprecated-components/DeprecatedCardWrapper.js.map +1 -0
  257. package/src/deprecated-components/DeprecatedFAB.js +118 -0
  258. package/src/deprecated-components/DeprecatedFAB.js.map +1 -0
  259. package/src/deprecated-components/FAB.js +50 -0
  260. package/src/deprecated-components/FAB.js.map +1 -0
  261. package/src/deprecated-components/FieldSearchBarFull.js +57 -0
  262. package/src/deprecated-components/FieldSearchBarFull.js.map +1 -0
  263. package/src/deprecated-components/Layout.js +69 -0
  264. package/src/deprecated-components/Layout.js.map +1 -0
  265. package/src/deprecated-components/ProgressBar.js +122 -0
  266. package/src/deprecated-components/ProgressBar.js.map +1 -0
  267. package/src/deprecated-components/ProgressCircle.js +17 -0
  268. package/src/deprecated-components/ProgressCircle.js.map +1 -0
  269. package/src/deprecated-components/RadioButtonFieldGroup.js +21 -0
  270. package/src/deprecated-components/RadioButtonFieldGroup.js.map +1 -0
  271. package/src/deprecated-components/RowBodyIcon.js +12 -0
  272. package/src/deprecated-components/RowBodyIcon.js.map +1 -0
  273. package/src/deprecated-components/RowHeadlineImageCaption.js +16 -0
  274. package/src/deprecated-components/RowHeadlineImageCaption.js.map +1 -0
  275. package/src/deprecated-components/RowHeadlineImageIcon.js +18 -0
  276. package/src/deprecated-components/RowHeadlineImageIcon.js.map +1 -0
  277. package/src/deprecated-components/ToggleButton.js +43 -0
  278. package/src/deprecated-components/ToggleButton.js.map +1 -0
  279. package/src/hooks.js +25 -0
  280. package/src/hooks.js.map +1 -0
  281. package/src/index.js +66 -0
  282. package/src/index.js.map +1 -0
  283. package/src/interfaces/Icon.js +9 -0
  284. package/src/interfaces/Icon.js.map +1 -0
  285. package/src/styles/DarkTheme.js +27 -0
  286. package/src/styles/DarkTheme.js.map +1 -0
  287. package/src/styles/DefaultTheme.js +112 -0
  288. package/src/styles/DefaultTheme.js.map +1 -0
  289. package/src/styles/fonts.js +63 -0
  290. package/src/styles/fonts.js.map +1 -0
  291. package/src/styles/overlay.js +61 -0
  292. package/src/styles/overlay.js.map +1 -0
  293. package/src/styles/shadow.js +52 -0
  294. package/src/styles/shadow.js.map +1 -0
  295. package/src/theming.js +4 -0
  296. package/src/theming.js.map +1 -0
  297. package/src/utilities.js +180 -0
  298. package/src/utilities.js.map +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Elevation.js","sourceRoot":"","sources":["Elevation.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EACL,QAAQ,EACR,UAAU,EAIV,IAAI,GACL,MAAM,cAAc,CAAC;AACtB,OAAO,MAAM,MAAM,kBAAkB,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAQvC,mHAAmH;AACnH,MAAM,SAAS,GAA6C,CAAC,EAC3D,KAAK,EACL,KAAK,EACL,QAAQ,EACR,GAAG,IAAI,EACR,EAAE,EAAE;IACH,MAAM,EAAE,SAAS,GAAG,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,GAC3C,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IAClC,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;IACzB,MAAM,YAAY,GAAG,MAAM,CAAC;IAE5B,OAAO,CACL,oBAAC,QAAQ,CAAC,IAAI,OACR,IAAI,EACR,KAAK,EAAE;YACL;gBACE,YAAY;gBACZ,eAAe,EAAE,MAAM,CAAC,OAAO;aAChC;YACD,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI;YACpC,KAAK;SACN;QAED,oBAAC,IAAI,IAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,IAAG,QAAQ,CAAQ,CACtD,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC,SAAS,CAAC,CAAC"}
@@ -0,0 +1,20 @@
1
+ import * as React from "react";
2
+ import { Text, StyleSheet } from "react-native";
3
+ import { extractStyles } from "../utilities";
4
+ import Touchable from "./Touchable";
5
+ export default function FormRow({ disabled, direction, children, label, style, onPress, ...rest }) {
6
+ const { textStyles, viewStyles } = extractStyles(style);
7
+ return (React.createElement(Touchable, { disabled: disabled, onPress: onPress, style: [styles.row, { flexDirection: direction }, viewStyles], ...rest },
8
+ React.createElement(Text, { style: textStyles }, label),
9
+ children));
10
+ }
11
+ const styles = StyleSheet.create({
12
+ row: {
13
+ marginLeft: 8,
14
+ marginRight: 8,
15
+ flexDirection: "row",
16
+ justifyContent: "space-between",
17
+ alignItems: "center",
18
+ },
19
+ });
20
+ //# sourceMappingURL=FormRow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormRow.js","sourceRoot":"","sources":["FormRow.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,IAAI,EAAwB,UAAU,EAAE,MAAM,cAAc,CAAC;AAEtE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,SAAS,MAAM,aAAa,CAAC;AAWpC,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,QAAQ,EACR,KAAK,EACL,KAAK,EACL,OAAO,EACP,GAAG,IAAI,EACD;IACN,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IACxD,OAAO,CACL,oBAAC,SAAS,IACR,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,SAAS,EAAE,EAAE,UAAU,CAAC,KACzD,IAAI;QAER,oBAAC,IAAI,IAAC,KAAK,EAAE,UAAU,IAAG,KAAK,CAAQ;QACtC,QAAQ,CACC,CACb,CAAC;AACJ,CAAC;AAED,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,GAAG,EAAE;QACH,UAAU,EAAE,CAAC;QACb,WAAW,EAAE,CAAC;QACd,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,eAAe;QAC/B,UAAU,EAAE,QAAQ;KACrB;CACF,CAAC,CAAC"}
@@ -0,0 +1,36 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet, ActivityIndicator, Pressable, Platform, } from "react-native";
3
+ import { withTheme } from "../theming";
4
+ const IconButton = ({ Icon, icon, color: customColor, size = 32, disabled, loading = false, onPress, theme, style, activeOpacity = 0.8, disabledOpacity = 0.8, ...props }) => {
5
+ const iconColor = customColor || theme.colors.primary;
6
+ return (React.createElement(Pressable, { onPress: onPress, disabled: disabled || loading, style: ({ pressed }) => {
7
+ return [
8
+ styles.container,
9
+ {
10
+ opacity: pressed ? activeOpacity : disabled ? disabledOpacity : 1,
11
+ width: size,
12
+ height: size,
13
+ alignItems: "center",
14
+ justifyContent: "center",
15
+ },
16
+ style,
17
+ ];
18
+ }, ...props },
19
+ React.createElement(View, null,
20
+ icon && !loading ? (React.createElement(Icon, { name: icon, size: size - 2, color: iconColor })) : null,
21
+ loading ? React.createElement(ActivityIndicator, { size: "small", color: iconColor }) : null)));
22
+ };
23
+ const styles = StyleSheet.create({
24
+ container: {
25
+ alignItems: "center",
26
+ justifyContent: "center",
27
+ ...Platform.select({
28
+ web: {
29
+ cursor: "pointer",
30
+ userSelect: "none",
31
+ },
32
+ }),
33
+ },
34
+ });
35
+ export default withTheme(IconButton);
36
+ //# sourceMappingURL=IconButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconButton.js","sourceRoot":"","sources":["IconButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EACL,IAAI,EACJ,UAAU,EACV,iBAAiB,EAGjB,SAAS,EAET,QAAQ,GACT,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAkBvC,MAAM,UAAU,GAA6C,CAAC,EAC5D,IAAI,EACJ,IAAI,EACJ,KAAK,EAAE,WAAW,EAClB,IAAI,GAAG,EAAE,EACT,QAAQ,EACR,OAAO,GAAG,KAAK,EACf,OAAO,EACP,KAAK,EACL,KAAK,EACL,aAAa,GAAG,GAAG,EACnB,eAAe,GAAG,GAAG,EACrB,GAAG,KAAK,EACT,EAAE,EAAE;IACH,MAAM,SAAS,GAAG,WAAW,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;IAEtD,OAAO,CACL,oBAAC,SAAS,IACR,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,IAAI,OAAO,EAC7B,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;YACrB,OAAO;gBACL,MAAM,CAAC,SAAS;gBAChB;oBACE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;oBACjE,KAAK,EAAE,IAAI;oBACX,MAAM,EAAE,IAAI;oBACZ,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;iBACzB;gBACD,KAAK;aACN,CAAC;QACJ,CAAC,KACG,KAAK;QAET,oBAAC,IAAI;YACF,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAClB,oBAAC,IAAI,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,EAAE,KAAK,EAAE,SAAS,GAAI,CACvD,CAAC,CAAC,CAAC,IAAI;YACP,OAAO,CAAC,CAAC,CAAC,oBAAC,iBAAiB,IAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAE,SAAS,GAAI,CAAC,CAAC,CAAC,IAAI,CACjE,CACG,CACb,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,SAAS,EAAE;QACT,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,GAAG,QAAQ,CAAC,MAAM,CAAC;YACjB,GAAG,EAAE;gBACH,MAAM,EAAE,SAAS;gBACjB,UAAU,EAAE,MAAM;aACnB;SACF,CAAC;KACH;CACF,CAAC,CAAC;AAEH,eAAe,SAAS,CAAC,UAAU,CAAC,CAAC"}
@@ -0,0 +1,48 @@
1
+ /* README: Internal Image component used for stuff like Card. DO NOT EXPORT! */
2
+ import React from "react";
3
+ import { Image as NativeImage, StyleSheet, } from "react-native";
4
+ import Config from "./Config";
5
+ import AspectRatio from "./AspectRatio";
6
+ const generateDimensions = ({ aspectRatio, width, height }) => {
7
+ if (aspectRatio && !width && !height) {
8
+ return {
9
+ aspectRatio,
10
+ width: "100%",
11
+ };
12
+ }
13
+ if (aspectRatio && height) {
14
+ return {
15
+ aspectRatio,
16
+ height,
17
+ width: aspectRatio * height,
18
+ };
19
+ }
20
+ if (aspectRatio && width) {
21
+ return {
22
+ aspectRatio,
23
+ width,
24
+ height: width / aspectRatio,
25
+ };
26
+ }
27
+ return { width, height };
28
+ };
29
+ const Image = ({ source, resizeMode = "cover", style, ...props }) => {
30
+ let imageSource = source === null || source === undefined
31
+ ? Config.placeholderImageURL
32
+ : source;
33
+ const styles = StyleSheet.flatten(style || {});
34
+ const { aspectRatio, width, height } = generateDimensions(styles);
35
+ if (aspectRatio) {
36
+ return (React.createElement(AspectRatio, { style: [style, { width, height, aspectRatio }] },
37
+ React.createElement(NativeImage, { ...props, source: imageSource, resizeMode: resizeMode, style: [
38
+ style,
39
+ {
40
+ height: "100%",
41
+ width: "100%",
42
+ },
43
+ ] })));
44
+ }
45
+ return (React.createElement(NativeImage, { ...props, source: source, resizeMode: resizeMode, style: style }));
46
+ };
47
+ export default Image;
48
+ //# sourceMappingURL=Image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Image.js","sourceRoot":"","sources":["Image.tsx"],"names":[],"mappings":"AAAA,+EAA+E;AAC/E,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EACL,KAAK,IAAI,WAAW,EAEpB,UAAU,GAEX,MAAM,cAAc,CAAC;AACtB,OAAO,MAAM,MAAM,UAAU,CAAC;AAE9B,OAAO,WAAW,MAAM,eAAe,CAAC;AAQxC,MAAM,kBAAkB,GAAG,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAkB,EAAE,EAAE;IAC5E,IAAI,WAAW,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,EAAE;QACpC,OAAO;YACL,WAAW;YACX,KAAK,EAAE,MAAM;SACd,CAAC;KACH;IAED,IAAI,WAAW,IAAI,MAAM,EAAE;QACzB,OAAO;YACL,WAAW;YACX,MAAM;YACN,KAAK,EAAE,WAAW,GAAG,MAAM;SAC5B,CAAC;KACH;IAED,IAAI,WAAW,IAAI,KAAK,EAAE;QACxB,OAAO;YACL,WAAW;YACX,KAAK;YACL,MAAM,EAAE,KAAK,GAAG,WAAW;SAC5B,CAAC;KACH;IAED,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,KAAK,GAAyB,CAAC,EACnC,MAAM,EACN,UAAU,GAAG,OAAO,EACpB,KAAK,EACL,GAAG,KAAK,EACT,EAAE,EAAE;IACH,IAAI,WAAW,GACb,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS;QACrC,CAAC,CAAC,MAAM,CAAC,mBAAmB;QAC5B,CAAC,CAAC,MAAM,CAAC;IAEb,MAAM,MAAM,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IAC/C,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,kBAAkB,CACvD,MAAwB,CACzB,CAAC;IAEF,IAAI,WAAW,EAAE;QACf,OAAO,CACL,oBAAC,WAAW,IAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;YACzD,oBAAC,WAAW,OACN,KAAK,EACT,MAAM,EAAE,WAAkC,EAC1C,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE;oBACL,KAAK;oBACL;wBACE,MAAM,EAAE,MAAM;wBACd,KAAK,EAAE,MAAM;qBACd;iBACF,GACD,CACU,CACf,CAAC;KACH;IAED,OAAO,CACL,oBAAC,WAAW,OACN,KAAK,EACT,MAAM,EAAE,MAA6B,EACrC,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,GACZ,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { View } from "react-native";
3
+ const AspectRatio = ({ aspectRatio = 1, style, ...rest }) => {
4
+ return React.createElement(View, { ...rest, style: [{ aspectRatio }, style] });
5
+ };
6
+ export default AspectRatio;
7
+ //# sourceMappingURL=AspectRatio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AspectRatio.js","sourceRoot":"","sources":["AspectRatio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAa,MAAM,cAAc,CAAC;AAM/C,MAAM,WAAW,GAA+B,CAAC,EAC/C,WAAW,GAAG,CAAC,EACf,KAAK,EACL,GAAG,IAAI,EACR,EAAE,EAAE;IACH,OAAO,oBAAC,IAAI,OAAK,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,WAAW,EAAE,EAAE,KAAK,CAAC,GAAI,CAAC;AAC7D,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ import { convertBackwardCompatiblePropsToStyle } from "./LayoutCommon";
4
+ const Center = ({ style, ...rest }) => {
5
+ const backwardsCompatibleStyle = convertBackwardCompatiblePropsToStyle(rest);
6
+ return (React.createElement(View, { ...rest, style: [styles.center, backwardsCompatibleStyle, style] }));
7
+ };
8
+ const styles = StyleSheet.create({
9
+ center: {
10
+ alignItems: "center",
11
+ justifyContent: "center",
12
+ },
13
+ });
14
+ export default Center;
15
+ //# sourceMappingURL=Center.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Center.js","sourceRoot":"","sources":["Center.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAa,UAAU,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,qCAAqC,EAAE,MAAM,gBAAgB,CAAC;AAEvE,MAAM,MAAM,GAAwB,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACzD,MAAM,wBAAwB,GAAG,qCAAqC,CAAC,IAAI,CAAC,CAAC;IAC7E,OAAO,CACL,oBAAC,IAAI,OAAK,IAAI,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,wBAAwB,EAAE,KAAK,CAAC,GAAI,CAC5E,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;KACzB;CACF,CAAC,CAAC;AAEH,eAAe,MAAM,CAAC"}
@@ -0,0 +1,16 @@
1
+ import React from "react";
2
+ import { StyleSheet } from "react-native";
3
+ import Square from "./Square";
4
+ import { pick } from "lodash";
5
+ import { convertBackwardCompatiblePropsToStyle } from "./LayoutCommon";
6
+ const Circle = ({ size, style, ...rest }) => {
7
+ const backwardsCompatibleStyle = pick(convertBackwardCompatiblePropsToStyle(rest), "backgroundColor");
8
+ return (React.createElement(Square, { ...rest, size: size, style: [backwardsCompatibleStyle, style, styles.circle] }));
9
+ };
10
+ const styles = StyleSheet.create({
11
+ circle: {
12
+ borderRadius: 1000, // Border radius maxes out as a circle, use an overly large number to ensure circle in all cases
13
+ },
14
+ });
15
+ export default Circle;
16
+ //# sourceMappingURL=Circle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Circle.js","sourceRoot":"","sources":["Circle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAa,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,qCAAqC,EAAE,MAAM,gBAAgB,CAAC;AAMvE,MAAM,MAAM,GAA0B,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACjE,MAAM,wBAAwB,GAAG,IAAI,CACnC,qCAAqC,CAAC,IAAI,CAAC,EAC3C,iBAAiB,CAClB,CAAC;IAEF,OAAO,CACL,oBAAC,MAAM,OACD,IAAI,EACR,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,CAAC,wBAAwB,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,GACvD,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,YAAY,EAAE,IAAI,EAAE,gGAAgG;KACrH;CACF,CAAC,CAAC;AAEH,eAAe,MAAM,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ const HStack = ({ style, ...rest }) => {
4
+ return React.createElement(View, { ...rest, style: [styles.hStack, style] });
5
+ };
6
+ const styles = StyleSheet.create({
7
+ hStack: {
8
+ flexDirection: "row",
9
+ },
10
+ });
11
+ export default HStack;
12
+ //# sourceMappingURL=HStack.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HStack.js","sourceRoot":"","sources":["HStack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAa,UAAU,EAAE,MAAM,cAAc,CAAC;AAE3D,MAAM,MAAM,GAAwB,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACzD,OAAO,oBAAC,IAAI,OAAK,IAAI,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAI,CAAC;AAC3D,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,aAAa,EAAE,KAAK;KACrB;CACF,CAAC,CAAC;AAEH,eAAe,MAAM,CAAC"}
@@ -0,0 +1,8 @@
1
+ export function convertBackwardCompatiblePropsToStyle(props) {
2
+ return {
3
+ width: props.width,
4
+ height: props.height,
5
+ backgroundColor: props.bgColor,
6
+ };
7
+ }
8
+ //# sourceMappingURL=LayoutCommon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LayoutCommon.js","sourceRoot":"","sources":["LayoutCommon.ts"],"names":[],"mappings":"AAgBA,MAAM,UAAU,qCAAqC,CACnD,KAA2C;IAE3C,OAAO;QACL,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,eAAe,EAAE,KAAK,CAAC,OAAO;KAC/B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+ import { View } from "react-native";
3
+ const Spacer = ({ top = 8, right = 8, bottom = 8, left = 8, style, }) => {
4
+ return (React.createElement(View, { style: [
5
+ style,
6
+ {
7
+ paddingRight: right,
8
+ paddingTop: top,
9
+ paddingLeft: left,
10
+ paddingBottom: bottom,
11
+ },
12
+ ] }));
13
+ };
14
+ export default Spacer;
15
+ //# sourceMappingURL=Spacer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Spacer.js","sourceRoot":"","sources":["Spacer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAwB,MAAM,cAAc,CAAC;AAU1D,MAAM,MAAM,GAA0B,CAAC,EACrC,GAAG,GAAG,CAAC,EACP,KAAK,GAAG,CAAC,EACT,MAAM,GAAG,CAAC,EACV,IAAI,GAAG,CAAC,EACR,KAAK,GACN,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,IAAI,IACH,KAAK,EAAE;YACL,KAAK;YACL;gBACE,YAAY,EAAE,KAAK;gBACnB,UAAU,EAAE,GAAG;gBACf,WAAW,EAAE,IAAI;gBACjB,aAAa,EAAE,MAAM;aACtB;SACF,GACD,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,MAAM,CAAC"}
@@ -0,0 +1,25 @@
1
+ import React from "react";
2
+ import Center from "./Center";
3
+ import { pick } from "lodash";
4
+ import { convertBackwardCompatiblePropsToStyle } from "./LayoutCommon";
5
+ const Square = ({ size, style, onLayout, ...rest }) => {
6
+ const [calculatedSize, setCalculatedSize] = React.useState(0);
7
+ const backwardsCompatibleStyle = pick(convertBackwardCompatiblePropsToStyle(rest), "backgroundColor");
8
+ return (React.createElement(Center, { onLayout: (e) => {
9
+ const layout = e.nativeEvent.layout;
10
+ setCalculatedSize(Math.max(layout.width, layout.height));
11
+ onLayout === null || onLayout === void 0 ? void 0 : onLayout(e);
12
+ }, ...rest, style: [
13
+ backwardsCompatibleStyle,
14
+ style,
15
+ size != undefined ? { width: size, height: size } : {},
16
+ calculatedSize > 0
17
+ ? {
18
+ width: calculatedSize,
19
+ height: calculatedSize,
20
+ }
21
+ : {},
22
+ ] }));
23
+ };
24
+ export default Square;
25
+ //# sourceMappingURL=Square.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Square.js","sourceRoot":"","sources":["Square.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,qCAAqC,EAAE,MAAM,gBAAgB,CAAC;AAMvE,MAAM,MAAM,GAA0B,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IAC3E,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC9D,MAAM,wBAAwB,GAAG,IAAI,CACnC,qCAAqC,CAAC,IAAI,CAAC,EAC3C,iBAAiB,CAClB,CAAC;IAEF,OAAO,CACL,oBAAC,MAAM,IACL,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE;YACd,MAAM,MAAM,GAAG,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC;YACpC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;YACzD,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,CAAC,CAAC,CAAC;QAChB,CAAC,KACG,IAAI,EACR,KAAK,EAAE;YACL,wBAAwB;YACxB,KAAK;YACL,IAAI,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE;YACtD,cAAc,GAAG,CAAC;gBAChB,CAAC,CAAC;oBACE,KAAK,EAAE,cAAc;oBACrB,MAAM,EAAE,cAAc;iBACvB;gBACH,CAAC,CAAC,EAAE;SACP,GACD,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,MAAM,CAAC"}
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ const VStack = ({ style, ...rest }) => {
4
+ return React.createElement(View, { ...rest, style: [styles.vStack, style] });
5
+ };
6
+ const styles = StyleSheet.create({
7
+ vStack: {
8
+ flexDirection: "column",
9
+ },
10
+ });
11
+ export default VStack;
12
+ //# sourceMappingURL=VStack.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VStack.js","sourceRoot":"","sources":["VStack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAa,UAAU,EAAE,MAAM,cAAc,CAAC;AAE3D,MAAM,MAAM,GAAwB,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACzD,OAAO,oBAAC,IAAI,OAAK,IAAI,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAI,CAAC;AAC3D,CAAC,CAAC;AAEF,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,aAAa,EAAE,QAAQ;KACxB;CACF,CAAC,CAAC;AAEH,eAAe,MAAM,CAAC"}
@@ -0,0 +1,20 @@
1
+ import React from "react";
2
+ import { View } from "react-native";
3
+ const ZStack = ({ reversed, children, ...rest }) => {
4
+ const absoluteChildren = React.useMemo(() => {
5
+ let childrenArray = React.Children.toArray(children);
6
+ if (reversed) {
7
+ childrenArray = childrenArray.reverse();
8
+ }
9
+ return childrenArray.map((child, index) => {
10
+ const props = child.props || {};
11
+ return React.cloneElement(child, {
12
+ ...props,
13
+ style: { position: "absolute", zIndex: index + 1, ...props.style },
14
+ }, props.children);
15
+ });
16
+ }, [children, reversed]);
17
+ return React.createElement(View, { ...rest }, absoluteChildren);
18
+ };
19
+ export default ZStack;
20
+ //# sourceMappingURL=ZStack.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ZStack.js","sourceRoot":"","sources":["ZStack.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,IAAI,EAAa,MAAM,cAAc,CAAC;AAM/C,MAAM,MAAM,GAA0B,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE;IACxE,MAAM,gBAAgB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC1C,IAAI,aAAa,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CACxC,QAAQ,CACe,CAAC;QAE1B,IAAI,QAAQ,EAAE;YACZ,aAAa,GAAG,aAAa,CAAC,OAAO,EAAE,CAAC;SACzC;QAED,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;YAChC,OAAO,KAAK,CAAC,YAAY,CACvB,KAAK,EACL;gBACE,GAAG,KAAK;gBACR,KAAK,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,KAAK,CAAC,KAAK,EAAE;aACnE,EACD,KAAK,CAAC,QAAQ,CACf,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;IAEzB,OAAO,oBAAC,IAAI,OAAK,IAAI,IAAG,gBAAgB,CAAQ,CAAC;AACnD,CAAC,CAAC;AAEF,eAAe,MAAM,CAAC"}
@@ -0,0 +1,9 @@
1
+ export { default as AspectRatio } from "./AspectRatio";
2
+ export { default as Circle } from "./Circle";
3
+ export { default as Center } from "./Center";
4
+ export { default as HStack } from "./HStack";
5
+ export { default as VStack } from "./VStack";
6
+ export { default as ZStack } from "./ZStack";
7
+ export { default as Spacer } from "./Spacer";
8
+ export { default as Square } from "./Square";
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC"}
@@ -0,0 +1,11 @@
1
+ import * as React from "react";
2
+ import { StyleSheet } from "react-native";
3
+ import MarkdownComponent from "react-native-markdown-display";
4
+ const Markdown = ({ children, style, }) => {
5
+ return (
6
+ //'body' style applies to all markdown components
7
+ //@ts-ignore TS does not like the type of this named style for some reason
8
+ React.createElement(MarkdownComponent, { style: { body: StyleSheet.flatten(style) } }, children));
9
+ };
10
+ export default Markdown;
11
+ //# sourceMappingURL=Markdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Markdown.js","sourceRoot":"","sources":["Markdown.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAwB,UAAU,EAAE,MAAM,cAAc,CAAC;AAChE,OAAO,iBAAiB,MAAM,+BAA+B,CAAC;AAM9D,MAAM,QAAQ,GAAqD,CAAC,EAClE,QAAQ,EACR,KAAK,GACN,EAAE,EAAE;IACH,OAAO;IACL,iDAAiD;IACjD,0EAA0E;IAC1E,oBAAC,iBAAiB,IAAC,KAAK,EAAE,EAAE,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,IAC1D,QAAQ,CACS,CACrB,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=AudioPlayerCommon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AudioPlayerCommon.js","sourceRoot":"","sources":["AudioPlayerCommon.ts"],"names":[],"mappings":""}
@@ -0,0 +1,126 @@
1
+ import * as React from "react";
2
+ import { Text, View, StyleSheet } from "react-native";
3
+ import { AntDesign } from "@expo/vector-icons";
4
+ import { withTheme } from "../../../theming";
5
+ import Slider from "@react-native-community/slider";
6
+ import HeadlessAudioPlayer from "./HeadlessAudioPlayer";
7
+ import Pressable from "../../Pressable";
8
+ /**
9
+ * Built on top of HeadlessAudioPlayer to provide a simple interface for playing audio
10
+ */
11
+ const AudioPlayerWithInterface = React.forwardRef(({ style, theme, thumbColor = theme.colors.primary, completedTrackColor = theme.colors.primary, remainingTrackColor = theme.colors.divider, togglePlaybackIconSize = 24, togglePlaybackIconColor = theme.colors.primary, onPlaybackStatusUpdate: onPlaybackStatusUpdateProp, onPlaybackFinish: onPlaybackFinishProp, hidePlaybackIcon = false, hideDuration = false, hideSlider = false, ...rest }, ref) => {
12
+ const [isPlaying, setIsPlaying] = React.useState(false);
13
+ const [isLoading, setIsLoading] = React.useState(false);
14
+ const [durationMillis, setDurationMillis] = React.useState(1);
15
+ const [isDraggingSlider, setIsDraggingSlider] = React.useState(false);
16
+ const [sliderPositionMillis, setSliderPositionMillis] = React.useState(0);
17
+ const newHeadlessAudioPlayerRef = React.useRef(null);
18
+ // Use the provided ref or default to new ref when not provided
19
+ const headlessAudioPlayerRef = ref
20
+ ? ref
21
+ : newHeadlessAudioPlayerRef;
22
+ const { color, fontFamily, fontWeight, fontSize, lineHeight, letterSpacing, textTransform, textAlign, textDecorationLine, textDecorationColor, textDecorationStyle, ...viewStyles } = StyleSheet.flatten(style || {});
23
+ const textStyles = {
24
+ color,
25
+ fontFamily,
26
+ fontWeight,
27
+ fontSize,
28
+ lineHeight,
29
+ letterSpacing,
30
+ textTransform,
31
+ textAlign,
32
+ textDecorationLine,
33
+ textDecorationColor,
34
+ textDecorationStyle,
35
+ };
36
+ const onPlaybackStatusUpdate = (status) => {
37
+ setIsLoading(status.isLoading);
38
+ setDurationMillis(status.durationMillis);
39
+ setSliderPositionMillis(status.currentPositionMillis);
40
+ setIsPlaying(status.isPlaying);
41
+ onPlaybackStatusUpdateProp === null || onPlaybackStatusUpdateProp === void 0 ? void 0 : onPlaybackStatusUpdateProp(status);
42
+ };
43
+ const onPlaybackFinish = () => {
44
+ var _a, _b;
45
+ setIsPlaying(false);
46
+ setSliderPositionMillis(0);
47
+ (_a = headlessAudioPlayerRef.current) === null || _a === void 0 ? void 0 : _a.togglePlayback();
48
+ (_b = headlessAudioPlayerRef.current) === null || _b === void 0 ? void 0 : _b.seekToPosition(0);
49
+ onPlaybackFinishProp === null || onPlaybackFinishProp === void 0 ? void 0 : onPlaybackFinishProp();
50
+ };
51
+ const onSlidingComplete = (sliderValue) => {
52
+ var _a;
53
+ if (isDraggingSlider) {
54
+ setIsDraggingSlider(false);
55
+ }
56
+ (_a = headlessAudioPlayerRef.current) === null || _a === void 0 ? void 0 : _a.seekToPosition(sliderValue);
57
+ };
58
+ const onSliderChange = () => {
59
+ if (!isDraggingSlider) {
60
+ setIsDraggingSlider(true);
61
+ }
62
+ };
63
+ let iconName;
64
+ if (isLoading) {
65
+ iconName = "loading1";
66
+ }
67
+ else if (isPlaying) {
68
+ iconName = "pause";
69
+ }
70
+ else {
71
+ iconName = "play";
72
+ }
73
+ return (React.createElement(React.Fragment, null,
74
+ React.createElement(HeadlessAudioPlayer, { ...rest, ref: headlessAudioPlayerRef, onPlaybackStatusUpdate: onPlaybackStatusUpdate, onPlaybackFinish: onPlaybackFinish }),
75
+ React.createElement(View, { testID: "audio-player-interface", style: [
76
+ {
77
+ backgroundColor: theme.colors.background,
78
+ borderColor: theme.colors.divider,
79
+ },
80
+ styles.container,
81
+ viewStyles,
82
+ ] },
83
+ !hidePlaybackIcon && (React.createElement(Pressable, { testID: "audio-player-playback-icon", onPress: () => { var _a; return (_a = headlessAudioPlayerRef.current) === null || _a === void 0 ? void 0 : _a.togglePlayback(); }, style: styles.spacingEnd },
84
+ React.createElement(AntDesign, { name: iconName, size: togglePlaybackIconSize, color: togglePlaybackIconColor }))),
85
+ !hideDuration && (React.createElement(Text, { testID: "audio-player-duration", style: [
86
+ { color: theme.colors.strong },
87
+ styles.spacingEnd,
88
+ { ...textStyles },
89
+ ] },
90
+ formatDuration(sliderPositionMillis !== null && sliderPositionMillis !== void 0 ? sliderPositionMillis : 0),
91
+ " /",
92
+ " ",
93
+ formatDuration(durationMillis || 0))),
94
+ !hideSlider && (React.createElement(Slider, { testID: "audio-player-slider", style: styles.slider, minimumTrackTintColor: completedTrackColor, maximumTrackTintColor: remainingTrackColor, thumbTintColor: thumbColor, minimumValue: 0, value: sliderPositionMillis, maximumValue: durationMillis, onValueChange: onSliderChange, onSlidingComplete: onSlidingComplete })))));
95
+ });
96
+ const styles = StyleSheet.create({
97
+ container: {
98
+ padding: 8,
99
+ flexDirection: "row",
100
+ alignItems: "center",
101
+ borderRadius: 8,
102
+ borderWidth: 1,
103
+ },
104
+ spacingEnd: {
105
+ marginEnd: 8,
106
+ },
107
+ slider: {
108
+ flex: 1,
109
+ },
110
+ });
111
+ function formatDuration(duration) {
112
+ if (duration === 0)
113
+ return "00:00";
114
+ const seconds = Math.floor((duration / 1000) % 60);
115
+ const minutes = Math.floor((duration / (1000 * 60)) % 60);
116
+ const hours = Math.floor((duration / (1000 * 60 * 60)) % 24);
117
+ const renderedHours = hours < 10 ? "0" + hours : hours;
118
+ const renderedMinutes = minutes < 10 ? "0" + minutes : minutes;
119
+ const renderedSeconds = seconds < 10 ? "0" + seconds : seconds;
120
+ if (hours > 0) {
121
+ return renderedHours + ":" + renderedMinutes + ":" + renderedSeconds;
122
+ }
123
+ return renderedMinutes + ":" + renderedSeconds;
124
+ }
125
+ export default withTheme(AudioPlayerWithInterface);
126
+ //# sourceMappingURL=AudioPlayerWithInterface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AudioPlayerWithInterface.js","sourceRoot":"","sources":["AudioPlayerWithInterface.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,93 @@
1
+ import * as React from "react";
2
+ import { Audio, InterruptionModeIOS, InterruptionModeAndroid, } from "expo-av";
3
+ import { mapToMediaPlayerStatus } from "../MediaPlayerCommon";
4
+ import MediaPlaybackWrapper from "../MediaPlaybackWrapper";
5
+ /**
6
+ * Audio Player component without an interface (UI).
7
+ * Only handles playing of the audio and provides callbacks and ref functions
8
+ */
9
+ const HeadlessAudioPlayer = React.forwardRef(({ source, interruptionMode = "lower volume", playsInBackground = false, playsInSilentModeIOS = false, playThroughEarpieceAndroid = false, onPlaybackStatusUpdate: onPlaybackStatusUpdateProp, onPlaybackFinish, }, ref) => {
10
+ const [currentSound, setCurrentSound] = React.useState();
11
+ const [isPlaying, setIsPlaying] = React.useState(false);
12
+ const updateAudioMode = React.useCallback(async () => {
13
+ try {
14
+ await Audio.setAudioModeAsync({
15
+ staysActiveInBackground: playsInBackground,
16
+ interruptionModeIOS: interruptionMode === "lower volume"
17
+ ? InterruptionModeIOS.DuckOthers
18
+ : InterruptionModeIOS.DoNotMix,
19
+ interruptionModeAndroid: interruptionMode === "lower volume"
20
+ ? InterruptionModeAndroid.DuckOthers
21
+ : InterruptionModeAndroid.DoNotMix,
22
+ playsInSilentModeIOS,
23
+ playThroughEarpieceAndroid,
24
+ });
25
+ }
26
+ catch (e) {
27
+ console.error("Failed to set audio mode. interruptionMode, playsInBackground, playsInSilentModeIOS, playThroughEarpieceAndroid might not be set. Failed with", e);
28
+ }
29
+ }, [
30
+ interruptionMode,
31
+ playsInBackground,
32
+ playsInSilentModeIOS,
33
+ playThroughEarpieceAndroid,
34
+ ]);
35
+ const onPlaybackStatusUpdate = (status) => {
36
+ const mappedStatus = mapToMediaPlayerStatus(status);
37
+ onPlaybackStatusUpdateProp === null || onPlaybackStatusUpdateProp === void 0 ? void 0 : onPlaybackStatusUpdateProp(mappedStatus);
38
+ if (status.isLoaded) {
39
+ if (status.didJustFinish) {
40
+ onPlaybackFinish === null || onPlaybackFinish === void 0 ? void 0 : onPlaybackFinish();
41
+ }
42
+ setIsPlaying(status.isPlaying);
43
+ }
44
+ };
45
+ const onTogglePlayback = () => {
46
+ //Has to be called everytime a player is played to reconfigure the global Audio config based on each player's configuration
47
+ updateAudioMode();
48
+ };
49
+ const loadAudio = async () => {
50
+ onPlaybackStatusUpdateProp === null || onPlaybackStatusUpdateProp === void 0 ? void 0 : onPlaybackStatusUpdateProp({
51
+ isPlaying: false,
52
+ isLoading: true,
53
+ isBuffering: false,
54
+ currentPositionMillis: 0,
55
+ durationMillis: 0,
56
+ bufferedDurationMillis: 0,
57
+ isError: false,
58
+ });
59
+ const { sound } = await Audio.Sound.createAsync(source);
60
+ setCurrentSound(sound);
61
+ sound.setOnPlaybackStatusUpdate(onPlaybackStatusUpdate);
62
+ };
63
+ useSourceDeepCompareEffect(() => {
64
+ loadAudio();
65
+ // Ignore dependency of loadAudio
66
+ }, [source]);
67
+ return (React.createElement(MediaPlaybackWrapper, { ref: ref, isPlaying: isPlaying, media: currentSound, onTogglePlayback: onTogglePlayback }));
68
+ });
69
+ // The source provided into the AudioPlayer can be of type {uri: "some uri"}
70
+ // In the case that this object is created inline, each rerender provides a new source object because a new object is initialized everytime
71
+ // This creates an issue with being a useEffect dependency
72
+ //
73
+ // This creates variants of useEffect that checks deep equality of 'uri' to determine if dependency changed or not
74
+ // Follows: https://stackoverflow.com/a/54096391
75
+ function sourceDeepCompareEquals(a, b) {
76
+ if ((a === null || a === void 0 ? void 0 : a.uri) && (b === null || b === void 0 ? void 0 : b.uri)) {
77
+ return a.uri === b.uri;
78
+ }
79
+ return a === b;
80
+ }
81
+ function useSourceDeepCompareMemoize(value) {
82
+ const ref = React.useRef();
83
+ if (!sourceDeepCompareEquals(value, ref.current)) {
84
+ ref.current = value;
85
+ }
86
+ return ref.current;
87
+ }
88
+ function useSourceDeepCompareEffect(callback, dependencies) {
89
+ // eslint-disable-next-line react-hooks/exhaustive-deps
90
+ React.useEffect(callback, dependencies.map(useSourceDeepCompareMemoize));
91
+ }
92
+ export default HeadlessAudioPlayer;
93
+ //# sourceMappingURL=HeadlessAudioPlayer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeadlessAudioPlayer.js","sourceRoot":"","sources":["HeadlessAudioPlayer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import * as React from "react";
2
+ import { withTheme } from "../../../theming";
3
+ import HeadlessAudioPlayer from "./HeadlessAudioPlayer";
4
+ import AudioPlayerWithInterface from "./AudioPlayerWithInterface";
5
+ const AudioPlayer = React.forwardRef(({ mode = "interface", ...rest }, ref) => {
6
+ switch (mode) {
7
+ case "headless":
8
+ return React.createElement(HeadlessAudioPlayer, { ref: ref, ...rest });
9
+ case "interface":
10
+ //@ts-ignore Typescript unable to handle nested passing of theme
11
+ return React.createElement(AudioPlayerWithInterface, { ref: ref, ...rest });
12
+ }
13
+ });
14
+ export default withTheme(AudioPlayer);
15
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAK7C,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAOlE,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAGlC,CAAC,EAAE,IAAI,GAAG,WAAW,EAAE,GAAG,IAAI,EAAE,EAAE,GAAG,EAAE,EAAE;IACzC,QAAQ,IAAI,EAAE;QACZ,KAAK,UAAU;YACb,OAAO,oBAAC,mBAAmB,IAAC,GAAG,EAAE,GAAG,KAAM,IAAI,GAAI,CAAC;QACrD,KAAK,WAAW;YACd,gEAAgE;YAChE,OAAO,oBAAC,wBAAwB,IAAC,GAAG,EAAE,GAAG,KAAM,IAAI,GAAI,CAAC;KAC3D;AACH,CAAC,CAAC,CAAC;AAEH,eAAe,SAAS,CAAC,WAAW,CAAC,CAAC"}