agora-appbuilder-core 4.0.0 → 4.0.1

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 (475) hide show
  1. package/package.json +3 -3
  2. package/template/.bundle/config +2 -0
  3. package/template/Gemfile +4 -0
  4. package/template/Gulpfile.js +29 -29
  5. package/template/_eslintrc.js +3 -3
  6. package/template/_gitignore +12 -11
  7. package/template/_package-lock.json +28491 -23647
  8. package/template/_prettierrc.js +2 -2
  9. package/template/agora-rn-uikit/.eslintrc.js +5 -0
  10. package/template/agora-rn-uikit/package.json +14 -14
  11. package/template/agora-rn-uikit/src/AgoraUIKit.tsx +6 -6
  12. package/template/agora-rn-uikit/src/Contexts/ContentContext.tsx +10 -0
  13. package/template/agora-rn-uikit/src/Contexts/DispatchContext.tsx +22 -0
  14. package/template/agora-rn-uikit/src/Contexts/LocalUserContext.tsx +6 -6
  15. package/template/agora-rn-uikit/src/Contexts/PropsContext.tsx +79 -38
  16. package/template/agora-rn-uikit/src/Contexts/RtcContext.tsx +26 -17
  17. package/template/agora-rn-uikit/src/Controls/BtnTemplate.tsx +1 -0
  18. package/template/agora-rn-uikit/src/Controls/Icons.ts +45 -0
  19. package/template/agora-rn-uikit/src/Controls/Local/EndCall.tsx +6 -4
  20. package/template/agora-rn-uikit/src/Controls/Local/FullScreen.tsx +3 -1
  21. package/template/agora-rn-uikit/src/Controls/Local/LocalAudioMute.tsx +5 -2
  22. package/template/agora-rn-uikit/src/Controls/Local/LocalVideoMute.tsx +5 -2
  23. package/template/agora-rn-uikit/src/Controls/Local/Recording.tsx +0 -2
  24. package/template/agora-rn-uikit/src/Controls/Local/SwitchCamera.tsx +7 -6
  25. package/template/agora-rn-uikit/src/Controls/LocalControls.tsx +5 -5
  26. package/template/agora-rn-uikit/src/Controls/Remote/RemoteAudioMute.tsx +5 -4
  27. package/template/agora-rn-uikit/src/Controls/Remote/RemoteSwap.tsx +3 -1
  28. package/template/agora-rn-uikit/src/Controls/Remote/RemoteVideoMute.tsx +5 -4
  29. package/template/agora-rn-uikit/src/Controls/RemoteControls.tsx +2 -2
  30. package/template/agora-rn-uikit/src/Reducer/ActiveSpeaker.ts +30 -0
  31. package/template/agora-rn-uikit/src/Reducer/LocalMuteAudio.ts +8 -7
  32. package/template/agora-rn-uikit/src/Reducer/LocalMuteVideo.ts +8 -7
  33. package/template/agora-rn-uikit/src/Reducer/LocalPermissionState.ts +6 -7
  34. package/template/agora-rn-uikit/src/Reducer/RemoteAudioStateChanged.ts +7 -8
  35. package/template/agora-rn-uikit/src/Reducer/RemoteVideoStateChanged.ts +9 -9
  36. package/template/agora-rn-uikit/src/Reducer/UpdateDualStreamMode.ts +7 -8
  37. package/template/agora-rn-uikit/src/Reducer/UserJoined.ts +14 -13
  38. package/template/agora-rn-uikit/src/Reducer/UserMuteRemoteAudio.ts +6 -7
  39. package/template/agora-rn-uikit/src/Reducer/UserMuteRemoteVideo.ts +6 -7
  40. package/template/agora-rn-uikit/src/Reducer/UserOffline.ts +5 -6
  41. package/template/agora-rn-uikit/src/Reducer/UserPin.ts +20 -3
  42. package/template/agora-rn-uikit/src/Reducer/UserSecondaryPin.ts +23 -0
  43. package/template/agora-rn-uikit/src/Reducer/index.ts +2 -1
  44. package/template/agora-rn-uikit/src/Rtc/Create.tsx +138 -100
  45. package/template/agora-rn-uikit/src/Rtc/Join.tsx +55 -28
  46. package/template/agora-rn-uikit/src/RtcConfigure.tsx +177 -77
  47. package/template/agora-rn-uikit/src/Utils/isBotUser.ts +15 -0
  48. package/template/agora-rn-uikit/src/Utils/quality.tsx +8 -0
  49. package/template/agora-rn-uikit/src/Views/MaxVideoView.native.tsx +56 -12
  50. package/template/agora-rn-uikit/src/Views/MaxVideoView.tsx +47 -17
  51. package/template/agora-rn-uikit/src/Views/MinVideoView.tsx +19 -11
  52. package/template/agora-rn-uikit/src/index.ts +15 -9
  53. package/template/android/app/build.gradle +59 -156
  54. package/template/android/app/src/debug/AndroidManifest.xml +6 -1
  55. package/template/android/app/src/debug/java/com/helloworld/ReactNativeFlipper.java +7 -4
  56. package/template/android/app/src/main/AndroidManifest.xml +6 -19
  57. package/template/android/app/src/main/assets/fonts/icomoon.ttf +0 -0
  58. package/template/android/app/src/main/java/com/helloworld/MainActivity.java +17 -0
  59. package/template/android/app/src/main/java/com/helloworld/MainApplication.java +22 -36
  60. package/template/android/app/src/main/java/com/helloworld/SSLPinningFactory.java +30 -0
  61. package/template/android/app/src/main/res/values/strings.xml +3 -0
  62. package/template/android/app/src/release/java/com/helloworld/ReactNativeFlipper.java +20 -0
  63. package/template/android/build.gradle +19 -33
  64. package/template/android/gradle/wrapper/gradle-wrapper.jar +0 -0
  65. package/template/android/gradle/wrapper/gradle-wrapper.properties +3 -2
  66. package/template/android/gradle.properties +18 -4
  67. package/template/android/gradlew +165 -104
  68. package/template/android/gradlew.bat +12 -23
  69. package/template/android/settings.gradle +1 -0
  70. package/template/bridge/rtc/webNg/RtcEngine.ts +200 -70
  71. package/template/bridge/rtc/webNg/{SurfaceView.tsx → RtcSurfaceView.tsx} +20 -26
  72. package/template/bridge/rtc/webNg/Types.ts +20 -5
  73. package/template/bridge/rtc/webNg/index.ts +81 -14
  74. package/template/bridge/rtm/web/index.ts +5 -3
  75. package/template/configTransform.js +16 -1
  76. package/template/customization-api/action-library.ts +4 -16
  77. package/template/customization-api/app-state.ts +15 -8
  78. package/template/customization-api/customEvents.ts +7 -2
  79. package/template/customization-api/customize.ts +1 -1
  80. package/template/customization-api/index.ts +4 -0
  81. package/template/customization-api/sub-components.ts +17 -16
  82. package/template/customization-api/temp.ts +52 -0
  83. package/template/customization-api/typeDefinition.ts +34 -46
  84. package/template/customization-api/types.ts +26 -0
  85. package/template/customization-api/utils.ts +4 -0
  86. package/template/customization-implementation/createHook.ts +24 -6
  87. package/template/customization-implementation/index.ts +1 -2
  88. package/template/customization-implementation/useCustomization.tsx +5 -7
  89. package/template/defaultConfig.js +72 -0
  90. package/template/global.d.ts +14 -1
  91. package/template/index.js +1 -4
  92. package/template/index.web.js +0 -5
  93. package/template/index.wsdk.tsx +1 -12
  94. package/template/ios/.xcode.env +11 -0
  95. package/template/ios/HelloWorld/AppDelegate.h +2 -4
  96. package/template/ios/HelloWorld/AppDelegate.mm +64 -0
  97. package/template/ios/HelloWorld/HelloWorldDebug.entitlements +10 -0
  98. package/template/ios/HelloWorld/Info.plist +8 -2
  99. package/template/ios/HelloWorld/main.m +2 -1
  100. package/template/ios/HelloWorld.xcodeproj/project.pbxproj +533 -17
  101. package/template/ios/HelloWorld.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
  102. package/template/ios/HelloWorld.xcworkspace/contents.xcworkspacedata +10 -0
  103. package/template/ios/HelloWorld.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
  104. package/template/ios/HelloWorldTests/HelloWorldTests.m +14 -13
  105. package/template/ios/HelloWorldTests/Info.plist +2 -2
  106. package/template/ios/Podfile +54 -20
  107. package/template/ios/Podfile.lock +809 -0
  108. package/template/ios/ScreenSharing/Info.plist +15 -0
  109. package/template/ios/ScreenSharing/SampleHandler.h +9 -0
  110. package/template/ios/ScreenSharing/SampleHandler.m +70 -0
  111. package/template/jest.config.js +4 -0
  112. package/template/metro.config.js +7 -32
  113. package/template/package.json +53 -39
  114. package/template/react-native-toast-message/index.d.ts +3 -1
  115. package/template/react-native-toast-message/index.js +1 -0
  116. package/template/react-native-toast-message/src/components/base/index.js +20 -32
  117. package/template/react-native-toast-message/src/components/base/styles.js +18 -21
  118. package/template/react-native-toast-message/src/components/checkbox.js +24 -19
  119. package/template/react-native-toast-message/src/index.js +3 -1
  120. package/template/react-native-toast-message/src/index.sdk.tsx +4 -1
  121. package/template/src/App.tsx +53 -69
  122. package/template/src/AppRoutes.tsx +90 -0
  123. package/template/src/AppWrapper.tsx +42 -25
  124. package/template/src/SDKAppWrapper.tsx +89 -57
  125. package/template/src/app-state/useLocalUserInfo.ts +3 -3
  126. package/template/src/app-state/useNoiseSupression.native.tsx +67 -0
  127. package/template/src/app-state/useNoiseSupression.tsx +107 -0
  128. package/template/src/app-state/useVideoQuality.tsx +39 -0
  129. package/template/src/assets/font-styles.css +175 -3
  130. package/template/src/assets/fonts/icomoon.ttf +0 -0
  131. package/template/src/assets/selection.json +1 -1
  132. package/template/src/atoms/ActionMenu.tsx +50 -11
  133. package/template/src/atoms/Avatar.tsx +51 -0
  134. package/template/src/atoms/Card.tsx +21 -8
  135. package/template/src/atoms/Carousel.native.tsx +105 -0
  136. package/template/src/atoms/Carousel.tsx +103 -0
  137. package/template/src/atoms/Checkbox.tsx +98 -0
  138. package/template/src/atoms/CircularProgress.tsx +0 -1
  139. package/template/src/atoms/ClipboardIconButton.tsx +91 -0
  140. package/template/src/atoms/CustomIcon.tsx +46 -0
  141. package/template/src/atoms/DropDownMulti.tsx +349 -0
  142. package/template/src/atoms/Dropdown.tsx +3 -3
  143. package/template/src/atoms/IconButton.tsx +52 -9
  144. package/template/src/atoms/ImageIcon.tsx +18 -5
  145. package/template/src/atoms/InlineNotification.tsx +81 -0
  146. package/template/src/atoms/InviteInfo.tsx +4 -4
  147. package/template/src/atoms/MeetingLink.tsx +160 -0
  148. package/template/src/atoms/ParticipantsCount.tsx +20 -8
  149. package/template/src/atoms/Popup.tsx +49 -27
  150. package/template/src/atoms/PrimaryButton.tsx +19 -5
  151. package/template/src/atoms/RecordingInfo.tsx +8 -5
  152. package/template/src/atoms/SecondaryButton.tsx +2 -0
  153. package/template/src/atoms/Spacer.tsx +1 -0
  154. package/template/src/atoms/TertiaryButton.tsx +35 -5
  155. package/template/src/atoms/TextInput.tsx +2 -1
  156. package/template/src/atoms/Toolbar.tsx +102 -0
  157. package/template/src/atoms/ToolbarItem.tsx +85 -0
  158. package/template/src/atoms/ToolbarMenu.tsx +40 -0
  159. package/template/src/atoms/ToolbarMenuItem.tsx +104 -0
  160. package/template/src/atoms/ToolbarPreset.tsx +71 -0
  161. package/template/src/atoms/Tooltip.tsx +30 -13
  162. package/template/src/atoms/pagination/Pagination.tsx +127 -0
  163. package/template/src/atoms/pagination/usePagination.tsx +88 -0
  164. package/template/src/auth/AuthProvider.tsx +500 -0
  165. package/template/src/auth/AuthRoute.tsx +94 -0
  166. package/template/src/auth/IDPAuth.electron.tsx +31 -0
  167. package/template/src/auth/IDPAuth.tsx +67 -0
  168. package/template/src/auth/IDPLogoutComponent.tsx +158 -0
  169. package/template/src/auth/UserCancelPopup.tsx +115 -0
  170. package/template/src/auth/config.ts +52 -0
  171. package/template/src/auth/openIDPURL.electron.tsx +39 -0
  172. package/template/src/auth/openIDPURL.native.tsx +51 -0
  173. package/template/src/auth/openIDPURL.tsx +20 -0
  174. package/template/src/auth/useIDPAuth.electron.tsx +65 -0
  175. package/template/src/auth/useIDPAuth.native.tsx +70 -0
  176. package/template/src/auth/useIDPAuth.tsx +63 -0
  177. package/template/src/auth/useTokenAuth.tsx +194 -0
  178. package/template/src/components/Chat.tsx +92 -72
  179. package/template/src/components/ChatContext.ts +2 -0
  180. package/template/src/components/ColorConfigure.tsx +0 -1
  181. package/template/src/components/CommonStyles.ts +9 -2
  182. package/template/src/components/Controls.tsx +914 -182
  183. package/template/src/components/Controls1.native.tsx +9 -5
  184. package/template/src/components/DeviceConfigure.native.tsx +2 -2
  185. package/template/src/components/DeviceConfigure.tsx +400 -149
  186. package/template/src/components/DeviceContext.tsx +2 -0
  187. package/template/src/components/EventsConfigure.tsx +722 -82
  188. package/template/src/components/GraphQLProvider.tsx +82 -39
  189. package/template/src/components/GridVideo.tsx +30 -16
  190. package/template/src/components/HostControlView.tsx +11 -14
  191. package/template/src/components/JoinPhrase.tsx +0 -1
  192. package/template/src/components/Leftbar.tsx +110 -0
  193. package/template/src/components/Navbar.tsx +305 -147
  194. package/template/src/components/NavbarMobile.tsx +119 -0
  195. package/template/src/components/Navigation.native.tsx +1 -15
  196. package/template/src/components/{Settings.native.tsx → Navigation.sdk.tsx} +17 -6
  197. package/template/src/components/NetworkQualityContext.tsx +12 -6
  198. package/template/src/components/ParticipantsView.tsx +63 -56
  199. package/template/src/components/PinnedVideo.tsx +191 -119
  200. package/template/src/components/Precall.native.tsx +177 -72
  201. package/template/src/components/Precall.tsx +247 -78
  202. package/template/src/components/RTMConfigure.tsx +205 -67
  203. package/template/src/components/Rightbar.tsx +112 -0
  204. package/template/src/components/Router.electron.ts +1 -0
  205. package/template/src/components/Router.native.ts +1 -0
  206. package/template/src/components/Router.sdk.ts +1 -0
  207. package/template/src/components/Router.ts +1 -0
  208. package/template/src/components/SdkApiContext.tsx +313 -0
  209. package/template/src/components/SdkMuteToggleListener.tsx +88 -0
  210. package/template/src/components/SessionContext.tsx +0 -1
  211. package/template/src/components/Settings.tsx +33 -4
  212. package/template/src/components/SettingsView.tsx +44 -9
  213. package/template/src/components/Share.tsx +152 -74
  214. package/template/src/components/StorageContext.tsx +23 -6
  215. package/template/src/components/ToastComponent.tsx +10 -1
  216. package/template/src/components/WhiteboardLayout.tsx +291 -0
  217. package/template/src/components/chat-messages/useChatMessages.tsx +454 -239
  218. package/template/src/components/chat-ui/{useChatUIControl.tsx → useChatUIControls.tsx} +29 -29
  219. package/template/src/components/common/Error.tsx +2 -0
  220. package/template/src/components/common/Logo.tsx +2 -2
  221. package/template/src/components/contexts/LiveStreamDataContext.tsx +13 -12
  222. package/template/src/components/contexts/ScreenShareContext.tsx +15 -1
  223. package/template/src/components/contexts/VideoMeetingDataContext.tsx +6 -6
  224. package/template/src/components/contexts/WaitingRoomContext.tsx +50 -0
  225. package/template/src/components/contexts/WhiteboardContext.tsx +54 -54
  226. package/template/src/components/disable-chat/useDisableChat.tsx +32 -0
  227. package/template/src/components/livestream/LiveStreamContext.tsx +314 -220
  228. package/template/src/components/livestream/Types.ts +36 -20
  229. package/template/src/components/livestream/views/LiveStreamAttendeeLandingTile.tsx +295 -0
  230. package/template/src/components/livestream/views/LiveStreamControls.tsx +5 -10
  231. package/template/src/components/meeting-info-invite/MeetingInfo.tsx +82 -0
  232. package/template/src/components/meeting-info-invite/MeetingInfoCardHeader.tsx +86 -0
  233. package/template/src/components/meeting-info-invite/MeetingInfoGridTile.tsx +218 -0
  234. package/template/src/components/meeting-info-invite/MeetingInfoLinks.tsx +122 -0
  235. package/template/src/components/participants/AllAudienceParticipants.tsx +19 -20
  236. package/template/src/components/participants/AllHostParticipants.tsx +20 -19
  237. package/template/src/components/participants/Participant.tsx +45 -16
  238. package/template/src/components/participants/ParticipantSectionTitle.tsx +5 -2
  239. package/template/src/components/participants/ScreenshareParticipants.tsx +17 -19
  240. package/template/src/components/participants/UserActionMenuOptions.tsx +173 -62
  241. package/template/src/components/participants/WaitingRoomParticipants.tsx +74 -0
  242. package/template/src/components/popups/InvitePopup.tsx +110 -45
  243. package/template/src/components/popups/StartScreenSharePopup.native.tsx +182 -0
  244. package/template/src/components/popups/StartScreenSharePopup.tsx +6 -0
  245. package/template/src/components/popups/StopRecordingPopup.tsx +11 -5
  246. package/template/src/components/popups/StopScreenSharePopup.native.tsx +135 -0
  247. package/template/src/components/popups/StopScreenSharePopup.tsx +6 -0
  248. package/template/src/components/popups/WhiteboardClearAllPopup.tsx +123 -0
  249. package/template/src/components/precall/LocalMute.tsx +69 -45
  250. package/template/src/components/precall/PermissionHelper.tsx +56 -28
  251. package/template/src/components/precall/PreCallSettings.tsx +1 -0
  252. package/template/src/components/precall/VideoFallback.tsx +173 -0
  253. package/template/src/components/precall/VideoPreview.native.tsx +19 -53
  254. package/template/src/components/precall/VideoPreview.tsx +29 -164
  255. package/template/src/components/precall/index.tsx +2 -0
  256. package/template/src/components/precall/joinCallBtn.native.tsx +12 -5
  257. package/template/src/components/precall/joinCallBtn.tsx +13 -4
  258. package/template/src/components/precall/joinWaitingRoomBtn.native.tsx +210 -0
  259. package/template/src/components/precall/joinWaitingRoomBtn.tsx +250 -0
  260. package/template/src/components/precall/meetingTitle.tsx +37 -11
  261. package/template/src/components/precall/selectDevice.tsx +5 -5
  262. package/template/src/components/precall/textInput.tsx +17 -19
  263. package/template/src/components/precall/usePreCall.tsx +33 -1
  264. package/template/src/components/recording-bot/RecordingBotRoute.tsx +42 -0
  265. package/template/src/components/recordings/RecordingsDateTable.tsx +62 -0
  266. package/template/src/components/recordings/RecordingsModal.tsx +135 -0
  267. package/template/src/components/recordings/ViewRecordingsModal.tsx +51 -0
  268. package/template/src/components/recordings/recording-table.tsx +154 -0
  269. package/template/src/components/recordings/style.ts +183 -0
  270. package/template/src/components/recordings/utils.ts +80 -0
  271. package/template/src/components/room-info/useRoomInfo.tsx +128 -0
  272. package/template/src/components/{meeting-info/useSetMeetingInfo.tsx → room-info/useSetRoomInfo.tsx} +12 -12
  273. package/template/src/components/useShareLink.tsx +28 -63
  274. package/template/src/components/useUserPreference.tsx +82 -16
  275. package/template/src/components/useVideoCall.tsx +93 -1
  276. package/template/src/components/virtual-background/VBButton.tsx +64 -0
  277. package/template/src/components/virtual-background/VBCard.native.tsx +282 -0
  278. package/template/src/components/virtual-background/VBCard.tsx +272 -0
  279. package/template/src/components/virtual-background/VBPanel.tsx +279 -0
  280. package/template/src/components/virtual-background/VButils.native.ts +37 -0
  281. package/template/src/components/virtual-background/VButils.ts +104 -0
  282. package/template/src/components/virtual-background/VideoPreview.native.tsx +43 -0
  283. package/template/src/components/virtual-background/VideoPreview.tsx +106 -0
  284. package/template/src/components/virtual-background/imagePaths.ts +87 -0
  285. package/template/src/components/virtual-background/images/beachImageBase64.ts +1 -0
  286. package/template/src/components/virtual-background/images/bedroomImageBase64.ts +1 -0
  287. package/template/src/components/virtual-background/images/bookImageBase64.ts +1 -0
  288. package/template/src/components/virtual-background/images/earthImageBase64.ts +1 -0
  289. package/template/src/components/virtual-background/images/index.ts +37 -0
  290. package/template/src/components/virtual-background/images/lampImageBase64.ts +1 -0
  291. package/template/src/components/virtual-background/images/mountainsImageBase64.ts +1 -0
  292. package/template/src/components/virtual-background/images/office1ImageBase64.ts +1 -0
  293. package/template/src/components/virtual-background/images/officeImageBase64.ts +1 -0
  294. package/template/src/components/virtual-background/images/plantsImageBase64.ts +1 -0
  295. package/template/src/components/virtual-background/images/skyImageBase64.ts +1 -0
  296. package/template/src/components/virtual-background/images/wallImageBase64.ts +1 -0
  297. package/template/src/components/virtual-background/useVB.native.tsx +185 -0
  298. package/template/src/components/virtual-background/useVB.tsx +267 -0
  299. package/template/src/components/whiteboard/StrokeWidthTool.tsx +137 -0
  300. package/template/src/components/whiteboard/WhiteboardButton.tsx +93 -0
  301. package/template/src/components/whiteboard/WhiteboardCanvas.tsx +99 -0
  302. package/template/src/components/whiteboard/WhiteboardConfigure.native.tsx +148 -0
  303. package/template/src/components/whiteboard/WhiteboardConfigure.tsx +446 -0
  304. package/template/src/components/whiteboard/WhiteboardCursor.tsx +152 -0
  305. package/template/src/components/whiteboard/WhiteboardToolBox.tsx +1246 -0
  306. package/template/src/components/whiteboard/WhiteboardView.native.tsx +188 -0
  307. package/template/src/components/whiteboard/WhiteboardView.tsx +81 -0
  308. package/template/src/components/whiteboard/WhiteboardWidget.tsx +685 -0
  309. package/template/src/components/whiteboard/WhiteboardWrapper.tsx +38 -0
  310. package/template/src/language/default-labels/commonLabels.ts +51 -14
  311. package/template/src/language/default-labels/createScreenLabels.ts +97 -17
  312. package/template/src/language/default-labels/joinScreenLabels.ts +45 -6
  313. package/template/src/language/default-labels/precallScreenLabels.ts +149 -25
  314. package/template/src/language/default-labels/shareLinkScreenLabels.ts +85 -37
  315. package/template/src/language/default-labels/videoCallScreenLabels.ts +1195 -158
  316. package/template/src/pages/Create.tsx +136 -106
  317. package/template/src/pages/Endcall.tsx +2 -2
  318. package/template/src/pages/Join.tsx +82 -40
  319. package/template/src/pages/Login.tsx +26 -0
  320. package/template/src/pages/VideoCall.tsx +329 -127
  321. package/template/src/pages/video-call/ActionSheet.native.tsx +54 -6
  322. package/template/src/pages/video-call/ActionSheet.tsx +55 -15
  323. package/template/src/pages/video-call/ActionSheetContent.tsx +498 -308
  324. package/template/src/pages/video-call/ActionSheetHandle.tsx +7 -1
  325. package/template/src/pages/video-call/DefaultLayouts.ts +20 -8
  326. package/template/src/pages/video-call/NameWithMicIcon.tsx +41 -64
  327. package/template/src/pages/video-call/PinchableView.tsx +119 -0
  328. package/template/src/pages/video-call/RenderComponent.tsx +14 -30
  329. package/template/src/pages/video-call/SidePanelHeader.tsx +227 -29
  330. package/template/src/pages/video-call/VideoCallMobileView.tsx +231 -89
  331. package/template/src/pages/video-call/VideoCallScreen.native.tsx +3 -2
  332. package/template/src/pages/video-call/VideoCallScreen.tsx +233 -84
  333. package/template/src/pages/video-call/VideoCallScreenWrapper.tsx +41 -0
  334. package/template/src/pages/video-call/VideoComponent.tsx +60 -8
  335. package/template/src/pages/video-call/VideoRenderer.tsx +343 -57
  336. package/template/src/pages/video-call/VisibilitySensor.tsx +104 -0
  337. package/template/src/pages/video-call/ZoomableWrapper.native.tsx +34 -0
  338. package/template/src/pages/video-call/ZoomableWrapper.tsx +5 -0
  339. package/template/src/pages/video-call/index.ts +42 -8
  340. package/template/src/rtm/RTMEngine.ts +17 -4
  341. package/template/src/rtm-events/constants.ts +21 -3
  342. package/template/src/rtm-events-api/Events.ts +7 -4
  343. package/template/src/rtm-events-api/LocalEvents.ts +14 -0
  344. package/template/src/rtm-events-api/types.ts +5 -5
  345. package/template/src/selection.json +1 -0
  346. package/template/src/subComponents/ChatBubble.tsx +87 -67
  347. package/template/src/subComponents/ChatContainer.tsx +70 -49
  348. package/template/src/subComponents/ChatInput.ios.tsx +32 -85
  349. package/template/src/subComponents/ChatInput.tsx +31 -80
  350. package/template/src/subComponents/Checkbox.native.tsx +46 -46
  351. package/template/src/subComponents/Checkbox.tsx +7 -6
  352. package/template/src/subComponents/CopyJoinInfo.tsx +31 -11
  353. package/template/src/subComponents/EndcallPopup.tsx +83 -12
  354. package/template/src/subComponents/FallbackLogo.tsx +2 -2
  355. package/template/src/subComponents/LanguageSelector.tsx +34 -30
  356. package/template/src/subComponents/LayoutIconButton.tsx +34 -17
  357. package/template/src/subComponents/LayoutIconDropdown.tsx +21 -8
  358. package/template/src/subComponents/Loading.tsx +60 -0
  359. package/template/src/subComponents/LocalAudioMute.tsx +87 -34
  360. package/template/src/subComponents/LocalEndCall.tsx +61 -24
  361. package/template/src/subComponents/LocalSwitchCamera.tsx +57 -13
  362. package/template/src/subComponents/LocalVideoMute.tsx +105 -36
  363. package/template/src/subComponents/LogoutButton.tsx +1 -1
  364. package/template/src/subComponents/NetworkQualityPill.tsx +22 -38
  365. package/template/src/subComponents/Recording.tsx +29 -9
  366. package/template/src/subComponents/RemoteAudioMute.tsx +5 -5
  367. package/template/src/subComponents/RemoteMutePopup.tsx +55 -14
  368. package/template/src/subComponents/RemoteVideoMute.tsx +5 -5
  369. package/template/src/subComponents/RemoveMeetingPopup.tsx +19 -6
  370. package/template/src/subComponents/RemoveScreensharePopup.tsx +20 -5
  371. package/template/src/subComponents/ScreenShareNotice.tsx +11 -6
  372. package/template/src/subComponents/SelectDevice.tsx +103 -34
  373. package/template/src/subComponents/SelectDeviceSettings.backup.tsx +9 -6
  374. package/template/src/subComponents/SidePanelButtons.ts +0 -3
  375. package/template/src/subComponents/SidePanelEnum.tsx +2 -0
  376. package/template/src/subComponents/SidePanelHeader.tsx +97 -63
  377. package/template/src/subComponents/ToastConfig.tsx +70 -61
  378. package/template/src/subComponents/caption/Caption.tsx +132 -0
  379. package/template/src/subComponents/caption/CaptionContainer.tsx +302 -0
  380. package/template/src/subComponents/caption/CaptionIcon.tsx +111 -0
  381. package/template/src/subComponents/caption/CaptionText.tsx +182 -0
  382. package/template/src/subComponents/caption/DownloadTranscriptBtn.tsx +65 -0
  383. package/template/src/subComponents/caption/LanguageSelectorPopup.tsx +192 -0
  384. package/template/src/subComponents/caption/Transcript.tsx +452 -0
  385. package/template/src/subComponents/caption/TranscriptIcon.tsx +123 -0
  386. package/template/src/subComponents/caption/TranscriptText.tsx +98 -0
  387. package/template/src/subComponents/caption/index.ts +3 -0
  388. package/template/src/subComponents/caption/proto/ptoto.js +91 -0
  389. package/template/src/subComponents/caption/proto/test.proto +23 -0
  390. package/template/src/subComponents/caption/useCaption.tsx +123 -0
  391. package/template/src/subComponents/caption/useCaptionWidth.ts +27 -0
  392. package/template/src/subComponents/caption/useSTTAPI.tsx +179 -0
  393. package/template/src/subComponents/caption/useStreamMessageUtils.native.ts +211 -0
  394. package/template/src/subComponents/caption/useStreamMessageUtils.ts +235 -0
  395. package/template/src/subComponents/caption/useTranscriptDownload.native.ts +63 -0
  396. package/template/src/subComponents/caption/useTranscriptDownload.ts +52 -0
  397. package/template/src/subComponents/caption/utils.ts +126 -0
  398. package/template/src/subComponents/chat/ChatParticipants.tsx +60 -24
  399. package/template/src/subComponents/livestream/ApprovedLiveStreamControlsView.tsx +2 -2
  400. package/template/src/subComponents/livestream/CurrentLiveStreamRequestsView.tsx +19 -20
  401. package/template/src/subComponents/livestream/controls/LocalRaiseHand.tsx +66 -35
  402. package/template/src/subComponents/livestream/controls/RemoteLiveStreamApprovedRequestRecall.tsx +3 -2
  403. package/template/src/subComponents/livestream/controls/RemoteLiveStreamRequestApprove.tsx +10 -6
  404. package/template/src/subComponents/livestream/controls/RemoteLiveStreamRequestReject.tsx +28 -19
  405. package/template/src/subComponents/recording/useIsRecordingBot.tsx +38 -0
  406. package/template/src/subComponents/recording/useRecording.tsx +251 -138
  407. package/template/src/subComponents/recording/useRecordingLayoutQuery.tsx +0 -1
  408. package/template/src/subComponents/screenshare/ScreenshareButton.tsx +39 -15
  409. package/template/src/subComponents/screenshare/ScreenshareConfigure.native.tsx +275 -69
  410. package/template/src/subComponents/screenshare/ScreenshareConfigure.tsx +193 -124
  411. package/template/src/subComponents/screenshare/useScreenshare.tsx +2 -0
  412. package/template/src/subComponents/waiting-rooms/WaitingRoomControls.tsx +85 -0
  413. package/template/src/subComponents/waiting-rooms/useWaitingRoomAPI.ts +75 -0
  414. package/template/src/theme/index.ts +13 -0
  415. package/template/src/utils/SdkEvents.ts +37 -14
  416. package/template/src/utils/SdkMethodEvents.ts +101 -0
  417. package/template/src/utils/axiomLogger.ts +117 -0
  418. package/template/src/utils/book.jpg +0 -0
  419. package/template/src/utils/common.tsx +118 -6
  420. package/template/src/utils/constants.ts +4 -0
  421. package/template/src/utils/getCustomRoute.ts +7 -0
  422. package/template/src/utils/index.tsx +34 -0
  423. package/template/src/utils/useActionSheet.tsx +50 -0
  424. package/template/src/utils/useActiveSpeaker.ts +38 -0
  425. package/template/src/utils/useAppState.ts +17 -0
  426. package/template/src/utils/useAsyncEffect.ts +138 -0
  427. package/template/src/utils/{useCreateMeeting.ts → useCreateRoom.ts} +27 -26
  428. package/template/src/utils/useEndCall.ts +65 -0
  429. package/template/src/utils/useFindActiveSpeaker.native.ts +4 -0
  430. package/template/src/utils/useFindActiveSpeaker.ts +335 -0
  431. package/template/src/utils/useGetMeetingPhrase.ts +10 -10
  432. package/template/src/utils/useIsAudioEnabled.ts +3 -3
  433. package/template/src/utils/useIsLocalUserSpeaking.native.ts +4 -0
  434. package/template/src/utils/useIsLocalUserSpeaking.ts +103 -0
  435. package/template/src/utils/useIsPSTN.ts +3 -3
  436. package/template/src/utils/useIsVideoEnabled.ts +3 -3
  437. package/template/src/utils/useJoinRoom.ts +199 -0
  438. package/template/src/utils/{useIsActiveSpeaker.ts → useLocalAudio.ts} +23 -12
  439. package/template/src/{components/OAuth.tsx → utils/useMenu.tsx} +16 -15
  440. package/template/src/utils/useModal.tsx +8 -0
  441. package/template/src/utils/useMutePSTN.ts +2 -2
  442. package/template/src/utils/useMuteToggleLocal.ts +121 -96
  443. package/template/src/utils/useRemoteEndCall.ts +4 -4
  444. package/template/src/utils/useRemoteEndScreenshare.ts +4 -4
  445. package/template/src/utils/useRemoteMute.ts +7 -7
  446. package/template/src/utils/useRemoteRequest.ts +7 -7
  447. package/template/src/utils/useSearchParams.tsx +18 -0
  448. package/template/src/utils/useString.ts +13 -3
  449. package/template/src/utils/useSwitchCamera.native.tsx +25 -0
  450. package/template/src/{subComponents/screenshare/ScreenshareButton.native.tsx → utils/useSwitchCamera.tsx} +12 -11
  451. package/template/src/utils/useToolbar.tsx +59 -0
  452. package/template/src/wasms/agora-virtual-background.wasm +0 -0
  453. package/template/static.d.ts +42 -0
  454. package/template/tsconfig_rsdk_index.json +3 -3
  455. package/template/tsconfig_wsdk_index.json +1 -1
  456. package/template/web/index.html +20 -0
  457. package/template/webpack.commons.js +21 -10
  458. package/template/webpack.rsdk.config.js +1 -2
  459. package/template/webpack.web.config.js +7 -3
  460. package/template/_buckconfig +0 -6
  461. package/template/_gitattributes +0 -1
  462. package/template/agora-rn-uikit/src/Contexts/RenderContext.tsx +0 -10
  463. package/template/agora-rn-uikit/src/Reducer/ActiveSpeakerDetected.ts +0 -11
  464. package/template/android/app/_BUCK +0 -55
  465. package/template/android/app/build_defs.bzl +0 -19
  466. package/template/bridge/rtc/webNg/LocalView.tsx +0 -20
  467. package/template/ios/HelloWorld/AppDelegate.m +0 -74
  468. package/template/src/components/OAuth.electron.tsx +0 -41
  469. package/template/src/components/OAuth.native.tsx +0 -55
  470. package/template/src/components/OAuthConfig.ts +0 -77
  471. package/template/src/components/StoreToken.tsx +0 -39
  472. package/template/src/components/meeting-info/useMeetingInfo.tsx +0 -70
  473. package/template/src/pages/video-call/CustomUserContextHolder.tsx +0 -20
  474. package/template/src/utils/useButtonTemplate.tsx +0 -44
  475. package/template/src/utils/useJoinMeeting.ts +0 -132
