@amityco/react-native-social-uikit 4.0.0-RC7 → 4.0.0-a9cb7bb.0

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 (416) hide show
  1. package/README.md +14 -14
  2. package/lib/commonjs/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js +1 -1
  3. package/lib/commonjs/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js.map +1 -1
  4. package/lib/commonjs/components/MediaSection/index.js +3 -3
  5. package/lib/commonjs/components/MediaSection/index.js.map +1 -1
  6. package/lib/commonjs/components/PostTypeChoiceModal/PostTypeChoiceModal.js +14 -5
  7. package/lib/commonjs/components/PostTypeChoiceModal/PostTypeChoiceModal.js.map +1 -1
  8. package/lib/commonjs/components/PostTypeChoiceModal/style.js +1 -2
  9. package/lib/commonjs/components/PostTypeChoiceModal/style.js.map +1 -1
  10. package/lib/commonjs/components/Social/PostList/index.js +1 -3
  11. package/lib/commonjs/components/Social/PostList/index.js.map +1 -1
  12. package/lib/commonjs/index.js +6 -0
  13. package/lib/commonjs/index.js.map +1 -1
  14. package/lib/commonjs/screens/CategorytList/index.js.map +1 -1
  15. package/lib/commonjs/screens/CreateLivestream/CreateLivestream.js +16 -16
  16. package/lib/commonjs/screens/CreateLivestream/CreateLivestream.js.map +1 -1
  17. package/lib/commonjs/screens/LivestreamPlayer/index.js +3 -6
  18. package/lib/commonjs/screens/LivestreamPlayer/index.js.map +1 -1
  19. package/lib/commonjs/snippet/AmityCommunitySearchResultComponent.js +3 -3
  20. package/lib/commonjs/snippet/AmityCommunitySearchResultComponent.js.map +1 -1
  21. package/lib/commonjs/snippet/AmityCreatePostMenuComponent.js +3 -3
  22. package/lib/commonjs/snippet/AmityCreatePostMenuComponent.js.map +1 -1
  23. package/lib/commonjs/snippet/AmityDetailedMediaAttachmentComponent.js +4 -4
  24. package/lib/commonjs/snippet/AmityDetailedMediaAttachmentComponent.js.map +1 -1
  25. package/lib/commonjs/snippet/AmityEmptyNewsFeedComponent.js +3 -3
  26. package/lib/commonjs/snippet/AmityEmptyNewsFeedComponent.js.map +1 -1
  27. package/lib/commonjs/snippet/AmityGlobalFeedComponent.js +3 -3
  28. package/lib/commonjs/snippet/AmityGlobalFeedComponent.js.map +1 -1
  29. package/lib/commonjs/snippet/AmityMediaAttachmentComponent.js +4 -4
  30. package/lib/commonjs/snippet/AmityMediaAttachmentComponent.js.map +1 -1
  31. package/lib/commonjs/snippet/AmityMyCommunitiesComponent.js +3 -3
  32. package/lib/commonjs/snippet/AmityMyCommunitiesComponent.js.map +1 -1
  33. package/lib/commonjs/snippet/AmityMyCommunitiesSearchPage.js +3 -3
  34. package/lib/commonjs/snippet/AmityMyCommunitiesSearchPage.js.map +1 -1
  35. package/lib/commonjs/snippet/AmityNewsFeedComponent.js +3 -3
  36. package/lib/commonjs/snippet/AmityNewsFeedComponent.js.map +1 -1
  37. package/lib/commonjs/snippet/AmityPostComposerPage.js +4 -4
  38. package/lib/commonjs/snippet/AmityPostComposerPage.js.map +1 -1
  39. package/lib/commonjs/snippet/AmityPostContentComponent.js +3 -3
  40. package/lib/commonjs/snippet/AmityPostContentComponent.js.map +1 -1
  41. package/lib/commonjs/snippet/AmityPostDetailPage.js +3 -3
  42. package/lib/commonjs/snippet/AmityPostDetailPage.js.map +1 -1
  43. package/lib/commonjs/snippet/AmityPostTargetSelectionPage.js +4 -4
  44. package/lib/commonjs/snippet/AmityPostTargetSelectionPage.js.map +1 -1
  45. package/lib/commonjs/snippet/AmityReactionListComponent.js +3 -3
  46. package/lib/commonjs/snippet/AmityReactionListComponent.js.map +1 -1
  47. package/lib/commonjs/snippet/AmitySocialGlobalSearchPage.js +3 -3
  48. package/lib/commonjs/snippet/AmitySocialGlobalSearchPage.js.map +1 -1
  49. package/lib/commonjs/snippet/AmitySocialHomePage.js +3 -3
  50. package/lib/commonjs/snippet/AmitySocialHomePage.js.map +1 -1
  51. package/lib/commonjs/snippet/AmitySocialHomeTopNavigationComponent.js +3 -3
  52. package/lib/commonjs/snippet/AmitySocialHomeTopNavigationComponent.js.map +1 -1
  53. package/lib/commonjs/snippet/AmityStoryTargetSelectionPage.js +3 -3
  54. package/lib/commonjs/snippet/AmityStoryTargetSelectionPage.js.map +1 -1
  55. package/lib/commonjs/snippet/AmityTopSearchBarComponent.js +3 -3
  56. package/lib/commonjs/snippet/AmityTopSearchBarComponent.js.map +1 -1
  57. package/lib/commonjs/snippet/AmityUserSearchResultComponent.js +3 -3
  58. package/lib/commonjs/snippet/AmityUserSearchResultComponent.js.map +1 -1
  59. package/lib/commonjs/svg/svg-xml-list.js +1 -1
  60. package/lib/commonjs/util/postTypeChecker.js.map +1 -1
  61. package/lib/commonjs/v4/PublicApi/Components/AmityCommunityFeedComponent/AmityCommunityFeedComponent.js.map +1 -1
  62. package/lib/commonjs/v4/PublicApi/Components/AmityCommunityProfileTabComponent/AmityCommunityProfileTabComponent.js.map +1 -1
  63. package/lib/commonjs/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js +11 -9
  64. package/lib/commonjs/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js.map +1 -1
  65. package/lib/commonjs/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.js +4 -3
  66. package/lib/commonjs/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.js.map +1 -1
  67. package/lib/commonjs/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.js +0 -1
  68. package/lib/commonjs/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.js.map +1 -1
  69. package/lib/commonjs/v4/PublicApi/Components/AmityReactionListComponent/AmityReactionListComponent.js.map +1 -1
  70. package/lib/commonjs/v4/PublicApi/Elements/ButtonWithIconElement/styles.js +3 -2
  71. package/lib/commonjs/v4/PublicApi/Elements/ButtonWithIconElement/styles.js.map +1 -1
  72. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js +28 -25
  73. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js.map +1 -1
  74. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js +2 -2
  75. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js.map +1 -1
  76. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js +206 -68
  77. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js.map +1 -1
  78. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js +50 -0
  79. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js.map +1 -0
  80. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js +71 -3
  81. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js.map +1 -1
  82. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js +117 -117
  83. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js.map +1 -1
  84. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js.map +1 -1
  85. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.js +7 -1
  86. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.js.map +1 -1
  87. package/lib/commonjs/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.js +7 -1
  88. package/lib/commonjs/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.js.map +1 -1
  89. package/lib/commonjs/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js +9 -2
  90. package/lib/commonjs/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js.map +1 -1
  91. package/lib/commonjs/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.js +7 -1
  92. package/lib/commonjs/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.js.map +1 -1
  93. package/lib/commonjs/v4/PublicApi/Pages/AmitySocialHomePage/AmitySocialHomePage.js.map +1 -1
  94. package/lib/commonjs/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.js +7 -1
  95. package/lib/commonjs/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.js.map +1 -1
  96. package/lib/commonjs/v4/component/LivestreamContent/index.js +12 -12
  97. package/lib/commonjs/v4/component/LivestreamContent/index.js.map +1 -1
  98. package/lib/commonjs/v4/component/MyStories/StoryCircleItem.js.map +1 -1
  99. package/lib/commonjs/v4/component/PostContent/index.js +4 -4
  100. package/lib/commonjs/v4/component/PostContent/index.js.map +1 -1
  101. package/lib/commonjs/v4/component/PostMenu/index.js +2 -2
  102. package/lib/commonjs/v4/component/PostMenu/index.js.map +1 -1
  103. package/lib/commonjs/v4/component/PreviewLink/LinkPreview.js +3 -3
  104. package/lib/commonjs/v4/component/PreviewLink/LinkPreview.js.map +1 -1
  105. package/lib/commonjs/v4/component/PreviewLink/utils.js +9 -73
  106. package/lib/commonjs/v4/component/PreviewLink/utils.js.map +1 -1
  107. package/lib/commonjs/v4/component/TargetSelectionPage/TargetSelectionPage.js +10 -4
  108. package/lib/commonjs/v4/component/TargetSelectionPage/TargetSelectionPage.js.map +1 -1
  109. package/lib/commonjs/v4/component/Toast/index.js +4 -4
  110. package/lib/commonjs/v4/component/Toast/index.js.map +1 -1
  111. package/lib/commonjs/v4/component/Toast/styles.js +2 -2
  112. package/lib/commonjs/v4/component/Toast/styles.js.map +1 -1
  113. package/lib/commonjs/v4/elements/ActionButton/ActionButton.js.map +1 -1
  114. package/lib/commonjs/v4/elements/ImageViewer/ImageViewer.js.map +1 -1
  115. package/lib/commonjs/v4/elements/VideoViewer/VideoViewer.js.map +1 -1
  116. package/lib/commonjs/v4/enum/roomStatus.js +14 -0
  117. package/lib/commonjs/v4/enum/roomStatus.js.map +1 -0
  118. package/lib/commonjs/v4/features/community/Membership/components/MemberItem/MemberItem.js.map +1 -1
  119. package/lib/commonjs/v4/features/community/shared/components/Privacy/index.js.map +1 -1
  120. package/lib/commonjs/v4/hook/index.js +22 -0
  121. package/lib/commonjs/v4/hook/index.js.map +1 -1
  122. package/lib/commonjs/v4/hook/useCustomRankingGlobalFeed.js +1 -3
  123. package/lib/commonjs/v4/hook/useCustomRankingGlobalFeed.js.map +1 -1
  124. package/lib/commonjs/v4/hook/useImagePicker.js.map +1 -1
  125. package/lib/commonjs/v4/hook/usePostSubscription.js +38 -0
  126. package/lib/commonjs/v4/hook/usePostSubscription.js.map +1 -0
  127. package/lib/commonjs/v4/hook/useRoomSubscription.js +22 -0
  128. package/lib/commonjs/v4/hook/useRoomSubscription.js.map +1 -0
  129. package/lib/commonjs/v4/index.js +7 -0
  130. package/lib/commonjs/v4/index.js.map +1 -1
  131. package/lib/commonjs/v4/providers/BehaviourProvider.js +2 -1
  132. package/lib/commonjs/v4/providers/BehaviourProvider.js.map +1 -1
  133. package/lib/commonjs/v4/stores/slices/toast.js +4 -1
  134. package/lib/commonjs/v4/stores/slices/toast.js.map +1 -1
  135. package/lib/module/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js +1 -1
  136. package/lib/module/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js.map +1 -1
  137. package/lib/module/components/MediaSection/index.js +3 -3
  138. package/lib/module/components/MediaSection/index.js.map +1 -1
  139. package/lib/module/components/PostTypeChoiceModal/PostTypeChoiceModal.js +15 -8
  140. package/lib/module/components/PostTypeChoiceModal/PostTypeChoiceModal.js.map +1 -1
  141. package/lib/module/components/PostTypeChoiceModal/style.js +1 -2
  142. package/lib/module/components/PostTypeChoiceModal/style.js.map +1 -1
  143. package/lib/module/components/Social/PostList/index.js +1 -3
  144. package/lib/module/components/Social/PostList/index.js.map +1 -1
  145. package/lib/module/index.js +2 -6
  146. package/lib/module/index.js.map +1 -1
  147. package/lib/module/screens/CategorytList/index.js.map +1 -1
  148. package/lib/module/screens/CreateLivestream/CreateLivestream.js +17 -17
  149. package/lib/module/screens/CreateLivestream/CreateLivestream.js.map +1 -1
  150. package/lib/module/screens/LivestreamPlayer/index.js +4 -8
  151. package/lib/module/screens/LivestreamPlayer/index.js.map +1 -1
  152. package/lib/module/snippet/AmityCommunitySearchResultComponent.js +1 -1
  153. package/lib/module/snippet/AmityCommunitySearchResultComponent.js.map +1 -1
  154. package/lib/module/snippet/AmityCreatePostMenuComponent.js +1 -1
  155. package/lib/module/snippet/AmityCreatePostMenuComponent.js.map +1 -1
  156. package/lib/module/snippet/AmityDetailedMediaAttachmentComponent.js +1 -1
  157. package/lib/module/snippet/AmityDetailedMediaAttachmentComponent.js.map +1 -1
  158. package/lib/module/snippet/AmityEmptyNewsFeedComponent.js +1 -1
  159. package/lib/module/snippet/AmityEmptyNewsFeedComponent.js.map +1 -1
  160. package/lib/module/snippet/AmityGlobalFeedComponent.js +1 -1
  161. package/lib/module/snippet/AmityGlobalFeedComponent.js.map +1 -1
  162. package/lib/module/snippet/AmityMediaAttachmentComponent.js +1 -1
  163. package/lib/module/snippet/AmityMediaAttachmentComponent.js.map +1 -1
  164. package/lib/module/snippet/AmityMyCommunitiesComponent.js +1 -1
  165. package/lib/module/snippet/AmityMyCommunitiesComponent.js.map +1 -1
  166. package/lib/module/snippet/AmityMyCommunitiesSearchPage.js +1 -1
  167. package/lib/module/snippet/AmityMyCommunitiesSearchPage.js.map +1 -1
  168. package/lib/module/snippet/AmityNewsFeedComponent.js +1 -1
  169. package/lib/module/snippet/AmityNewsFeedComponent.js.map +1 -1
  170. package/lib/module/snippet/AmityPostComposerPage.js +1 -1
  171. package/lib/module/snippet/AmityPostComposerPage.js.map +1 -1
  172. package/lib/module/snippet/AmityPostContentComponent.js +1 -1
  173. package/lib/module/snippet/AmityPostContentComponent.js.map +1 -1
  174. package/lib/module/snippet/AmityPostDetailPage.js +1 -1
  175. package/lib/module/snippet/AmityPostDetailPage.js.map +1 -1
  176. package/lib/module/snippet/AmityPostTargetSelectionPage.js +1 -1
  177. package/lib/module/snippet/AmityPostTargetSelectionPage.js.map +1 -1
  178. package/lib/module/snippet/AmityReactionListComponent.js +1 -1
  179. package/lib/module/snippet/AmityReactionListComponent.js.map +1 -1
  180. package/lib/module/snippet/AmitySocialGlobalSearchPage.js +1 -1
  181. package/lib/module/snippet/AmitySocialGlobalSearchPage.js.map +1 -1
  182. package/lib/module/snippet/AmitySocialHomePage.js +1 -1
  183. package/lib/module/snippet/AmitySocialHomePage.js.map +1 -1
  184. package/lib/module/snippet/AmitySocialHomeTopNavigationComponent.js +1 -1
  185. package/lib/module/snippet/AmitySocialHomeTopNavigationComponent.js.map +1 -1
  186. package/lib/module/snippet/AmityStoryTargetSelectionPage.js +1 -1
  187. package/lib/module/snippet/AmityStoryTargetSelectionPage.js.map +1 -1
  188. package/lib/module/snippet/AmityTopSearchBarComponent.js +1 -1
  189. package/lib/module/snippet/AmityTopSearchBarComponent.js.map +1 -1
  190. package/lib/module/snippet/AmityUserSearchResultComponent.js +1 -1
  191. package/lib/module/snippet/AmityUserSearchResultComponent.js.map +1 -1
  192. package/lib/module/svg/svg-xml-list.js +1 -1
  193. package/lib/module/util/postTypeChecker.js.map +1 -1
  194. package/lib/module/v4/PublicApi/Components/AmityCommunityFeedComponent/AmityCommunityFeedComponent.js.map +1 -1
  195. package/lib/module/v4/PublicApi/Components/AmityCommunityProfileTabComponent/AmityCommunityProfileTabComponent.js.map +1 -1
  196. package/lib/module/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js +11 -9
  197. package/lib/module/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js.map +1 -1
  198. package/lib/module/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.js +5 -4
  199. package/lib/module/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.js.map +1 -1
  200. package/lib/module/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.js +0 -1
  201. package/lib/module/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.js.map +1 -1
  202. package/lib/module/v4/PublicApi/Components/AmityReactionListComponent/AmityReactionListComponent.js.map +1 -1
  203. package/lib/module/v4/PublicApi/Elements/ButtonWithIconElement/styles.js +3 -2
  204. package/lib/module/v4/PublicApi/Elements/ButtonWithIconElement/styles.js.map +1 -1
  205. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js +29 -26
  206. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js.map +1 -1
  207. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js +2 -2
  208. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js.map +1 -1
  209. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js +211 -72
  210. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js.map +1 -1
  211. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js +42 -0
  212. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js.map +1 -0
  213. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js +71 -3
  214. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js.map +1 -1
  215. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js +120 -120
  216. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js.map +1 -1
  217. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js.map +1 -1
  218. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.js +7 -1
  219. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.js.map +1 -1
  220. package/lib/module/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.js +7 -1
  221. package/lib/module/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.js.map +1 -1
  222. package/lib/module/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js +9 -2
  223. package/lib/module/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js.map +1 -1
  224. package/lib/module/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.js +7 -1
  225. package/lib/module/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.js.map +1 -1
  226. package/lib/module/v4/PublicApi/Pages/AmitySocialHomePage/AmitySocialHomePage.js.map +1 -1
  227. package/lib/module/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.js +7 -1
  228. package/lib/module/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.js.map +1 -1
  229. package/lib/module/v4/component/LivestreamContent/index.js +13 -13
  230. package/lib/module/v4/component/LivestreamContent/index.js.map +1 -1
  231. package/lib/module/v4/component/MyStories/StoryCircleItem.js.map +1 -1
  232. package/lib/module/v4/component/PostContent/index.js +4 -4
  233. package/lib/module/v4/component/PostContent/index.js.map +1 -1
  234. package/lib/module/v4/component/PostMenu/index.js +2 -2
  235. package/lib/module/v4/component/PostMenu/index.js.map +1 -1
  236. package/lib/module/v4/component/PreviewLink/LinkPreview.js +3 -3
  237. package/lib/module/v4/component/PreviewLink/LinkPreview.js.map +1 -1
  238. package/lib/module/v4/component/PreviewLink/utils.js +9 -73
  239. package/lib/module/v4/component/PreviewLink/utils.js.map +1 -1
  240. package/lib/module/v4/component/TargetSelectionPage/TargetSelectionPage.js +10 -4
  241. package/lib/module/v4/component/TargetSelectionPage/TargetSelectionPage.js.map +1 -1
  242. package/lib/module/v4/component/Toast/index.js +4 -4
  243. package/lib/module/v4/component/Toast/index.js.map +1 -1
  244. package/lib/module/v4/component/Toast/styles.js +2 -2
  245. package/lib/module/v4/component/Toast/styles.js.map +1 -1
  246. package/lib/module/v4/elements/ActionButton/ActionButton.js.map +1 -1
  247. package/lib/module/v4/elements/ImageViewer/ImageViewer.js.map +1 -1
  248. package/lib/module/v4/elements/VideoViewer/VideoViewer.js.map +1 -1
  249. package/lib/module/v4/enum/roomStatus.js +8 -0
  250. package/lib/module/v4/enum/roomStatus.js.map +1 -0
  251. package/lib/module/v4/features/community/Membership/components/MemberItem/MemberItem.js.map +1 -1
  252. package/lib/module/v4/features/community/shared/components/Privacy/index.js.map +1 -1
  253. package/lib/module/v4/hook/index.js +2 -0
  254. package/lib/module/v4/hook/index.js.map +1 -1
  255. package/lib/module/v4/hook/useCustomRankingGlobalFeed.js +1 -3
  256. package/lib/module/v4/hook/useCustomRankingGlobalFeed.js.map +1 -1
  257. package/lib/module/v4/hook/useImagePicker.js.map +1 -1
  258. package/lib/module/v4/hook/usePostSubscription.js +31 -0
  259. package/lib/module/v4/hook/usePostSubscription.js.map +1 -0
  260. package/lib/module/v4/hook/useRoomSubscription.js +15 -0
  261. package/lib/module/v4/hook/useRoomSubscription.js.map +1 -0
  262. package/lib/module/v4/index.js +1 -1
  263. package/lib/module/v4/index.js.map +1 -1
  264. package/lib/module/v4/providers/BehaviourProvider.js +2 -1
  265. package/lib/module/v4/providers/BehaviourProvider.js.map +1 -1
  266. package/lib/module/v4/stores/slices/toast.js +4 -1
  267. package/lib/module/v4/stores/slices/toast.js.map +1 -1
  268. package/lib/typescript/src/components/MediaSection/index.d.ts.map +1 -1
  269. package/lib/typescript/src/components/PostTypeChoiceModal/style.d.ts +1 -2
  270. package/lib/typescript/src/components/PostTypeChoiceModal/style.d.ts.map +1 -1
  271. package/lib/typescript/src/components/Social/PostList/index.d.ts +1 -3
  272. package/lib/typescript/src/components/Social/PostList/index.d.ts.map +1 -1
  273. package/lib/typescript/src/index.d.ts +2 -2
  274. package/lib/typescript/src/index.d.ts.map +1 -1
  275. package/lib/typescript/src/screens/CategorytList/index.d.ts.map +1 -1
  276. package/lib/typescript/src/screens/LivestreamPlayer/index.d.ts.map +1 -1
  277. package/lib/typescript/src/util/postTypeChecker.d.ts +1 -1
  278. package/lib/typescript/src/util/postTypeChecker.d.ts.map +1 -1
  279. package/lib/typescript/src/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.d.ts +1 -0
  280. package/lib/typescript/src/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.d.ts.map +1 -1
  281. package/lib/typescript/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.d.ts +1 -3
  282. package/lib/typescript/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.d.ts.map +1 -1
  283. package/lib/typescript/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.d.ts +1 -0
  284. package/lib/typescript/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.d.ts.map +1 -1
  285. package/lib/typescript/src/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.d.ts.map +1 -1
  286. package/lib/typescript/src/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.d.ts +1 -1
  287. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.d.ts.map +1 -1
  288. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.d.ts +8 -0
  289. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.d.ts.map +1 -0
  290. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.d.ts +70 -2
  291. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.d.ts.map +1 -1
  292. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.d.ts.map +1 -1
  293. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.d.ts.map +1 -1
  294. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.d.ts.map +1 -1
  295. package/lib/typescript/src/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.d.ts.map +1 -1
  296. package/lib/typescript/src/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.d.ts.map +1 -1
  297. package/lib/typescript/src/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.d.ts.map +1 -1
  298. package/lib/typescript/src/v4/PublicApi/Pages/AmitySocialHomePage/AmitySocialHomePage.d.ts.map +1 -1
  299. package/lib/typescript/src/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.d.ts.map +1 -1
  300. package/lib/typescript/src/v4/component/LivestreamContent/index.d.ts +1 -1
  301. package/lib/typescript/src/v4/component/LivestreamContent/index.d.ts.map +1 -1
  302. package/lib/typescript/src/v4/component/PostContent/index.d.ts.map +1 -1
  303. package/lib/typescript/src/v4/component/PreviewLink/utils.d.ts +6 -1
  304. package/lib/typescript/src/v4/component/PreviewLink/utils.d.ts.map +1 -1
  305. package/lib/typescript/src/v4/component/TargetSelectionPage/TargetSelectionPage.d.ts +2 -1
  306. package/lib/typescript/src/v4/component/TargetSelectionPage/TargetSelectionPage.d.ts.map +1 -1
  307. package/lib/typescript/src/v4/component/Toast/styles.d.ts +1 -1
  308. package/lib/typescript/src/v4/component/Toast/styles.d.ts.map +1 -1
  309. package/lib/typescript/src/v4/elements/ActionButton/ActionButton.d.ts.map +1 -1
  310. package/lib/typescript/src/v4/enum/roomStatus.d.ts +8 -0
  311. package/lib/typescript/src/v4/enum/roomStatus.d.ts.map +1 -0
  312. package/lib/typescript/src/v4/features/community/Membership/components/MemberItem/MemberItem.d.ts.map +1 -1
  313. package/lib/typescript/src/v4/features/community/shared/components/Privacy/index.d.ts.map +1 -1
  314. package/lib/typescript/src/v4/hook/index.d.ts +2 -0
  315. package/lib/typescript/src/v4/hook/index.d.ts.map +1 -1
  316. package/lib/typescript/src/v4/hook/useImagePicker.d.ts.map +1 -1
  317. package/lib/typescript/src/v4/hook/usePendingPostQuery.d.ts +3 -0
  318. package/lib/typescript/src/v4/hook/usePendingPostQuery.d.ts.map +1 -1
  319. package/lib/typescript/src/v4/hook/usePostSubscription.d.ts +4 -0
  320. package/lib/typescript/src/v4/hook/usePostSubscription.d.ts.map +1 -0
  321. package/lib/typescript/src/v4/hook/useRoomSubscription.d.ts +4 -0
  322. package/lib/typescript/src/v4/hook/useRoomSubscription.d.ts.map +1 -0
  323. package/lib/typescript/src/v4/index.d.ts +1 -0
  324. package/lib/typescript/src/v4/index.d.ts.map +1 -1
  325. package/lib/typescript/src/v4/providers/BehaviourProvider.d.ts.map +1 -1
  326. package/lib/typescript/src/v4/routes/RouteParamList.d.ts +1 -1
  327. package/lib/typescript/src/v4/routes/RouteParamList.d.ts.map +1 -1
  328. package/lib/typescript/src/v4/stores/slices/toast.d.ts +1 -0
  329. package/lib/typescript/src/v4/stores/slices/toast.d.ts.map +1 -1
  330. package/lib/typescript/src/v4/types/behaviour.interface.d.ts +7 -0
  331. package/lib/typescript/src/v4/types/behaviour.interface.d.ts.map +1 -1
  332. package/package.json +6 -3
  333. package/src/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.tsx +1 -1
  334. package/src/components/MediaSection/index.tsx +4 -6
  335. package/src/components/PostTypeChoiceModal/PostTypeChoiceModal.tsx +15 -15
  336. package/src/components/PostTypeChoiceModal/style.ts +1 -2
  337. package/src/components/Social/PostList/index.tsx +1 -4
  338. package/src/index.tsx +2 -2
  339. package/src/screens/CategorytList/index.tsx +7 -14
  340. package/src/screens/CreateLivestream/CreateLivestream.tsx +17 -17
  341. package/src/screens/LivestreamPlayer/index.tsx +9 -15
  342. package/src/snippet/AmityCommunitySearchResultComponent.tsx +1 -1
  343. package/src/snippet/AmityCreatePostMenuComponent.tsx +1 -1
  344. package/src/snippet/AmityDetailedMediaAttachmentComponent.tsx +1 -1
  345. package/src/snippet/AmityEmptyNewsFeedComponent.tsx +1 -1
  346. package/src/snippet/AmityGlobalFeedComponent.tsx +1 -1
  347. package/src/snippet/AmityMediaAttachmentComponent.tsx +1 -1
  348. package/src/snippet/AmityMyCommunitiesComponent.tsx +1 -1
  349. package/src/snippet/AmityMyCommunitiesSearchPage.tsx +1 -1
  350. package/src/snippet/AmityNewsFeedComponent.tsx +1 -1
  351. package/src/snippet/AmityPostComposerPage.tsx +1 -1
  352. package/src/snippet/AmityPostContentComponent.tsx +1 -1
  353. package/src/snippet/AmityPostDetailPage.tsx +1 -1
  354. package/src/snippet/AmityPostTargetSelectionPage.tsx +1 -1
  355. package/src/snippet/AmityReactionListComponent.tsx +1 -1
  356. package/src/snippet/AmitySocialGlobalSearchPage.tsx +1 -1
  357. package/src/snippet/AmitySocialHomePage.tsx +1 -1
  358. package/src/snippet/AmitySocialHomeTopNavigationComponent.tsx +1 -1
  359. package/src/snippet/AmityStoryTargetSelectionPage.tsx +1 -1
  360. package/src/snippet/AmityTopSearchBarComponent.tsx +1 -1
  361. package/src/snippet/AmityUserSearchResultComponent.tsx +1 -1
  362. package/src/svg/svg-xml-list.ts +1 -1
  363. package/src/util/postTypeChecker.ts +1 -1
  364. package/src/v4/PublicApi/Components/AmityCommunityFeedComponent/AmityCommunityFeedComponent.tsx +2 -2
  365. package/src/v4/PublicApi/Components/AmityCommunityProfileTabComponent/AmityCommunityProfileTabComponent.tsx +97 -97
  366. package/src/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.tsx +10 -10
  367. package/src/v4/PublicApi/Components/AmityGlobalFeedComponent/AmityGlobalFeedComponent.tsx +12 -7
  368. package/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.tsx +1 -3
  369. package/src/v4/PublicApi/Components/AmityReactionListComponent/AmityReactionListComponent.tsx +9 -9
  370. package/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.ts +3 -2
  371. package/src/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.tsx +24 -25
  372. package/src/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.ts +2 -2
  373. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.tsx +241 -89
  374. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.tsx +48 -0
  375. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.ts +72 -3
  376. package/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.tsx +131 -148
  377. package/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.ts +1 -0
  378. package/src/v4/PublicApi/Pages/AmityLivestreamPostTargetSelectionPage/AmityLivestreamPostTargetSelectionPage.tsx +6 -0
  379. package/src/v4/PublicApi/Pages/AmityPollTargetSelectionPage/AmityPollTargetSelectionPage.tsx +6 -1
  380. package/src/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.tsx +7 -2
  381. package/src/v4/PublicApi/Pages/AmityPostTargetSelectionPage/AmityPostTargetSelectionPage.tsx +7 -0
  382. package/src/v4/PublicApi/Pages/AmitySocialHomePage/AmitySocialHomePage.tsx +5 -1
  383. package/src/v4/PublicApi/Pages/AmityStoryTargetSelectionPage/AmityStoryTargetSelectionPage.tsx +7 -0
  384. package/src/v4/component/LivestreamContent/index.tsx +21 -22
  385. package/src/v4/component/MyStories/StoryCircleItem.tsx +8 -8
  386. package/src/v4/component/PostContent/index.tsx +6 -8
  387. package/src/v4/component/PostMenu/index.tsx +2 -2
  388. package/src/v4/component/PreviewLink/LinkPreview.tsx +3 -3
  389. package/src/v4/component/PreviewLink/utils.ts +9 -108
  390. package/src/v4/component/TargetSelectionPage/TargetSelectionPage.tsx +12 -4
  391. package/src/v4/component/Toast/index.tsx +1 -1
  392. package/src/v4/component/Toast/styles.ts +2 -2
  393. package/src/v4/elements/ActionButton/ActionButton.tsx +4 -1
  394. package/src/v4/elements/ImageViewer/ImageViewer.tsx +1 -1
  395. package/src/v4/elements/VideoViewer/VideoViewer.tsx +1 -1
  396. package/src/v4/enum/roomStatus.ts +7 -0
  397. package/src/v4/features/community/Membership/components/MemberItem/MemberItem.tsx +11 -2
  398. package/src/v4/features/community/shared/components/Privacy/index.tsx +4 -1
  399. package/src/v4/hook/index.ts +2 -0
  400. package/src/v4/hook/useCustomRankingGlobalFeed.ts +1 -1
  401. package/src/v4/hook/useImagePicker.ts +4 -1
  402. package/src/v4/hook/usePostSubscription.ts +34 -0
  403. package/src/v4/hook/useRoomSubscription.ts +19 -0
  404. package/src/v4/index.tsx +1 -1
  405. package/src/v4/providers/BehaviourProvider.tsx +1 -0
  406. package/src/v4/routes/RouteParamList.tsx +1 -1
  407. package/src/v4/stores/slices/toast.ts +5 -0
  408. package/src/v4/types/behaviour.interface.ts +7 -0
  409. package/uikit.config.json +1 -1
  410. package/lib/commonjs/v4/enum/livestreamStatus.js +0 -13
  411. package/lib/commonjs/v4/enum/livestreamStatus.js.map +0 -1
  412. package/lib/module/v4/enum/livestreamStatus.js +0 -7
  413. package/lib/module/v4/enum/livestreamStatus.js.map +0 -1
  414. package/lib/typescript/src/v4/enum/livestreamStatus.d.ts +0 -7
  415. package/lib/typescript/src/v4/enum/livestreamStatus.d.ts.map +0 -1
  416. package/src/v4/enum/livestreamStatus.ts +0 -6
