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.
- package/package.json +3 -3
- package/template/.bundle/config +2 -0
- package/template/Gemfile +4 -0
- package/template/Gulpfile.js +29 -29
- package/template/_eslintrc.js +3 -3
- package/template/_gitignore +12 -11
- package/template/_package-lock.json +28491 -23647
- package/template/_prettierrc.js +2 -2
- package/template/agora-rn-uikit/.eslintrc.js +5 -0
- package/template/agora-rn-uikit/package.json +14 -14
- package/template/agora-rn-uikit/src/AgoraUIKit.tsx +6 -6
- package/template/agora-rn-uikit/src/Contexts/ContentContext.tsx +10 -0
- package/template/agora-rn-uikit/src/Contexts/DispatchContext.tsx +22 -0
- package/template/agora-rn-uikit/src/Contexts/LocalUserContext.tsx +6 -6
- package/template/agora-rn-uikit/src/Contexts/PropsContext.tsx +79 -38
- package/template/agora-rn-uikit/src/Contexts/RtcContext.tsx +26 -17
- package/template/agora-rn-uikit/src/Controls/BtnTemplate.tsx +1 -0
- package/template/agora-rn-uikit/src/Controls/Icons.ts +45 -0
- package/template/agora-rn-uikit/src/Controls/Local/EndCall.tsx +6 -4
- package/template/agora-rn-uikit/src/Controls/Local/FullScreen.tsx +3 -1
- package/template/agora-rn-uikit/src/Controls/Local/LocalAudioMute.tsx +5 -2
- package/template/agora-rn-uikit/src/Controls/Local/LocalVideoMute.tsx +5 -2
- package/template/agora-rn-uikit/src/Controls/Local/Recording.tsx +0 -2
- package/template/agora-rn-uikit/src/Controls/Local/SwitchCamera.tsx +7 -6
- package/template/agora-rn-uikit/src/Controls/LocalControls.tsx +5 -5
- package/template/agora-rn-uikit/src/Controls/Remote/RemoteAudioMute.tsx +5 -4
- package/template/agora-rn-uikit/src/Controls/Remote/RemoteSwap.tsx +3 -1
- package/template/agora-rn-uikit/src/Controls/Remote/RemoteVideoMute.tsx +5 -4
- package/template/agora-rn-uikit/src/Controls/RemoteControls.tsx +2 -2
- package/template/agora-rn-uikit/src/Reducer/ActiveSpeaker.ts +30 -0
- package/template/agora-rn-uikit/src/Reducer/LocalMuteAudio.ts +8 -7
- package/template/agora-rn-uikit/src/Reducer/LocalMuteVideo.ts +8 -7
- package/template/agora-rn-uikit/src/Reducer/LocalPermissionState.ts +6 -7
- package/template/agora-rn-uikit/src/Reducer/RemoteAudioStateChanged.ts +7 -8
- package/template/agora-rn-uikit/src/Reducer/RemoteVideoStateChanged.ts +9 -9
- package/template/agora-rn-uikit/src/Reducer/UpdateDualStreamMode.ts +7 -8
- package/template/agora-rn-uikit/src/Reducer/UserJoined.ts +14 -13
- package/template/agora-rn-uikit/src/Reducer/UserMuteRemoteAudio.ts +6 -7
- package/template/agora-rn-uikit/src/Reducer/UserMuteRemoteVideo.ts +6 -7
- package/template/agora-rn-uikit/src/Reducer/UserOffline.ts +5 -6
- package/template/agora-rn-uikit/src/Reducer/UserPin.ts +20 -3
- package/template/agora-rn-uikit/src/Reducer/UserSecondaryPin.ts +23 -0
- package/template/agora-rn-uikit/src/Reducer/index.ts +2 -1
- package/template/agora-rn-uikit/src/Rtc/Create.tsx +138 -100
- package/template/agora-rn-uikit/src/Rtc/Join.tsx +55 -28
- package/template/agora-rn-uikit/src/RtcConfigure.tsx +177 -77
- package/template/agora-rn-uikit/src/Utils/isBotUser.ts +15 -0
- package/template/agora-rn-uikit/src/Utils/quality.tsx +8 -0
- package/template/agora-rn-uikit/src/Views/MaxVideoView.native.tsx +56 -12
- package/template/agora-rn-uikit/src/Views/MaxVideoView.tsx +47 -17
- package/template/agora-rn-uikit/src/Views/MinVideoView.tsx +19 -11
- package/template/agora-rn-uikit/src/index.ts +15 -9
- package/template/android/app/build.gradle +59 -156
- package/template/android/app/src/debug/AndroidManifest.xml +6 -1
- package/template/android/app/src/debug/java/com/helloworld/ReactNativeFlipper.java +7 -4
- package/template/android/app/src/main/AndroidManifest.xml +6 -19
- package/template/android/app/src/main/assets/fonts/icomoon.ttf +0 -0
- package/template/android/app/src/main/java/com/helloworld/MainActivity.java +17 -0
- package/template/android/app/src/main/java/com/helloworld/MainApplication.java +22 -36
- package/template/android/app/src/main/java/com/helloworld/SSLPinningFactory.java +30 -0
- package/template/android/app/src/main/res/values/strings.xml +3 -0
- package/template/android/app/src/release/java/com/helloworld/ReactNativeFlipper.java +20 -0
- package/template/android/build.gradle +19 -33
- package/template/android/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/template/android/gradle/wrapper/gradle-wrapper.properties +3 -2
- package/template/android/gradle.properties +18 -4
- package/template/android/gradlew +165 -104
- package/template/android/gradlew.bat +12 -23
- package/template/android/settings.gradle +1 -0
- package/template/bridge/rtc/webNg/RtcEngine.ts +200 -70
- package/template/bridge/rtc/webNg/{SurfaceView.tsx → RtcSurfaceView.tsx} +20 -26
- package/template/bridge/rtc/webNg/Types.ts +20 -5
- package/template/bridge/rtc/webNg/index.ts +81 -14
- package/template/bridge/rtm/web/index.ts +5 -3
- package/template/configTransform.js +16 -1
- package/template/customization-api/action-library.ts +4 -16
- package/template/customization-api/app-state.ts +15 -8
- package/template/customization-api/customEvents.ts +7 -2
- package/template/customization-api/customize.ts +1 -1
- package/template/customization-api/index.ts +4 -0
- package/template/customization-api/sub-components.ts +17 -16
- package/template/customization-api/temp.ts +52 -0
- package/template/customization-api/typeDefinition.ts +34 -46
- package/template/customization-api/types.ts +26 -0
- package/template/customization-api/utils.ts +4 -0
- package/template/customization-implementation/createHook.ts +24 -6
- package/template/customization-implementation/index.ts +1 -2
- package/template/customization-implementation/useCustomization.tsx +5 -7
- package/template/defaultConfig.js +72 -0
- package/template/global.d.ts +14 -1
- package/template/index.js +1 -4
- package/template/index.web.js +0 -5
- package/template/index.wsdk.tsx +1 -12
- package/template/ios/.xcode.env +11 -0
- package/template/ios/HelloWorld/AppDelegate.h +2 -4
- package/template/ios/HelloWorld/AppDelegate.mm +64 -0
- package/template/ios/HelloWorld/HelloWorldDebug.entitlements +10 -0
- package/template/ios/HelloWorld/Info.plist +8 -2
- package/template/ios/HelloWorld/main.m +2 -1
- package/template/ios/HelloWorld.xcodeproj/project.pbxproj +533 -17
- package/template/ios/HelloWorld.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/template/ios/HelloWorld.xcworkspace/contents.xcworkspacedata +10 -0
- package/template/ios/HelloWorld.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/template/ios/HelloWorldTests/HelloWorldTests.m +14 -13
- package/template/ios/HelloWorldTests/Info.plist +2 -2
- package/template/ios/Podfile +54 -20
- package/template/ios/Podfile.lock +809 -0
- package/template/ios/ScreenSharing/Info.plist +15 -0
- package/template/ios/ScreenSharing/SampleHandler.h +9 -0
- package/template/ios/ScreenSharing/SampleHandler.m +70 -0
- package/template/jest.config.js +4 -0
- package/template/metro.config.js +7 -32
- package/template/package.json +53 -39
- package/template/react-native-toast-message/index.d.ts +3 -1
- package/template/react-native-toast-message/index.js +1 -0
- package/template/react-native-toast-message/src/components/base/index.js +20 -32
- package/template/react-native-toast-message/src/components/base/styles.js +18 -21
- package/template/react-native-toast-message/src/components/checkbox.js +24 -19
- package/template/react-native-toast-message/src/index.js +3 -1
- package/template/react-native-toast-message/src/index.sdk.tsx +4 -1
- package/template/src/App.tsx +53 -69
- package/template/src/AppRoutes.tsx +90 -0
- package/template/src/AppWrapper.tsx +42 -25
- package/template/src/SDKAppWrapper.tsx +89 -57
- package/template/src/app-state/useLocalUserInfo.ts +3 -3
- package/template/src/app-state/useNoiseSupression.native.tsx +67 -0
- package/template/src/app-state/useNoiseSupression.tsx +107 -0
- package/template/src/app-state/useVideoQuality.tsx +39 -0
- package/template/src/assets/font-styles.css +175 -3
- package/template/src/assets/fonts/icomoon.ttf +0 -0
- package/template/src/assets/selection.json +1 -1
- package/template/src/atoms/ActionMenu.tsx +50 -11
- package/template/src/atoms/Avatar.tsx +51 -0
- package/template/src/atoms/Card.tsx +21 -8
- package/template/src/atoms/Carousel.native.tsx +105 -0
- package/template/src/atoms/Carousel.tsx +103 -0
- package/template/src/atoms/Checkbox.tsx +98 -0
- package/template/src/atoms/CircularProgress.tsx +0 -1
- package/template/src/atoms/ClipboardIconButton.tsx +91 -0
- package/template/src/atoms/CustomIcon.tsx +46 -0
- package/template/src/atoms/DropDownMulti.tsx +349 -0
- package/template/src/atoms/Dropdown.tsx +3 -3
- package/template/src/atoms/IconButton.tsx +52 -9
- package/template/src/atoms/ImageIcon.tsx +18 -5
- package/template/src/atoms/InlineNotification.tsx +81 -0
- package/template/src/atoms/InviteInfo.tsx +4 -4
- package/template/src/atoms/MeetingLink.tsx +160 -0
- package/template/src/atoms/ParticipantsCount.tsx +20 -8
- package/template/src/atoms/Popup.tsx +49 -27
- package/template/src/atoms/PrimaryButton.tsx +19 -5
- package/template/src/atoms/RecordingInfo.tsx +8 -5
- package/template/src/atoms/SecondaryButton.tsx +2 -0
- package/template/src/atoms/Spacer.tsx +1 -0
- package/template/src/atoms/TertiaryButton.tsx +35 -5
- package/template/src/atoms/TextInput.tsx +2 -1
- package/template/src/atoms/Toolbar.tsx +102 -0
- package/template/src/atoms/ToolbarItem.tsx +85 -0
- package/template/src/atoms/ToolbarMenu.tsx +40 -0
- package/template/src/atoms/ToolbarMenuItem.tsx +104 -0
- package/template/src/atoms/ToolbarPreset.tsx +71 -0
- package/template/src/atoms/Tooltip.tsx +30 -13
- package/template/src/atoms/pagination/Pagination.tsx +127 -0
- package/template/src/atoms/pagination/usePagination.tsx +88 -0
- package/template/src/auth/AuthProvider.tsx +500 -0
- package/template/src/auth/AuthRoute.tsx +94 -0
- package/template/src/auth/IDPAuth.electron.tsx +31 -0
- package/template/src/auth/IDPAuth.tsx +67 -0
- package/template/src/auth/IDPLogoutComponent.tsx +158 -0
- package/template/src/auth/UserCancelPopup.tsx +115 -0
- package/template/src/auth/config.ts +52 -0
- package/template/src/auth/openIDPURL.electron.tsx +39 -0
- package/template/src/auth/openIDPURL.native.tsx +51 -0
- package/template/src/auth/openIDPURL.tsx +20 -0
- package/template/src/auth/useIDPAuth.electron.tsx +65 -0
- package/template/src/auth/useIDPAuth.native.tsx +70 -0
- package/template/src/auth/useIDPAuth.tsx +63 -0
- package/template/src/auth/useTokenAuth.tsx +194 -0
- package/template/src/components/Chat.tsx +92 -72
- package/template/src/components/ChatContext.ts +2 -0
- package/template/src/components/ColorConfigure.tsx +0 -1
- package/template/src/components/CommonStyles.ts +9 -2
- package/template/src/components/Controls.tsx +914 -182
- package/template/src/components/Controls1.native.tsx +9 -5
- package/template/src/components/DeviceConfigure.native.tsx +2 -2
- package/template/src/components/DeviceConfigure.tsx +400 -149
- package/template/src/components/DeviceContext.tsx +2 -0
- package/template/src/components/EventsConfigure.tsx +722 -82
- package/template/src/components/GraphQLProvider.tsx +82 -39
- package/template/src/components/GridVideo.tsx +30 -16
- package/template/src/components/HostControlView.tsx +11 -14
- package/template/src/components/JoinPhrase.tsx +0 -1
- package/template/src/components/Leftbar.tsx +110 -0
- package/template/src/components/Navbar.tsx +305 -147
- package/template/src/components/NavbarMobile.tsx +119 -0
- package/template/src/components/Navigation.native.tsx +1 -15
- package/template/src/components/{Settings.native.tsx → Navigation.sdk.tsx} +17 -6
- package/template/src/components/NetworkQualityContext.tsx +12 -6
- package/template/src/components/ParticipantsView.tsx +63 -56
- package/template/src/components/PinnedVideo.tsx +191 -119
- package/template/src/components/Precall.native.tsx +177 -72
- package/template/src/components/Precall.tsx +247 -78
- package/template/src/components/RTMConfigure.tsx +205 -67
- package/template/src/components/Rightbar.tsx +112 -0
- package/template/src/components/Router.electron.ts +1 -0
- package/template/src/components/Router.native.ts +1 -0
- package/template/src/components/Router.sdk.ts +1 -0
- package/template/src/components/Router.ts +1 -0
- package/template/src/components/SdkApiContext.tsx +313 -0
- package/template/src/components/SdkMuteToggleListener.tsx +88 -0
- package/template/src/components/SessionContext.tsx +0 -1
- package/template/src/components/Settings.tsx +33 -4
- package/template/src/components/SettingsView.tsx +44 -9
- package/template/src/components/Share.tsx +152 -74
- package/template/src/components/StorageContext.tsx +23 -6
- package/template/src/components/ToastComponent.tsx +10 -1
- package/template/src/components/WhiteboardLayout.tsx +291 -0
- package/template/src/components/chat-messages/useChatMessages.tsx +454 -239
- package/template/src/components/chat-ui/{useChatUIControl.tsx → useChatUIControls.tsx} +29 -29
- package/template/src/components/common/Error.tsx +2 -0
- package/template/src/components/common/Logo.tsx +2 -2
- package/template/src/components/contexts/LiveStreamDataContext.tsx +13 -12
- package/template/src/components/contexts/ScreenShareContext.tsx +15 -1
- package/template/src/components/contexts/VideoMeetingDataContext.tsx +6 -6
- package/template/src/components/contexts/WaitingRoomContext.tsx +50 -0
- package/template/src/components/contexts/WhiteboardContext.tsx +54 -54
- package/template/src/components/disable-chat/useDisableChat.tsx +32 -0
- package/template/src/components/livestream/LiveStreamContext.tsx +314 -220
- package/template/src/components/livestream/Types.ts +36 -20
- package/template/src/components/livestream/views/LiveStreamAttendeeLandingTile.tsx +295 -0
- package/template/src/components/livestream/views/LiveStreamControls.tsx +5 -10
- package/template/src/components/meeting-info-invite/MeetingInfo.tsx +82 -0
- package/template/src/components/meeting-info-invite/MeetingInfoCardHeader.tsx +86 -0
- package/template/src/components/meeting-info-invite/MeetingInfoGridTile.tsx +218 -0
- package/template/src/components/meeting-info-invite/MeetingInfoLinks.tsx +122 -0
- package/template/src/components/participants/AllAudienceParticipants.tsx +19 -20
- package/template/src/components/participants/AllHostParticipants.tsx +20 -19
- package/template/src/components/participants/Participant.tsx +45 -16
- package/template/src/components/participants/ParticipantSectionTitle.tsx +5 -2
- package/template/src/components/participants/ScreenshareParticipants.tsx +17 -19
- package/template/src/components/participants/UserActionMenuOptions.tsx +173 -62
- package/template/src/components/participants/WaitingRoomParticipants.tsx +74 -0
- package/template/src/components/popups/InvitePopup.tsx +110 -45
- package/template/src/components/popups/StartScreenSharePopup.native.tsx +182 -0
- package/template/src/components/popups/StartScreenSharePopup.tsx +6 -0
- package/template/src/components/popups/StopRecordingPopup.tsx +11 -5
- package/template/src/components/popups/StopScreenSharePopup.native.tsx +135 -0
- package/template/src/components/popups/StopScreenSharePopup.tsx +6 -0
- package/template/src/components/popups/WhiteboardClearAllPopup.tsx +123 -0
- package/template/src/components/precall/LocalMute.tsx +69 -45
- package/template/src/components/precall/PermissionHelper.tsx +56 -28
- package/template/src/components/precall/PreCallSettings.tsx +1 -0
- package/template/src/components/precall/VideoFallback.tsx +173 -0
- package/template/src/components/precall/VideoPreview.native.tsx +19 -53
- package/template/src/components/precall/VideoPreview.tsx +29 -164
- package/template/src/components/precall/index.tsx +2 -0
- package/template/src/components/precall/joinCallBtn.native.tsx +12 -5
- package/template/src/components/precall/joinCallBtn.tsx +13 -4
- package/template/src/components/precall/joinWaitingRoomBtn.native.tsx +210 -0
- package/template/src/components/precall/joinWaitingRoomBtn.tsx +250 -0
- package/template/src/components/precall/meetingTitle.tsx +37 -11
- package/template/src/components/precall/selectDevice.tsx +5 -5
- package/template/src/components/precall/textInput.tsx +17 -19
- package/template/src/components/precall/usePreCall.tsx +33 -1
- package/template/src/components/recording-bot/RecordingBotRoute.tsx +42 -0
- package/template/src/components/recordings/RecordingsDateTable.tsx +62 -0
- package/template/src/components/recordings/RecordingsModal.tsx +135 -0
- package/template/src/components/recordings/ViewRecordingsModal.tsx +51 -0
- package/template/src/components/recordings/recording-table.tsx +154 -0
- package/template/src/components/recordings/style.ts +183 -0
- package/template/src/components/recordings/utils.ts +80 -0
- package/template/src/components/room-info/useRoomInfo.tsx +128 -0
- package/template/src/components/{meeting-info/useSetMeetingInfo.tsx → room-info/useSetRoomInfo.tsx} +12 -12
- package/template/src/components/useShareLink.tsx +28 -63
- package/template/src/components/useUserPreference.tsx +82 -16
- package/template/src/components/useVideoCall.tsx +93 -1
- package/template/src/components/virtual-background/VBButton.tsx +64 -0
- package/template/src/components/virtual-background/VBCard.native.tsx +282 -0
- package/template/src/components/virtual-background/VBCard.tsx +272 -0
- package/template/src/components/virtual-background/VBPanel.tsx +279 -0
- package/template/src/components/virtual-background/VButils.native.ts +37 -0
- package/template/src/components/virtual-background/VButils.ts +104 -0
- package/template/src/components/virtual-background/VideoPreview.native.tsx +43 -0
- package/template/src/components/virtual-background/VideoPreview.tsx +106 -0
- package/template/src/components/virtual-background/imagePaths.ts +87 -0
- package/template/src/components/virtual-background/images/beachImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/bedroomImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/bookImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/earthImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/index.ts +37 -0
- package/template/src/components/virtual-background/images/lampImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/mountainsImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/office1ImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/officeImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/plantsImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/skyImageBase64.ts +1 -0
- package/template/src/components/virtual-background/images/wallImageBase64.ts +1 -0
- package/template/src/components/virtual-background/useVB.native.tsx +185 -0
- package/template/src/components/virtual-background/useVB.tsx +267 -0
- package/template/src/components/whiteboard/StrokeWidthTool.tsx +137 -0
- package/template/src/components/whiteboard/WhiteboardButton.tsx +93 -0
- package/template/src/components/whiteboard/WhiteboardCanvas.tsx +99 -0
- package/template/src/components/whiteboard/WhiteboardConfigure.native.tsx +148 -0
- package/template/src/components/whiteboard/WhiteboardConfigure.tsx +446 -0
- package/template/src/components/whiteboard/WhiteboardCursor.tsx +152 -0
- package/template/src/components/whiteboard/WhiteboardToolBox.tsx +1246 -0
- package/template/src/components/whiteboard/WhiteboardView.native.tsx +188 -0
- package/template/src/components/whiteboard/WhiteboardView.tsx +81 -0
- package/template/src/components/whiteboard/WhiteboardWidget.tsx +685 -0
- package/template/src/components/whiteboard/WhiteboardWrapper.tsx +38 -0
- package/template/src/language/default-labels/commonLabels.ts +51 -14
- package/template/src/language/default-labels/createScreenLabels.ts +97 -17
- package/template/src/language/default-labels/joinScreenLabels.ts +45 -6
- package/template/src/language/default-labels/precallScreenLabels.ts +149 -25
- package/template/src/language/default-labels/shareLinkScreenLabels.ts +85 -37
- package/template/src/language/default-labels/videoCallScreenLabels.ts +1195 -158
- package/template/src/pages/Create.tsx +136 -106
- package/template/src/pages/Endcall.tsx +2 -2
- package/template/src/pages/Join.tsx +82 -40
- package/template/src/pages/Login.tsx +26 -0
- package/template/src/pages/VideoCall.tsx +329 -127
- package/template/src/pages/video-call/ActionSheet.native.tsx +54 -6
- package/template/src/pages/video-call/ActionSheet.tsx +55 -15
- package/template/src/pages/video-call/ActionSheetContent.tsx +498 -308
- package/template/src/pages/video-call/ActionSheetHandle.tsx +7 -1
- package/template/src/pages/video-call/DefaultLayouts.ts +20 -8
- package/template/src/pages/video-call/NameWithMicIcon.tsx +41 -64
- package/template/src/pages/video-call/PinchableView.tsx +119 -0
- package/template/src/pages/video-call/RenderComponent.tsx +14 -30
- package/template/src/pages/video-call/SidePanelHeader.tsx +227 -29
- package/template/src/pages/video-call/VideoCallMobileView.tsx +231 -89
- package/template/src/pages/video-call/VideoCallScreen.native.tsx +3 -2
- package/template/src/pages/video-call/VideoCallScreen.tsx +233 -84
- package/template/src/pages/video-call/VideoCallScreenWrapper.tsx +41 -0
- package/template/src/pages/video-call/VideoComponent.tsx +60 -8
- package/template/src/pages/video-call/VideoRenderer.tsx +343 -57
- package/template/src/pages/video-call/VisibilitySensor.tsx +104 -0
- package/template/src/pages/video-call/ZoomableWrapper.native.tsx +34 -0
- package/template/src/pages/video-call/ZoomableWrapper.tsx +5 -0
- package/template/src/pages/video-call/index.ts +42 -8
- package/template/src/rtm/RTMEngine.ts +17 -4
- package/template/src/rtm-events/constants.ts +21 -3
- package/template/src/rtm-events-api/Events.ts +7 -4
- package/template/src/rtm-events-api/LocalEvents.ts +14 -0
- package/template/src/rtm-events-api/types.ts +5 -5
- package/template/src/selection.json +1 -0
- package/template/src/subComponents/ChatBubble.tsx +87 -67
- package/template/src/subComponents/ChatContainer.tsx +70 -49
- package/template/src/subComponents/ChatInput.ios.tsx +32 -85
- package/template/src/subComponents/ChatInput.tsx +31 -80
- package/template/src/subComponents/Checkbox.native.tsx +46 -46
- package/template/src/subComponents/Checkbox.tsx +7 -6
- package/template/src/subComponents/CopyJoinInfo.tsx +31 -11
- package/template/src/subComponents/EndcallPopup.tsx +83 -12
- package/template/src/subComponents/FallbackLogo.tsx +2 -2
- package/template/src/subComponents/LanguageSelector.tsx +34 -30
- package/template/src/subComponents/LayoutIconButton.tsx +34 -17
- package/template/src/subComponents/LayoutIconDropdown.tsx +21 -8
- package/template/src/subComponents/Loading.tsx +60 -0
- package/template/src/subComponents/LocalAudioMute.tsx +87 -34
- package/template/src/subComponents/LocalEndCall.tsx +61 -24
- package/template/src/subComponents/LocalSwitchCamera.tsx +57 -13
- package/template/src/subComponents/LocalVideoMute.tsx +105 -36
- package/template/src/subComponents/LogoutButton.tsx +1 -1
- package/template/src/subComponents/NetworkQualityPill.tsx +22 -38
- package/template/src/subComponents/Recording.tsx +29 -9
- package/template/src/subComponents/RemoteAudioMute.tsx +5 -5
- package/template/src/subComponents/RemoteMutePopup.tsx +55 -14
- package/template/src/subComponents/RemoteVideoMute.tsx +5 -5
- package/template/src/subComponents/RemoveMeetingPopup.tsx +19 -6
- package/template/src/subComponents/RemoveScreensharePopup.tsx +20 -5
- package/template/src/subComponents/ScreenShareNotice.tsx +11 -6
- package/template/src/subComponents/SelectDevice.tsx +103 -34
- package/template/src/subComponents/SelectDeviceSettings.backup.tsx +9 -6
- package/template/src/subComponents/SidePanelButtons.ts +0 -3
- package/template/src/subComponents/SidePanelEnum.tsx +2 -0
- package/template/src/subComponents/SidePanelHeader.tsx +97 -63
- package/template/src/subComponents/ToastConfig.tsx +70 -61
- package/template/src/subComponents/caption/Caption.tsx +132 -0
- package/template/src/subComponents/caption/CaptionContainer.tsx +302 -0
- package/template/src/subComponents/caption/CaptionIcon.tsx +111 -0
- package/template/src/subComponents/caption/CaptionText.tsx +182 -0
- package/template/src/subComponents/caption/DownloadTranscriptBtn.tsx +65 -0
- package/template/src/subComponents/caption/LanguageSelectorPopup.tsx +192 -0
- package/template/src/subComponents/caption/Transcript.tsx +452 -0
- package/template/src/subComponents/caption/TranscriptIcon.tsx +123 -0
- package/template/src/subComponents/caption/TranscriptText.tsx +98 -0
- package/template/src/subComponents/caption/index.ts +3 -0
- package/template/src/subComponents/caption/proto/ptoto.js +91 -0
- package/template/src/subComponents/caption/proto/test.proto +23 -0
- package/template/src/subComponents/caption/useCaption.tsx +123 -0
- package/template/src/subComponents/caption/useCaptionWidth.ts +27 -0
- package/template/src/subComponents/caption/useSTTAPI.tsx +179 -0
- package/template/src/subComponents/caption/useStreamMessageUtils.native.ts +211 -0
- package/template/src/subComponents/caption/useStreamMessageUtils.ts +235 -0
- package/template/src/subComponents/caption/useTranscriptDownload.native.ts +63 -0
- package/template/src/subComponents/caption/useTranscriptDownload.ts +52 -0
- package/template/src/subComponents/caption/utils.ts +126 -0
- package/template/src/subComponents/chat/ChatParticipants.tsx +60 -24
- package/template/src/subComponents/livestream/ApprovedLiveStreamControlsView.tsx +2 -2
- package/template/src/subComponents/livestream/CurrentLiveStreamRequestsView.tsx +19 -20
- package/template/src/subComponents/livestream/controls/LocalRaiseHand.tsx +66 -35
- package/template/src/subComponents/livestream/controls/RemoteLiveStreamApprovedRequestRecall.tsx +3 -2
- package/template/src/subComponents/livestream/controls/RemoteLiveStreamRequestApprove.tsx +10 -6
- package/template/src/subComponents/livestream/controls/RemoteLiveStreamRequestReject.tsx +28 -19
- package/template/src/subComponents/recording/useIsRecordingBot.tsx +38 -0
- package/template/src/subComponents/recording/useRecording.tsx +251 -138
- package/template/src/subComponents/recording/useRecordingLayoutQuery.tsx +0 -1
- package/template/src/subComponents/screenshare/ScreenshareButton.tsx +39 -15
- package/template/src/subComponents/screenshare/ScreenshareConfigure.native.tsx +275 -69
- package/template/src/subComponents/screenshare/ScreenshareConfigure.tsx +193 -124
- package/template/src/subComponents/screenshare/useScreenshare.tsx +2 -0
- package/template/src/subComponents/waiting-rooms/WaitingRoomControls.tsx +85 -0
- package/template/src/subComponents/waiting-rooms/useWaitingRoomAPI.ts +75 -0
- package/template/src/theme/index.ts +13 -0
- package/template/src/utils/SdkEvents.ts +37 -14
- package/template/src/utils/SdkMethodEvents.ts +101 -0
- package/template/src/utils/axiomLogger.ts +117 -0
- package/template/src/utils/book.jpg +0 -0
- package/template/src/utils/common.tsx +118 -6
- package/template/src/utils/constants.ts +4 -0
- package/template/src/utils/getCustomRoute.ts +7 -0
- package/template/src/utils/index.tsx +34 -0
- package/template/src/utils/useActionSheet.tsx +50 -0
- package/template/src/utils/useActiveSpeaker.ts +38 -0
- package/template/src/utils/useAppState.ts +17 -0
- package/template/src/utils/useAsyncEffect.ts +138 -0
- package/template/src/utils/{useCreateMeeting.ts → useCreateRoom.ts} +27 -26
- package/template/src/utils/useEndCall.ts +65 -0
- package/template/src/utils/useFindActiveSpeaker.native.ts +4 -0
- package/template/src/utils/useFindActiveSpeaker.ts +335 -0
- package/template/src/utils/useGetMeetingPhrase.ts +10 -10
- package/template/src/utils/useIsAudioEnabled.ts +3 -3
- package/template/src/utils/useIsLocalUserSpeaking.native.ts +4 -0
- package/template/src/utils/useIsLocalUserSpeaking.ts +103 -0
- package/template/src/utils/useIsPSTN.ts +3 -3
- package/template/src/utils/useIsVideoEnabled.ts +3 -3
- package/template/src/utils/useJoinRoom.ts +199 -0
- package/template/src/utils/{useIsActiveSpeaker.ts → useLocalAudio.ts} +23 -12
- package/template/src/{components/OAuth.tsx → utils/useMenu.tsx} +16 -15
- package/template/src/utils/useModal.tsx +8 -0
- package/template/src/utils/useMutePSTN.ts +2 -2
- package/template/src/utils/useMuteToggleLocal.ts +121 -96
- package/template/src/utils/useRemoteEndCall.ts +4 -4
- package/template/src/utils/useRemoteEndScreenshare.ts +4 -4
- package/template/src/utils/useRemoteMute.ts +7 -7
- package/template/src/utils/useRemoteRequest.ts +7 -7
- package/template/src/utils/useSearchParams.tsx +18 -0
- package/template/src/utils/useString.ts +13 -3
- package/template/src/utils/useSwitchCamera.native.tsx +25 -0
- package/template/src/{subComponents/screenshare/ScreenshareButton.native.tsx → utils/useSwitchCamera.tsx} +12 -11
- package/template/src/utils/useToolbar.tsx +59 -0
- package/template/src/wasms/agora-virtual-background.wasm +0 -0
- package/template/static.d.ts +42 -0
- package/template/tsconfig_rsdk_index.json +3 -3
- package/template/tsconfig_wsdk_index.json +1 -1
- package/template/web/index.html +20 -0
- package/template/webpack.commons.js +21 -10
- package/template/webpack.rsdk.config.js +1 -2
- package/template/webpack.web.config.js +7 -3
- package/template/_buckconfig +0 -6
- package/template/_gitattributes +0 -1
- package/template/agora-rn-uikit/src/Contexts/RenderContext.tsx +0 -10
- package/template/agora-rn-uikit/src/Reducer/ActiveSpeakerDetected.ts +0 -11
- package/template/android/app/_BUCK +0 -55
- package/template/android/app/build_defs.bzl +0 -19
- package/template/bridge/rtc/webNg/LocalView.tsx +0 -20
- package/template/ios/HelloWorld/AppDelegate.m +0 -74
- package/template/src/components/OAuth.electron.tsx +0 -41
- package/template/src/components/OAuth.native.tsx +0 -55
- package/template/src/components/OAuthConfig.ts +0 -77
- package/template/src/components/StoreToken.tsx +0 -39
- package/template/src/components/meeting-info/useMeetingInfo.tsx +0 -70
- package/template/src/pages/video-call/CustomUserContextHolder.tsx +0 -20
- package/template/src/utils/useButtonTemplate.tsx +0 -44
- package/template/src/utils/useJoinMeeting.ts +0 -132
|
@@ -1,17 +1,19 @@
|
|
|
1
|
+
/* eslint-disable react-native/no-inline-styles */
|
|
1
2
|
import React, {useState, useContext} from 'react';
|
|
2
3
|
import {View, TouchableOpacity, Image} from 'react-native';
|
|
3
|
-
|
|
4
|
+
|
|
5
|
+
import {RenderModeType, RtcSurfaceView} from 'react-native-agora';
|
|
4
6
|
import styles from '../Style';
|
|
5
7
|
import icons from '../Controls/Icons';
|
|
6
8
|
import RemoteControls from '../Controls/RemoteControls';
|
|
7
|
-
import PropsContext, {
|
|
9
|
+
import PropsContext, {ContentInterface} from '../Contexts/PropsContext';
|
|
8
10
|
import useLocalUid from '../Utils/useLocalUid';
|
|
9
11
|
|
|
10
|
-
const LocalView =
|
|
11
|
-
const RemoteView =
|
|
12
|
+
const LocalView = RtcSurfaceView;
|
|
13
|
+
const RemoteView = RtcSurfaceView;
|
|
12
14
|
|
|
13
15
|
interface MinViewInterface {
|
|
14
|
-
user:
|
|
16
|
+
user: ContentInterface;
|
|
15
17
|
color?: string;
|
|
16
18
|
showOverlay?: boolean;
|
|
17
19
|
}
|
|
@@ -23,6 +25,7 @@ const MinVideoView: React.FC<MinViewInterface> = (props) => {
|
|
|
23
25
|
const {minCloseBtnStyles} = remoteBtnStyles || {};
|
|
24
26
|
const {showOverlay} = props || {};
|
|
25
27
|
const localUid = useLocalUid();
|
|
28
|
+
//@ts-ignore
|
|
26
29
|
const uid = props.user.uid === rtcProps?.screenShareUid ? 1 : props.user.uid;
|
|
27
30
|
return (
|
|
28
31
|
<View style={{margin: 5}}>
|
|
@@ -32,7 +35,7 @@ const MinVideoView: React.FC<MinViewInterface> = (props) => {
|
|
|
32
35
|
props.user.video ? (
|
|
33
36
|
<LocalView
|
|
34
37
|
style={{...styles.minView, ...(minViewStyles as object)}}
|
|
35
|
-
|
|
38
|
+
canvas={{renderMode: RenderModeType.RenderModeHidden, uid: 0}}
|
|
36
39
|
zOrderMediaOverlay={true}
|
|
37
40
|
/>
|
|
38
41
|
) : (
|
|
@@ -48,8 +51,10 @@ const MinVideoView: React.FC<MinViewInterface> = (props) => {
|
|
|
48
51
|
) : (
|
|
49
52
|
<RemoteView
|
|
50
53
|
style={{...styles.minView, ...(minViewStyles as object)}}
|
|
51
|
-
|
|
52
|
-
|
|
54
|
+
canvas={{
|
|
55
|
+
renderMode: RenderModeType.RenderModeHidden,
|
|
56
|
+
uid: uid as number,
|
|
57
|
+
}}
|
|
53
58
|
zOrderMediaOverlay={true}
|
|
54
59
|
/>
|
|
55
60
|
)}
|
|
@@ -57,14 +62,16 @@ const MinVideoView: React.FC<MinViewInterface> = (props) => {
|
|
|
57
62
|
) : uid === localUid ? (
|
|
58
63
|
<LocalView
|
|
59
64
|
style={{...styles.minView, ...(minViewStyles as object)}}
|
|
60
|
-
|
|
65
|
+
canvas={{renderMode: RenderModeType.RenderModeHidden, uid: 0}}
|
|
61
66
|
zOrderMediaOverlay={true}
|
|
62
67
|
/>
|
|
63
68
|
) : (
|
|
64
69
|
<RemoteView
|
|
65
70
|
style={{...styles.minView, ...(minViewStyles as object)}}
|
|
66
|
-
|
|
67
|
-
|
|
71
|
+
canvas={{
|
|
72
|
+
renderMode: RenderModeType.RenderModeHidden,
|
|
73
|
+
uid: uid as number,
|
|
74
|
+
}}
|
|
68
75
|
zOrderMediaOverlay={true}
|
|
69
76
|
/>
|
|
70
77
|
)}
|
|
@@ -80,6 +87,7 @@ const MinVideoView: React.FC<MinViewInterface> = (props) => {
|
|
|
80
87
|
height: 25,
|
|
81
88
|
tintColor: theme || props.color || '#fff',
|
|
82
89
|
}}
|
|
90
|
+
//@ts-ignore
|
|
83
91
|
source={{uri: icons.close}}
|
|
84
92
|
/>
|
|
85
93
|
</TouchableOpacity>
|
|
@@ -12,10 +12,16 @@ export {
|
|
|
12
12
|
} from './Contexts/LocalUserContext';
|
|
13
13
|
|
|
14
14
|
export {
|
|
15
|
-
default as
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
} from './Contexts/
|
|
15
|
+
default as ContentContext,
|
|
16
|
+
ContentConsumer,
|
|
17
|
+
ContentProvider,
|
|
18
|
+
} from './Contexts/ContentContext';
|
|
19
|
+
|
|
20
|
+
export {
|
|
21
|
+
default as DispatchContext,
|
|
22
|
+
DispatchConsumer,
|
|
23
|
+
DispatchProvider,
|
|
24
|
+
} from './Contexts/DispatchContext';
|
|
19
25
|
|
|
20
26
|
export {
|
|
21
27
|
default as PropsContext,
|
|
@@ -28,15 +34,15 @@ export {DualStreamMode} from './Contexts/PropsContext';
|
|
|
28
34
|
export {ToggleState, PermissionState} from './Contexts/PropsContext';
|
|
29
35
|
|
|
30
36
|
export type {
|
|
31
|
-
|
|
32
|
-
|
|
37
|
+
DefaultContentInterface,
|
|
38
|
+
ContentInterface,
|
|
33
39
|
RtcPropsInterface,
|
|
34
40
|
CallbacksInterface,
|
|
35
41
|
CustomCallbacksInterface,
|
|
36
42
|
PropsInterface,
|
|
37
43
|
} from './Contexts/PropsContext';
|
|
38
44
|
|
|
39
|
-
export {
|
|
45
|
+
export {ClientRoleType, ChannelProfileType} from './Contexts/PropsContext';
|
|
40
46
|
|
|
41
47
|
export {
|
|
42
48
|
default as RtcContext,
|
|
@@ -46,11 +52,11 @@ export {
|
|
|
46
52
|
export type {
|
|
47
53
|
UidType,
|
|
48
54
|
RtcContextInterface,
|
|
49
|
-
|
|
50
|
-
RenderStateInterface,
|
|
55
|
+
ContentStateInterface,
|
|
51
56
|
ActionInterface,
|
|
52
57
|
ActionType,
|
|
53
58
|
} from './Contexts/RtcContext';
|
|
59
|
+
export type {DispatchType} from './Contexts/DispatchContext';
|
|
54
60
|
|
|
55
61
|
export {default as BtnTemplate} from './Controls/BtnTemplate';
|
|
56
62
|
export type {BtnTemplateInterface} from './Controls/BtnTemplate';
|
|
@@ -1,133 +1,79 @@
|
|
|
1
1
|
apply plugin: "com.android.application"
|
|
2
|
-
|
|
3
|
-
import com.android.build.OutputFile
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
|
|
7
|
-
* and bundleReleaseJsAndAssets).
|
|
8
|
-
* These basically call `react-native bundle` with the correct arguments during the Android build
|
|
9
|
-
* cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
|
|
10
|
-
* bundle directly from the development server. Below you can see all the possible configurations
|
|
11
|
-
* and their defaults. If you decide to add a configuration block, make sure to add it before the
|
|
12
|
-
* `apply from: "../../node_modules/react-native/react.gradle"` line.
|
|
13
|
-
*
|
|
14
|
-
* project.ext.react = [
|
|
15
|
-
* // the name of the generated asset file containing your JS bundle
|
|
16
|
-
* bundleAssetName: "index.android.bundle",
|
|
17
|
-
*
|
|
18
|
-
* // the entry file for bundle generation. If none specified and
|
|
19
|
-
* // "index.android.js" exists, it will be used. Otherwise "index.js" is
|
|
20
|
-
* // default. Can be overridden with ENTRY_FILE environment variable.
|
|
21
|
-
* entryFile: "index.android.js",
|
|
22
|
-
*
|
|
23
|
-
* // https://reactnative.dev/docs/performance#enable-the-ram-format
|
|
24
|
-
* bundleCommand: "ram-bundle",
|
|
25
|
-
*
|
|
26
|
-
* // whether to bundle JS and assets in debug mode
|
|
27
|
-
* bundleInDebug: false,
|
|
28
|
-
*
|
|
29
|
-
* // whether to bundle JS and assets in release mode
|
|
30
|
-
* bundleInRelease: true,
|
|
31
|
-
*
|
|
32
|
-
* // whether to bundle JS and assets in another build variant (if configured).
|
|
33
|
-
* // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
|
|
34
|
-
* // The configuration property can be in the following formats
|
|
35
|
-
* // 'bundleIn${productFlavor}${buildType}'
|
|
36
|
-
* // 'bundleIn${buildType}'
|
|
37
|
-
* // bundleInFreeDebug: true,
|
|
38
|
-
* // bundleInPaidRelease: true,
|
|
39
|
-
* // bundleInBeta: true,
|
|
40
|
-
*
|
|
41
|
-
* // whether to disable dev mode in custom build variants (by default only disabled in release)
|
|
42
|
-
* // for example: to disable dev mode in the staging build type (if configured)
|
|
43
|
-
* devDisabledInStaging: true,
|
|
44
|
-
* // The configuration property can be in the following formats
|
|
45
|
-
* // 'devDisabledIn${productFlavor}${buildType}'
|
|
46
|
-
* // 'devDisabledIn${buildType}'
|
|
47
|
-
*
|
|
48
|
-
* // the root of your project, i.e. where "package.json" lives
|
|
49
|
-
* root: "../../",
|
|
50
|
-
*
|
|
51
|
-
* // where to put the JS bundle asset in debug mode
|
|
52
|
-
* jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
|
|
53
|
-
*
|
|
54
|
-
* // where to put the JS bundle asset in release mode
|
|
55
|
-
* jsBundleDirRelease: "$buildDir/intermediates/assets/release",
|
|
56
|
-
*
|
|
57
|
-
* // where to put drawable resources / React Native assets, e.g. the ones you use via
|
|
58
|
-
* // require('./image.png')), in debug mode
|
|
59
|
-
* resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
|
|
60
|
-
*
|
|
61
|
-
* // where to put drawable resources / React Native assets, e.g. the ones you use via
|
|
62
|
-
* // require('./image.png')), in release mode
|
|
63
|
-
* resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
|
|
64
|
-
*
|
|
65
|
-
* // by default the gradle tasks are skipped if none of the JS files or assets change; this means
|
|
66
|
-
* // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
|
|
67
|
-
* // date; if you have any other folders that you want to ignore for performance reasons (gradle
|
|
68
|
-
* // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
|
|
69
|
-
* // for example, you might want to remove it from here.
|
|
70
|
-
* inputExcludes: ["android/**", "ios/**"],
|
|
71
|
-
*
|
|
72
|
-
* // override which node gets called and with what additional arguments
|
|
73
|
-
* nodeExecutableAndArgs: ["node"],
|
|
74
|
-
*
|
|
75
|
-
* // supply additional arguments to the packager
|
|
76
|
-
* extraPackagerArgs: []
|
|
77
|
-
* ]
|
|
78
|
-
*/
|
|
79
|
-
|
|
80
|
-
project.ext.react = [
|
|
81
|
-
enableHermes: false, // clean and rebuild if changing
|
|
82
|
-
]
|
|
83
|
-
|
|
84
|
-
apply from: "../../node_modules/react-native/react.gradle"
|
|
2
|
+
apply plugin: "com.facebook.react"
|
|
85
3
|
|
|
86
4
|
/**
|
|
87
|
-
*
|
|
88
|
-
*
|
|
89
|
-
* - An APK that only works on x86 devices
|
|
90
|
-
* The advantage is the size of the APK is reduced by about 4MB.
|
|
91
|
-
* Upload all the APKs to the Play Store and people will download
|
|
92
|
-
* the correct one based on the CPU architecture of their device.
|
|
5
|
+
* This is the configuration block to customize your React Native Android app.
|
|
6
|
+
* By default you don't need to apply any configuration, just uncomment the lines you need.
|
|
93
7
|
*/
|
|
94
|
-
|
|
8
|
+
react {
|
|
9
|
+
/* Folders */
|
|
10
|
+
// The root of your project, i.e. where "package.json" lives. Default is '..'
|
|
11
|
+
// root = file("../")
|
|
12
|
+
// The folder where the react-native NPM package is. Default is ../node_modules/react-native
|
|
13
|
+
// reactNativeDir = file("../node_modules/react-native")
|
|
14
|
+
// The folder where the react-native Codegen package is. Default is ../node_modules/@react-native/codegen
|
|
15
|
+
// codegenDir = file("../node_modules/@react-native/codegen")
|
|
16
|
+
// The cli.js file which is the React Native CLI entrypoint. Default is ../node_modules/react-native/cli.js
|
|
17
|
+
// cliFile = file("../node_modules/react-native/cli.js")
|
|
18
|
+
|
|
19
|
+
/* Variants */
|
|
20
|
+
// The list of variants to that are debuggable. For those we're going to
|
|
21
|
+
// skip the bundling of the JS bundle and the assets. By default is just 'debug'.
|
|
22
|
+
// If you add flavors like lite, prod, etc. you'll have to list your debuggableVariants.
|
|
23
|
+
// debuggableVariants = ["liteDebug", "prodDebug"]
|
|
24
|
+
|
|
25
|
+
/* Bundling */
|
|
26
|
+
// A list containing the node command and its flags. Default is just 'node'.
|
|
27
|
+
// nodeExecutableAndArgs = ["node"]
|
|
28
|
+
//
|
|
29
|
+
// The command to run when bundling. By default is 'bundle'
|
|
30
|
+
// bundleCommand = "ram-bundle"
|
|
31
|
+
//
|
|
32
|
+
// The path to the CLI configuration file. Default is empty.
|
|
33
|
+
// bundleConfig = file(../rn-cli.config.js)
|
|
34
|
+
//
|
|
35
|
+
// The name of the generated asset file containing your JS bundle
|
|
36
|
+
// bundleAssetName = "MyApplication.android.bundle"
|
|
37
|
+
//
|
|
38
|
+
// The entry file for bundle generation. Default is 'index.android.js' or 'index.js'
|
|
39
|
+
// entryFile = file("../js/MyApplication.android.js")
|
|
40
|
+
//
|
|
41
|
+
// A list of extra flags to pass to the 'bundle' commands.
|
|
42
|
+
// See https://github.com/react-native-community/cli/blob/main/docs/commands.md#bundle
|
|
43
|
+
// extraPackagerArgs = []
|
|
44
|
+
|
|
45
|
+
/* Hermes Commands */
|
|
46
|
+
// The hermes compiler command to run. By default it is 'hermesc'
|
|
47
|
+
// hermesCommand = "$rootDir/my-custom-hermesc/bin/hermesc"
|
|
48
|
+
//
|
|
49
|
+
// The list of flags to pass to the Hermes compiler. By default is "-O", "-output-source-map"
|
|
50
|
+
// hermesFlags = ["-O", "-output-source-map"]
|
|
51
|
+
}
|
|
95
52
|
|
|
96
53
|
/**
|
|
97
|
-
* Run Proguard to
|
|
54
|
+
* Set this to true to Run Proguard on Release builds to minify the Java bytecode.
|
|
98
55
|
*/
|
|
99
56
|
def enableProguardInReleaseBuilds = false
|
|
100
57
|
|
|
101
58
|
/**
|
|
102
|
-
* The preferred build flavor of JavaScriptCore
|
|
59
|
+
* The preferred build flavor of JavaScriptCore (JSC)
|
|
103
60
|
*
|
|
104
61
|
* For example, to use the international variant, you can use:
|
|
105
62
|
* `def jscFlavor = 'org.webkit:android-jsc-intl:+'`
|
|
106
63
|
*
|
|
107
64
|
* The international variant includes ICU i18n library and necessary data
|
|
108
65
|
* allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that
|
|
109
|
-
* give correct results when using with locales other than en-US.
|
|
66
|
+
* give correct results when using with locales other than en-US. Note that
|
|
110
67
|
* this variant is about 6MiB larger per architecture than default.
|
|
111
68
|
*/
|
|
112
69
|
def jscFlavor = 'org.webkit:android-jsc:+'
|
|
113
70
|
|
|
114
|
-
/**
|
|
115
|
-
* Whether to enable the Hermes VM.
|
|
116
|
-
*
|
|
117
|
-
* This should be set on project.ext.react and mirrored here. If it is not set
|
|
118
|
-
* on project.ext.react, JavaScript will not be compiled to Hermes Bytecode
|
|
119
|
-
* and the benefits of using Hermes will therefore be sharply reduced.
|
|
120
|
-
*/
|
|
121
|
-
def enableHermes = project.ext.react.get("enableHermes", false);
|
|
122
|
-
|
|
123
71
|
android {
|
|
124
|
-
|
|
72
|
+
ndkVersion rootProject.ext.ndkVersion
|
|
125
73
|
|
|
126
|
-
|
|
127
|
-
sourceCompatibility JavaVersion.VERSION_1_8
|
|
128
|
-
targetCompatibility JavaVersion.VERSION_1_8
|
|
129
|
-
}
|
|
74
|
+
compileSdkVersion rootProject.ext.compileSdkVersion
|
|
130
75
|
|
|
76
|
+
namespace "com.helloworld"
|
|
131
77
|
defaultConfig {
|
|
132
78
|
applicationId "com.helloworld"
|
|
133
79
|
minSdkVersion rootProject.ext.minSdkVersion
|
|
@@ -135,14 +81,6 @@ android {
|
|
|
135
81
|
versionCode 1
|
|
136
82
|
versionName "1.0"
|
|
137
83
|
}
|
|
138
|
-
splits {
|
|
139
|
-
abi {
|
|
140
|
-
reset()
|
|
141
|
-
enable enableSeparateBuildPerCPUArchitecture
|
|
142
|
-
universalApk false // If true, also generate a universal APK
|
|
143
|
-
include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
84
|
signingConfigs {
|
|
147
85
|
debug {
|
|
148
86
|
storeFile file('debug.keystore')
|
|
@@ -163,58 +101,23 @@ android {
|
|
|
163
101
|
proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
|
|
164
102
|
}
|
|
165
103
|
}
|
|
166
|
-
|
|
167
|
-
// applicationVariants are e.g. debug, release
|
|
168
|
-
applicationVariants.all { variant ->
|
|
169
|
-
variant.outputs.each { output ->
|
|
170
|
-
// For each separate APK per architecture, set a unique version code as described here:
|
|
171
|
-
// https://developer.android.com/studio/build/configure-apk-splits.html
|
|
172
|
-
def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
|
|
173
|
-
def abi = output.getFilter(OutputFile.ABI)
|
|
174
|
-
if (abi != null) { // null for the universal-debug, universal-release variants
|
|
175
|
-
output.versionCodeOverride =
|
|
176
|
-
versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
|
|
182
104
|
}
|
|
183
105
|
|
|
184
106
|
dependencies {
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
implementation "com.facebook.react:react-native:+" // From node_modules
|
|
188
|
-
|
|
189
|
-
implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0"
|
|
190
|
-
|
|
191
|
-
debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") {
|
|
192
|
-
exclude group:'com.facebook.fbjni'
|
|
193
|
-
}
|
|
107
|
+
// The version of react-native is set by the React Native Gradle Plugin
|
|
108
|
+
implementation("com.facebook.react:react-android")
|
|
194
109
|
|
|
110
|
+
debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}")
|
|
195
111
|
debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") {
|
|
196
|
-
exclude group:'com.facebook.flipper'
|
|
197
112
|
exclude group:'com.squareup.okhttp3', module:'okhttp'
|
|
198
113
|
}
|
|
199
114
|
|
|
200
|
-
debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}")
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
if (enableHermes) {
|
|
205
|
-
def hermesPath = "../../node_modules/hermes-engine/android/";
|
|
206
|
-
debugImplementation files(hermesPath + "hermes-debug.aar")
|
|
207
|
-
releaseImplementation files(hermesPath + "hermes-release.aar")
|
|
115
|
+
debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}")
|
|
116
|
+
if (hermesEnabled.toBoolean()) {
|
|
117
|
+
implementation("com.facebook.react:hermes-android")
|
|
208
118
|
} else {
|
|
209
119
|
implementation jscFlavor
|
|
210
120
|
}
|
|
211
121
|
}
|
|
212
122
|
|
|
213
|
-
// Run this once to be able to run the application with BUCK
|
|
214
|
-
// puts all compile dependencies into folder libs for BUCK to use
|
|
215
|
-
task copyDownloadableDepsToLibs(type: Copy) {
|
|
216
|
-
from configurations.compile
|
|
217
|
-
into 'libs'
|
|
218
|
-
}
|
|
219
|
-
|
|
220
123
|
apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
|
|
@@ -4,5 +4,10 @@
|
|
|
4
4
|
|
|
5
5
|
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
|
|
6
6
|
|
|
7
|
-
<application
|
|
7
|
+
<application
|
|
8
|
+
android:usesCleartextTraffic="true"
|
|
9
|
+
tools:targetApi="28"
|
|
10
|
+
tools:ignore="GoogleAppIndexingWarning">
|
|
11
|
+
<activity android:name="com.facebook.react.devsupport.DevSettingsActivity" android:exported="false" />
|
|
12
|
+
</application>
|
|
8
13
|
</manifest>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright (c)
|
|
2
|
+
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
3
|
*
|
|
4
4
|
* <p>This source code is licensed under the MIT license found in the LICENSE file in the root
|
|
5
5
|
* directory of this source tree.
|
|
@@ -17,20 +17,23 @@ import com.facebook.flipper.plugins.inspector.DescriptorMapping;
|
|
|
17
17
|
import com.facebook.flipper.plugins.inspector.InspectorFlipperPlugin;
|
|
18
18
|
import com.facebook.flipper.plugins.network.FlipperOkhttpInterceptor;
|
|
19
19
|
import com.facebook.flipper.plugins.network.NetworkFlipperPlugin;
|
|
20
|
-
import com.facebook.flipper.plugins.react.ReactFlipperPlugin;
|
|
21
20
|
import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin;
|
|
21
|
+
import com.facebook.react.ReactInstanceEventListener;
|
|
22
22
|
import com.facebook.react.ReactInstanceManager;
|
|
23
23
|
import com.facebook.react.bridge.ReactContext;
|
|
24
24
|
import com.facebook.react.modules.network.NetworkingModule;
|
|
25
25
|
import okhttp3.OkHttpClient;
|
|
26
26
|
|
|
27
|
+
/**
|
|
28
|
+
* Class responsible of loading Flipper inside your React Native application. This is the debug
|
|
29
|
+
* flavor of it. Here you can add your own plugins and customize the Flipper setup.
|
|
30
|
+
*/
|
|
27
31
|
public class ReactNativeFlipper {
|
|
28
32
|
public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) {
|
|
29
33
|
if (FlipperUtils.shouldEnableFlipper(context)) {
|
|
30
34
|
final FlipperClient client = AndroidFlipperClient.getInstance(context);
|
|
31
35
|
|
|
32
36
|
client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults()));
|
|
33
|
-
client.addPlugin(new ReactFlipperPlugin());
|
|
34
37
|
client.addPlugin(new DatabasesFlipperPlugin(context));
|
|
35
38
|
client.addPlugin(new SharedPreferencesFlipperPlugin(context));
|
|
36
39
|
client.addPlugin(CrashReporterPlugin.getInstance());
|
|
@@ -51,7 +54,7 @@ public class ReactNativeFlipper {
|
|
|
51
54
|
ReactContext reactContext = reactInstanceManager.getCurrentReactContext();
|
|
52
55
|
if (reactContext == null) {
|
|
53
56
|
reactInstanceManager.addReactInstanceEventListener(
|
|
54
|
-
new
|
|
57
|
+
new ReactInstanceEventListener() {
|
|
55
58
|
@Override
|
|
56
59
|
public void onReactContextInitialized(ReactContext reactContext) {
|
|
57
60
|
reactInstanceManager.removeReactInstanceEventListener(this);
|
|
@@ -1,24 +1,11 @@
|
|
|
1
|
-
<manifest
|
|
2
|
-
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
3
|
-
package="com.helloworld">
|
|
1
|
+
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
|
|
4
2
|
<uses-permission android:name="android.permission.INTERNET" />
|
|
5
3
|
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
|
|
6
4
|
<uses-permission android:name="android.permission.WAKE_LOCK" />
|
|
7
|
-
<
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
android:roundIcon="@mipmap/ic_launcher_round"
|
|
12
|
-
android:allowBackup="false"
|
|
13
|
-
android:theme="@style/AppTheme">
|
|
14
|
-
<activity
|
|
15
|
-
android:name=".MainActivity"
|
|
16
|
-
android:label="@string/app_name"
|
|
17
|
-
android:configChanges="keyboard|keyboardHidden|orientation|screenSize|uiMode"
|
|
18
|
-
android:launchMode="singleTask"
|
|
19
|
-
android:windowSoftInputMode="adjustResize"
|
|
20
|
-
android:screenOrientation="portrait"
|
|
21
|
-
android:exported="true">
|
|
5
|
+
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
|
|
6
|
+
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
|
|
7
|
+
<application android:name=".MainApplication" android:label="@string/app_name" android:icon="@mipmap/ic_launcher" android:roundIcon="@mipmap/ic_launcher_round" android:allowBackup="false" android:theme="@style/AppTheme">
|
|
8
|
+
<activity android:name=".MainActivity" android:label="@string/app_name" android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|screenSize|smallestScreenSize|uiMode" android:launchMode="singleTask" android:windowSoftInputMode="adjustResize" android:screenOrientation="portrait" android:exported="true">
|
|
22
9
|
<intent-filter>
|
|
23
10
|
<action android:name="android.intent.action.MAIN" />
|
|
24
11
|
<category android:name="android.intent.category.LAUNCHER" />
|
|
@@ -31,4 +18,4 @@
|
|
|
31
18
|
<service android:name="com.supersami.foregroundservice.ForegroundService" />
|
|
32
19
|
<service android:name="com.supersami.foregroundservice.ForegroundServiceTask" />
|
|
33
20
|
</application>
|
|
34
|
-
</manifest>
|
|
21
|
+
</manifest>
|
|
Binary file
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
package com.helloworld;
|
|
2
2
|
|
|
3
3
|
import com.facebook.react.ReactActivity;
|
|
4
|
+
import com.facebook.react.ReactActivityDelegate;
|
|
5
|
+
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint;
|
|
6
|
+
import com.facebook.react.defaults.DefaultReactActivityDelegate;
|
|
4
7
|
|
|
5
8
|
// for bg audio
|
|
6
9
|
import android.content.Intent;
|
|
@@ -62,4 +65,18 @@ public class MainActivity extends ReactActivity {
|
|
|
62
65
|
protected String getMainComponentName() {
|
|
63
66
|
return "HelloWorld";
|
|
64
67
|
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Returns the instance of the {@link ReactActivityDelegate}. Here we use a util class {@link
|
|
71
|
+
* DefaultReactActivityDelegate} which allows you to easily enable Fabric and Concurrent React
|
|
72
|
+
* (aka React 18) with two boolean flags.
|
|
73
|
+
*/
|
|
74
|
+
@Override
|
|
75
|
+
protected ReactActivityDelegate createReactActivityDelegate() {
|
|
76
|
+
return new DefaultReactActivityDelegate(
|
|
77
|
+
this,
|
|
78
|
+
getMainComponentName(),
|
|
79
|
+
// If you opted-in for the New Architecture, we enable the Fabric Renderer.
|
|
80
|
+
DefaultNewArchitectureEntryPoint.getFabricEnabled());
|
|
81
|
+
}
|
|
65
82
|
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
package com.helloworld;
|
|
2
2
|
|
|
3
3
|
import android.app.Application;
|
|
4
|
-
import android.content.Context;
|
|
5
4
|
import com.facebook.react.PackageList;
|
|
6
5
|
import com.facebook.react.ReactApplication;
|
|
7
|
-
import com.facebook.react.ReactInstanceManager;
|
|
8
6
|
import com.facebook.react.ReactNativeHost;
|
|
9
7
|
import com.facebook.react.ReactPackage;
|
|
8
|
+
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint;
|
|
9
|
+
import com.facebook.react.defaults.DefaultReactNativeHost;
|
|
10
10
|
import com.facebook.soloader.SoLoader;
|
|
11
|
-
import java.lang.reflect.InvocationTargetException;
|
|
12
11
|
import java.util.List;
|
|
12
|
+
import com.facebook.react.modules.network.OkHttpClientProvider;
|
|
13
13
|
|
|
14
14
|
public class MainApplication extends Application implements ReactApplication {
|
|
15
15
|
|
|
16
16
|
private final ReactNativeHost mReactNativeHost =
|
|
17
|
-
new
|
|
17
|
+
new DefaultReactNativeHost(this) {
|
|
18
18
|
@Override
|
|
19
19
|
public boolean getUseDeveloperSupport() {
|
|
20
20
|
return BuildConfig.DEBUG;
|
|
@@ -33,6 +33,17 @@ public class MainApplication extends Application implements ReactApplication {
|
|
|
33
33
|
protected String getJSMainModuleName() {
|
|
34
34
|
return "index";
|
|
35
35
|
}
|
|
36
|
+
|
|
37
|
+
@Override
|
|
38
|
+
protected boolean isNewArchEnabled() {
|
|
39
|
+
return BuildConfig.IS_NEW_ARCHITECTURE_ENABLED;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
@Override
|
|
43
|
+
protected Boolean isHermesEnabled() {
|
|
44
|
+
return BuildConfig.IS_HERMES_ENABLED;
|
|
45
|
+
}
|
|
46
|
+
|
|
36
47
|
};
|
|
37
48
|
|
|
38
49
|
@Override
|
|
@@ -44,37 +55,12 @@ public class MainApplication extends Application implements ReactApplication {
|
|
|
44
55
|
public void onCreate() {
|
|
45
56
|
super.onCreate();
|
|
46
57
|
SoLoader.init(this, /* native exopackage */ false);
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* Loads Flipper in React Native templates. Call this in the onCreate method with something like
|
|
52
|
-
* initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
|
|
53
|
-
*
|
|
54
|
-
* @param context
|
|
55
|
-
* @param reactInstanceManager
|
|
56
|
-
*/
|
|
57
|
-
private static void initializeFlipper(
|
|
58
|
-
Context context, ReactInstanceManager reactInstanceManager) {
|
|
59
|
-
if (BuildConfig.DEBUG) {
|
|
60
|
-
try {
|
|
61
|
-
/*
|
|
62
|
-
We use reflection here to pick up the class that initializes Flipper,
|
|
63
|
-
since Flipper library is not available in release mode
|
|
64
|
-
*/
|
|
65
|
-
Class<?> aClass = Class.forName("com.helloworld.ReactNativeFlipper");
|
|
66
|
-
aClass
|
|
67
|
-
.getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
|
|
68
|
-
.invoke(null, context, reactInstanceManager);
|
|
69
|
-
} catch (ClassNotFoundException e) {
|
|
70
|
-
e.printStackTrace();
|
|
71
|
-
} catch (NoSuchMethodException e) {
|
|
72
|
-
e.printStackTrace();
|
|
73
|
-
} catch (IllegalAccessException e) {
|
|
74
|
-
e.printStackTrace();
|
|
75
|
-
} catch (InvocationTargetException e) {
|
|
76
|
-
e.printStackTrace();
|
|
77
|
-
}
|
|
58
|
+
if (BuildConfig.IS_NEW_ARCHITECTURE_ENABLED) {
|
|
59
|
+
// If you opted-in for the New Architecture, we load the native entry point for this app.
|
|
60
|
+
DefaultNewArchitectureEntryPoint.load();
|
|
78
61
|
}
|
|
79
|
-
|
|
62
|
+
ReactNativeFlipper.initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
|
|
63
|
+
SSLPinningFactory sslPinningFactory = new SSLPinningFactory(getApplicationContext());
|
|
64
|
+
OkHttpClientProvider.setOkHttpClientFactory(sslPinningFactory);
|
|
65
|
+
}
|
|
80
66
|
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
package com.helloworld;
|
|
2
|
+
|
|
3
|
+
import com.facebook.react.modules.network.OkHttpClientFactory;
|
|
4
|
+
import com.facebook.react.modules.network.OkHttpClientProvider;
|
|
5
|
+
import okhttp3.CertificatePinner;
|
|
6
|
+
import okhttp3.OkHttpClient;
|
|
7
|
+
import android.content.Context;
|
|
8
|
+
|
|
9
|
+
public class SSLPinningFactory implements OkHttpClientFactory {
|
|
10
|
+
private Context context;
|
|
11
|
+
|
|
12
|
+
public SSLPinningFactory(Context context) {
|
|
13
|
+
this.context = context;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
public OkHttpClient createNewNetworkModuleClient() {
|
|
17
|
+
|
|
18
|
+
String hostname = context.getString(R.string.hostname);
|
|
19
|
+
String main_public_key = context.getString(R.string.main_public_key);
|
|
20
|
+
String backup_public_key = context.getString(R.string.backup_public_key);
|
|
21
|
+
|
|
22
|
+
CertificatePinner certificatePinner = new CertificatePinner.Builder()
|
|
23
|
+
.add(hostname, "sha256/"+ main_public_key)
|
|
24
|
+
.add(hostname, "sha256/"+ backup_public_key)
|
|
25
|
+
.build();
|
|
26
|
+
|
|
27
|
+
OkHttpClient.Builder clientBuilder = OkHttpClientProvider.createClientBuilder();
|
|
28
|
+
return clientBuilder.certificatePinner(certificatePinner).build();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
1
|
<resources>
|
|
2
2
|
<string name="app_name">Hello App Display Name</string>
|
|
3
|
+
<string name="hostname">managedservices-prod.rteappbuilder.com</string>
|
|
4
|
+
<string name="main_public_key">59d0kvzJLl7UOwYCl9KLk+Nzx9fD49Ah5qem+VGG8p8=</string>
|
|
5
|
+
<string name="backup_public_key">++MBgDH5WGvL9Bcn5Be30cRcL0f5O+NyoXuWtQdX1aI=</string>
|
|
3
6
|
</resources>
|