@amityco/react-native-social-uikit 4.0.0-8da9962.0 → 4.0.0-9b57f0b0.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 (232) hide show
  1. package/lib/commonjs/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js +1 -1
  2. package/lib/commonjs/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js.map +1 -1
  3. package/lib/commonjs/components/MediaSection/index.js +3 -3
  4. package/lib/commonjs/components/MediaSection/index.js.map +1 -1
  5. package/lib/commonjs/components/PostTypeChoiceModal/PostTypeChoiceModal.js +14 -5
  6. package/lib/commonjs/components/PostTypeChoiceModal/PostTypeChoiceModal.js.map +1 -1
  7. package/lib/commonjs/components/PostTypeChoiceModal/style.js +1 -2
  8. package/lib/commonjs/components/PostTypeChoiceModal/style.js.map +1 -1
  9. package/lib/commonjs/components/Social/PostList/index.js +1 -3
  10. package/lib/commonjs/components/Social/PostList/index.js.map +1 -1
  11. package/lib/commonjs/index.js +6 -0
  12. package/lib/commonjs/index.js.map +1 -1
  13. package/lib/commonjs/screens/CreateLivestream/CreateLivestream.js +16 -16
  14. package/lib/commonjs/screens/CreateLivestream/CreateLivestream.js.map +1 -1
  15. package/lib/commonjs/screens/LivestreamPlayer/index.js +3 -6
  16. package/lib/commonjs/screens/LivestreamPlayer/index.js.map +1 -1
  17. package/lib/commonjs/svg/svg-xml-list.js +1 -1
  18. package/lib/commonjs/util/postTypeChecker.js.map +1 -1
  19. package/lib/commonjs/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js +11 -9
  20. package/lib/commonjs/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js.map +1 -1
  21. package/lib/commonjs/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/DetailStyle.js +1 -1
  22. package/lib/commonjs/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/DetailStyle.js.map +1 -1
  23. package/lib/commonjs/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/FeedStyle.js +2 -1
  24. package/lib/commonjs/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/FeedStyle.js.map +1 -1
  25. package/lib/commonjs/v4/PublicApi/Elements/ButtonWithIconElement/styles.js +3 -2
  26. package/lib/commonjs/v4/PublicApi/Elements/ButtonWithIconElement/styles.js.map +1 -1
  27. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js +28 -25
  28. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js.map +1 -1
  29. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js +2 -2
  30. package/lib/commonjs/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js.map +1 -1
  31. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js +217 -68
  32. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js.map +1 -1
  33. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js +50 -0
  34. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js.map +1 -0
  35. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js +71 -3
  36. package/lib/commonjs/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js.map +1 -1
  37. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js +150 -124
  38. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js.map +1 -1
  39. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js +2 -1
  40. package/lib/commonjs/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js.map +1 -1
  41. package/lib/commonjs/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js +1 -1
  42. package/lib/commonjs/v4/component/LivestreamContent/index.js +12 -12
  43. package/lib/commonjs/v4/component/LivestreamContent/index.js.map +1 -1
  44. package/lib/commonjs/v4/component/PostContent/index.js +4 -4
  45. package/lib/commonjs/v4/component/PostContent/index.js.map +1 -1
  46. package/lib/commonjs/v4/component/PostMenu/index.js +2 -2
  47. package/lib/commonjs/v4/component/PostMenu/index.js.map +1 -1
  48. package/lib/commonjs/v4/component/PreviewLink/LinkPreview.js +3 -3
  49. package/lib/commonjs/v4/component/PreviewLink/LinkPreview.js.map +1 -1
  50. package/lib/commonjs/v4/component/PreviewLink/utils.js +9 -73
  51. package/lib/commonjs/v4/component/PreviewLink/utils.js.map +1 -1
  52. package/lib/commonjs/v4/component/Toast/index.js +4 -4
  53. package/lib/commonjs/v4/component/Toast/index.js.map +1 -1
  54. package/lib/commonjs/v4/component/Toast/styles.js +2 -2
  55. package/lib/commonjs/v4/component/Toast/styles.js.map +1 -1
  56. package/lib/commonjs/v4/enum/roomStatus.js +14 -0
  57. package/lib/commonjs/v4/enum/roomStatus.js.map +1 -0
  58. package/lib/commonjs/v4/hook/index.js +22 -0
  59. package/lib/commonjs/v4/hook/index.js.map +1 -1
  60. package/lib/commonjs/v4/hook/useCustomRankingGlobalFeed.js +1 -3
  61. package/lib/commonjs/v4/hook/useCustomRankingGlobalFeed.js.map +1 -1
  62. package/lib/commonjs/v4/hook/usePostSubscription.js +38 -0
  63. package/lib/commonjs/v4/hook/usePostSubscription.js.map +1 -0
  64. package/lib/commonjs/v4/hook/useRoomSubscription.js +22 -0
  65. package/lib/commonjs/v4/hook/useRoomSubscription.js.map +1 -0
  66. package/lib/commonjs/v4/index.js +7 -0
  67. package/lib/commonjs/v4/index.js.map +1 -1
  68. package/lib/commonjs/v4/stores/slices/toast.js +4 -1
  69. package/lib/commonjs/v4/stores/slices/toast.js.map +1 -1
  70. package/lib/module/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js +1 -1
  71. package/lib/module/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.js.map +1 -1
  72. package/lib/module/components/MediaSection/index.js +3 -3
  73. package/lib/module/components/MediaSection/index.js.map +1 -1
  74. package/lib/module/components/PostTypeChoiceModal/PostTypeChoiceModal.js +15 -8
  75. package/lib/module/components/PostTypeChoiceModal/PostTypeChoiceModal.js.map +1 -1
  76. package/lib/module/components/PostTypeChoiceModal/style.js +1 -2
  77. package/lib/module/components/PostTypeChoiceModal/style.js.map +1 -1
  78. package/lib/module/components/Social/PostList/index.js +1 -3
  79. package/lib/module/components/Social/PostList/index.js.map +1 -1
  80. package/lib/module/index.js +2 -6
  81. package/lib/module/index.js.map +1 -1
  82. package/lib/module/screens/CreateLivestream/CreateLivestream.js +17 -17
  83. package/lib/module/screens/CreateLivestream/CreateLivestream.js.map +1 -1
  84. package/lib/module/screens/LivestreamPlayer/index.js +4 -8
  85. package/lib/module/screens/LivestreamPlayer/index.js.map +1 -1
  86. package/lib/module/svg/svg-xml-list.js +1 -1
  87. package/lib/module/util/postTypeChecker.js.map +1 -1
  88. package/lib/module/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js +11 -9
  89. package/lib/module/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.js.map +1 -1
  90. package/lib/module/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/DetailStyle.js +1 -1
  91. package/lib/module/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/DetailStyle.js.map +1 -1
  92. package/lib/module/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/FeedStyle.js +2 -1
  93. package/lib/module/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/FeedStyle.js.map +1 -1
  94. package/lib/module/v4/PublicApi/Elements/ButtonWithIconElement/styles.js +3 -2
  95. package/lib/module/v4/PublicApi/Elements/ButtonWithIconElement/styles.js.map +1 -1
  96. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js +29 -26
  97. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.js.map +1 -1
  98. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js +2 -2
  99. package/lib/module/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.js.map +1 -1
  100. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js +222 -72
  101. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.js.map +1 -1
  102. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js +42 -0
  103. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.js.map +1 -0
  104. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js +71 -3
  105. package/lib/module/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.js.map +1 -1
  106. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js +152 -126
  107. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.js.map +1 -1
  108. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js +2 -1
  109. package/lib/module/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.js.map +1 -1
  110. package/lib/module/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.js +1 -1
  111. package/lib/module/v4/component/LivestreamContent/index.js +13 -13
  112. package/lib/module/v4/component/LivestreamContent/index.js.map +1 -1
  113. package/lib/module/v4/component/PostContent/index.js +4 -4
  114. package/lib/module/v4/component/PostContent/index.js.map +1 -1
  115. package/lib/module/v4/component/PostMenu/index.js +2 -2
  116. package/lib/module/v4/component/PostMenu/index.js.map +1 -1
  117. package/lib/module/v4/component/PreviewLink/LinkPreview.js +3 -3
  118. package/lib/module/v4/component/PreviewLink/LinkPreview.js.map +1 -1
  119. package/lib/module/v4/component/PreviewLink/utils.js +9 -73
  120. package/lib/module/v4/component/PreviewLink/utils.js.map +1 -1
  121. package/lib/module/v4/component/Toast/index.js +4 -4
  122. package/lib/module/v4/component/Toast/index.js.map +1 -1
  123. package/lib/module/v4/component/Toast/styles.js +2 -2
  124. package/lib/module/v4/component/Toast/styles.js.map +1 -1
  125. package/lib/module/v4/enum/roomStatus.js +8 -0
  126. package/lib/module/v4/enum/roomStatus.js.map +1 -0
  127. package/lib/module/v4/hook/index.js +2 -0
  128. package/lib/module/v4/hook/index.js.map +1 -1
  129. package/lib/module/v4/hook/useCustomRankingGlobalFeed.js +1 -3
  130. package/lib/module/v4/hook/useCustomRankingGlobalFeed.js.map +1 -1
  131. package/lib/module/v4/hook/usePostSubscription.js +31 -0
  132. package/lib/module/v4/hook/usePostSubscription.js.map +1 -0
  133. package/lib/module/v4/hook/useRoomSubscription.js +15 -0
  134. package/lib/module/v4/hook/useRoomSubscription.js.map +1 -0
  135. package/lib/module/v4/index.js +1 -1
  136. package/lib/module/v4/index.js.map +1 -1
  137. package/lib/module/v4/stores/slices/toast.js +4 -1
  138. package/lib/module/v4/stores/slices/toast.js.map +1 -1
  139. package/lib/typescript/src/components/MediaSection/index.d.ts.map +1 -1
  140. package/lib/typescript/src/components/PostTypeChoiceModal/style.d.ts +1 -2
  141. package/lib/typescript/src/components/PostTypeChoiceModal/style.d.ts.map +1 -1
  142. package/lib/typescript/src/components/Social/PostList/index.d.ts +1 -3
  143. package/lib/typescript/src/components/Social/PostList/index.d.ts.map +1 -1
  144. package/lib/typescript/src/index.d.ts +2 -2
  145. package/lib/typescript/src/index.d.ts.map +1 -1
  146. package/lib/typescript/src/screens/LivestreamPlayer/index.d.ts.map +1 -1
  147. package/lib/typescript/src/util/postTypeChecker.d.ts +1 -1
  148. package/lib/typescript/src/util/postTypeChecker.d.ts.map +1 -1
  149. package/lib/typescript/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.d.ts +1 -3
  150. package/lib/typescript/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.d.ts.map +1 -1
  151. package/lib/typescript/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.d.ts +1 -0
  152. package/lib/typescript/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.d.ts.map +1 -1
  153. package/lib/typescript/src/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.d.ts.map +1 -1
  154. package/lib/typescript/src/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.d.ts +1 -1
  155. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.d.ts.map +1 -1
  156. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.d.ts +8 -0
  157. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.d.ts.map +1 -0
  158. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.d.ts +70 -2
  159. package/lib/typescript/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.d.ts.map +1 -1
  160. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.d.ts.map +1 -1
  161. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.d.ts +1 -0
  162. package/lib/typescript/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.d.ts.map +1 -1
  163. package/lib/typescript/src/v4/component/LivestreamContent/index.d.ts +1 -1
  164. package/lib/typescript/src/v4/component/LivestreamContent/index.d.ts.map +1 -1
  165. package/lib/typescript/src/v4/component/PostContent/index.d.ts.map +1 -1
  166. package/lib/typescript/src/v4/component/PreviewLink/utils.d.ts +6 -1
  167. package/lib/typescript/src/v4/component/PreviewLink/utils.d.ts.map +1 -1
  168. package/lib/typescript/src/v4/component/Toast/styles.d.ts +1 -1
  169. package/lib/typescript/src/v4/component/Toast/styles.d.ts.map +1 -1
  170. package/lib/typescript/src/v4/enum/roomStatus.d.ts +8 -0
  171. package/lib/typescript/src/v4/enum/roomStatus.d.ts.map +1 -0
  172. package/lib/typescript/src/v4/hook/index.d.ts +2 -0
  173. package/lib/typescript/src/v4/hook/index.d.ts.map +1 -1
  174. package/lib/typescript/src/v4/hook/usePendingPostQuery.d.ts +3 -0
  175. package/lib/typescript/src/v4/hook/usePendingPostQuery.d.ts.map +1 -1
  176. package/lib/typescript/src/v4/hook/usePostSubscription.d.ts +4 -0
  177. package/lib/typescript/src/v4/hook/usePostSubscription.d.ts.map +1 -0
  178. package/lib/typescript/src/v4/hook/useRoomSubscription.d.ts +4 -0
  179. package/lib/typescript/src/v4/hook/useRoomSubscription.d.ts.map +1 -0
  180. package/lib/typescript/src/v4/index.d.ts +1 -0
  181. package/lib/typescript/src/v4/index.d.ts.map +1 -1
  182. package/lib/typescript/src/v4/routes/RouteParamList.d.ts +1 -1
  183. package/lib/typescript/src/v4/routes/RouteParamList.d.ts.map +1 -1
  184. package/lib/typescript/src/v4/stores/slices/toast.d.ts +1 -0
  185. package/lib/typescript/src/v4/stores/slices/toast.d.ts.map +1 -1
  186. package/package.json +6 -3
  187. package/src/components/CreatePostChooseTargetModal/CreatePostChooseTargetModal.tsx +1 -1
  188. package/src/components/MediaSection/index.tsx +4 -6
  189. package/src/components/PostTypeChoiceModal/PostTypeChoiceModal.tsx +15 -15
  190. package/src/components/PostTypeChoiceModal/style.ts +1 -2
  191. package/src/components/Social/PostList/index.tsx +1 -4
  192. package/src/index.tsx +2 -2
  193. package/src/screens/CreateLivestream/CreateLivestream.tsx +17 -17
  194. package/src/screens/LivestreamPlayer/index.tsx +9 -15
  195. package/src/svg/svg-xml-list.ts +1 -1
  196. package/src/util/postTypeChecker.ts +1 -1
  197. package/src/v4/PublicApi/Components/AmityCreatePostMenuComponent/AmityCreatePostMenuComponent.tsx +10 -10
  198. package/src/v4/PublicApi/Components/AmityPostContentComponent/AmityPostContentComponent.tsx +1 -1
  199. package/src/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/DetailStyle.tsx +1 -1
  200. package/src/v4/PublicApi/Components/AmityPostEngagementActionsComponent/Components/FeedStyle.tsx +1 -1
  201. package/src/v4/PublicApi/Elements/ButtonWithIconElement/styles.ts +3 -2
  202. package/src/v4/PublicApi/Pages/AmityCommunityProfilePage/AmityCommunityProfilePage.tsx +24 -25
  203. package/src/v4/PublicApi/Pages/AmityCommunityProfilePage/styles.ts +2 -2
  204. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/AmityCreateLivestreamPage.tsx +255 -89
  205. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/RoomView.tsx +48 -0
  206. package/src/v4/PublicApi/Pages/AmityCreateLivestreamPage/styles.ts +72 -3
  207. package/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/AmityLivestreamPlayerPage.tsx +205 -154
  208. package/src/v4/PublicApi/Pages/AmityLivestreamPlayerPage/styles.ts +2 -0
  209. package/src/v4/PublicApi/Pages/AmityPostComposerPage/AmityPostComposerPage.tsx +1 -1
  210. package/src/v4/component/LivestreamContent/index.tsx +21 -22
  211. package/src/v4/component/PostContent/index.tsx +6 -8
  212. package/src/v4/component/PostMenu/index.tsx +2 -2
  213. package/src/v4/component/PreviewLink/LinkPreview.tsx +3 -3
  214. package/src/v4/component/PreviewLink/utils.ts +9 -108
  215. package/src/v4/component/Toast/index.tsx +1 -1
  216. package/src/v4/component/Toast/styles.ts +2 -2
  217. package/src/v4/enum/roomStatus.ts +7 -0
  218. package/src/v4/hook/index.ts +2 -0
  219. package/src/v4/hook/useCustomRankingGlobalFeed.ts +1 -1
  220. package/src/v4/hook/usePostSubscription.ts +34 -0
  221. package/src/v4/hook/useRoomSubscription.ts +19 -0
  222. package/src/v4/index.tsx +1 -1
  223. package/src/v4/routes/RouteParamList.tsx +1 -1
  224. package/src/v4/stores/slices/toast.ts +5 -0
  225. package/uikit.config.json +1 -1
  226. package/lib/commonjs/v4/enum/livestreamStatus.js +0 -13
  227. package/lib/commonjs/v4/enum/livestreamStatus.js.map +0 -1
  228. package/lib/module/v4/enum/livestreamStatus.js +0 -7
  229. package/lib/module/v4/enum/livestreamStatus.js.map +0 -1
  230. package/lib/typescript/src/v4/enum/livestreamStatus.d.ts +0 -7
  231. package/lib/typescript/src/v4/enum/livestreamStatus.d.ts.map +0 -1
  232. package/src/v4/enum/livestreamStatus.ts +0 -6