@@ -0,0 +1,48 @@
1
+ import React, { useEffect } from 'react';
2
+ import { View } from 'react-native';
3
+ import { Track } from 'livekit-client';
4
+ import { VideoTrack, useLocalParticipant } from '@livekit/react-native';
5
+ import { useStyles } from './styles';
6
+
7
+ interface RoomViewProps {
8
+ onLocalParticipantReady?: (participant: any) => void;
9
+ isFrontCamera: boolean;
10
+ }
11
+
12
+ export const RoomView: React.FC<RoomViewProps> = ({
13
+ onLocalParticipantReady,
14
+ isFrontCamera,
15
+ }) => {
16
+ const { localParticipant } = useLocalParticipant();
17
+ const styles = useStyles();
18
+
19
+ useEffect(() => {
20
+ if (localParticipant && onLocalParticipantReady) {
21
+ onLocalParticipantReady(localParticipant);
22
+ }
23
+ }, [localParticipant, onLocalParticipantReady]);
24
+
25
+ if (!localParticipant?.isCameraEnabled) {
26
+ return <View style={styles.roomContainer} />;
27
+ }
28
+
29
+ const cameraTrack = localParticipant.getTrackPublication(Track.Source.Camera);
30
+
31
+ if (!cameraTrack?.track) {
32
+ return <View style={styles.roomContainer} />;
33
+ }
34
+
35
+ return (
36
+ <View style={styles.roomContainer}>
37
+ <VideoTrack
38
+ trackRef={{
39
+ participant: localParticipant,
40
+ publication: cameraTrack,
41
+ source: Track.Source.Camera,
42
+ }}
43
+ style={styles.videoTrack}
44
+ mirror={isFrontCamera}
45
+ />
46
+ </View>
47
+ );
48
+ };
@@ -8,7 +8,7 @@ export const useStyles = () => {
8
8
  const { height: screenHeight } = Dimensions.get('window');
9
9
  const insets = useSafeAreaInsets();
10
10
 
11
- const availableHeight = screenHeight - 80 - 60 - 40 - 40 - 120;
11
+ const availableHeight = screenHeight - 80 - 60 - 40 - 40 - 120 - 50;
12
12
  const styles = StyleSheet.create({
13
13
  container: {
14
14
  flex: 1,
@@ -26,7 +26,6 @@ export const useStyles = () => {
26
26
  },
27
27
  overlay: {
28
28
  flex: 1,
29
- height: '100%',
30
29
  top: 0,
31
30
  bottom: 0,
32
31
  left: 0,
@@ -158,12 +157,19 @@ export const useStyles = () => {
158
157
  text: {
159
158
  color: theme.colors.background,
160
159
  },
161
- timer: {
160
+
161
+ closeButton: {
162
162
  left: 16,
163
163
  zIndex: 100,
164
164
  position: 'absolute',
165
165
  top: 20 + insets.top,
166
166
  },
167
+ timer: {
168
+ right: 16,
169
+ zIndex: 100,
170
+ position: 'absolute',
171
+ top: 20 + insets.top,
172
+ },
167
173
  permission: {
168
174
  flex: 1,
169
175
  top: 80 + insets.top,
@@ -191,6 +197,69 @@ export const useStyles = () => {
191
197
  color: theme.colors.background,
192
198
  textAlign: 'center',
193
199
  },
200
+ containerRoom: {
201
+ flex: 1,
202
+ alignItems: 'stretch',
203
+ justifyContent: 'center',
204
+ padding: 10,
205
+ },
206
+ participantView: {
207
+ flex: 1,
208
+ margin: 5,
209
+ height: 200,
210
+ backgroundColor: '#ccc',
211
+ },
212
+ roomContainer: {
213
+ flex: 1,
214
+ width: '100%',
215
+ height: '100%',
216
+ },
217
+ videoTrack: {
218
+ width: '100%',
219
+ height: '100%',
220
+ },
221
+ countdownOverlay: {
222
+ position: 'absolute',
223
+ top: 0,
224
+ left: 0,
225
+ right: 0,
226
+ bottom: 80,
227
+ justifyContent: 'center',
228
+ alignItems: 'center',
229
+ backgroundColor: 'rgba(0, 0, 0, 0.7)',
230
+ zIndex: 150,
231
+ },
232
+ countdownContainer: {
233
+ alignItems: 'center',
234
+ gap: 24,
235
+ },
236
+ countdownCircle: {
237
+ position: 'relative',
238
+ alignItems: 'center',
239
+ justifyContent: 'center',
240
+ width: 72,
241
+ height: 72,
242
+ },
243
+ countdownNumberContainer: {
244
+ position: 'absolute',
245
+ top: 0,
246
+ left: 0,
247
+ right: 0,
248
+ bottom: 0,
249
+ alignItems: 'center',
250
+ justifyContent: 'center',
251
+ },
252
+ countdownNumber: {
253
+ fontSize: 32,
254
+ fontWeight: '700',
255
+ color: theme.colors.background,
256
+ },
257
+ countdownText: {
258
+ fontSize: 24,
259
+ fontWeight: '500',
260
+ color: theme.colors.background,
261
+ textAlign: 'center',
262
+ },
194
263
  });
195
264
 
196
265
  return styles;
@@ -1,131 +1,75 @@
1
- import React, { useEffect, useRef, useState } from 'react';
2
- import {
3
- View,
4
- TouchableOpacity,
5
- TouchableWithoutFeedback,
6
- useAnimatedValue,
7
- } from 'react-native';
1
+ import React, { useEffect, useState, useRef } from 'react';
2
+ import { View, TouchableOpacity } from 'react-native';
8
3
  import { useStyles } from './styles';
9
- // @ts-ignore
10
- // import { AmityStreamPlayer } from '@amityco/video-player-react-native';
11
4
  import LiveStreamEndThumbnail from '../../../component/LivestreamContent/LivestreamEndedThumbnail';
12
- import { Animated } from 'react-native';
13
5
  import { SvgXml } from 'react-native-svg';
14
- import {
15
- getPostTopic,
16
- PostRepository,
17
- StreamRepository,
18
- subscribeTopic,
19
- } from '@amityco/ts-sdk-react-native';
20
- import { close, pause, resume } from '../../../assets/icons';
6
+ import { RoomRepository } from '@amityco/ts-sdk-react-native';
7
+ import { close } from '../../../assets/icons';
21
8
  import { RouteProp, useNavigation, useRoute } from '@react-navigation/native';
22
9
  import { NativeStackNavigationProp } from '@react-navigation/native-stack';
23
10
  import { RootStackParamList } from '../../../routes/RouteParamList';
24
- import { LivestreamStatus } from '../../../enum/livestreamStatus';
11
+ import { RoomStatus } from '../../../enum/roomStatus';
25
12
  import LiveStreamIdleThumbnail from '../../../component/LivestreamContent/LivestreamIdleThumbnail';
26
13
  import { Typography } from '../../../component/Typography/Typography';
27
14
  import { SafeAreaView } from 'react-native-safe-area-context';
28
15
  import NetInfo from '@react-native-community/netinfo';
29
16
  import { CircularProgressIndicator } from '../../../component/CircularProgressIndicator';
30
- const usePostSubscription = (postId: string) => {
31
- const [subscribedPost, setSubscribedPost] = useState<Amity.Post>(null);
32
-
33
- useEffect(() => {
34
- let unsubscribe: () => void;
35
- if (postId) {
36
- unsubscribe = PostRepository.getPost(postId, ({ data }) => {
37
- setSubscribedPost(data);
38
- });
39
- }
40
- return () => {
41
- unsubscribe && unsubscribe();
42
- };
43
- }, [postId]);
44
-
45
- useEffect(() => {
46
- let unsubscribe: () => void;
47
- if (subscribedPost) {
48
- unsubscribe = subscribeTopic(getPostTopic(subscribedPost));
49
- }
50
- return () => {
51
- unsubscribe && unsubscribe();
52
- };
53
- }, [subscribedPost]);
54
-
55
- return { subscribedPost };
56
- };
17
+ import Video from 'react-native-video';
18
+ import useAuth from '../../../../hooks/useAuth';
19
+ import {
20
+ usePostSubscription,
21
+ useRoomSubscription,
22
+ } from '../../../../v4/hook/index';
57
23
 
58
24
  function AmityLiveStreamPlayerPage() {
59
- const ref = useRef<any>(null);
60
25
  const { styles, theme } = useStyles();
61
- const controlOpacity = useAnimatedValue(0);
62
26
  const navigation =
63
27
  useNavigation<NativeStackNavigationProp<RootStackParamList>>();
64
28
  const route = useRoute<RouteProp<RootStackParamList, 'LivestreamPlayer'>>();
65
29
 
66
- const [error, setError] = useState<any>(null);
67
- const [isPlaying, setIsPlaying] = useState(true);
68
30
  const [reconnecting, setReconnecting] = useState(false);
69
- const [livestream, setLivestream] = useState<Amity.Stream>();
70
-
71
- const { streamId, post } = route.params;
31
+ const [room, setRoom] = useState<Amity.Room | null>(null);
32
+ const [error, setError] = useState<Error | null>(null);
33
+ const [wasLive, setWasLive] = useState(false);
34
+ const [showEndThumbnail, setShowEndThumbnail] = useState(false);
35
+ const { roomId, post } = route.params;
36
+ const { client } = useAuth();
37
+ const videoRef = useRef<any>(null);
38
+ const isProgrammaticDismiss = useRef(false);
72
39
 
73
40
  const { subscribedPost } = usePostSubscription(post?.postId);
74
41
 
75
- const onStopPlayer = () => {
76
- ref.current && ref.current.pause();
77
- setIsPlaying(false);
78
- };
79
-
80
- const onStartPlayer = () => {
81
- ref.current && ref.current.play();
82
- setIsPlaying(true);
83
- };
84
-
85
- const onPressControlButton = () => {
86
- isPlaying ? onStopPlayer() : onStartPlayer();
87
- };
88
-
89
- const onToggleControl = () => {
90
- controlOpacity.stopAnimation((currentValue) => {
91
- Animated.timing(controlOpacity, {
92
- toValue: currentValue === 0 ? 1 : 0,
93
- duration: 300,
94
- useNativeDriver: false,
95
- }).start();
96
- });
97
- };
42
+ useRoomSubscription({ room });
98
43
 
99
44
  useEffect(() => {
100
- const unsubscribe = StreamRepository.getStreamById(
101
- streamId,
45
+ const unsubscribe = RoomRepository.getRoom(
46
+ roomId,
102
47
  ({ data, loading, error: streamError }) => {
103
48
  if (streamError) setError(streamError);
104
- if (!loading && data) setLivestream({ ...data });
49
+ if (!loading && data) setRoom({ ...data });
105
50
  }
106
51
  );
107
52
 
108
53
  return () => unsubscribe();
109
- }, [streamId]);
54
+ }, [roomId]);
110
55
 
111
56
  useEffect(() => {
112
- if (livestream?.isDeleted || subscribedPost?.isDeleted) {
57
+ if (room?.isDeleted || subscribedPost?.isDeleted) {
113
58
  navigation.replace('PostDetail', { postId: subscribedPost?.postId });
114
59
  }
115
- }, [livestream?.isDeleted, subscribedPost, navigation]);
60
+ }, [room?.isDeleted, subscribedPost, navigation]);
116
61
 
117
62
  useEffect(() => {
118
63
  const isTerminated =
119
- livestream?.moderation?.terminateLabels &&
120
- livestream?.moderation?.terminateLabels?.length > 0;
64
+ room?.moderation?.terminateLabels &&
65
+ room?.moderation?.terminateLabels?.length > 0;
121
66
  const isLiveOrEnded =
122
- livestream?.status === LivestreamStatus.live ||
123
- livestream?.status === LivestreamStatus.ended;
67
+ room?.status === RoomStatus.live || room?.status === RoomStatus.ended;
124
68
 
125
69
  if (isLiveOrEnded && isTerminated) {
126
70
  navigation.replace('LivestreamTerminated', { type: 'viewer' });
127
71
  }
128
- }, [livestream?.moderation?.terminateLabels, livestream?.status, navigation]);
72
+ }, [room?.moderation?.terminateLabels, room?.status, navigation]);
129
73
 
130
74
  useEffect(() => {
131
75
  const unsubscribe = NetInfo.addEventListener((state) => {
@@ -134,24 +78,73 @@ function AmityLiveStreamPlayerPage() {
134
78
  return () => unsubscribe();
135
79
  }, []);
136
80
 
137
- if (!livestream || error)
81
+ // Track if user was watching live
82
+ useEffect(() => {
83
+ if (room?.status === RoomStatus.live) {
84
+ setWasLive(true);
85
+ }
86
+ }, [room?.status]);
87
+
88
+ // Dismiss fullscreen player when stream ends
89
+ useEffect(() => {
90
+ const shouldShowEndThumbnail =
91
+ room?.status === RoomStatus.ended ||
92
+ (room?.status === RoomStatus.recorded && wasLive);
93
+
94
+ if (shouldShowEndThumbnail && videoRef.current) {
95
+ isProgrammaticDismiss.current = true;
96
+ videoRef.current?.dismissFullscreenPlayer();
97
+ // Delay showing end thumbnail to allow fullscreen dismiss to complete
98
+ setTimeout(() => {
99
+ setShowEndThumbnail(true);
100
+ }, 300);
101
+ } else if (shouldShowEndThumbnail && !videoRef.current) {
102
+ // If video ref is already null, show end thumbnail immediately
103
+ setShowEndThumbnail(true);
104
+ } else if (!shouldShowEndThumbnail) {
105
+ setShowEndThumbnail(false);
106
+ }
107
+ }, [room?.status, wasLive]);
108
+
109
+ // Start in fullscreen mode on iOS
110
+ useEffect(() => {
111
+ if (videoRef.current && room && room.status !== RoomStatus.ended) {
112
+ const timer = setTimeout(() => {
113
+ videoRef.current?.presentFullscreenPlayer();
114
+ }, 100);
115
+ return () => clearTimeout(timer);
116
+ }
117
+ return undefined;
118
+ }, [room]);
119
+
120
+ if (!room || error) {
138
121
  return (
139
122
  <SafeAreaView style={styles.container}>
140
123
  <LiveStreamIdleThumbnail />
141
124
  </SafeAreaView>
142
125
  );
126
+ }
127
+
128
+ const closePlayer = () => {
129
+ navigation.goBack();
130
+ };
131
+
132
+ const handleFullscreenDismiss = () => {
133
+ // Only navigate back if user manually dismissed, not programmatically
134
+ if (!isProgrammaticDismiss.current) {
135
+ closePlayer();
136
+ }
137
+ isProgrammaticDismiss.current = false;
138
+ };
143
139
 
144
140
  return (
145
141
  <SafeAreaView style={styles.container}>
146
- {livestream.status === LivestreamStatus.ended ? (
142
+ {showEndThumbnail ? (
147
143
  <>
148
144
  <View style={styles.steamEndContainer}>
149
145
  <LiveStreamEndThumbnail />
150
146
  </View>
151
- <TouchableOpacity
152
- style={styles.closeButton}
153
- onPress={navigation.goBack}
154
- >
147
+ <TouchableOpacity style={styles.closeButton} onPress={closePlayer}>
155
148
  <SvgXml
156
149
  xml={close()}
157
150
  width="28"
@@ -160,14 +153,52 @@ function AmityLiveStreamPlayerPage() {
160
153
  />
161
154
  </TouchableOpacity>
162
155
  </>
163
- ) : // <AmityStreamPlayer
164
- // ref={ref}
165
- // stream={livestream}
166
- // onBack={navigation.goBack}
167
- // status={livestream.status === 'live' ? 'live' : 'recorded'}
168
- // />
169
- null}
170
- {livestream.status === LivestreamStatus.live && reconnecting && (
156
+ ) : (
157
+ <View style={styles.container}>
158
+ {(room.status === RoomStatus.live ||
159
+ room.status === RoomStatus.waiting_reconnect) && (
160
+ <View style={styles.indicator}>
161
+ <View style={styles.status}>
162
+ <Typography.CaptionBold style={styles.live}>
163
+ LIVE
164
+ </Typography.CaptionBold>
165
+ </View>
166
+ </View>
167
+ )}
168
+ <Video
169
+ ref={videoRef}
170
+ source={{
171
+ uri:
172
+ room.status === RoomStatus.recorded
173
+ ? room.recordedPlaybackInfos[0]?.url
174
+ : room.livePlaybackUrl,
175
+ headers: {
176
+ Authorization: `Bearer ${client.token.accessToken}`,
177
+ },
178
+
179
+ type: 'm3u8',
180
+ }}
181
+ style={styles.container}
182
+ resizeMode="contain"
183
+ controls={room.status === RoomStatus.recorded}
184
+ fullscreen={true}
185
+ fullscreenOrientation="landscape"
186
+ paused={false}
187
+ muted={false}
188
+ volume={1.0}
189
+ audioOutput="speaker"
190
+ playInBackground={false}
191
+ playWhenInactive={false}
192
+ onError={(e) => {
193
+ console.log('Video Player Error: ', e);
194
+ }}
195
+ onFullscreenPlayerDidDismiss={handleFullscreenDismiss}
196
+ />
197
+ </View>
198
+ )}
199
+
200
+ {((room.status === RoomStatus.live && reconnecting) ||
201
+ room.status === RoomStatus.waiting_reconnect) && (
171
202
  <View style={styles.connecting}>
172
203
  <CircularProgressIndicator size={40} strokeWidth={2} />
173
204
  <Typography.TitleBold style={styles.text}>
@@ -179,54 +210,6 @@ function AmityLiveStreamPlayerPage() {
179
210
  </Typography.Caption>
180
211
  </View>
181
212
  )}
182
- {livestream.status === LivestreamStatus.live && (
183
- <>
184
- <View style={styles.indicator}>
185
- <View style={styles.status}>
186
- <Typography.CaptionBold style={styles.live}>
187
- LIVE
188
- </Typography.CaptionBold>
189
- </View>
190
- </View>
191
- <TouchableWithoutFeedback onPress={onToggleControl}>
192
- <Animated.View
193
- style={[styles.control, { opacity: controlOpacity }]}
194
- >
195
- <TouchableOpacity
196
- style={styles.closeButton}
197
- onPress={navigation.goBack}
198
- >
199
- <SvgXml
200
- xml={close()}
201
- width="28"
202
- height="28"
203
- color={theme.colors.background}
204
- />
205
- </TouchableOpacity>
206
-
207
- <View style={styles.controller}>
208
- <TouchableOpacity onPress={onPressControlButton}>
209
- {isPlaying ? (
210
- <SvgXml
211
- width={32}
212
- height={32}
213
- xml={pause()}
214
- color={theme.colors.background}
215
- />
216
- ) : (
217
- <SvgXml
218
- width={32}
219
- height={32}
220
- xml={resume()}
221
- color={theme.colors.background}
222
- />
223
- )}
224
- </TouchableOpacity>
225
- </View>
226
- </Animated.View>
227
- </TouchableWithoutFeedback>
228
- </>
229
- )}
230
213
  </SafeAreaView>
231
214
  );
232
215
  }
@@ -13,6 +13,7 @@ export const useStyles = () => {
13
13
  position: 'relative',
14
14
  backgroundColor: '#000000',
15
15
  },
16
+
16
17
  steamEndContainer: {
17
18
  flex: 1,
18
19
  justifyContent: 'center',
@@ -37,10 +37,16 @@ const AmityLivestreamPostTargetSelectionPage = () => {
37
37
  navigation.navigate('CreateLivestream', context);
38
38
  };
39
39
 
40
+ const onClickClose = () => {
41
+ if (AmityLivestreamPostTargetSelectionPageBehavior?.onClickClose) {
42
+ AmityLivestreamPostTargetSelectionPageBehavior.onClickClose();
43
+ }
44
+ };
40
45
  return (
41
46
  <TargetSelectionPage
42
47
  onSelectFeed={onSelectFeed}
43
48
  pageId={PageID.livestream_post_target_selection_page}
49
+ onClickClose={onClickClose}
44
50
  />
45
51
  );
46
52
  };
@@ -28,11 +28,16 @@ const AmityPollTargetSelectionPage = () => {
28
28
  }
29
29
  navigation.navigate('PollPostComposer', context);
30
30
  };
31
-
31
+ const onClickClose = () => {
32
+ if (AmityPollTargetSelectionPageBehavior?.onClickClose) {
33
+ AmityPollTargetSelectionPageBehavior.onClickClose();
34
+ }
35
+ };
32
36
  return (
33
37
  <TargetSelectionPage
34
38
  onSelectFeed={onSelectFeed}
35
39
  pageId={PageID.select_poll_target_page}
40
+ onClickClose={onClickClose}
36
41
  />
37
42
  );
38
43
  };
@@ -60,6 +60,7 @@ import { getPostErrorMessage } from '../../../utils/errors';
60
60
  import { MAXIMUM_POST_CHARACTERS } from '../../../constants';
61
61
  import { replaceTriggerValues } from 'react-native-controlled-mentions';
62
62
  import { useUIKitDispatch } from '../../../../redux/store';
63
+ import { useBehaviour } from '../../../../v4/providers/BehaviourProvider';
63
64
 
64
65
  const AmityPostComposerPage: FC<AmityPostComposerPageType> = ({
65
66
  mode,
@@ -75,6 +76,7 @@ const AmityPostComposerPage: FC<AmityPostComposerPageType> = ({
75
76
  shouldCall: true,
76
77
  });
77
78
  const pageId = PageID.post_composer_page;
79
+ const { AmityPostComposerPageBehavior } = useBehaviour();
78
80
  const { isExcluded, themeStyles, accessibilityId } = useAmityPage({ pageId });
79
81
  const styles = useStyles(themeStyles);
80
82
  const { getImage } = useFile();
@@ -286,17 +288,20 @@ const AmityPostComposerPage: FC<AmityPostComposerPageType> = ({
286
288
 
287
289
  const onPressClose = useCallback(() => {
288
290
  const routes = navigation.getState().routes;
291
+ if (AmityPostComposerPageBehavior?.onPressPost) {
292
+ AmityPostComposerPageBehavior.onPressPost();
293
+ }
289
294
  if (routes[routes.length - 2].name === 'PostTargetSelection') {
290
295
  navigation.pop(2);
291
296
  } else navigation.pop();
292
- }, [navigation]);
297
+ }, [navigation, AmityPostComposerPageBehavior]);
293
298
 
294
299
  const onClose = useCallback(() => {
295
300
  Alert.alert(
296
301
  'Discard this post',
297
302
  'The post will be permanently deleted. It cannot be undone',
298
303
  [
299
- { text: 'Keey Editing', style: 'cancel' },
304
+ { text: 'Keep Editing', style: 'cancel' },
300
305
  {
301
306
  text: 'Discard',
302
307
  style: 'destructive',
@@ -81,10 +81,17 @@ const AmityPostTargetSelectionPage = ({
81
81
  }
82
82
  };
83
83
 
84
+ const onClickClose = () => {
85
+ if (AmityPostTargetSelectionPageBehavior?.onClickClose) {
86
+ AmityPostTargetSelectionPageBehavior.onClickClose();
87
+ }
88
+ };
89
+
84
90
  return (
85
91
  <TargetSelectionPage
86
92
  pageId={PageID.select_post_target_page}
87
93
  onSelectFeed={onSelectFeed}
94
+ onClickClose={onClickClose}
88
95
  />
89
96
  );
90
97
  };
@@ -3,7 +3,11 @@ import { useCallback, useState } from 'react';
3
3
  import { LogBox, SafeAreaView, StyleSheet } from 'react-native';
4
4
  import CustomSocialTab from '../../../../v4/component/CustomSocialTab/CustomSocialTab';
5
5
  import { useUiKitConfig } from '../../../../v4/hook';
6
- import { ComponentID, ElementID, PageID } from '../../../../v4/enum/enumUIKitID';
6
+ import {
7
+ ComponentID,
8
+ ElementID,
9
+ PageID,
10
+ } from '../../../../v4/enum/enumUIKitID';
7
11
 
8
12
  import { useTheme } from 'react-native-paper';
9
13
  import { useBehaviour } from '../../../../v4/providers/BehaviourProvider';
@@ -24,11 +24,18 @@ const AmityStoryTargetSelectionPage = () => {
24
24
  });
25
25
  };
26
26
 
27
+ const onClickClose = () => {
28
+ if (AmityStoryTargetSelectionPageBehavior?.onClickClose) {
29
+ AmityStoryTargetSelectionPageBehavior.onClickClose();
30
+ }
31
+ };
32
+
27
33
  return (
28
34
  <TargetSelectionPage
29
35
  pageId={PageID.select_story_target_page}
30
36
  onSelectFeed={onSelectFeed}
31
37
  hideMyTimelineTarget={true}
38
+ onClickClose={onClickClose}
32
39
  />
33
40
  );
34
41
  };