@@ -17,7 +17,7 @@ const VideoCallleScreen = () => {
17
17
  delay: 1000,
18
18
  onLoop: true,
19
19
  taskId: 'taskid',
20
- onError: (e) => console.log(`Error logging:`, e),
20
+ onError: e => console.log(`Error logging:`, e),
21
21
  },
22
22
  );
23
23
  ReactNativeForegroundService.start({
@@ -27,9 +27,10 @@ const VideoCallleScreen = () => {
27
27
  });
28
28
  }
29
29
  }, []);
30
+
30
31
  return (
31
32
  <GestureHandlerRootView style={{flex: 1}}>
32
- <VideoCallMobileView />
33
+ <VideoCallMobileView native={true} />
33
34
  </GestureHandlerRootView>
34
35
  );
35
36
  };
@@ -7,10 +7,10 @@ import {
7
7
  Platform,
8
8
  } from 'react-native';
9
9
  import {useCustomization} from 'customization-implementation';
10
- import Navbar from '../../components/Navbar';
10
+ import Navbar, {NavbarProps} from '../../components/Navbar';
11
11
  import ParticipantsView from '../../components/ParticipantsView';
12
12
  import SettingsView from '../../components/SettingsView';
13
- import Controls from '../../components/Controls';
13
+ import Controls, {ControlsProps} from '../../components/Controls';
14
14
  import Chat, {ChatProps} from '../../components/Chat';