@@ -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,77 @@
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, Platform } 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 { close } from '../../../assets/icons';
21
7
  import { RouteProp, useNavigation, useRoute } from '@react-navigation/native';
22
8
  import { NativeStackNavigationProp } from '@react-navigation/native-stack';
23
9
  import { RootStackParamList } from '../../../routes/RouteParamList';
24
- import { LivestreamStatus } from '../../../enum/livestreamStatus';
10
+ import { RoomStatus } from '../../../enum/roomStatus';
25
11
  import LiveStreamIdleThumbnail from '../../../component/LivestreamContent/LivestreamIdleThumbnail';
26
12
  import { Typography } from '../../../component/Typography/Typography';
27
13
  import { SafeAreaView } from 'react-native-safe-area-context';
28
14
  import NetInfo from '@react-native-community/netinfo';
29
15
  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
- };
16
+ import Video from 'react-native-video';
17
+ import useAuth from '../../../../hooks/useAuth';
18
+ import {
19
+ usePostSubscription,
20
+ useRoomSubscription,
21
+ } from '../../../../v4/hook/index';
22
+ import { RoomRepository } from '@amityco/ts-sdk-react-native';
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 [videoError, setVideoError] = useState(false);
33
+ const [error, setError] = useState<Error | null>(null);
34
+ const [, setPlayerInitialized] = useState(false);
35
+ const [videoKey, setVideoKey] = useState(0);
36
+ const [isPaused, setIsPaused] = useState(false);
37
+ const [wasLive, setWasLive] = useState(false);
72
38
 
