@aic-kits/react-native 0.0.2 → 0.0.4

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 (655) hide show
  1. package/lib/auth/components/SocialAuthButton/constants.d.ts +7 -0
  2. package/lib/auth/components/SocialAuthButton/constants.d.ts.map +1 -0
  3. package/lib/auth/components/SocialAuthButton/constants.js +14 -0
  4. package/lib/auth/components/SocialAuthButton/index.d.ts +22 -0
  5. package/lib/auth/components/SocialAuthButton/index.d.ts.map +1 -0
  6. package/lib/auth/components/SocialAuthButton/index.js +37 -0
  7. package/lib/auth/components/SocialSignIn/constants.d.ts +3 -0
  8. package/lib/auth/components/SocialSignIn/constants.d.ts.map +1 -0
  9. package/lib/auth/components/SocialSignIn/constants.js +1 -0
  10. package/lib/auth/components/SocialSignIn/index.d.ts +16 -0
  11. package/lib/auth/components/SocialSignIn/index.d.ts.map +1 -0
  12. package/lib/auth/components/SocialSignIn/index.js +11 -0
  13. package/lib/auth/components/index.d.ts +3 -0
  14. package/lib/auth/components/index.d.ts.map +1 -0
  15. package/lib/auth/components/index.js +2 -0
  16. package/lib/auth/hooks/index.d.ts +2 -0
  17. package/lib/auth/hooks/index.d.ts.map +1 -0
  18. package/lib/auth/hooks/index.js +1 -0
  19. package/lib/auth/hooks/useAuthListener.d.ts +6 -0
  20. package/lib/auth/hooks/useAuthListener.d.ts.map +1 -0
  21. package/lib/auth/hooks/useAuthListener.js +40 -0
  22. package/lib/auth/index.d.ts +7 -0
  23. package/lib/auth/index.d.ts.map +1 -0
  24. package/lib/auth/index.js +6 -0
  25. package/lib/auth/types.d.ts +26 -0
  26. package/lib/auth/types.d.ts.map +1 -0
  27. package/lib/auth/types.js +1 -0
  28. package/lib/auth/utils/apple.d.ts +4 -0
  29. package/lib/auth/utils/apple.d.ts.map +1 -0
  30. package/lib/auth/utils/apple.js +90 -0
  31. package/lib/auth/utils/email.d.ts +11 -0
  32. package/lib/auth/utils/email.d.ts.map +1 -0
  33. package/lib/auth/utils/email.js +33 -0
  34. package/lib/auth/utils/facebook.d.ts +4 -0
  35. package/lib/auth/utils/facebook.d.ts.map +1 -0
  36. package/lib/auth/utils/facebook.js +59 -0
  37. package/lib/auth/utils/google.d.ts +3 -0
  38. package/lib/auth/utils/google.d.ts.map +1 -0
  39. package/lib/auth/utils/google.js +33 -0
  40. package/lib/auth/utils/index.d.ts +8 -0
  41. package/lib/auth/utils/index.d.ts.map +1 -0
  42. package/lib/auth/utils/index.js +55 -0
  43. package/lib/components/Art/BrandArt.d.ts +3 -0
  44. package/lib/components/Art/BrandArt.d.ts.map +1 -0
  45. package/lib/components/Art/BrandArt.js +6 -0
  46. package/lib/components/Art/EmojiArt.d.ts +3 -0
  47. package/lib/components/Art/EmojiArt.d.ts.map +1 -0
  48. package/lib/components/Art/EmojiArt.js +25 -0
  49. package/lib/components/Art/IconArt.d.ts +3 -0
  50. package/lib/components/Art/IconArt.d.ts.map +1 -0
  51. package/lib/components/Art/IconArt.js +26 -0
  52. package/lib/components/Art/ImageArt.d.ts +3 -0
  53. package/lib/components/Art/ImageArt.d.ts.map +1 -0
  54. package/lib/components/Art/ImageArt.js +24 -0
  55. package/lib/components/Art/SvgArt.d.ts +3 -0
  56. package/lib/components/Art/SvgArt.d.ts.map +1 -0
  57. package/lib/components/Art/SvgArt.js +51 -0
  58. package/lib/components/Art/constants.d.ts +5 -0
  59. package/lib/components/Art/constants.d.ts.map +1 -0
  60. package/lib/components/Art/constants.js +6 -0
  61. package/lib/components/Art/hooks.d.ts +3 -0
  62. package/lib/components/Art/hooks.d.ts.map +1 -0
  63. package/lib/components/Art/hooks.js +8 -0
  64. package/lib/components/Art/index.d.ts +10 -0
  65. package/lib/components/Art/index.d.ts.map +1 -0
  66. package/lib/components/Art/index.js +29 -0
  67. package/lib/components/Art/types.d.ts +157 -0
  68. package/lib/components/Art/types.d.ts.map +1 -0
  69. package/lib/components/Art/types.js +1 -0
  70. package/lib/components/Art/utils.d.ts +40 -0
  71. package/lib/components/Art/utils.d.ts.map +1 -0
  72. package/lib/components/Art/utils.js +68 -0
  73. package/lib/components/Avatar/Wrapper.d.ts +11 -0
  74. package/lib/components/Avatar/Wrapper.d.ts.map +1 -0
  75. package/lib/components/Avatar/Wrapper.js +67 -0
  76. package/lib/components/Avatar/apiCalls/useUploadCloudinaryImageApi.d.ts +14 -0
  77. package/lib/components/Avatar/apiCalls/useUploadCloudinaryImageApi.d.ts.map +1 -0
  78. package/lib/components/Avatar/apiCalls/useUploadCloudinaryImageApi.js +24 -0
  79. package/lib/components/Avatar/index.d.ts +3 -0
  80. package/lib/components/Avatar/index.d.ts.map +1 -0
  81. package/lib/components/Avatar/index.js +37 -0
  82. package/lib/components/Avatar/types.d.ts +51 -0
  83. package/lib/components/Avatar/types.d.ts.map +1 -0
  84. package/lib/components/Avatar/types.js +1 -0
  85. package/lib/components/Avatar/utils.d.ts +6 -0
  86. package/lib/components/Avatar/utils.d.ts.map +1 -0
  87. package/lib/components/Avatar/utils.js +9 -0
  88. package/lib/components/Base/BaseFooter.d.ts +8 -0
  89. package/lib/components/Base/BaseFooter.d.ts.map +1 -0
  90. package/lib/components/Base/BaseFooter.js +18 -0
  91. package/lib/components/Base/index.d.ts +4 -0
  92. package/lib/components/Base/index.d.ts.map +1 -0
  93. package/lib/components/Base/index.js +49 -0
  94. package/lib/components/Base/types.d.ts +83 -0
  95. package/lib/components/Base/types.d.ts.map +1 -0
  96. package/lib/components/Base/types.js +1 -0
  97. package/lib/components/Box/StyledBox.d.ts +254 -0
  98. package/lib/components/Box/StyledBox.d.ts.map +1 -0
  99. package/lib/components/Box/StyledBox.js +53 -0
  100. package/lib/components/Box/config.d.ts +359 -0
  101. package/lib/components/Box/config.d.ts.map +1 -0
  102. package/lib/components/Box/config.js +227 -0
  103. package/lib/components/Box/index.d.ts +11 -0
  104. package/lib/components/Box/index.d.ts.map +1 -0
  105. package/lib/components/Box/index.js +14 -0
  106. package/lib/components/Box/types.d.ts +53 -0
  107. package/lib/components/Box/types.d.ts.map +1 -0
  108. package/lib/components/Box/types.js +1 -0
  109. package/lib/components/Bubble/index.d.ts +8 -0
  110. package/lib/components/Bubble/index.d.ts.map +1 -0
  111. package/lib/components/Bubble/index.js +20 -0
  112. package/lib/components/Bubble/type.d.ts +18 -0
  113. package/lib/components/Bubble/type.d.ts.map +1 -0
  114. package/lib/components/Bubble/type.js +1 -0
  115. package/lib/components/Bubble/utils.d.ts +12 -0
  116. package/lib/components/Bubble/utils.d.ts.map +1 -0
  117. package/lib/components/Bubble/utils.js +33 -0
  118. package/lib/components/Button/StyledButton.d.ts +34 -0
  119. package/lib/components/Button/StyledButton.d.ts.map +1 -0
  120. package/lib/components/Button/StyledButton.js +49 -0
  121. package/lib/components/Button/index.d.ts +64 -0
  122. package/lib/components/Button/index.d.ts.map +1 -0
  123. package/lib/components/Button/index.js +20 -0
  124. package/lib/components/Button/utils.d.ts +4 -0
  125. package/lib/components/Button/utils.d.ts.map +1 -0
  126. package/lib/components/Button/utils.js +10 -0
  127. package/lib/components/Card/StyledCard.d.ts +226 -0
  128. package/lib/components/Card/StyledCard.d.ts.map +1 -0
  129. package/lib/components/Card/StyledCard.js +17 -0
  130. package/lib/components/Card/index.d.ts +27 -0
  131. package/lib/components/Card/index.d.ts.map +1 -0
  132. package/lib/components/Card/index.js +44 -0
  133. package/lib/components/Chart/LineChart.d.ts +3 -0
  134. package/lib/components/Chart/LineChart.d.ts.map +1 -0
  135. package/lib/components/Chart/LineChart.js +27 -0
  136. package/lib/components/Chart/constants.d.ts +2 -0
  137. package/lib/components/Chart/constants.d.ts.map +1 -0
  138. package/lib/components/Chart/constants.js +47 -0
  139. package/lib/components/Chart/index.d.ts +3 -0
  140. package/lib/components/Chart/index.d.ts.map +1 -0
  141. package/lib/components/Chart/index.js +10 -0
  142. package/lib/components/Chart/types.d.ts +32 -0
  143. package/lib/components/Chart/types.d.ts.map +1 -0
  144. package/lib/components/Chart/types.js +1 -0
  145. package/lib/components/Chart/utils.d.ts +6 -0
  146. package/lib/components/Chart/utils.d.ts.map +1 -0
  147. package/lib/components/Chart/utils.js +8 -0
  148. package/lib/components/Chat/ImageChat.d.ts +8 -0
  149. package/lib/components/Chat/ImageChat.d.ts.map +1 -0
  150. package/lib/components/Chat/ImageChat.js +24 -0
  151. package/lib/components/Chat/TextChat.d.ts +8 -0
  152. package/lib/components/Chat/TextChat.d.ts.map +1 -0
  153. package/lib/components/Chat/TextChat.js +37 -0
  154. package/lib/components/Chat/VideoChat.d.ts +6 -0
  155. package/lib/components/Chat/VideoChat.d.ts.map +1 -0
  156. package/lib/components/Chat/VideoChat.js +56 -0
  157. package/lib/components/Chat/index.d.ts +4 -0
  158. package/lib/components/Chat/index.d.ts.map +1 -0
  159. package/lib/components/Chat/index.js +26 -0
  160. package/lib/components/Chat/type.d.ts +95 -0
  161. package/lib/components/Chat/type.d.ts.map +1 -0
  162. package/lib/components/Chat/type.js +1 -0
  163. package/lib/components/ChatCluster/index.d.ts +4 -0
  164. package/lib/components/ChatCluster/index.d.ts.map +1 -0
  165. package/lib/components/ChatCluster/index.js +22 -0
  166. package/lib/components/ChatCluster/types.d.ts +11 -0
  167. package/lib/components/ChatCluster/types.d.ts.map +1 -0
  168. package/lib/components/ChatCluster/types.js +1 -0
  169. package/lib/components/ChatCluster/utils.d.ts +5 -0
  170. package/lib/components/ChatCluster/utils.d.ts.map +1 -0
  171. package/lib/components/ChatCluster/utils.js +15 -0
  172. package/lib/components/Chip/index.d.ts +3 -0
  173. package/lib/components/Chip/index.d.ts.map +1 -0
  174. package/lib/components/Chip/index.js +16 -0
  175. package/lib/components/Chip/types.d.ts +50 -0
  176. package/lib/components/Chip/types.d.ts.map +1 -0
  177. package/lib/components/Chip/types.js +1 -0
  178. package/lib/components/Divider/StyledDivider.d.ts +12 -0
  179. package/lib/components/Divider/StyledDivider.d.ts.map +1 -0
  180. package/lib/components/Divider/StyledDivider.js +17 -0
  181. package/lib/components/Divider/index.d.ts +15 -0
  182. package/lib/components/Divider/index.d.ts.map +1 -0
  183. package/lib/components/Divider/index.js +4 -0
  184. package/lib/components/FastList/index.d.ts +25 -0
  185. package/lib/components/FastList/index.d.ts.map +1 -0
  186. package/lib/components/FastList/index.js +13 -0
  187. package/lib/components/Filter/index.d.ts +40 -0
  188. package/lib/components/Filter/index.d.ts.map +1 -0
  189. package/lib/components/Filter/index.js +23 -0
  190. package/lib/components/Gradient/index.d.ts +11 -0
  191. package/lib/components/Gradient/index.d.ts.map +1 -0
  192. package/lib/components/Gradient/index.js +10 -0
  193. package/lib/components/Header/BackButton.d.ts +5 -0
  194. package/lib/components/Header/BackButton.d.ts.map +1 -0
  195. package/lib/components/Header/BackButton.js +22 -0
  196. package/lib/components/Header/DefaultHeader.d.ts +8 -0
  197. package/lib/components/Header/DefaultHeader.d.ts.map +1 -0
  198. package/lib/components/Header/DefaultHeader.js +13 -0
  199. package/lib/components/Header/HeaderContent.d.ts +6 -0
  200. package/lib/components/Header/HeaderContent.d.ts.map +1 -0
  201. package/lib/components/Header/HeaderContent.js +18 -0
  202. package/lib/components/Header/IconButton.d.ts +13 -0
  203. package/lib/components/Header/IconButton.d.ts.map +1 -0
  204. package/lib/components/Header/IconButton.js +6 -0
  205. package/lib/components/Header/ProgressHeader.d.ts +7 -0
  206. package/lib/components/Header/ProgressHeader.d.ts.map +1 -0
  207. package/lib/components/Header/ProgressHeader.js +18 -0
  208. package/lib/components/Header/RightButton.d.ts +3 -0
  209. package/lib/components/Header/RightButton.d.ts.map +1 -0
  210. package/lib/components/Header/RightButton.js +15 -0
  211. package/lib/components/Header/index.d.ts +4 -0
  212. package/lib/components/Header/index.d.ts.map +1 -0
  213. package/lib/components/Header/index.js +12 -0
  214. package/lib/components/Header/types.d.ts +86 -0
  215. package/lib/components/Header/types.d.ts.map +1 -0
  216. package/lib/components/Header/types.js +1 -0
  217. package/lib/components/Header/utils.d.ts +10 -0
  218. package/lib/components/Header/utils.d.ts.map +1 -0
  219. package/lib/components/Header/utils.js +3 -0
  220. package/lib/components/Icon/AnimatedIcon.d.ts +6 -0
  221. package/lib/components/Icon/AnimatedIcon.d.ts.map +1 -0
  222. package/lib/components/Icon/AnimatedIcon.js +34 -0
  223. package/lib/components/Icon/PlainIcon.d.ts +16 -0
  224. package/lib/components/Icon/PlainIcon.d.ts.map +1 -0
  225. package/lib/components/Icon/PlainIcon.js +13 -0
  226. package/lib/components/Icon/constants.d.ts +703 -0
  227. package/lib/components/Icon/constants.d.ts.map +1 -0
  228. package/lib/components/Icon/constants.js +702 -0
  229. package/lib/components/Icon/index.d.ts +34 -0
  230. package/lib/components/Icon/index.d.ts.map +1 -0
  231. package/lib/components/Icon/index.js +24 -0
  232. package/lib/components/Icon/utils.d.ts +3 -0
  233. package/lib/components/Icon/utils.d.ts.map +1 -0
  234. package/lib/components/Icon/utils.js +2 -0
  235. package/lib/components/Image/ImageDetail.d.ts +11 -0
  236. package/lib/components/Image/ImageDetail.d.ts.map +1 -0
  237. package/lib/components/Image/ImageDetail.js +33 -0
  238. package/lib/components/Image/index.d.ts +11 -0
  239. package/lib/components/Image/index.d.ts.map +1 -0
  240. package/lib/components/Image/index.js +5 -0
  241. package/lib/components/Image/utils.d.ts +6 -0
  242. package/lib/components/Image/utils.d.ts.map +1 -0
  243. package/lib/components/Image/utils.js +12 -0
  244. package/lib/components/InfoCard/BasicInfoCard.d.ts +19 -0
  245. package/lib/components/InfoCard/BasicInfoCard.d.ts.map +1 -0
  246. package/lib/components/InfoCard/BasicInfoCard.js +18 -0
  247. package/lib/components/InfoCard/NewsInfoCard.d.ts +22 -0
  248. package/lib/components/InfoCard/NewsInfoCard.d.ts.map +1 -0
  249. package/lib/components/InfoCard/NewsInfoCard.js +15 -0
  250. package/lib/components/InfoCard/ThumbnailInfoCard.d.ts +33 -0
  251. package/lib/components/InfoCard/ThumbnailInfoCard.d.ts.map +1 -0
  252. package/lib/components/InfoCard/ThumbnailInfoCard.js +24 -0
  253. package/lib/components/InfoCard/index.d.ts +15 -0
  254. package/lib/components/InfoCard/index.d.ts.map +1 -0
  255. package/lib/components/InfoCard/index.js +16 -0
  256. package/lib/components/Input/StyledInput.d.ts +13 -0
  257. package/lib/components/Input/StyledInput.d.ts.map +1 -0
  258. package/lib/components/Input/StyledInput.js +14 -0
  259. package/lib/components/Input/index.d.ts +34 -0
  260. package/lib/components/Input/index.d.ts.map +1 -0
  261. package/lib/components/Input/index.js +15 -0
  262. package/lib/components/LevelStep/CircularProgress.d.ts +12 -0
  263. package/lib/components/LevelStep/CircularProgress.d.ts.map +1 -0
  264. package/lib/components/LevelStep/CircularProgress.js +27 -0
  265. package/lib/components/LevelStep/TransformedSvg.d.ts +13 -0
  266. package/lib/components/LevelStep/TransformedSvg.d.ts.map +1 -0
  267. package/lib/components/LevelStep/TransformedSvg.js +9 -0
  268. package/lib/components/LevelStep/constants.d.ts +8 -0
  269. package/lib/components/LevelStep/constants.d.ts.map +1 -0
  270. package/lib/components/LevelStep/constants.js +17 -0
  271. package/lib/components/LevelStep/index.d.ts +3 -0
  272. package/lib/components/LevelStep/index.d.ts.map +1 -0
  273. package/lib/components/LevelStep/index.js +78 -0
  274. package/lib/components/LevelStep/types.d.ts +7 -0
  275. package/lib/components/LevelStep/types.d.ts.map +1 -0
  276. package/lib/components/LevelStep/types.js +1 -0
  277. package/lib/components/List/index.d.ts +13 -0
  278. package/lib/components/List/index.d.ts.map +1 -0
  279. package/lib/components/List/index.js +13 -0
  280. package/lib/components/Loading/Loading.d.ts +3 -0
  281. package/lib/components/Loading/Loading.d.ts.map +1 -0
  282. package/lib/components/Loading/Loading.js +61 -0
  283. package/lib/components/Loading/StyledLoading.d.ts +14 -0
  284. package/lib/components/Loading/StyledLoading.d.ts.map +1 -0
  285. package/lib/components/Loading/StyledLoading.js +18 -0
  286. package/lib/components/Loading/index.d.ts +3 -0
  287. package/lib/components/Loading/index.d.ts.map +1 -0
  288. package/lib/components/Loading/index.js +26 -0
  289. package/lib/components/Loading/types.d.ts +25 -0
  290. package/lib/components/Loading/types.d.ts.map +1 -0
  291. package/lib/components/Loading/types.js +1 -0
  292. package/lib/components/Notification/Notification.d.ts +6 -0
  293. package/lib/components/Notification/Notification.d.ts.map +1 -0
  294. package/lib/components/Notification/Notification.js +13 -0
  295. package/lib/components/Notification/NotificationProvider.d.ts +4 -0
  296. package/lib/components/Notification/NotificationProvider.d.ts.map +1 -0
  297. package/lib/components/Notification/NotificationProvider.js +13 -0
  298. package/lib/components/Notification/Toast.d.ts +8 -0
  299. package/lib/components/Notification/Toast.d.ts.map +1 -0
  300. package/lib/components/Notification/Toast.js +32 -0
  301. package/lib/components/Notification/context.d.ts +7 -0
  302. package/lib/components/Notification/context.d.ts.map +1 -0
  303. package/lib/components/Notification/context.js +9 -0
  304. package/lib/components/Notification/index.d.ts +3 -0
  305. package/lib/components/Notification/index.d.ts.map +1 -0
  306. package/lib/components/Notification/index.js +2 -0
  307. package/lib/components/PlaySwitch/index.d.ts +4 -0
  308. package/lib/components/PlaySwitch/index.d.ts.map +1 -0
  309. package/lib/components/PlaySwitch/index.js +62 -0
  310. package/lib/components/PlaySwitch/types.d.ts +23 -0
  311. package/lib/components/PlaySwitch/types.d.ts.map +1 -0
  312. package/lib/components/PlaySwitch/types.js +1 -0
  313. package/lib/components/Progress/StyledProgress.d.ts +225 -0
  314. package/lib/components/Progress/StyledProgress.d.ts.map +1 -0
  315. package/lib/components/Progress/StyledProgress.js +22 -0
  316. package/lib/components/Progress/index.d.ts +25 -0
  317. package/lib/components/Progress/index.d.ts.map +1 -0
  318. package/lib/components/Progress/index.js +33 -0
  319. package/lib/components/Scrollable/StyledScrollable.d.ts +33 -0
  320. package/lib/components/Scrollable/StyledScrollable.d.ts.map +1 -0
  321. package/lib/components/Scrollable/StyledScrollable.js +56 -0
  322. package/lib/components/Scrollable/index.d.ts +6 -0
  323. package/lib/components/Scrollable/index.d.ts.map +1 -0
  324. package/lib/components/Scrollable/index.js +15 -0
  325. package/lib/components/Scrollable/types.d.ts +5 -0
  326. package/lib/components/Scrollable/types.d.ts.map +1 -0
  327. package/lib/components/Scrollable/types.js +1 -0
  328. package/lib/components/Sectional/Item.d.ts +13 -0
  329. package/lib/components/Sectional/Item.d.ts.map +1 -0
  330. package/lib/components/Sectional/Item.js +21 -0
  331. package/lib/components/Sectional/index.d.ts +9 -0
  332. package/lib/components/Sectional/index.d.ts.map +1 -0
  333. package/lib/components/Sectional/index.js +25 -0
  334. package/lib/components/Sectional/types.d.ts +33 -0
  335. package/lib/components/Sectional/types.d.ts.map +1 -0
  336. package/lib/components/Sectional/types.js +1 -0
  337. package/lib/components/Sectional/utils.d.ts +11 -0
  338. package/lib/components/Sectional/utils.d.ts.map +1 -0
  339. package/lib/components/Sectional/utils.js +37 -0
  340. package/lib/components/Selection/index.d.ts +17 -0
  341. package/lib/components/Selection/index.d.ts.map +1 -0
  342. package/lib/components/Selection/index.js +24 -0
  343. package/lib/components/Skeleton/SkeletonBackground.d.ts +6 -0
  344. package/lib/components/Skeleton/SkeletonBackground.d.ts.map +1 -0
  345. package/lib/components/Skeleton/SkeletonBackground.js +23 -0
  346. package/lib/components/Skeleton/SkeletonWrapper.d.ts +8 -0
  347. package/lib/components/Skeleton/SkeletonWrapper.d.ts.map +1 -0
  348. package/lib/components/Skeleton/SkeletonWrapper.js +50 -0
  349. package/lib/components/Skeleton/index.d.ts +4 -0
  350. package/lib/components/Skeleton/index.d.ts.map +1 -0
  351. package/lib/components/Skeleton/index.js +16 -0
  352. package/lib/components/Skeleton/types.d.ts +16 -0
  353. package/lib/components/Skeleton/types.d.ts.map +1 -0
  354. package/lib/components/Skeleton/types.js +1 -0
  355. package/lib/components/Slides/index.d.ts +14 -0
  356. package/lib/components/Slides/index.d.ts.map +1 -0
  357. package/lib/components/Slides/index.js +46 -0
  358. package/lib/components/Squircle/index.d.ts +35 -0
  359. package/lib/components/Squircle/index.d.ts.map +1 -0
  360. package/lib/components/Squircle/index.js +21 -0
  361. package/lib/components/Squircle/types.d.ts +20 -0
  362. package/lib/components/Squircle/types.d.ts.map +1 -0
  363. package/lib/components/Squircle/types.js +1 -0
  364. package/lib/components/Squircle/utils.d.ts +4 -0
  365. package/lib/components/Squircle/utils.d.ts.map +1 -0
  366. package/lib/components/Squircle/utils.js +86 -0
  367. package/lib/components/Text/StyledText.d.ts +18 -0
  368. package/lib/components/Text/StyledText.d.ts.map +1 -0
  369. package/lib/components/Text/StyledText.js +19 -0
  370. package/lib/components/Text/constants.d.ts +3 -0
  371. package/lib/components/Text/constants.d.ts.map +1 -0
  372. package/lib/components/Text/constants.js +6 -0
  373. package/lib/components/Text/index.d.ts +6 -0
  374. package/lib/components/Text/index.d.ts.map +1 -0
  375. package/lib/components/Text/index.js +7 -0
  376. package/lib/components/Text/types.d.ts +55 -0
  377. package/lib/components/Text/types.d.ts.map +1 -0
  378. package/lib/components/Text/types.js +1 -0
  379. package/lib/components/Text/withRichText.d.ts +6 -0
  380. package/lib/components/Text/withRichText.d.ts.map +1 -0
  381. package/lib/components/Text/withRichText.js +38 -0
  382. package/lib/components/Touchable/index.d.ts +5 -0
  383. package/lib/components/Touchable/index.d.ts.map +1 -0
  384. package/lib/components/Touchable/index.js +56 -0
  385. package/lib/components/Touchable/types.d.ts +22 -0
  386. package/lib/components/Touchable/types.d.ts.map +1 -0
  387. package/lib/components/Touchable/types.js +1 -0
  388. package/lib/components/Video/StyledVideoControlManager.d.ts +49 -0
  389. package/lib/components/Video/StyledVideoControlManager.d.ts.map +1 -0
  390. package/lib/components/Video/StyledVideoControlManager.js +64 -0
  391. package/lib/components/Video/StyledVideoDetail.d.ts +16 -0
  392. package/lib/components/Video/StyledVideoDetail.d.ts.map +1 -0
  393. package/lib/components/Video/StyledVideoDetail.js +23 -0
  394. package/lib/components/Video/VideoControlManager.d.ts +10 -0
  395. package/lib/components/Video/VideoControlManager.d.ts.map +1 -0
  396. package/lib/components/Video/VideoControlManager.js +67 -0
  397. package/lib/components/Video/VideoDetail.d.ts +11 -0
  398. package/lib/components/Video/VideoDetail.d.ts.map +1 -0
  399. package/lib/components/Video/VideoDetail.js +102 -0
  400. package/lib/components/Video/index.d.ts +25 -0
  401. package/lib/components/Video/index.d.ts.map +1 -0
  402. package/lib/components/Video/index.js +49 -0
  403. package/lib/components/Vimeo/Player.d.ts +4 -0
  404. package/lib/components/Vimeo/Player.d.ts.map +1 -0
  405. package/lib/components/Vimeo/Player.js +30 -0
  406. package/lib/components/Vimeo/constants.d.ts +2 -0
  407. package/lib/components/Vimeo/constants.d.ts.map +1 -0
  408. package/lib/components/Vimeo/constants.js +23 -0
  409. package/lib/components/Vimeo/index.d.ts +10 -0
  410. package/lib/components/Vimeo/index.d.ts.map +1 -0
  411. package/lib/components/Vimeo/index.js +35 -0
  412. package/lib/components/Vimeo/types.d.ts +74 -0
  413. package/lib/components/Vimeo/types.d.ts.map +1 -0
  414. package/lib/components/Vimeo/types.js +1 -0
  415. package/lib/components/Vimeo/utils.d.ts +4 -0
  416. package/lib/components/Vimeo/utils.d.ts.map +1 -0
  417. package/lib/components/Vimeo/utils.js +126 -0
  418. package/lib/components/index.d.ts +33 -0
  419. package/lib/components/index.d.ts.map +1 -0
  420. package/lib/components/index.js +32 -0
  421. package/lib/hooks/index.d.ts +3 -0
  422. package/lib/hooks/index.d.ts.map +1 -0
  423. package/lib/hooks/index.js +2 -0
  424. package/lib/hooks/useKeyboard.d.ts +10 -0
  425. package/lib/hooks/useKeyboard.d.ts.map +1 -0
  426. package/lib/hooks/useKeyboard.js +54 -0
  427. package/lib/hooks/usePrevious.d.ts +3 -0
  428. package/lib/hooks/usePrevious.d.ts.map +1 -0
  429. package/lib/hooks/usePrevious.js +9 -0
  430. package/lib/index.d.ts +7 -0
  431. package/lib/index.d.ts.map +1 -0
  432. package/lib/index.js +6 -0
  433. package/lib/services/base/BaseResponse.d.ts +12 -0
  434. package/lib/services/base/BaseResponse.d.ts.map +1 -0
  435. package/lib/services/base/BaseResponse.js +9 -0
  436. package/lib/services/base/BaseService.d.ts +8 -0
  437. package/lib/services/base/BaseService.d.ts.map +1 -0
  438. package/lib/services/base/BaseService.js +61 -0
  439. package/lib/services/base/index.d.ts +3 -0
  440. package/lib/services/base/index.d.ts.map +1 -0
  441. package/lib/services/base/index.js +2 -0
  442. package/lib/services/hooks/index.d.ts +2 -0
  443. package/lib/services/hooks/index.d.ts.map +1 -0
  444. package/lib/services/hooks/index.js +1 -0
  445. package/lib/services/hooks/useRequest.d.ts +14 -0
  446. package/lib/services/hooks/useRequest.d.ts.map +1 -0
  447. package/lib/services/hooks/useRequest.js +30 -0
  448. package/lib/services/index.d.ts +3 -0
  449. package/lib/services/index.d.ts.map +1 -0
  450. package/lib/services/index.js +2 -0
  451. package/lib/theme/ThemeProvider.d.ts +13 -0
  452. package/lib/theme/ThemeProvider.d.ts.map +1 -0
  453. package/lib/theme/ThemeProvider.js +5 -0
  454. package/lib/theme/ThemeSwitcher.d.ts +9 -0
  455. package/lib/theme/ThemeSwitcher.d.ts.map +1 -0
  456. package/lib/theme/ThemeSwitcher.js +19 -0
  457. package/lib/theme/common/borders.d.ts +9 -0
  458. package/lib/theme/common/borders.d.ts.map +1 -0
  459. package/lib/theme/common/borders.js +27 -0
  460. package/lib/theme/common/colors.d.ts +74 -0
  461. package/lib/theme/common/colors.d.ts.map +1 -0
  462. package/lib/theme/common/colors.js +73 -0
  463. package/lib/theme/common/gradient.d.ts +13 -0
  464. package/lib/theme/common/gradient.d.ts.map +1 -0
  465. package/lib/theme/common/gradient.js +12 -0
  466. package/lib/theme/common/index.d.ts +50 -0
  467. package/lib/theme/common/index.d.ts.map +1 -0
  468. package/lib/theme/common/index.js +37 -0
  469. package/lib/theme/common/scale.d.ts +12 -0
  470. package/lib/theme/common/scale.d.ts.map +1 -0
  471. package/lib/theme/common/scale.js +16 -0
  472. package/lib/theme/common/shadows.d.ts +17 -0
  473. package/lib/theme/common/shadows.d.ts.map +1 -0
  474. package/lib/theme/common/shadows.js +13 -0
  475. package/lib/theme/common/sizes.d.ts +6 -0
  476. package/lib/theme/common/sizes.d.ts.map +1 -0
  477. package/lib/theme/common/sizes.js +26 -0
  478. package/lib/theme/common/spaces.d.ts +5 -0
  479. package/lib/theme/common/spaces.d.ts.map +1 -0
  480. package/lib/theme/common/spaces.js +31 -0
  481. package/lib/theme/common/text.d.ts +14 -0
  482. package/lib/theme/common/text.d.ts.map +1 -0
  483. package/lib/theme/common/text.js +70 -0
  484. package/lib/theme/components/art.d.ts +17 -0
  485. package/lib/theme/components/art.d.ts.map +1 -0
  486. package/lib/theme/components/art.js +15 -0
  487. package/lib/theme/components/avatar.d.ts +11 -0
  488. package/lib/theme/components/avatar.d.ts.map +1 -0
  489. package/lib/theme/components/avatar.js +20 -0
  490. package/lib/theme/components/base.d.ts +14 -0
  491. package/lib/theme/components/base.d.ts.map +1 -0
  492. package/lib/theme/components/base.js +17 -0
  493. package/lib/theme/components/bubble.d.ts +6 -0
  494. package/lib/theme/components/bubble.d.ts.map +1 -0
  495. package/lib/theme/components/bubble.js +10 -0
  496. package/lib/theme/components/button.d.ts +12 -0
  497. package/lib/theme/components/button.d.ts.map +1 -0
  498. package/lib/theme/components/button.js +22 -0
  499. package/lib/theme/components/card.d.ts +8 -0
  500. package/lib/theme/components/card.d.ts.map +1 -0
  501. package/lib/theme/components/card.js +16 -0
  502. package/lib/theme/components/chart.d.ts +16 -0
  503. package/lib/theme/components/chart.d.ts.map +1 -0
  504. package/lib/theme/components/chart.js +22 -0
  505. package/lib/theme/components/chat.d.ts +11 -0
  506. package/lib/theme/components/chat.d.ts.map +1 -0
  507. package/lib/theme/components/chat.js +20 -0
  508. package/lib/theme/components/chip.d.ts +18 -0
  509. package/lib/theme/components/chip.d.ts.map +1 -0
  510. package/lib/theme/components/chip.js +43 -0
  511. package/lib/theme/components/divider.d.ts +12 -0
  512. package/lib/theme/components/divider.d.ts.map +1 -0
  513. package/lib/theme/components/divider.js +16 -0
  514. package/lib/theme/components/filter.d.ts +5 -0
  515. package/lib/theme/components/filter.d.ts.map +1 -0
  516. package/lib/theme/components/filter.js +8 -0
  517. package/lib/theme/components/header.d.ts +30 -0
  518. package/lib/theme/components/header.d.ts.map +1 -0
  519. package/lib/theme/components/header.js +36 -0
  520. package/lib/theme/components/image.d.ts +4 -0
  521. package/lib/theme/components/image.d.ts.map +1 -0
  522. package/lib/theme/components/image.js +6 -0
  523. package/lib/theme/components/index.d.ts +27 -0
  524. package/lib/theme/components/index.d.ts.map +1 -0
  525. package/lib/theme/components/index.js +26 -0
  526. package/lib/theme/components/infoCard.d.ts +25 -0
  527. package/lib/theme/components/infoCard.d.ts.map +1 -0
  528. package/lib/theme/components/infoCard.js +32 -0
  529. package/lib/theme/components/input.d.ts +21 -0
  530. package/lib/theme/components/input.d.ts.map +1 -0
  531. package/lib/theme/components/input.js +34 -0
  532. package/lib/theme/components/levelStep.d.ts +48 -0
  533. package/lib/theme/components/levelStep.d.ts.map +1 -0
  534. package/lib/theme/components/levelStep.js +56 -0
  535. package/lib/theme/components/loading.d.ts +16 -0
  536. package/lib/theme/components/loading.d.ts.map +1 -0
  537. package/lib/theme/components/loading.js +27 -0
  538. package/lib/theme/components/notification.d.ts +23 -0
  539. package/lib/theme/components/notification.d.ts.map +1 -0
  540. package/lib/theme/components/notification.js +38 -0
  541. package/lib/theme/components/playSwitch.d.ts +10 -0
  542. package/lib/theme/components/playSwitch.d.ts.map +1 -0
  543. package/lib/theme/components/playSwitch.js +14 -0
  544. package/lib/theme/components/progress.d.ts +10 -0
  545. package/lib/theme/components/progress.d.ts.map +1 -0
  546. package/lib/theme/components/progress.js +14 -0
  547. package/lib/theme/components/selection.d.ts +9 -0
  548. package/lib/theme/components/selection.d.ts.map +1 -0
  549. package/lib/theme/components/selection.js +21 -0
  550. package/lib/theme/components/skeleton.d.ts +11 -0
  551. package/lib/theme/components/skeleton.d.ts.map +1 -0
  552. package/lib/theme/components/skeleton.js +18 -0
  553. package/lib/theme/components/slides.d.ts +7 -0
  554. package/lib/theme/components/slides.d.ts.map +1 -0
  555. package/lib/theme/components/slides.js +10 -0
  556. package/lib/theme/components/text.d.ts +21 -0
  557. package/lib/theme/components/text.d.ts.map +1 -0
  558. package/lib/theme/components/text.js +22 -0
  559. package/lib/theme/components/touchable.d.ts +15 -0
  560. package/lib/theme/components/touchable.d.ts.map +1 -0
  561. package/lib/theme/components/touchable.js +41 -0
  562. package/lib/theme/components/video.d.ts +18 -0
  563. package/lib/theme/components/video.d.ts.map +1 -0
  564. package/lib/theme/components/video.js +47 -0
  565. package/lib/theme/getTheme.d.ts +34 -0
  566. package/lib/theme/getTheme.d.ts.map +1 -0
  567. package/lib/theme/getTheme.js +36 -0
  568. package/lib/theme/index.d.ts +10 -0
  569. package/lib/theme/index.d.ts.map +1 -0
  570. package/lib/theme/index.js +7 -0
  571. package/lib/utils/api/index.d.ts +3 -0
  572. package/lib/utils/api/index.d.ts.map +1 -0
  573. package/lib/utils/api/index.js +2 -0
  574. package/lib/utils/api/keys.d.ts +3 -0
  575. package/lib/utils/api/keys.d.ts.map +1 -0
  576. package/lib/utils/api/keys.js +11 -0
  577. package/lib/utils/api/urls.d.ts +3 -0
  578. package/lib/utils/api/urls.d.ts.map +1 -0
  579. package/lib/utils/api/urls.js +8 -0
  580. package/lib/utils/format/index.d.ts +3 -0
  581. package/lib/utils/format/index.d.ts.map +1 -0
  582. package/lib/utils/format/index.js +2 -0
  583. package/lib/utils/format/text.d.ts +4 -0
  584. package/lib/utils/format/text.d.ts.map +1 -0
  585. package/lib/utils/format/text.js +13 -0
  586. package/lib/utils/haptic/index.d.ts +4 -0
  587. package/lib/utils/haptic/index.d.ts.map +1 -0
  588. package/lib/utils/haptic/index.js +3 -0
  589. package/lib/utils/haptic/types.d.ts +25 -0
  590. package/lib/utils/haptic/types.d.ts.map +1 -0
  591. package/lib/utils/haptic/types.js +25 -0
  592. package/lib/utils/haptic/utils.d.ts +3 -0
  593. package/lib/utils/haptic/utils.d.ts.map +1 -0
  594. package/lib/utils/haptic/utils.js +8 -0
  595. package/lib/utils/index.d.ts +9 -0
  596. package/lib/utils/index.d.ts.map +1 -0
  597. package/lib/utils/index.js +8 -0
  598. package/lib/utils/intl/IntlProvider.d.ts +7 -0
  599. package/lib/utils/intl/IntlProvider.d.ts.map +1 -0
  600. package/lib/utils/intl/IntlProvider.js +16 -0
  601. package/lib/utils/intl/context.d.ts +15 -0
  602. package/lib/utils/intl/context.d.ts.map +1 -0
  603. package/lib/utils/intl/context.js +9 -0
  604. package/lib/utils/intl/global.d.ts +7 -0
  605. package/lib/utils/intl/global.d.ts.map +1 -0
  606. package/lib/utils/intl/global.js +1 -0
  607. package/lib/utils/intl/hooks.d.ts +7 -0
  608. package/lib/utils/intl/hooks.d.ts.map +1 -0
  609. package/lib/utils/intl/hooks.js +10 -0
  610. package/lib/utils/intl/index.d.ts +5 -0
  611. package/lib/utils/intl/index.d.ts.map +1 -0
  612. package/lib/utils/intl/index.js +4 -0
  613. package/lib/utils/intl/state.d.ts +12 -0
  614. package/lib/utils/intl/state.d.ts.map +1 -0
  615. package/lib/utils/intl/state.js +14 -0
  616. package/lib/utils/intl/utils.d.ts +6 -0
  617. package/lib/utils/intl/utils.d.ts.map +1 -0
  618. package/lib/utils/intl/utils.js +7 -0
  619. package/lib/utils/notification/index.d.ts +2 -0
  620. package/lib/utils/notification/index.d.ts.map +1 -0
  621. package/lib/utils/notification/index.js +1 -0
  622. package/lib/utils/notification/toast/constants.d.ts +4 -0
  623. package/lib/utils/notification/toast/constants.d.ts.map +1 -0
  624. package/lib/utils/notification/toast/constants.js +7 -0
  625. package/lib/utils/notification/toast/index.d.ts +3 -0
  626. package/lib/utils/notification/toast/index.d.ts.map +1 -0
  627. package/lib/utils/notification/toast/index.js +2 -0
  628. package/lib/utils/notification/toast/types.d.ts +2 -0
  629. package/lib/utils/notification/toast/types.d.ts.map +1 -0
  630. package/lib/utils/notification/toast/types.js +1 -0
  631. package/lib/utils/notification/toast/utils.d.ts +6 -0
  632. package/lib/utils/notification/toast/utils.d.ts.map +1 -0
  633. package/lib/utils/notification/toast/utils.js +23 -0
  634. package/lib/utils/routes/index.d.ts +4 -0
  635. package/lib/utils/routes/index.d.ts.map +1 -0
  636. package/lib/utils/routes/index.js +3 -0
  637. package/lib/utils/routes/types.d.ts +10 -0
  638. package/lib/utils/routes/types.d.ts.map +1 -0
  639. package/lib/utils/routes/types.js +1 -0
  640. package/lib/utils/routes/utils.d.ts +5 -0
  641. package/lib/utils/routes/utils.d.ts.map +1 -0
  642. package/lib/utils/routes/utils.js +3 -0
  643. package/lib/utils/scale.d.ts +4 -0
  644. package/lib/utils/scale.d.ts.map +1 -0
  645. package/lib/utils/scale.js +15 -0
  646. package/lib/utils/ui/color/index.d.ts +3 -0
  647. package/lib/utils/ui/color/index.d.ts.map +1 -0
  648. package/lib/utils/ui/color/index.js +2 -0
  649. package/lib/utils/ui/color/utils.d.ts +2 -0
  650. package/lib/utils/ui/color/utils.d.ts.map +1 -0
  651. package/lib/utils/ui/color/utils.js +9 -0
  652. package/lib/utils/ui/index.d.ts +2 -0
  653. package/lib/utils/ui/index.d.ts.map +1 -0
  654. package/lib/utils/ui/index.js +1 -0
  655. package/package.json +7 -6