15
15
  import {SidePanelType} from '../../subComponents/SidePanelEnum';
16
16
  import {
@@ -18,27 +18,37 @@ import {
18
18
  isValidReactComponent,
19
19
  isWebInternal,
20
20
  useIsDesktop,
21
+ useIsSmall,
21
22
  } from '../../utils/common';
22
23
  import {useSidePanel} from '../../utils/useSidePanel';
23
24
  import VideoComponent from './VideoComponent';
24
25
  import {videoView} from '../../../theme.json';
25
- import {
26
- ButtonTemplateProvider,
27
- ButtonTemplateName,
28
- } from '../../utils/useButtonTemplate';
26
+ import {ToolbarProvider, ToolbarPosition} from '../../utils/useToolbar';
29
27
  import SDKEvents from '../../utils/SdkEvents';
30
- import {useMeetingInfo} from '../../components/meeting-info/useMeetingInfo';
31
- import {controlMessageEnum, useRtc, useUserName} from 'customization-api';
32
- import events, {EventPersistLevel} from '../../rtm-events-api';
28
+ import {useRoomInfo} from '../../components/room-info/useRoomInfo';
29
+ import {
30
+ ToolbarCustomItem,
31
+ controlMessageEnum,
32
+ useUserName,
33
+ } from 'customization-api';
34
+ import events, {PersistanceLevel} from '../../rtm-events-api';
33
35
  import VideoCallMobileView from './VideoCallMobileView';
36
+ import CaptionContainer from '../../subComponents/caption/CaptionContainer';
37
+ import Transcript from '../../subComponents/caption/Transcript';
38
+ import Spacer from '../../atoms/Spacer';
39
+ import Leftbar, {LeftbarProps} from '../../components/Leftbar';
40
+ import Rightbar, {RightbarProps} from '../../components/Rightbar';
41
+ import useFindActiveSpeaker from '../../utils/useFindActiveSpeaker';
42
+ import VBPanel from '../../components/virtual-background/VBPanel';
43
+ import {useIsRecordingBot} from '../../subComponents/recording/useIsRecordingBot';
34
44
 
35
45
  const VideoCallScreen = () => {
46
+ useFindActiveSpeaker();
36
47
  const {sidePanel} = useSidePanel();
37
48
  const [name] = useUserName();
38
- const rtc = useRtc();
39
49
  const {
40
50
  data: {meetingTitle, isHost},
41
- } = useMeetingInfo();
51
+ } = useRoomInfo();
42
52
  const {
43
53
  ChatComponent,
44
54
  VideocallComponent,
@@ -48,16 +58,30 @@ const VideoCallScreen = () => {
48
58
  TopbarComponent,
49
59
  VideocallBeforeView,
50
60
  VideocallAfterView,
51
- } = useCustomization((data) => {
61
+ LeftbarComponent,
62
+ RightbarComponent,
63
+ BottombarProps,
64
+ TopbarProps,
65
+ LeftbarProps,
66
+ RightbarProps,
67
+ VideocallWrapper,
68
+ } = useCustomization(data => {
52
69
  let components: {
70
+ VideocallWrapper: React.ComponentType;
53
71
  VideocallComponent?: React.ComponentType;
54
72
  ChatComponent: React.ComponentType<ChatProps>;
55
- BottombarComponent: React.ComponentType;
73
+ BottombarComponent: React.ComponentType<ControlsProps>;
56
74
  ParticipantsComponent: React.ComponentType;
57
75
  SettingsComponent: React.ComponentType;
58
- TopbarComponent: React.ComponentType;
76
+ TopbarComponent: React.ComponentType<NavbarProps>;
59
77
  VideocallBeforeView: React.ComponentType;
60
78
  VideocallAfterView: React.ComponentType;
79
+ LeftbarComponent: React.ComponentType<LeftbarProps>;
80
+ RightbarComponent: React.ComponentType<RightbarProps>;
81
+ BottombarProps?: ToolbarCustomItem[];
82
+ TopbarProps?: ToolbarCustomItem[];
83
+ LeftbarProps?: ToolbarCustomItem[];
84
+ RightbarProps?: ToolbarCustomItem[];
61
85
  } = {
62
86
  BottombarComponent: Controls,
63
87
  TopbarComponent: Navbar,
@@ -66,6 +90,13 @@ const VideoCallScreen = () => {
66
90
  SettingsComponent: SettingsView,
67
91
  VideocallAfterView: React.Fragment,
68
92
  VideocallBeforeView: React.Fragment,
93
+ VideocallWrapper: React.Fragment,
94
+ LeftbarComponent: Leftbar,
95
+ RightbarComponent: Rightbar,
96
+ BottombarProps: [],
97
+ TopbarProps: [],
98
+ LeftbarProps: [],
99
+ RightbarProps: [],
69
100
  };
70
101
  if (
71
102
  data?.components?.videoCall &&
@@ -104,19 +135,65 @@ const VideoCallScreen = () => {
104
135
  // }
105
136
 
106
137
  if (
107
- data?.components?.videoCall.bottomBar &&
108
- typeof data?.components?.videoCall.bottomBar !== 'object' &&
109
- isValidReactComponent(data?.components?.videoCall.bottomBar)
138
+ data?.components?.videoCall.bottomToolBar &&
139
+ typeof data?.components?.videoCall.bottomToolBar !== 'object' &&
140
+ isValidReactComponent(data?.components?.videoCall.bottomToolBar)
141
+ ) {
142
+ components.BottombarComponent =
143
+ data?.components?.videoCall.bottomToolBar;
144
+ }
145
+
146
+ if (
147
+ data?.components?.videoCall.topToolBar &&
148
+ typeof data?.components?.videoCall.topToolBar !== 'object' &&
149
+ isValidReactComponent(data?.components?.videoCall.topToolBar)
110
150
  ) {
111
- components.BottombarComponent = data?.components?.videoCall.bottomBar;
151
+ components.TopbarComponent = data?.components?.videoCall.topToolBar;
112
152
  }
113
153
 
114
154
  if (
115
- data?.components?.videoCall.topBar &&
116
- typeof data?.components?.videoCall.topBar !== 'object' &&
117
- isValidReactComponent(data?.components?.videoCall.topBar)
155
+ data?.components?.videoCall.leftToolBar &&
156
+ typeof data?.components?.videoCall.leftToolBar !== 'object' &&
157
+ isValidReactComponent(data?.components?.videoCall.leftToolBar)
158
+ ) {
159
+ components.LeftbarComponent = data?.components?.videoCall.leftToolBar;
160
+ }
161
+
162
+ if (
163
+ data?.components?.videoCall.rightToolBar &&
164
+ typeof data?.components?.videoCall.rightToolBar !== 'object' &&
165
+ isValidReactComponent(data?.components?.videoCall.rightToolBar)
166
+ ) {
167
+ components.RightbarComponent = data?.components?.videoCall.rightToolBar;
168
+ }
169
+
170
+ if (
171
+ data?.components?.videoCall.bottomToolBar &&
172
+ typeof data?.components?.videoCall.bottomToolBar === 'object' &&
173
+ data?.components?.videoCall.bottomToolBar.length
174
+ ) {
175
+ components.BottombarProps = data?.components?.videoCall.bottomToolBar;
176
+ }
177
+ if (
178
+ data?.components?.videoCall.topToolBar &&
179
+ typeof data?.components?.videoCall.topToolBar === 'object' &&
180
+ data?.components?.videoCall.topToolBar.length
181
+ ) {
182
+ components.TopbarProps = data?.components?.videoCall.topToolBar;
183
+ }
184
+ if (
185
+ data?.components?.videoCall.rightToolBar &&
186
+ typeof data?.components?.videoCall.rightToolBar === 'object' &&
187
+ data?.components?.videoCall.rightToolBar.length
188
+ ) {
189
+ components.RightbarProps = data?.components?.videoCall.rightToolBar;
190
+ }
191
+ if (
192
+ data?.components?.videoCall.leftToolBar &&
193
+ typeof data?.components?.videoCall.leftToolBar === 'object' &&
194
+ data?.components?.videoCall.leftToolBar.length
118
195
  ) {
119
- components.TopbarComponent = data?.components?.videoCall.topBar;
196
+ components.LeftbarProps = data?.components?.videoCall.leftToolBar;
120
197
  }
121
198
 
122
199
  if (
@@ -128,6 +205,15 @@ const VideoCallScreen = () => {
128
205
  data?.components?.videoCall.participantsPanel;
129
206
  }
130
207
 
208
+ //todo hari - need to remove wrapper
209
+ if (
210
+ data?.components?.videoCall.wrapper &&
211
+ typeof data?.components?.videoCall.wrapper !== 'object' &&
212
+ isValidReactComponent(data?.components?.videoCall.wrapper)
213
+ ) {
214
+ components.VideocallWrapper = data?.components?.videoCall.wrapper;
215
+ }
216
+
131
217
  // commented for v1 release
132
218
  // if (
133
219
  // data?.components?.videoCall.settingsPanel &&
@@ -142,82 +228,129 @@ const VideoCallScreen = () => {
142
228
  return components;
143
229
  });
144
230
 
145
- useEffect(() => {
146
- // setTimeout(() => {
147
- // events.send(
148
- // controlMessageEnum.newUserJoined,
149
- // JSON.stringify({name}),
150
- // EventPersistLevel.LEVEL1,
151
- // );
152
- // }, 1000);
153
-
154
- /**
155
- * OLD: Commenting this code as getDevices API is web only
156
- * The below code fails on native app
157
- * RESPONSE: Added isWebInternal check to restrict execution only on web.
158
- */
159
- if (isWebInternal()) {
160
- new Promise((res) =>
161
- //@ts-ignore
162
- rtc.RtcEngine.getDevices(function (devices: MediaDeviceInfo[]) {
163
- res(devices);
164
- }),
165
- ).then((devices: MediaDeviceInfo[]) => {
166
- SDKEvents.emit('join', meetingTitle, devices, isHost);
167
- console.log('SDKEvents: Event Called join');
168
- });
169
- }
170
- }, []);
171
-
172
231
  const isDesktop = useIsDesktop();
232
+ const isSmall = useIsSmall();
233
+
234
+ const {isRecordingBot, recordingBotUIConfig} = useIsRecordingBot();
173
235
 
174
236
  return VideocallComponent ? (
175
237
  <VideocallComponent />
176
238
  ) : // ) : !isDesktop ? (
177
239
  isMobileUA() ? (
178
240
  // Mobile View
179
- <VideoCallMobileView />
241
+ <VideoCallMobileView native={false} />
180
242
  ) : (
181
243
  // Desktop View
182
244
  <>
183
- <VideocallBeforeView />
184
- <View style={style.full}>
185
- <ButtonTemplateProvider
186
- value={{buttonTemplateName: ButtonTemplateName.topBar}}>
187
- <TopbarComponent />
188
- </ButtonTemplateProvider>
245
+ <VideocallWrapper>
246
+ <VideocallBeforeView />
189
247
  <View
190
- style={[
191
- style.videoView,
192
- {paddingHorizontal: isDesktop() ? 32 : 10, paddingVertical: 10},
193
- ]}>
194
- <VideoComponent />
195
- {sidePanel === SidePanelType.Participants ? (
196
- <ParticipantsComponent />
197
- ) : (
198
- <></>
199
- )}
200
- {sidePanel === SidePanelType.Chat ? (
201
- $config.CHAT ? (
202
- <ChatComponent />
248
+ style={$config.ICON_TEXT ? style.fullRow : style.fullRowWithoutIcon}>
249
+ <ToolbarProvider value={{position: ToolbarPosition.left}}>
250
+ {LeftbarProps?.length ? (
251
+ <LeftbarComponent
252
+ customItems={LeftbarProps}
253
+ includeDefaultItems={false}
254
+ />
203
255
  ) : (
256
+ <LeftbarComponent />
257
+ )}
258
+ </ToolbarProvider>
259
+ <View style={style.full}>
260
+ <View
261
+ style={
262
+ isRecordingBot &&
263
+ !recordingBotUIConfig.topBar &&
264
+ style.zeroHeight
265
+ }>
266
+ <ToolbarProvider value={{position: ToolbarPosition.top}}>
267
+ {TopbarProps?.length ? (
268
+ <TopbarComponent
269
+ customItems={TopbarProps}
270
+ includeDefaultItems={false}
271
+ />
272
+ ) : (
273
+ <TopbarComponent />
274
+ )}
275
+ </ToolbarProvider>
276
+ </View>
277
+ <View
278
+ style={[
279
+ style.videoView,
280
+ $config.ICON_TEXT
281
+ ? {
282
+ paddingHorizontal: isDesktop() ? 32 : 10,
283
+ paddingVertical: 10,
284
+ paddingBottom: 0,
285
+ }
286
+ : {marginVertical: 20},
287
+ ]}>
288
+ <VideoComponent />
289
+ {sidePanel === SidePanelType.Participants ? (
290
+ <ParticipantsComponent />
291
+ ) : (
292
+ <></>
293
+ )}
294
+ {sidePanel === SidePanelType.Chat ? (
295
+ $config.CHAT ? (
296
+ <ChatComponent />
297
+ ) : (
298
+ <></>
299
+ )
300
+ ) : (
301
+ <></>
302
+ )}
303
+ {sidePanel === SidePanelType.Settings ? (
304
+ <SettingsComponent />
305
+ ) : (
306
+ <></>
307
+ )}
308
+ {sidePanel === SidePanelType.Transcript ? <Transcript /> : <></>}
309
+ {sidePanel === SidePanelType.VirtualBackground ? (
310
+ <VBPanel />
311
+ ) : (
312
+ <></>
313
+ )}
314
+ </View>
315
+ {!isWebInternal() && sidePanel === SidePanelType.Chat ? (
204
316
  <></>
205
- )
206
- ) : (
207
- <></>
208
- )}
209
- {sidePanel === SidePanelType.Settings ? <SettingsComponent /> : <></>}
317
+ ) : (
318
+ <ToolbarProvider value={{position: ToolbarPosition.bottom}}>
319
+ {BottombarProps?.length ? (
320
+ <BottombarComponent
321
+ customItems={BottombarProps}
322
+ includeDefaultItems={false}
323
+ />
324
+ ) : (
325
+ <>
326
+ <CaptionContainer />
327
+ <Spacer size={10} />
328
+ <View
329
+ style={
330
+ isRecordingBot &&
331
+ !recordingBotUIConfig.bottomBar &&
332
+ style.zeroHeight
333
+ }>
334
+ <BottombarComponent />
335
+ </View>
336
+ </>
337
+ )}
338
+ </ToolbarProvider>
339
+ )}
340
+ </View>
341
+ <ToolbarProvider value={{position: ToolbarPosition.right}}>
342
+ {RightbarProps?.length ? (
343
+ <RightbarComponent
344
+ customItems={RightbarProps}
345
+ includeDefaultItems={false}
346
+ />
347
+ ) : (
348
+ <RightbarComponent />
349
+ )}
350
+ </ToolbarProvider>
210
351
  </View>
211
- {!isWebInternal() && sidePanel === SidePanelType.Chat ? (
212
- <></>
213
- ) : (
214
- <ButtonTemplateProvider
215
- value={{buttonTemplateName: ButtonTemplateName.bottomBar}}>
216
- <BottombarComponent />
217
- </ButtonTemplateProvider>
218
- )}
219
- </View>
220
- <VideocallAfterView />
352
+ <VideocallAfterView />
353
+ </VideocallWrapper>
221
354
  </>
222
355
  );
223
356
  };
@@ -229,8 +362,24 @@ const style = StyleSheet.create({
229
362
  flexDirection: 'column',
230
363
  overflow: 'hidden',
231
364
  },
365
+ fullRow: {
366
+ flex: 1,
367
+ flexDirection: 'row',
368
+ overflow: 'hidden',
369
+ },
370
+ fullRowWithoutIcon: {
371
+ flex: 1,
372
+ flexDirection: 'row',
373
+ overflow: 'hidden',
374
+ paddingHorizontal: 32,
375
+ paddingVertical: 20,
376
+ },
232
377
  videoView: {
233
378
  flex: 12,
234
379
  flexDirection: 'row',
235
380
  },
381
+ zeroHeight: {
382
+ height: 0,
383
+ visibility: 'hidden',
384
+ },
236
385
  });
@@ -0,0 +1,41 @@
1
+ import React, {useContext, useEffect} from 'react';
2
+ import {PropsContext} from '../../../agora-rn-uikit';
3
+ import VideoCallScreen from '../video-call/VideoCallScreen';
4
+ import {isWebInternal} from '../../utils/common';
5
+ import {useLocation} from '../../components/Router';
6
+ import {getParamFromURL} from '../../utils/common';
7
+ import {useUserPreference} from '../../components/useUserPreference';
8
+ import WhiteboardConfigure from '../../components/whiteboard/WhiteboardConfigure';
9
+
10
+ const VideoCallScreenWithRecordingBot: React.FC = () => {
11
+ const location = useLocation();
12
+ const {setDisplayName} = useUserPreference();
13
+
14
+ const recordingBotName = getParamFromURL(location?.search, 'user_name');
15
+
16
+ useEffect(() => {
17
+ setDisplayName(recordingBotName);
18
+ }, []);
19
+ return <VideoCallScreen />;
20
+ };
21
+
22
+ const VideoCallScreenWrapper: React.FC = () => {
23
+ const {rtcProps} = useContext(PropsContext);
24
+
25
+ if ($config.ENABLE_WHITEBOARD) {
26
+ return (
27
+ <WhiteboardConfigure>
28
+ {rtcProps?.recordingBot ? (
29
+ <VideoCallScreenWithRecordingBot />
30
+ ) : (
31
+ <VideoCallScreen />
32
+ )}
33
+ </WhiteboardConfigure>
34
+ );
35
+ } else if (rtcProps?.recordingBot) {
36
+ return <VideoCallScreenWithRecordingBot />;
37
+ }
38
+ return <VideoCallScreen />;
39
+ };
40
+
41
+ export default VideoCallScreenWrapper;
@@ -1,44 +1,96 @@
1
- import React, {useEffect, useState} from 'react';
1
+ import React, {useContext, useEffect, useRef, useState} from 'react';
2
+ import {View} from 'react-native';
2
3
  import useLayoutsData from './useLayoutsData';
3
- import {isArray, isValidReactComponent} from '../../utils/common';
4
+ import {isArray, useIsDesktop, isValidReactComponent} from '../../utils/common';
5
+ import {PropsContext, ClientRoleType} from '../../../agora-rn-uikit';
4
6
  import {useLayout} from '../../utils/useLayout';
5
- import {useRender, useRtc} from 'customization-api';
7
+ import {useContent} from 'customization-api';
6
8
  import {getGridLayoutName} from './DefaultLayouts';
9
+ import {DispatchContext} from '../../../agora-rn-uikit';
10
+ import MeetingInfoGridTile from '../../components/meeting-info-invite/MeetingInfoGridTile';
11
+ import Spacer from '../../atoms/Spacer';
12
+ import {useLiveStreamDataContext} from '../../components/contexts/LiveStreamDataContext';
7
13
 
8
14
  const VideoComponent = () => {
9
- const {dispatch} = useRtc();
15
+ const {dispatch} = useContext(DispatchContext);
10
16
  const [layout, setLayoutIndex] = useState(0);
11
17
  const layoutsData = useLayoutsData();
12
18
  const {currentLayout, setLayout} = useLayout();
13
- const {activeUids, pinnedUid} = useRender();
19
+ const {activeUids, pinnedUid} = useContent();
20
+ const {rtcProps} = useContext(PropsContext);
21
+ const isDesktop = useIsDesktop();
22
+ const {audienceUids, hostUids} = useLiveStreamDataContext();
23
+ const [showNoUserInfo, setShowNoUserInfo] = useState(false);
14
24
 
25
+ useEffect(() => {
26
+ setTimeout(() => {
27
+ setShowNoUserInfo(true);
28
+ }, 2500);
29
+ }, []);
30
+
31
+ const currentLayoutRef = useRef(currentLayout);
32
+ const gridLayoutName = getGridLayoutName();
15
33
  useEffect(() => {
16
34
  if (activeUids && activeUids.length === 1) {
17
35
  if (pinnedUid) {
18
36
  dispatch({type: 'UserPin', value: [0]});
37
+ dispatch({type: 'UserSecondaryPin', value: [0]});
19
38
  }
20
- const gridLayoutName = getGridLayoutName();
21
- if (currentLayout !== gridLayoutName) {
39
+ if (currentLayoutRef.current != gridLayoutName) {
22
40
  setLayout(gridLayoutName);
23
41
  }
24
42
  }
25
43
  }, [activeUids]);
26
44
 
27
45
  useEffect(() => {
46
+ currentLayoutRef.current = currentLayout;
28
47
  if (isArray(layoutsData)) {
29
- let index = layoutsData.findIndex((item) => item.name === currentLayout);
48
+ let index = layoutsData.findIndex(item => item.name === currentLayout);
30
49
  if (index >= 0) {
31
50
  setLayoutIndex(index);
32
51
  }
33
52
  }
34
53
  }, [currentLayout]);
35
54
 
55
+ const showInviteTile = () => {
56
+ if (
57
+ $config.EVENT_MODE &&
58
+ rtcProps.role == ClientRoleType.ClientRoleAudience
59
+ ) {
60
+ return false;
61
+ }
62
+ if (activeUids.length == 1) return true;
63
+ return false;
64
+ };
65
+
36
66
  if (
37
67
  layoutsData &&
38
68
  layoutsData[layout] &&
39
69
  isValidReactComponent(layoutsData[layout].component)
40
70
  ) {
41
71
  const CurrentLayout = layoutsData[layout].component;
72
+ if (showInviteTile() && showNoUserInfo) {
73
+ return (
74
+ <View
75
+ style={{
76
+ flex: 1,
77
+ flexDirection: isDesktop() ? 'row' : 'column',
78
+ justifyContent: 'space-between',
79
+ }}>
80
+ <CurrentLayout renderData={activeUids} />
81
+ {(!$config.EVENT_MODE && activeUids.length === 1) ||
82
+ ($config.EVENT_MODE &&
83
+ hostUids.concat(audienceUids)?.length === 1) ? (
84
+ <>
85
+ <Spacer size={8} horizontal={isDesktop() ? true : false} />
86
+ <MeetingInfoGridTile />
87
+ </>
88
+ ) : (
89
+ <></>
90
+ )}
91
+ </View>
92
+ );
93
+ }
42
94
  return <CurrentLayout renderData={activeUids} />;
43
95
  } else {
44
96
  return <></>;