39
+ const { roomId, post } = route.params;
73
40
  const { subscribedPost } = usePostSubscription(post?.postId);
41
+ useRoomSubscription({ room });
74
42
 
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
- };
43
+ const { client } = useAuth();
44
+ const videoRef = useRef<any>(null);
45
+ const isStreamEnding = useRef(false);
98
46
 
99
47
  useEffect(() => {
100
- const unsubscribe = StreamRepository.getStreamById(
101
- streamId,
48
+ const unsubscribe = RoomRepository.getRoom(
49
+ roomId,
102
50
  ({ data, loading, error: streamError }) => {
103
51
  if (streamError) setError(streamError);
104
- if (!loading && data) setLivestream({ ...data });
52
+ if (!loading && data) setRoom({ ...data });
105
53
  }
106
54
  );
107
55
 
108
56
  return () => unsubscribe();
109
- }, [streamId]);
57
+ }, [roomId]);
110
58
 
111
59
  useEffect(() => {
112
- if (livestream?.isDeleted || subscribedPost?.isDeleted) {
113
- navigation.replace('PostDetail', { postId: subscribedPost?.postId });
60
+ if (room?.status === RoomStatus.live) {
61
+ setWasLive(true);
114
62
  }
115
- }, [livestream?.isDeleted, subscribedPost, navigation]);
63
+ }, [room?.status]);
116
64
 