@@ -0,0 +1,55 @@
1
+ import type { ReactNode } from 'react';
2
+ import type { TextProps as NativeTextProps, StyleProp, TextStyle } from 'react-native';
3
+ import type { Color, FontSize, FontWeight, Scale } from '../../theme';
4
+ export interface TextProps extends NativeTextProps {
5
+ /**
6
+ * Text content.
7
+ */
8
+ children: ReactNode;
9
+ /**
10
+ * Size of the text.
11
+ */
12
+ fontSize?: FontSize;
13
+ /**
14
+ * Font weight of the text.
15
+ */
16
+ fontWeight?: FontWeight;
17
+ /**
18
+ * Visual color to apply to the text.
19
+ */
20
+ color?: Color;
21
+ /**
22
+ * Additional style.
23
+ */
24
+ style?: StyleProp<TextStyle>;
25
+ /**
26
+ * Specifies the alignment of the text.
27
+ */
28
+ textAlign?: 'auto' | 'left' | 'right' | 'center' | 'justify' | undefined;
29
+ /**
30
+ * Transform the text.
31
+ */
32
+ textTransform?: 'none' | 'capitalize' | 'uppercase' | 'lowercase' | undefined;
33
+ /**
34
+ * Specifies the decoration of the text.
35
+ */
36
+ textDecorationLine?: 'none' | 'underline' | 'line-through' | 'underline line-through' | undefined;
37
+ /**
38
+ * Testing id of the component.
39
+ */
40
+ testID?: string;
41
+ /**
42
+ * The typeface to render the text in:
43
+ * - `neutral`: The default typeface for the platform.
44
+ */
45
+ typeface?: keyof Scale['font'];
46
+ /**
47
+ * Whether to render the text with rich text formatting.
48
+ */
49
+ useRichText?: boolean;
50
+ }
51
+ export interface TagStyle {
52
+ pattern: RegExp;
53
+ props: Partial<TextProps>;
54
+ }
55
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Text/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,SAAS,IAAI,eAAe,EAAG,SAAS,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAExF,OAAO,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEtE,MAAM,WAAW,SAAU,SAAQ,eAAe;IAChD;;OAEG;IACJ,QAAQ,EAAE,SAAS,CAAC;IAEnB;;OAEG;IACJ,QAAQ,CAAC,EAAE,QAAQ,CAAC;IAEnB;;OAEG;IACJ,UAAU,CAAC,EAAE,UAAU,CAAC;IAEvB;;OAEG;IACJ,KAAK,CAAC,EAAE,KAAK,CAAC;IAEb;;OAEG;IACJ,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;IAE5B;;OAEG;IACJ,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,SAAS,CAAC;IAExE;;OAEG;IACJ,aAAa,CAAC,EAAE,MAAM,GAAG,YAAY,GAAG,WAAW,GAAG,WAAW,GAAG,SAAS,CAAC;IAE9E;;OAEG;IACH,kBAAkB,CAAC,EAAE,MAAM,GAAG,WAAW,GAAG,cAAc,GAAG,wBAAwB,GAAG,SAAS,CAAC;IAEjG;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACJ,QAAQ,CAAC,EAAE,MAAM,KAAK,CAAC,MAAM,CAAC,CAAC;IAE/B;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAC;CACtB;AACD,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;CAC3B"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import type { TextProps } from './types';
3
+ export declare const withRichText: (BaseText: React.ComponentType<TextProps>) => (props: TextProps & {
4
+ useRichText?: boolean;
5
+ }) => import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=withRichText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"withRichText.d.ts","sourceRoot":"","sources":["../../../src/components/Text/withRichText.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAwCzC,eAAO,MAAM,YAAY,aAAc,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,aACnC,SAAS,GAAG;IAAE,WAAW,CAAC,EAAE,OAAO,CAAA;CAAE,4CAatE,CAAC"}
@@ -0,0 +1,38 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { createElement as _createElement } from "react";
3
+ import isString from 'lodash/fp/isString';
4
+ import React from 'react';
5
+ import { SUPPORTED_RICH_TEXT_TAGS } from './constants';
6
+ const processText = (text, BaseText, parentProps) => {
7
+ if (typeof text !== 'string') {
8
+ return text;
9
+ }
10
+ let lastIndex = 0;
11
+ const elements = [];
12
+ SUPPORTED_RICH_TEXT_TAGS.forEach(({ pattern, props }) => {
13
+ const matches = Array.from(text.matchAll(pattern));
14
+ matches.forEach(match => {
15
+ const [fullMatch, content] = match;
16
+ const startIndex = match.index;
17
+ if (startIndex > lastIndex) {
18
+ elements.push(text.slice(lastIndex, startIndex));
19
+ }
20
+ elements.push(_createElement(BaseText, { ...parentProps, ...props, key: startIndex }, content));
21
+ lastIndex = startIndex + fullMatch.length;
22
+ });
23
+ });
24
+ if (lastIndex < text.length) {
25
+ elements.push(text.slice(lastIndex));
26
+ }
27
+ return elements;
28
+ };
29
+ export const withRichText = (BaseText) => {
30
+ return function RichText(props) {
31
+ const { useRichText = false, children, } = props;
32
+ if (!useRichText || !isString(children)) {
33
+ return _jsx(BaseText, { ...props, children: children });
34
+ }
35
+ const processedChildren = processText(children.toString(), BaseText, props);
36
+ return _jsx(BaseText, { ...props, children: processedChildren });
37
+ };
38
+ };
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import type { TouchableProps } from './types';
3
+ export declare const Touchable: React.FC<TouchableProps>;
4
+ export * from './types';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Touchable/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAA+B,MAAM,OAAO,CAAC;AAWpD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAI9C,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAwE9C,CAAC;AAEF,cAAc,SAAS,CAAC"}
@@ -0,0 +1,56 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { isNil } from 'lodash';
3
+ import React, { useCallback, useMemo } from 'react';
4
+ import { Pressable } from 'react-native';
5
+ import Animated, { useAnimatedStyle, useSharedValue, withSpring, } from 'react-native-reanimated';
6
+ import { useTheme } from '../../theme';
7
+ import { HapticFeedback } from '../../utils';
8
+ const AnimatedPressable = Animated.createAnimatedComponent(Pressable);
9
+ export const Touchable = ({ children, onPress, style, hapticFeedback = 'soft', ...props }) => {
10
+ const theme = useTheme();
11
+ const themeAnimation = useMemo(() => theme.__hd__.touchable.animation, [theme.__hd__.touchable.animation]);
12
+ const scale = useSharedValue(themeAnimation.maxScale);
13
+ const opacity = useSharedValue(themeAnimation.maxOpacity);
14
+ const animatedStyle = useAnimatedStyle(() => {
15
+ return {
16
+ transform: [{ scale: scale.value }],
17
+ opacity: opacity.value,
18
+ };
19
+ });
20
+ const handlePressIn = useCallback(() => {
21
+ scale.value = withSpring(themeAnimation.minScale, {
22
+ mass: themeAnimation.springConfig.mass,
23
+ });
24
+ opacity.value = withSpring(themeAnimation.minOpacity, {
25
+ mass: themeAnimation.springConfig.mass,
26
+ });
27
+ const hapticFeedbackType = theme.__hd__.touchable.hapticFeedbackTypes[hapticFeedback];
28
+ if (!isNil(hapticFeedbackType)) {
29
+ HapticFeedback.trigger(hapticFeedbackType);
30
+ }
31
+ }, [
32
+ hapticFeedback,
33
+ opacity,
34
+ scale,
35
+ themeAnimation.minOpacity,
36
+ themeAnimation.minScale,
37
+ themeAnimation.springConfig.mass,
38
+ theme.__hd__.touchable.hapticFeedbackTypes,
39
+ ]);
40
+ const handlePressOut = useCallback(() => {
41
+ scale.value = withSpring(themeAnimation.maxScale, {
42
+ mass: themeAnimation.springConfig.mass,
43
+ });
44
+ opacity.value = withSpring(themeAnimation.maxOpacity, {
45
+ mass: themeAnimation.springConfig.mass,
46
+ });
47
+ }, [
48
+ opacity,
49
+ scale,
50
+ themeAnimation.maxOpacity,
51
+ themeAnimation.maxScale,
52
+ themeAnimation.springConfig.mass,
53
+ ]);
54
+ return (_jsx(AnimatedPressable, { onPress: onPress, onPressIn: handlePressIn, onPressOut: handlePressOut, style: [animatedStyle, style], ...props, children: children }));
55
+ };
56
+ export * from './types';
@@ -0,0 +1,22 @@
1
+ import type { PressableProps, StyleProp, ViewStyle } from 'react-native';
2
+ import type { TouchableHapticFeedbackType } from '../../theme';
3
+ import type { BoxProps } from '../Box';
4
+ export interface TouchableProps extends PressableProps, Omit<BoxProps, 'hitSlop'> {
5
+ /**
6
+ * Haptic feedback type.
7
+ */
8
+ hapticFeedback?: TouchableHapticFeedbackType;
9
+ /**
10
+ * Touchable's content.
11
+ */
12
+ children?: React.ReactNode | undefined;
13
+ /**
14
+ * Additional styles.
15
+ */
16
+ style?: StyleProp<ViewStyle> | undefined;
17
+ /**
18
+ * Testing id of the component.
19
+ */
20
+ testID?: string | undefined;
21
+ }
22
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Touchable/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzE,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAC;AAC/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAEvC,MAAM,WAAW,cACf,SAAQ,cAAc,EACpB,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC;IAC3B;;OAEG;IACH,cAAc,CAAC,EAAE,2BAA2B,CAAC;IAC7C;;OAEG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;IACvC;;OAEG;IACH,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC;IACzC;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC7B"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,49 @@
1
+ import { View } from 'react-native';
2
+ declare const StyledControlContainer: import("@emotion/native").StyledComponent<import("react-native").ViewProps & {
3
+ theme?: import("@emotion/react").Theme;
4
+ as?: React.ElementType;
5
+ } & {
6
+ mode: "fullscreen" | "standard";
7
+ }, {}, {
8
+ ref?: import("react").Ref<View> | undefined;
9
+ }>;
10
+ declare const StyledControlWrapper: import("@emotion/native").StyledComponent<import("react-native").ViewProps & {
11
+ theme?: import("@emotion/react").Theme;
12
+ as?: React.ElementType;
13
+ } & {
14
+ mode: "fullscreen" | "standard";
15
+ }, {}, {
16
+ ref?: import("react").Ref<View> | undefined;
17
+ }>;
18
+ declare const StyledActionButtons: import("@emotion/native").StyledComponent<import("..").BoxProps & {
19
+ ref?: import("react").ForwardedRef<View>;
20
+ } & {
21
+ theme?: import("@emotion/react").Theme;
22
+ as?: React.ElementType;
23
+ } & {
24
+ mode: "fullscreen" | "standard";
25
+ }, {}, {}>;
26
+ declare const StyledSeekBarWrapper: import("@emotion/native").StyledComponent<import("react-native").PressableProps & import("react").RefAttributes<View> & {
27
+ theme?: import("@emotion/react").Theme;
28
+ as?: React.ElementType;
29
+ } & {
30
+ mode: "fullscreen" | "standard";
31
+ }, {}, {}>;
32
+ declare const StyledSeekBar: import("@emotion/native").StyledComponent<import("..").BoxProps & {
33
+ ref?: import("react").ForwardedRef<View>;
34
+ } & {
35
+ theme?: import("@emotion/react").Theme;
36
+ as?: React.ElementType;
37
+ } & {
38
+ mode: "fullscreen" | "standard";
39
+ }, {}, {}>;
40
+ declare const StyledTextContainer: import("@emotion/native").StyledComponent<import("react-native").ViewProps & {
41
+ theme?: import("@emotion/react").Theme;
42
+ as?: React.ElementType;
43
+ } & {
44
+ mode: "fullscreen" | "standard";
45
+ }, {}, {
46
+ ref?: import("react").Ref<View> | undefined;
47
+ }>;
48
+ export { StyledControlContainer, StyledControlWrapper, StyledActionButtons, StyledSeekBarWrapper, StyledSeekBar, StyledTextContainer, };
49
+ //# sourceMappingURL=StyledVideoControlManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledVideoControlManager.d.ts","sourceRoot":"","sources":["../../../src/components/Video/StyledVideoControlManager.tsx"],"names":[],"mappings":"AACA,OAAO,EAAa,IAAI,EAAE,MAAM,cAAc,CAAC;AAI/C,QAAA,MAAM,sBAAsB;;SAuFojF,MAAO,WAAW;;UAtF1lF,YAAY,GAAG,UAAU;;;EAa/B,CAAC;AAEH,QAAA,MAAM,oBAAoB;;SAuEsjF,MAAO,WAAW;;UAtE1lF,YAAY,GAAG,UAAU;;;EAW/B,CAAC;AAEH,QAAA,MAAM,mBAAmB;;;;SAyDk3G,MAAO,WAAW;;UAxDr5G,YAAY,GAAG,UAAU;UAa/B,CAAC;AAEH,QAAA,MAAM,oBAAoB;;SAyCi3G,MAAO,WAAW;;UAxCr5G,YAAY,GAAG,UAAU;UAO/B,CAAC;AAEH,QAAA,MAAM,aAAa;;;;SA+Bw3G,MAAO,WAAW;;UA9Br5G,YAAY,GAAG,UAAU;UAO/B,CAAC;AAGH,QAAA,MAAM,mBAAmB;;SAoBujF,MAAO,WAAW;;UAnB1lF,YAAY,GAAG,UAAU;;;EAS/B,CAAC;AAEH,OAAO,EACL,sBAAsB,EACtB,oBAAoB,EACpB,mBAAmB,EACnB,oBAAoB,EACpB,aAAa,EACb,mBAAmB,GACpB,CAAC"}
@@ -0,0 +1,64 @@
1
+ import styled from '@emotion/native';
2
+ import { Pressable, View } from 'react-native';
3
+ import { Box } from '../Box';
4
+ const StyledControlContainer = styled(View)(({ theme, mode }) => {
5
+ return {
6
+ flex: 1,
7
+ paddingBottom: theme.__hd__.video.videoControlContainerPadding[mode],
8
+ paddingHorizontal: theme.__hd__.video.videoControlContainerPadding[mode],
9
+ position: 'absolute',
10
+ top: 0,
11
+ left: 0,
12
+ right: 0,
13
+ bottom: 0,
14
+ justifyContent: 'flex-end',
15
+ };
16
+ });
17
+ const StyledControlWrapper = styled(View)(({ theme, mode }) => {
18
+ return {
19
+ height: mode === 'fullscreen' ? 'auto' : theme.__hd__.video.defaultHeight,
20
+ flex: mode === 'fullscreen' ? 1 : undefined,
21
+ display: 'flex',
22
+ flexDirection: mode === 'fullscreen' ? 'column' : 'row',
23
+ alignItems: 'center',
24
+ justifyContent: 'flex-end',
25
+ marginBottom: theme.__hd__.video.defaultSpace,
26
+ };
27
+ });
28
+ const StyledActionButtons = styled(Box)(({ theme, mode }) => {
29
+ return {
30
+ alignItems: 'center',
31
+ display: 'flex',
32
+ flexDirection: 'row',
33
+ position: mode === 'fullscreen' ? 'absolute' : 'relative',
34
+ top: mode === 'fullscreen' ? 0 : undefined,
35
+ left: mode === 'fullscreen' ? -theme.__hd__.video.defaultSpace : undefined,
36
+ right: mode === 'fullscreen' ? -theme.__hd__.video.defaultSpace : undefined,
37
+ bottom: mode === 'fullscreen' ? 0 : undefined,
38
+ justifyContent: 'space-evenly',
39
+ };
40
+ });
41
+ const StyledSeekBarWrapper = styled(Pressable)(({ theme, mode }) => {
42
+ return {
43
+ flex: mode === 'fullscreen' ? undefined : 1,
44
+ width: theme.__hd__.video.defaultWidth,
45
+ height: mode === 'fullscreen' ? theme.__hd__.video.defaultHeight : 'auto',
46
+ };
47
+ });
48
+ const StyledSeekBar = styled(Box)(({ theme }) => {
49
+ return {
50
+ marginVertical: 12,
51
+ backgroundColor: theme.colors.grey400,
52
+ borderRadius: 999,
53
+ };
54
+ });
55
+ const StyledTextContainer = styled(View)(({ theme, mode }) => {
56
+ return {
57
+ display: 'flex',
58
+ flexDirection: 'row',
59
+ marginHorizontal: 2,
60
+ marginBottom: mode === 'fullscreen' ? 40 : undefined,
61
+ width: mode === 'fullscreen' ? theme.__hd__.video.defaultWidth : undefined,
62
+ };
63
+ });
64
+ export { StyledControlContainer, StyledControlWrapper, StyledActionButtons, StyledSeekBarWrapper, StyledSeekBar, StyledTextContainer, };
@@ -0,0 +1,16 @@
1
+ declare const StyledVideoContainer: import("@emotion/native").StyledComponent<import("..").BoxProps & {
2
+ ref?: import("react").ForwardedRef<import("react-native").View>;
3
+ } & {
4
+ theme?: import("@emotion/react").Theme;
5
+ as?: React.ElementType;
6
+ } & {
7
+ mode: "fullscreen" | "standard";
8
+ }, {}, {}>;
9
+ declare const StyledVideoOverlay: import("@emotion/native").StyledComponent<import("..").BoxProps & {
10
+ ref?: import("react").ForwardedRef<import("react-native").View>;
11
+ } & {
12
+ theme?: import("@emotion/react").Theme;
13
+ as?: React.ElementType;
14
+ }, {}, {}>;
15
+ export { StyledVideoContainer, StyledVideoOverlay };
16
+ //# sourceMappingURL=StyledVideoDetail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyledVideoDetail.d.ts","sourceRoot":"","sources":["../../../src/components/Video/StyledVideoDetail.tsx"],"names":[],"mappings":"AAIA,QAAA,MAAM,oBAAoB;;;;SA2BguK,MAAO,WAAW;;UA1BpwK,YAAY,GAAG,UAAU;UAQ/B,CAAC;AAEH,QAAA,MAAM,kBAAkB;;;;SAgBkuK,MAAO,WAAW;UAJ1wK,CAAC;AAGH,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,CAAC"}
@@ -0,0 +1,23 @@
1
+ import styled from '@emotion/native';
2
+ import { Box } from '../Box';
3
+ const StyledVideoContainer = styled(Box)(({ theme, mode }) => {
4
+ return {
5
+ flex: 1,
6
+ backgroundColor: theme.__hd__.video.videoDetailBackgroundColor[mode],
7
+ alignItems: 'center',
8
+ justifyContent: 'center',
9
+ };
10
+ });
11
+ const StyledVideoOverlay = styled(Box)(() => {
12
+ return {
13
+ position: 'absolute',
14
+ top: 0,
15
+ left: 0,
16
+ right: 0,
17
+ bottom: 0,
18
+ backgroundColor: 'black',
19
+ opacity: 0.4,
20
+ display: 'flex',
21
+ };
22
+ });
23
+ export { StyledVideoContainer, StyledVideoOverlay };
@@ -0,0 +1,10 @@
1
+ import type { PlaySwitchProps } from '../PlaySwitch/types';
2
+ interface VideoControlManagerProps extends PlaySwitchProps {
3
+ onSeek: (position: number) => void;
4
+ currentPosition?: number;
5
+ duration?: number;
6
+ mode: 'fullscreen' | 'standard';
7
+ }
8
+ declare const VideoControlManager: ({ onSeek, currentPosition, duration, mode, status, onChange, }: VideoControlManagerProps) => import("react/jsx-runtime").JSX.Element;
9
+ export default VideoControlManager;
10
+ //# sourceMappingURL=VideoControlManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VideoControlManager.d.ts","sourceRoot":"","sources":["../../../src/components/Video/VideoControlManager.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAY3D,UAAU,wBAAyB,SAAQ,eAAe;IACxD,MAAM,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,YAAY,GAAG,UAAU,CAAC;CACjC;AAED,QAAA,MAAM,mBAAmB,mEAOtB,wBAAwB,4CAkJ1B,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
@@ -0,0 +1,67 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useTheme } from '@emotion/react';
3
+ import { useCallback, useEffect, useRef, useState } from 'react';
4
+ import { View } from 'react-native';
5
+ import Animated, { Easing, useAnimatedStyle, useSharedValue, withTiming } from 'react-native-reanimated';
6
+ import { Box } from '../Box';
7
+ import { Icon } from '../Icon';
8
+ import { PlaySwitch } from '../PlaySwitch';
9
+ import { Text } from '../Text';
10
+ import { Touchable } from '../Touchable';
11
+ import { StyledActionButtons, StyledControlContainer, StyledControlWrapper, StyledSeekBarWrapper, StyledTextContainer, } from './StyledVideoControlManager';
12
+ const VideoControlManager = ({ onSeek, currentPosition, duration, mode, status, onChange, }) => {
13
+ const theme = useTheme();
14
+ const themeVideo = theme.__hd__.video;
15
+ const [position, setPosition] = useState(0);
16
+ const pressableRef = useRef(null);
17
+ const [width, setWidth] = useState(0);
18
+ const innerSeekWidth = useSharedValue(position);
19
+ useEffect(() => {
20
+ if (currentPosition !== undefined &&
21
+ duration !== undefined &&
22
+ duration > 0) {
23
+ const newPosition = width * currentPosition / duration;
24
+ setPosition(newPosition);
25
+ innerSeekWidth.value = withTiming(newPosition, {
26
+ duration: 200,
27
+ easing: Easing.out(Easing.poly(8)),
28
+ });
29
+ }
30
+ }, [currentPosition, duration, innerSeekWidth, width]);
31
+ const onPressSeekBar = useCallback((event) => {
32
+ if (width === 0) {
33
+ return;
34
+ }
35
+ const touchX = event.nativeEvent.locationX;
36
+ if (duration !== undefined && duration > 0) {
37
+ onSeek(touchX / width * duration);
38
+ }
39
+ }, [width, duration, onSeek]);
40
+ const onForward = useCallback(() => {
41
+ if (duration !== undefined && duration > 0) {
42
+ onSeek(Math.min(currentPosition ? currentPosition + 5 : duration, duration));
43
+ }
44
+ }, [currentPosition, duration, onSeek]);
45
+ const onBackward = useCallback(() => {
46
+ if (duration !== undefined && duration > 0) {
47
+ onSeek(Math.max(currentPosition ? currentPosition - 5 : duration, 0));
48
+ }
49
+ }, [currentPosition, duration, onSeek]);
50
+ const onLayout = useCallback((event) => {
51
+ const { width: newWidth } = event.nativeEvent.layout;
52
+ setWidth(newWidth);
53
+ }, []);
54
+ const innerSeekAnimatedStyle = useAnimatedStyle(() => ({
55
+ width: innerSeekWidth.value,
56
+ }));
57
+ const parseTime = (time) => {
58
+ return time ?
59
+ `${Math.floor(time / 60)}:${('0' + Math.floor(time % 60)).slice(-2)}`
60
+ : '0:00';
61
+ };
62
+ return (_jsx(StyledControlContainer, { mode: mode, children: _jsxs(StyledControlWrapper, { mode: mode, children: [_jsxs(StyledActionButtons, { mode: mode, children: [mode === 'fullscreen' &&
63
+ _jsx(Touchable, { onPress: onBackward, children: _jsx(Icon, { icon: "arrow-left-bold", color: themeVideo.actionColor[mode], size: themeVideo.actionButtonsSize[mode] }) }), _jsx(PlaySwitch, { marginHorizontal: "xxsmall", size: themeVideo.actionButtonsSize[mode], color: themeVideo.actionColor[mode], onChange: onChange, status: status }), mode === 'fullscreen' &&
64
+ _jsx(Touchable, { onPress: onForward, children: _jsx(Icon, { icon: "arrow-right-bold", color: themeVideo.actionColor[mode], size: themeVideo.actionButtonsSize[mode] }) })] }), _jsx(StyledSeekBarWrapper, { ref: pressableRef, onPress: onPressSeekBar, onLayout: onLayout, mode: mode, children: _jsx(Box, { marginVertical: "smallMedium", backgroundColor: "grey400", borderRadius: "rounded", children: _jsx(Animated.View, { style: [innerSeekAnimatedStyle], children: _jsx(Box, { height: "100%", width: "100%", backgroundColor: themeVideo.actionColor[mode], borderRadius: "rounded" }) }) }) }), _jsxs(StyledTextContainer, { mode: mode, children: [_jsx(Text, { color: "grey700", fontSize: "xlarge", fontWeight: "medium", children: parseTime(currentPosition) }), mode !== 'fullscreen' ||
65
+ _jsxs(_Fragment, { children: [_jsx(Box, { flex: 1 }), _jsx(Text, { color: "grey700", fontSize: "xlarge", fontWeight: "medium", children: `-${parseTime((duration ?? 0) - (currentPosition ?? 0))}` })] })] })] }) }));
66
+ };
67
+ export default VideoControlManager;
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import type { VideoChatProps } from '../../components/Chat/type';
3
+ import type { VideoRef } from '../../components/Video';
4
+ type VideoDetailProps = VideoChatProps & {
5
+ onBack: () => void;
6
+ initialPosition?: number;
7
+ videoRef: React.RefObject<VideoRef>;
8
+ };
9
+ declare const VideoDetail: React.FC<VideoDetailProps>;
10
+ export default VideoDetail;
11
+ //# sourceMappingURL=VideoDetail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VideoDetail.d.ts","sourceRoot":"","sources":["../../../src/components/Video/VideoDetail.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAOxC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAOvD,KAAK,gBAAgB,GAAG,cAAc,GAAG;IACvC,MAAM,EAAE,MAAM,IAAI,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;CACrC,CAAC;AAmBF,QAAA,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CA8K3C,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,102 @@
1
+ import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import styled from '@emotion/native';
3
+ import { useTheme } from '@emotion/react';
4
+ import React, { useState } from 'react';
5
+ import { Pressable, useWindowDimensions } from 'react-native';
6
+ import Orientation from 'react-native-orientation-locker';
7
+ import { Base, Box, Icon, Touchable } from '../../components';
8
+ import { calculateCanvasSize } from '../../components/Image/utils';
9
+ import { Video } from '../../components/Video';
10
+ import { StyledVideoContainer, StyledVideoOverlay } from './StyledVideoDetail';
11
+ import VideoControlManager from './VideoControlManager';
12
+ const StyledVideo = styled(Video)(({ theme, mode, fullscreenSize, canvasBox }) => {
13
+ return {
14
+ width: mode === 'fullscreen' ? fullscreenSize.width : canvasBox.width,
15
+ height: mode === 'fullscreen' ? fullscreenSize.height : canvasBox.height ?? -theme.spaces.xxlarge,
16
+ };
17
+ });
18
+ const VideoDetail = ({ source, width, height, videoRef, initialPosition, onBack, }) => {
19
+ const theme = useTheme();
20
+ const themeVideo = theme.__hd__.video;
21
+ const [boxWidth, setBoxWidth] = useState(0);
22
+ const [boxHeight, setBoxHeight] = useState(0);
23
+ const [mode, setMode] = useState('standard');
24
+ const [play, setPlay] = useState(true);
25
+ const [seeking, setSeeking] = useState(false);
26
+ const [currentPosition, setCurrentPosition] = useState(0);
27
+ const [duration, setDuration] = useState(0);
28
+ const [showControl, setShowControl] = useState(true);
29
+ const [canvasBox, setCanvasBox] = useState({
30
+ width: undefined,
31
+ height: undefined,
32
+ });
33
+ const windowDimension = useWindowDimensions();
34
+ if (!source) {
35
+ return _jsx(_Fragment, {});
36
+ }
37
+ const fullscreenSize = calculateCanvasSize(width, height, windowDimension.width, 1, windowDimension.width / windowDimension.height);
38
+ const onLayout = (event) => {
39
+ const { width: sWidth, height: sHeight } = event.nativeEvent.layout;
40
+ if (width !== boxWidth || height !== boxHeight) {
41
+ setBoxWidth(sWidth);
42
+ setBoxHeight(sHeight);
43
+ setCanvasBox(calculateCanvasSize(width, height, sWidth, 1, (sHeight > 0) ? sWidth / sHeight : undefined));
44
+ }
45
+ };
46
+ const handlePlaySwitchStatus = () => {
47
+ if (play) {
48
+ pauseAllStates();
49
+ return;
50
+ }
51
+ videoRef.current?.resume();
52
+ setPlay(true);
53
+ setTimeout(() => setShowControl(false), 2000);
54
+ };
55
+ const pauseAllStates = () => {
56
+ videoRef.current?.pause();
57
+ setPlay(false);
58
+ setShowControl(true);
59
+ };
60
+ const handleSeek = (position) => {
61
+ setSeeking(true);
62
+ setCurrentPosition(position);
63
+ videoRef.current?.seek(position);
64
+ };
65
+ const handleProgress = (position) => {
66
+ if (seeking) {
67
+ setSeeking(false);
68
+ return;
69
+ }
70
+ setCurrentPosition(position);
71
+ };
72
+ const handleControls = () => {
73
+ if (showControl) {
74
+ setShowControl(false);
75
+ }
76
+ else {
77
+ setShowControl(true);
78
+ }
79
+ };
80
+ const handleInit = (e) => {
81
+ setDuration(e.duration);
82
+ };
83
+ const changeToFullscreen = () => {
84
+ if (mode === 'standard') {
85
+ setMode('fullscreen');
86
+ setShowControl(true);
87
+ if (width && height && width > height) {
88
+ Orientation.lockToLandscape();
89
+ }
90
+ }
91
+ };
92
+ const exitFullscreen = () => {
93
+ if (mode === 'fullscreen') {
94
+ setMode('standard');
95
+ Orientation.lockToPortrait();
96
+ }
97
+ };
98
+ return (_jsxs(Base, { flex: 1, padding: themeVideo.videoDetailBasePadding[mode], children: [_jsxs(StyledVideoContainer, { mode: mode, onLayout: mode === 'fullscreen' ? undefined : onLayout, children: [_jsx(Pressable, { onPress: mode === 'fullscreen' ? handleControls : changeToFullscreen, children: _jsx(Box, { borderRadius: themeVideo.videoDetailBorderRadius[mode], width: mode === 'fullscreen' ? fullscreenSize.width : canvasBox.width, height: mode === 'fullscreen' ? fullscreenSize.height : canvasBox.height ?? -theme.spaces.xxlarge, overflow: "hidden", children: _jsx(StyledVideo, { ref: videoRef, source: source, initialPosition: initialPosition, initialPlay: true, mode: mode, fullscreenSize: fullscreenSize, canvasBox: canvasBox, theme: theme, tracking: handleProgress, onInit: handleInit }) }) }), (showControl && mode === 'fullscreen') &&
99
+ _jsx(StyledVideoOverlay, { children: _jsx(Touchable, { onPress: handleControls, flex: 1 }) })] }), (showControl || mode !== 'fullscreen') &&
100
+ _jsx(VideoControlManager, { status: play ? 'pause' : 'play', onChange: handlePlaySwitchStatus, onSeek: handleSeek, currentPosition: currentPosition, duration: duration, mode: mode }), _jsx(Box, { position: "absolute", top: 0, left: 0, padding: "large", children: _jsx(Touchable, { onPress: mode === 'fullscreen' ? exitFullscreen : onBack, children: _jsx(Icon, { art: "arrow-left-light", size: themeVideo.defaultActionIconSize, color: themeVideo.videoDetailActionButtonColor[mode] }) }) })] }));
101
+ };
102
+ export default VideoDetail;
@@ -0,0 +1,25 @@
1
+ import { type ForwardedRef } from 'react';
2
+ import type { StyleProp, ViewStyle } from 'react-native';
3
+ import type { OnLoadData, ReactVideoSourceProperties, VideoRef as RNVideoRef } from 'react-native-video';
4
+ export interface VideoProps {
5
+ source: Readonly<Omit<ReactVideoSourceProperties, 'uri'> & {
6
+ uri?: string | NodeRequire | undefined;
7
+ }> | undefined;
8
+ initialPosition?: number;
9
+ initialPlay?: boolean;
10
+ style?: StyleProp<ViewStyle>;
11
+ afterEnd?: () => void;
12
+ tracking?: (currentTime: number) => void;
13
+ onInit?: (e: OnLoadData) => void;
14
+ }
15
+ export interface VideoRef extends Pick<RNVideoRef, 'seek' | 'pause' | 'resume'> {
16
+ play: boolean;
17
+ currentTime: number;
18
+ duration: number;
19
+ }
20
+ declare const PlainVideo: ({ source, initialPosition, initialPlay, style, afterEnd, tracking, onInit, }: VideoProps, ref: React.Ref<VideoRef>) => import("react/jsx-runtime").JSX.Element;
21
+ export declare const Video: (props: VideoProps & {
22
+ ref?: ForwardedRef<VideoRef>;
23
+ }) => ReturnType<typeof PlainVideo>;
24
+ export {};
25
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Video/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,YAAY,EAMlB,MAAM,OAAO,CAAC;AACf,OAAO,KAAK,EACV,SAAS,EACT,SAAS,EACV,MAAM,cAAc,CAAC;AAEtB,OAAO,KAAK,EACV,UAAU,EAEV,0BAA0B,EAC1B,QAAQ,IAAI,UAAU,EACvB,MAAM,oBAAoB,CAAC;AAE5B,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC,GAAG;QACzD,GAAG,CAAC,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS,CAAC;KACxC,CAAC,GAAG,SAAS,CAAC;IAEf,eAAe,CAAC,EAAE,MAAM,CAAC;IAEzB,WAAW,CAAC,EAAE,OAAO,CAAC;IAEtB,KAAK,CAAC,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;IAE7B,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IAEtB,QAAQ,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,IAAI,CAAC;IAEzC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,UAAU,KAAK,IAAI,CAAC;CAClC;AAED,MAAM,WAAW,QAAS,SAAQ,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;IAC7E,IAAI,EAAE,OAAO,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,QAAA,MAAM,UAAU,iFAQb,UAAU,OAAO,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,4CAiEtC,CAAC;AAEF,eAAO,MAAM,KAAK,EAA6B,CAC7C,KAAK,EAAE,UAAU,GAAG;IAAE,GAAG,CAAC,EAAE,YAAY,CAAC,QAAQ,CAAC,CAAA;CAAE,KACjD,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC"}