117
65
  useEffect(() => {
118
- const isTerminated =
119
- livestream?.moderation?.terminateLabels &&
120
- livestream?.moderation?.terminateLabels?.length > 0;
121
- const isLiveOrEnded =
122
- livestream?.status === LivestreamStatus.live ||
123
- livestream?.status === LivestreamStatus.ended;
124
-
125
- if (isLiveOrEnded && isTerminated) {
126
- navigation.replace('LivestreamTerminated', { type: 'viewer' });
66
+ if (room?.isDeleted || subscribedPost?.isDeleted) {
67
+ navigation.replace('PostDetail', { postId: subscribedPost?.postId });
127
68
  }
128
- }, [livestream?.moderation?.terminateLabels, livestream?.status, navigation]);
69
+ }, [
70
+ navigation,
71
+ room?.isDeleted,
72
+ subscribedPost?.postId,
73
+ subscribedPost?.isDeleted,
74
+ ]);
129
75
 
130
76
  useEffect(() => {
131
77
  const unsubscribe = NetInfo.addEventListener((state) => {
@@ -134,24 +80,121 @@ function AmityLiveStreamPlayerPage() {
134
80
  return () => unsubscribe();
135
81
  }, []);
136
82
 
137
- if (!livestream || error)
83
+ useEffect(() => {
84
+ if (!room?.status) return;
85
+
86
+ const shouldEnd =
87
+ room.status === RoomStatus.ended ||
88
+ (room.status === RoomStatus.recorded && wasLive);
89
+
90
+ if (!shouldEnd || isStreamEnding.current) return;
91
+
92
+ isStreamEnding.current = true;
93
+ setIsPaused(true);
94
+
95
+ if (Platform.OS === 'ios') {
96
+ // iOS: ONLY dismiss fullscreen. DO NOT touch key. DO NOT unmount.
97
+ requestAnimationFrame(() => {
98
+ videoRef.current?.dismissFullscreenPlayer?.();
99
+ });
100
+ } else {
101
+ // Android: HARD destroy
102
+ setTimeout(() => {
103
+ setVideoKey((prev) => prev + 1);
104
+ }, 50);
105
+ }
106
+ }, [room?.status, wasLive]);
107
+
108
+ useEffect(() => {
109
+ let timer: ReturnType<typeof setTimeout> | null = null;
110
+
111
+ if (
112
+ videoRef.current &&
113
+ room &&
114
+ room.status === RoomStatus.live &&
115
+ !videoError &&
116
+ Platform.OS === 'ios'
117
+ ) {
118
+ const isTerminated =
119
+ room?.moderation?.terminateLabels &&
120
+ room?.moderation?.terminateLabels?.length > 0;
121
+
122
+ if (!isTerminated) {
123
+ timer = setTimeout(() => {
124
+ videoRef.current?.presentFullscreenPlayer();
125
+ }, 100);
126
+ }
127
+ }
128
+
129
+ return () => {
130
+ if (timer !== null) {
131
+ clearTimeout(timer);
132
+ }
133
+ };
134
+ }, [room, videoError]);
135
+
136
+ const isTerminated =
137
+ room?.moderation?.terminateLabels &&
138
+ room?.moderation?.terminateLabels?.length > 0;
139
+
140
+ const shouldShowEndThumbnail =
141
+ room?.status === RoomStatus.ended ||
142
+ (room?.status === RoomStatus.recorded && wasLive) ||
143
+ isTerminated;
144
+
145
+ useEffect(() => {
146
+ if (!room?.status) return;
147
+
148
+ const shouldEnd =
149
+ room.status === RoomStatus.ended ||
150
+ (room.status === RoomStatus.recorded && wasLive);
151
+
152
+ if (!shouldEnd || isStreamEnding.current) return;
153
+
154
+ isStreamEnding.current = true;
155
+ setIsPaused(true);
156
+
157
+ if (Platform.OS === 'ios') {
158
+ // iOS: just dismiss fullscreen, DO NOT destroy immediately
159
+ if (videoRef.current) {
160
+ try {
161
+ videoRef.current.dismissFullscreenPlayer?.();
162
+ } catch {}
163
+ }
164
+ } else {
165
+ // Android: HARD destroy
166
+ setTimeout(() => {
167
+ setVideoKey((prev) => prev + 1);
168
+ }, 50);
169
+ }
170
+ }, [room?.status, wasLive]);
171
+
172
+ if (!room || error) {
138
173
  return (
139
174
  <SafeAreaView style={styles.container}>
140
175
  <LiveStreamIdleThumbnail />
141
176
  </SafeAreaView>
142
177
  );
178
+ }
179
+
180
+ const closePlayer = () => {
181
+ navigation.goBack();
182
+ };
183
+
184
+ const videoUrl =
185
+ room.status === RoomStatus.recorded
186
+ ? room.recordedPlaybackInfos[0]?.url
187
+ : room.livePlaybackUrl;
143
188
 
144
189
  return (
145
190
  <SafeAreaView style={styles.container}>
146
- {livestream.status === LivestreamStatus.ended ? (
191
+ {shouldShowEndThumbnail ? (
147
192
  <>
148
193
  <View style={styles.steamEndContainer}>
149
194
  <LiveStreamEndThumbnail />
150
195
  </View>
151
- <TouchableOpacity
152
- style={styles.closeButton}
153
- onPress={navigation.goBack}
154
- >
196
+
197
+ <TouchableOpacity style={styles.closeButton} onPress={closePlayer}>
155
198
  <SvgXml
156
199
  xml={close()}
157
200
  width="28"
@@ -160,14 +203,70 @@ function AmityLiveStreamPlayerPage() {
160
203
  />
161
204
  </TouchableOpacity>
162
205
  </>
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 && (
206
+ ) : (
207
+ <View style={styles.container}>
208
+ {(room.status === RoomStatus.live ||
209
+ room.status === RoomStatus.waiting_reconnect) && (
210
+ <View style={styles.indicator}>
211
+ <View style={styles.status}>
212
+ <Typography.CaptionBold style={styles.live}>
213
+ LIVE
214
+ </Typography.CaptionBold>
215
+ </View>
216
+ </View>
217
+ )}
218
+
219
+ {!shouldShowEndThumbnail && (
220
+ <Video
221
+ key={
222
+ Platform.OS === 'android' ? `${videoUrl}-${videoKey}` : videoUrl
223
+ }
224
+ ref={videoRef}
225
+ source={{
226
+ uri:
227
+ room.status === RoomStatus.recorded
228
+ ? room.recordedPlaybackInfos[0]?.url
229
+ : room.livePlaybackUrl,
230
+ headers: {
231
+ Authorization: `Bearer ${client.token.accessToken}`,
232
+ },
233
+ }}
234
+ style={styles.container}
235
+ resizeMode="contain"
236
+ controls={room?.status === RoomStatus.recorded && !wasLive}
237
+ fullscreen={
238
+ Platform.OS === 'ios' && room.status !== RoomStatus.recorded
239
+ }
240
+ fullscreenOrientation="landscape"
241
+ paused={isPaused}
242
+ muted={false}
243
+ volume={1.0}
244
+ audioOutput="speaker"
245
+ playInBackground={false}
246
+ playWhenInactive={false}
247
+ repeat={false}
248
+ onLoad={() => {
249
+ setPlayerInitialized(true);
250
+ if (room.status === RoomStatus.recorded) {
251
+ setIsPaused(false);
252
+ }
253
+ }}
254
+ onError={(e) => {
255
+ console.log('Video Error: ', e);
256
+ setVideoError(true);
257
+ }}
258
+ onFullscreenPlayerDidDismiss={() => {
259
+ if (Platform.OS === 'ios') {
260
+ closePlayer();
261
+ }
262
+ }}
263
+ />
264
+ )}
265
+ </View>
266
+ )}
267
+
268
+ {((room.status === RoomStatus.live && reconnecting) ||
269
+ room.status === RoomStatus.waiting_reconnect) && (
171
270
  <View style={styles.connecting}>
172
271
  <CircularProgressIndicator size={40} strokeWidth={2} />
173
272
  <Typography.TitleBold style={styles.text}>
@@ -179,54 +278,6 @@ function AmityLiveStreamPlayerPage() {
179
278
  </Typography.Caption>
180
279
  </View>
181
280
  )}
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
281
  </SafeAreaView>
231
282
  );
232
283
  }
@@ -13,9 +13,11 @@ 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',
20
+ backgroundColor: '#000000',
19
21
  },
20
22
  indicator: {
21
23
  left: 16,
@@ -301,7 +301,7 @@ const AmityPostComposerPage: FC<AmityPostComposerPageType> = ({
301
301
  'Discard this post',
302
302
  'The post will be permanently deleted. It cannot be undone',
303
303
  [
304
- { text: 'Keey Editing', style: 'cancel' },
304
+ { text: 'Keep Editing', style: 'cancel' },
305
305
  {
306
306
  text: 'Discard',
307
307
  style: 'destructive',