fcr-ui-scene 3.7.5 → 3.7.7
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/installer/icons/icon.png +0 -0
- package/installer/mac/entitlements.mac.plist +1 -5
- package/lib/creator/index.js +15 -7
- package/lib/creator/provider-initializer.browser.js +13 -4
- package/lib/creator/provider-initializer.electron.js +22 -10
- package/lib/creator.d.ts +36 -0
- package/lib/creator.js +465 -0
- package/lib/electron/bootstrap-sdk.js +90 -6
- package/lib/electron/injections.d.ts +1 -0
- package/lib/electron/injections.js +5 -1
- package/lib/electron/ipc/type.d.ts +1 -0
- package/lib/electron/ipc/type.js +1 -0
- package/lib/electron/preload.js +1 -0
- package/lib/electron/sdk-helper.d.ts +3 -0
- package/lib/electron/sdk-helper.js +53 -19
- package/lib/electron/struct.d.ts +7 -1
- package/lib/electron/struct.js +8 -1
- package/lib/electron/until.d.ts +7 -1
- package/lib/electron/until.js +11 -2
- package/lib/fragments/annotation/store.js +2 -0
- package/lib/modules/action-bar/components/item/index.js +1 -0
- package/lib/modules/action-bar/components/more/poppover-content.js +1 -1
- package/lib/modules/action-bar/components/screen-share/index.browser.js +4 -2
- package/lib/modules/action-bar/components/screen-share/index.electron.js +4 -2
- package/lib/modules/action-bar/components/screen-share/submenu.d.ts +5 -1
- package/lib/modules/action-bar/components/screen-share/submenu.js +12 -9
- package/lib/modules/action-bar/index.d.ts +55 -14
- package/lib/modules/action-bar/index.dev.js +94 -0
- package/lib/modules/action-bar/index.js +78 -32
- package/lib/modules/action-bar/store.d.ts +259 -0
- package/lib/modules/action-bar/store.js +1529 -0
- package/lib/modules/action-bar/types.d.ts +90 -0
- package/lib/modules/action-bar/types.js +6 -0
- package/lib/modules/action-bar/view.d.ts +1 -1
- package/lib/modules/action-bar/view.js +2 -2
- package/lib/modules/annotation/annotation-index.d.ts +2 -0
- package/lib/modules/annotation/annotation-index.js +80 -0
- package/lib/modules/annotation/annotation-toolbar-store.d.ts +75 -0
- package/lib/modules/annotation/annotation-toolbar-store.js +459 -0
- package/lib/modules/annotation/board-cursor.css +77 -0
- package/lib/modules/annotation/components/color-picker/components/color.d.ts +5 -0
- package/lib/modules/annotation/components/color-picker/components/color.js +38 -0
- package/lib/modules/annotation/components/color-picker/components/panel.d.ts +1 -0
- package/lib/modules/annotation/components/color-picker/components/panel.js +109 -0
- package/lib/modules/annotation/components/color-picker/components/picker.d.ts +1 -0
- package/lib/modules/annotation/components/color-picker/components/picker.js +75 -0
- package/lib/modules/annotation/components/color-picker/index.d.ts +2 -0
- package/lib/modules/annotation/components/color-picker/index.js +47 -0
- package/lib/modules/annotation/components/eraser-picker.d.ts +4 -0
- package/lib/modules/annotation/components/eraser-picker.js +144 -0
- package/lib/modules/annotation/components/expansion/index.d.ts +1 -0
- package/lib/modules/annotation/components/expansion/index.js +100 -0
- package/lib/modules/annotation/components/extra-tool-picker.d.ts +1 -0
- package/lib/modules/annotation/components/extra-tool-picker.js +62 -0
- package/lib/modules/annotation/components/history.d.ts +2 -0
- package/lib/modules/annotation/components/history.js +78 -0
- package/lib/modules/annotation/components/icons/fold-icon.d.ts +2 -0
- package/lib/modules/annotation/components/icons/fold-icon.js +41 -0
- package/lib/modules/annotation/components/icons/move-icon.d.ts +1 -0
- package/lib/modules/annotation/components/icons/move-icon.js +66 -0
- package/lib/modules/annotation/components/item/index.d.ts +1 -0
- package/lib/modules/annotation/components/item/index.js +43 -0
- package/lib/modules/annotation/components/move-handle.d.ts +5 -0
- package/lib/modules/annotation/components/move-handle.js +134 -0
- package/lib/modules/annotation/components/pen-picker.d.ts +4 -0
- package/lib/modules/annotation/components/pen-picker.js +155 -0
- package/lib/modules/annotation/components/screen-capture-picker.d.ts +4 -0
- package/lib/modules/annotation/components/screen-capture-picker.js +85 -0
- package/lib/modules/annotation/components/shape-picker.d.ts +4 -0
- package/lib/modules/annotation/components/shape-picker.js +210 -0
- package/lib/modules/annotation/hooks/index.d.ts +14 -0
- package/lib/modules/annotation/hooks/index.js +292 -0
- package/lib/modules/annotation/index.d.ts +45 -0
- package/lib/modules/annotation/index.js +168 -0
- package/lib/modules/annotation/store.d.ts +98 -0
- package/lib/modules/annotation/store.js +620 -0
- package/lib/modules/annotation/style.css +36 -0
- package/lib/modules/annotation/view.d.ts +3 -0
- package/lib/modules/annotation/view.js +44 -0
- package/lib/modules/audio-stream/index.js +4 -2
- package/lib/modules/chat/index.css +8 -0
- package/lib/modules/chat/view.js +7 -1
- package/lib/modules/components/control-bar/components/switch-theme/index.css +2 -0
- package/lib/modules/components/control-bar/components/switch-theme/index.js +5 -7
- package/lib/modules/components/control-bar/index.css +0 -2
- package/lib/modules/components/control-bar/index.d.ts +1 -0
- package/lib/modules/components/control-bar/index.js +51 -15
- package/lib/modules/components/device-control/store.d.ts +42 -0
- package/lib/modules/components/device-control/store.js +241 -0
- package/lib/modules/components/leave-meeting/main-scene/store.d.ts +3 -0
- package/lib/modules/components/leave-meeting/main-scene/store.js +12 -0
- package/lib/modules/components/leave-meeting/store.base.d.ts +4 -3
- package/lib/modules/components/leave-meeting/store.base.js +0 -10
- package/lib/modules/components/leave-meeting/store.d.ts +39 -0
- package/lib/modules/components/leave-meeting/store.js +270 -0
- package/lib/modules/components/leave-meeting/waiting-scene/store.d.ts +5 -1
- package/lib/modules/components/leave-meeting/waiting-scene/store.js +17 -3
- package/lib/modules/components/member-window/components/member-actions/components/more-actions.js +1 -2
- package/lib/modules/components/member-window/components/video-player/components/local-video-player-with-zoom.js +4 -3
- package/lib/modules/components/member-window/components/video-player/components/zoomable-container.js +18 -32
- package/lib/modules/components/toolbar/components/capture-tool/index.d.ts +0 -1
- package/lib/modules/components/toolbar/components/capture-tool/index.js +1 -2
- package/lib/modules/components/toolbar/components/vertical-frame/index.js +2 -2
- package/lib/modules/components/toolbar/hooks/use-resize-visible.js +45 -32
- package/lib/modules/components/toolbar/index.js +6 -24
- package/lib/modules/control-bar/components/annotation-button/index.d.ts +1 -0
- package/lib/modules/control-bar/components/annotation-button/index.js +72 -0
- package/lib/modules/control-bar/components/boundary-detector.d.ts +7 -5
- package/lib/modules/control-bar/components/boundary-detector.js +22 -2
- package/lib/modules/control-bar/components/cloud-recording-buttons.d.ts +3 -0
- package/lib/modules/control-bar/components/cloud-recording-buttons.js +68 -3
- package/lib/modules/control-bar/hooks.js +2 -1
- package/lib/modules/control-bar/store.d.ts +1 -0
- package/lib/modules/control-bar/store.js +21 -7
- package/lib/modules/control-bar/types.d.ts +5 -16
- package/lib/modules/control-bar/view.js +96 -28
- package/lib/modules/dialog/components/confirm/index.js +6 -24
- package/lib/modules/dialog/components/dialog-container/component/body.d.ts +1 -0
- package/lib/modules/dialog/components/dialog-container/component/body.js +3 -2
- package/lib/modules/dialog/components/dialog-container/index.css +8 -1
- package/lib/modules/dialog/components/dialog-container/index.d.ts +1 -0
- package/lib/modules/dialog/components/dialog-container/index.js +4 -1
- package/lib/modules/dialog/components/normal-window/index.d.ts +1 -0
- package/lib/modules/dialog/components/normal-window/index.js +3 -1
- package/lib/modules/dialog/dialogs/chat/index.js +2 -1
- package/lib/modules/dialog/dialogs/control-bar-leave-meeting/index.js +0 -1
- package/lib/modules/dialog/dialogs/device-setting/index.d.ts +1 -0
- package/lib/modules/dialog/dialogs/device-setting/index.js +4 -2
- package/lib/modules/dialog/dialogs/end-meeting/index.d.ts +1 -0
- package/lib/modules/dialog/dialogs/end-meeting/index.js +2 -1
- package/lib/modules/dialog/dialogs/invite/index.d.ts +1 -0
- package/lib/modules/dialog/dialogs/invite/index.js +2 -1
- package/lib/modules/dialog/dialogs/mute-all/index.d.ts +1 -0
- package/lib/modules/dialog/dialogs/mute-all/index.js +2 -1
- package/lib/modules/dialog/dialogs/participant/index.js +9 -2
- package/lib/modules/dialog/dialogs/pre-setting/index.d.ts +3 -3
- package/lib/modules/dialog/dialogs/pre-setting/index.js +25 -20
- package/lib/modules/dialog/dialogs/share-screen-selection/index.js +1 -1
- package/lib/modules/dialog/dialogs/sub-window/index.js +1 -7
- package/lib/modules/dialog/dialogs/toast/index.d.ts +1 -1
- package/lib/modules/dialog/dialogs/toast/index.js +1 -1
- package/lib/modules/dialog/dialogs/video-window/index.d.ts +4 -1
- package/lib/modules/dialog/dialogs/video-window/index.js +5 -2
- package/lib/modules/dialog/dialogs/widget/electron.d.ts +6 -0
- package/lib/modules/dialog/dialogs/widget/electron.js +38 -0
- package/lib/modules/dialog/dialogs/widget/index.d.ts +2 -0
- package/lib/modules/dialog/dialogs/widget/index.js +11 -3
- package/lib/modules/dialog/hooks/use-popover-watcher.js +1 -3
- package/lib/modules/dialog/hooks/useElectron.d.ts +28 -0
- package/lib/modules/dialog/hooks/useElectron.js +277 -0
- package/lib/modules/dialog/index.css +6 -2
- package/lib/modules/dialog/level-config.d.ts +1 -0
- package/lib/modules/dialog/level-config.js +2 -1
- package/lib/modules/dialog/store.base.d.ts +2 -0
- package/lib/modules/dialog/store.browser.d.ts +2 -0
- package/lib/modules/dialog/store.browser.js +6 -1
- package/lib/modules/dialog/store.d.ts +135 -0
- package/lib/modules/dialog/store.electron.d.ts +9 -1
- package/lib/modules/dialog/store.electron.js +64 -4
- package/lib/modules/dialog/store.js +616 -0
- package/lib/modules/dialog/type.d.ts +3 -0
- package/lib/modules/event-confirm/components/window/index.d.ts +7 -0
- package/lib/modules/event-confirm/components/window/index.js +221 -0
- package/lib/modules/event-confirm/index.css +24 -0
- package/lib/modules/event-confirm/index.d.ts +27 -0
- package/lib/modules/event-confirm/index.js +76 -0
- package/lib/modules/event-confirm/store.d.ts +50 -0
- package/lib/modules/event-confirm/store.js +394 -0
- package/lib/modules/event-confirm/view.d.ts +2 -0
- package/lib/modules/event-confirm/view.js +55 -0
- package/lib/modules/event-toast/index.css +0 -1
- package/lib/modules/event-toast/index.js +1 -0
- package/lib/modules/event-toast/store.base.d.ts +2 -0
- package/lib/modules/event-toast/store.base.js +40 -21
- package/lib/modules/event-toast/store.d.ts +9 -5
- package/lib/modules/event-toast/store.electron.d.ts +2 -0
- package/lib/modules/event-toast/store.electron.js +19 -9
- package/lib/modules/event-toast/store.js +57 -39
- package/lib/modules/layout/components/CommonVideoRenderer.js +1 -0
- package/lib/modules/layout/store.d.ts +176 -0
- package/lib/modules/layout/store.electron.js +1 -1
- package/lib/modules/layout/store.js +1452 -0
- package/lib/modules/participant/components/confirm-input/index.js +1 -1
- package/lib/modules/participant/store.base.d.ts +30 -3
- package/lib/modules/participant/store.base.js +249 -96
- package/lib/modules/participant/store.browser.js +4 -3
- package/lib/modules/participant/store.d.ts +222 -0
- package/lib/modules/participant/store.electron.js +5 -3
- package/lib/modules/participant/store.js +1929 -0
- package/lib/modules/pc-audio-connect/index.d.ts +22 -0
- package/lib/modules/pc-audio-connect/index.js +67 -0
- package/lib/modules/pc-audio-connect/main-scene/store.js +1 -0
- package/lib/modules/pc-audio-connect/store.d.ts +46 -0
- package/lib/modules/pc-audio-connect/store.js +304 -0
- package/lib/modules/secondary-window/store.d.ts +1 -1
- package/lib/modules/secondary-window/store.js +14 -22
- package/lib/modules/secondary-window/view.js +10 -10
- package/lib/modules/setting/audio-settings/audio-settings.js +0 -17
- package/lib/modules/setting/dialog-wrapper.d.ts +2 -0
- package/lib/modules/setting/dialog-wrapper.js +110 -0
- package/lib/modules/setting/index.js +1 -1
- package/lib/modules/setting/state/index.js +1 -1
- package/lib/modules/setting/store.base.d.ts +5 -2
- package/lib/modules/setting/store.base.js +72 -26
- package/lib/modules/setting/store.d.ts +261 -0
- package/lib/modules/setting/store.js +1321 -0
- package/lib/modules/share-screen/components/selection/index.css +4 -0
- package/lib/modules/share-screen/store.base.js +17 -4
- package/lib/modules/share-screen/store.d.ts +148 -0
- package/lib/modules/share-screen/store.electron.js +5 -2
- package/lib/modules/share-screen/store.js +960 -0
- package/lib/modules/share-screen/types.d.ts +26 -0
- package/lib/modules/share-screen/types.js +6 -0
- package/lib/modules/state-bar/layout-config.js +6 -0
- package/lib/modules/state-bar/main-scene/store.base.d.ts +2 -0
- package/lib/modules/state-bar/main-scene/store.base.js +6 -0
- package/lib/modules/state-bar/store.d.ts +124 -0
- package/lib/modules/state-bar/store.js +664 -0
- package/lib/modules/video-window/index.css +6 -0
- package/lib/modules/video-window/popover-watcher.d.ts +5 -10
- package/lib/modules/video-window/popover-watcher.js +34 -31
- package/lib/modules/video-window/store.d.ts +32 -5
- package/lib/modules/video-window/store.js +156 -63
- package/lib/modules/video-window/view.js +50 -1
- package/lib/modules/whiteboard/components/progress/electron.d.ts +1 -0
- package/lib/modules/whiteboard/components/progress/electron.js +33 -0
- package/lib/modules/whiteboard/index.d.ts +1 -1
- package/lib/modules/whiteboard/index.js +1 -1
- package/lib/modules/whiteboard/store.d.ts +3 -0
- package/lib/modules/whiteboard/store.js +31 -2
- package/lib/modules/whiteboard/view.js +10 -1
- package/lib/modules/widget/sdk.js +1 -1
- package/lib/modules/widget/store.base.d.ts +1 -0
- package/lib/modules/widget/store.browser.d.ts +1 -0
- package/lib/modules/widget/store.browser.js +60 -4
- package/lib/modules/widget/store.d.ts +5 -8
- package/lib/modules/widget/store.electron.d.ts +1 -0
- package/lib/modules/widget/store.electron.js +59 -2
- package/lib/modules/widget/store.js +4 -47
- package/lib/modules/widget/type.d.ts +3 -2
- package/lib/modules/widget/view.js +9 -4
- package/lib/modules/widget/web-widget.d.ts +2 -1
- package/lib/modules/widget/web-widget.js +7 -5
- package/lib/object-manager.d.ts +2 -2
- package/lib/object-manager.js +1 -1
- package/lib/providers/annotation-provider.d.ts +124 -0
- package/lib/providers/annotation-provider.js +369 -0
- package/lib/providers/board-share/bar-control/base.d.ts +1 -1
- package/lib/providers/board-share/bar-control/base.js +37 -28
- package/lib/providers/board-share/bar-control/electron.d.ts +1 -1
- package/lib/providers/board-share/bar-control/electron.js +19 -16
- package/lib/providers/board-share/provider.base.d.ts +8 -1
- package/lib/providers/board-share/provider.base.js +12 -2
- package/lib/providers/board-share/provider.browser.d.ts +3 -0
- package/lib/providers/board-share/provider.browser.js +21 -3
- package/lib/providers/device-provider.d.ts +16 -2
- package/lib/providers/device-provider.js +53 -60
- package/lib/providers/dialog/provider.base.d.ts +1 -0
- package/lib/providers/dialog/provider.browser.d.ts +1 -0
- package/lib/providers/dialog/provider.browser.js +7 -2
- package/lib/providers/dialog/provider.electron.d.ts +4 -1
- package/lib/providers/dialog/provider.electron.js +94 -2
- package/lib/providers/dialog/type.d.ts +7 -0
- package/lib/providers/dialog-provider.d.ts +137 -0
- package/lib/providers/dialog-provider.js +194 -0
- package/lib/providers/message-provider.d.ts +69 -0
- package/lib/providers/message-provider.js +140 -0
- package/lib/providers/mouse-detect/provider.d.ts +9 -1
- package/lib/providers/mouse-detect/provider.js +119 -5
- package/lib/providers/mouse-detect/struct.d.ts +2 -1
- package/lib/providers/mouse-detect/struct.js +1 -0
- package/lib/providers/mouse-detect/type.d.ts +2 -0
- package/lib/providers/multi-display-provider.d.ts +3 -5
- package/lib/providers/multi-display-provider.js +0 -9
- package/lib/providers/renderer-provider.d.ts +5 -0
- package/lib/providers/renderer-provider.js +5 -0
- package/lib/providers/room-provider/room-provider.d.ts +4 -14
- package/lib/providers/room-provider/room-provider.js +28 -39
- package/lib/providers/room-provider.d.ts +194 -0
- package/lib/providers/room-provider.js +916 -0
- package/lib/providers/screen-share/provider.base.js +3 -11
- package/lib/providers/screen-share/provider.browser.js +23 -14
- package/lib/providers/screen-share/provider.electron.d.ts +1 -0
- package/lib/providers/screen-share/provider.electron.js +44 -17
- package/lib/providers/screen-share/strategy/browser.js +16 -13
- package/lib/providers/screen-share/strategy/electron.d.ts +2 -2
- package/lib/providers/screen-share/strategy/electron.js +15 -10
- package/lib/providers/screen-share/strategy/type.d.ts +6 -0
- package/lib/providers/screen-share/stream-state-sync.d.ts +3 -2
- package/lib/providers/screen-share/stream-state-sync.js +26 -16
- package/lib/providers/screen-share/struct.d.ts +9 -7
- package/lib/providers/screen-share/struct.js +11 -8
- package/lib/providers/screen-share/type.d.ts +7 -1
- package/lib/providers/screen-share-provider.d.ts +245 -0
- package/lib/providers/screen-share-provider.js +850 -0
- package/lib/providers/sharing-provider.d.ts +42 -0
- package/lib/providers/sharing-provider.js +228 -0
- package/lib/providers/user-setting-storage-provider.d.ts +21 -0
- package/lib/providers/user-setting-storage-provider.js +65 -0
- package/lib/providers/whiteboard-provider.d.ts +2 -4
- package/lib/providers/whiteboard-provider.js +4 -7
- package/lib/providers/widget-provider.d.ts +5 -3
- package/lib/providers/widget-provider.js +12 -18
- package/lib/providers/window/main-window.d.ts +0 -5
- package/lib/providers/window/main-window.js +3 -44
- package/lib/providers/window/renderer-window.d.ts +1 -0
- package/lib/providers/window/renderer-window.js +13 -2
- package/lib/runtime.d.ts +1 -0
- package/lib/runtime.js +2 -1
- package/lib/scenes/main-scene.js +5 -0
- package/lib/shared-context/board-context.d.ts +2 -0
- package/lib/shared-context/board-context.js +2 -0
- package/lib/shared-data/member-data.d.ts +0 -8
- package/lib/shared-data/member-data.js +26 -78
- package/lib/shared-data/widget-data.d.ts +13 -0
- package/lib/shared-data/widget-data.js +50 -0
- package/lib/shared-data-source/annotation-data.d.ts +17 -0
- package/lib/{modules/action-bar/store.base.js → shared-data-source/annotation-data.js} +34 -41
- package/lib/shared-data-source/app-list-data.d.ts +34 -0
- package/lib/shared-data-source/app-list-data.js +133 -0
- package/lib/shared-data-source/chat-data.d.ts +25 -0
- package/lib/shared-data-source/chat-data.js +139 -0
- package/lib/shared-data-source/config.d.ts +35 -0
- package/lib/shared-data-source/config.js +40 -0
- package/lib/shared-data-source/confirm-data.d.ts +44 -0
- package/lib/shared-data-source/confirm-data.js +201 -0
- package/lib/shared-data-source/device-privilege-data.d.ts +8 -0
- package/lib/shared-data-source/device-privilege-data.js +25 -0
- package/lib/shared-data-source/interpreter.d.ts +77 -0
- package/lib/shared-data-source/interpreter.js +247 -0
- package/lib/shared-data-source/layout-data.d.ts +31 -0
- package/lib/shared-data-source/layout-data.js +189 -0
- package/lib/shared-data-source/meeting-time.d.ts +90 -0
- package/lib/shared-data-source/meeting-time.js +416 -0
- package/lib/shared-data-source/member-data.d.ts +139 -0
- package/lib/shared-data-source/member-data.js +517 -0
- package/lib/shared-data-source/pin-data.d.ts +13 -0
- package/lib/{modules/action-bar/waiting-scene/store.js → shared-data-source/pin-data.js} +55 -35
- package/lib/shared-data-source/screen-share-data.d.ts +357 -0
- package/lib/shared-data-source/screen-share-data.js +513 -0
- package/lib/shared-data-source/security-data.d.ts +39 -0
- package/lib/shared-data-source/security-data.js +156 -0
- package/lib/shared-data-source/setting.d.ts +67 -0
- package/lib/shared-data-source/setting.js +220 -0
- package/lib/shared-data-source/speaker-spotlight.d.ts +5 -0
- package/lib/shared-data-source/speaker-spotlight.js +15 -0
- package/lib/shared-data-source/video-window.d.ts +165 -0
- package/lib/shared-data-source/video-window.js +1266 -0
- package/lib/shared-data-source/waiting-room.d.ts +46 -0
- package/lib/shared-data-source/waiting-room.js +222 -0
- package/lib/{shared-data → shared-data-source}/whiteboard-data.d.ts +2 -2
- package/lib/{shared-data → shared-data-source}/whiteboard-data.js +23 -17
- package/lib/translations/enUS.d.ts +0 -2
- package/lib/translations/enUS.js +4 -6
- package/lib/translations/zhCN.d.ts +0 -2
- package/lib/translations/zhCN.js +4 -6
- package/lib/type.d.ts +5 -0
- package/lib/ui-scene.d.ts +2 -4
- package/lib/ui-scene.js +31 -42
- package/lib/utilities/board-context.d.ts +4 -0
- package/lib/utilities/board-context.js +12 -0
- package/lib/utilities/constant.d.ts +3 -1
- package/lib/utilities/constant.js +5 -2
- package/lib/utilities/copyText.d.ts +2 -0
- package/lib/utilities/copyText.js +48 -0
- package/lib/utilities/default-config.d.ts +18 -0
- package/lib/utilities/default-config.js +19 -1
- package/lib/utilities/focus-helper.js +10 -3
- package/lib/utilities/logger.js +3 -1
- package/lib/utilities/renderer-event.d.ts +10 -0
- package/lib/utilities/renderer-event.js +95 -0
- package/lib/utilities/renderer.d.ts +1 -0
- package/lib/utilities/renderer.js +7 -1
- package/lib/utilities/screen-capture-permission.d.ts +2 -0
- package/lib/utilities/screen-capture-permission.js +24 -0
- package/lib/utilities/screen.d.ts +3 -0
- package/lib/utilities/screen.js +53 -0
- package/lib/utilities/video-track-render-context.d.ts +6 -0
- package/lib/utilities/video-track-render-context.js +9 -0
- package/lib/waiting-room-control-manager.d.ts +28 -0
- package/lib/waiting-room-control-manager.js +230 -0
- package/package.json +5 -5
- package/public/index.html +35 -4
- package/lib/modules/action-bar/store.base.d.ts +0 -15
- package/lib/modules/action-bar/waiting-scene/store.d.ts +0 -6
- package/lib/providers/board-share/bar-control.d.ts +0 -51
- package/lib/providers/board-share/bar-control.js +0 -390
- package/lib/providers/board-share/provider.d.ts +0 -66
- package/lib/providers/board-share/provider.js +0 -456
- package/lib/providers/screen-share/provider.d.ts +0 -69
- package/lib/providers/screen-share/provider.js +0 -615
- package/lib/providers/window/browser-window-proxy.js +0 -1
- package/lib/providers/window/ipc-protocol.d.ts +0 -0
- package/lib/providers/window/ipc-protocol.js +0 -1
- package/lib/providers/window/main-process-handler.d.ts +0 -0
- package/lib/providers/window/main-process-handler.js +0 -1
- package/lib/providers/window/main-process-integration.d.ts +0 -0
- package/lib/providers/window/main-process-integration.js +0 -1
- package/lib/utilities/ipc-protocol.d.ts +0 -91
- package/lib/utilities/ipc-protocol.js +0 -61
- /package/lib/{providers/window/browser-window-proxy.d.ts → modules/action-bar/index.dev.d.ts} +0 -0
|
@@ -1,615 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
require("core-js/modules/es.symbol.js");
|
|
4
|
-
require("core-js/modules/es.symbol.description.js");
|
|
5
|
-
require("core-js/modules/es.symbol.to-primitive.js");
|
|
6
|
-
require("core-js/modules/es.array.is-array.js");
|
|
7
|
-
require("core-js/modules/es.array.push.js");
|
|
8
|
-
require("core-js/modules/es.date.to-primitive.js");
|
|
9
|
-
require("core-js/modules/es.function.bind.js");
|
|
10
|
-
require("core-js/modules/es.function.name.js");
|
|
11
|
-
require("core-js/modules/es.map.js");
|
|
12
|
-
require("core-js/modules/es.number.constructor.js");
|
|
13
|
-
require("core-js/modules/es.object.create.js");
|
|
14
|
-
require("core-js/modules/es.object.define-property.js");
|
|
15
|
-
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
16
|
-
require("core-js/modules/esnext.function.metadata.js");
|
|
17
|
-
require("core-js/modules/esnext.map.delete-all.js");
|
|
18
|
-
require("core-js/modules/esnext.map.emplace.js");
|
|
19
|
-
require("core-js/modules/esnext.map.every.js");
|
|
20
|
-
require("core-js/modules/esnext.map.filter.js");
|
|
21
|
-
require("core-js/modules/esnext.map.find.js");
|
|
22
|
-
require("core-js/modules/esnext.map.find-key.js");
|
|
23
|
-
require("core-js/modules/esnext.map.includes.js");
|
|
24
|
-
require("core-js/modules/esnext.map.key-of.js");
|
|
25
|
-
require("core-js/modules/esnext.map.map-keys.js");
|
|
26
|
-
require("core-js/modules/esnext.map.map-values.js");
|
|
27
|
-
require("core-js/modules/esnext.map.merge.js");
|
|
28
|
-
require("core-js/modules/esnext.map.reduce.js");
|
|
29
|
-
require("core-js/modules/esnext.map.some.js");
|
|
30
|
-
require("core-js/modules/esnext.map.update.js");
|
|
31
|
-
require("core-js/modules/esnext.symbol.metadata.js");
|
|
32
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
33
|
-
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
34
|
-
Object.defineProperty(exports, "__esModule", {
|
|
35
|
-
value: true
|
|
36
|
-
});
|
|
37
|
-
exports.FcrUIScreenShareProviderImpl = void 0;
|
|
38
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
39
|
-
require("core-js/modules/es.error.cause.js");
|
|
40
|
-
require("core-js/modules/es.error.to-string.js");
|
|
41
|
-
require("core-js/modules/es.array.iterator.js");
|
|
42
|
-
require("core-js/modules/es.array.map.js");
|
|
43
|
-
require("core-js/modules/es.object.to-string.js");
|
|
44
|
-
require("core-js/modules/es.promise.js");
|
|
45
|
-
require("core-js/modules/es.string.iterator.js");
|
|
46
|
-
require("core-js/modules/es.weak-map.js");
|
|
47
|
-
require("core-js/modules/esnext.iterator.constructor.js");
|
|
48
|
-
require("core-js/modules/esnext.iterator.map.js");
|
|
49
|
-
require("core-js/modules/esnext.weak-map.delete-all.js");
|
|
50
|
-
require("core-js/modules/esnext.weak-map.emplace.js");
|
|
51
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
52
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
53
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
54
|
-
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
55
|
-
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
56
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
57
|
-
var _logger = require("../../utilities/logger");
|
|
58
|
-
var _objectManager2 = require("../../object-manager");
|
|
59
|
-
var _env = require("agora-foundation/lib/utilities/env");
|
|
60
|
-
var _electron = require("./strategy/electron");
|
|
61
|
-
var _browser = require("./strategy/browser");
|
|
62
|
-
var _type = require("./strategy/type");
|
|
63
|
-
var _fcrCore = require("fcr-core");
|
|
64
|
-
var _type2 = require("fcr-core/lib/type");
|
|
65
|
-
var _streamStateSync = require("./stream-state-sync");
|
|
66
|
-
var _struct = require("./struct");
|
|
67
|
-
var _observable = require("agora-foundation/lib/utilities/observable");
|
|
68
|
-
var _decorator = require("agora-foundation/lib/decorator");
|
|
69
|
-
var _mobx = require("mobx");
|
|
70
|
-
var _FcrUIScreenShareProviderImpl;
|
|
71
|
-
var _initProto, _init__isSharingWithAudio, _init__isScreenSharing, _init__shareStreamId, _init__sharingUser;
|
|
72
|
-
function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); }
|
|
73
|
-
function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); }
|
|
74
|
-
function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; }
|
|
75
|
-
function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); }
|
|
76
|
-
function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
|
|
77
|
-
function _applyDecs(e, t, r, n, o, a) { function i(e, t, r) { return function (n, o) { return r && r(n), e[t].call(n, o); }; } function c(e, t) { for (var r = 0; r < e.length; r++) e[r].call(t); return t; } function s(e, t, r, n) { if ("function" != typeof e && (n || void 0 !== e)) throw new TypeError(t + " must " + (r || "be") + " a function" + (n ? "" : " or undefined")); return e; } function applyDec(e, t, r, n, o, a, c, u, l, f, p, d, h) { function m(e) { if (!h(e)) throw new TypeError("Attempted to access private element on non-instance"); } var y, v = t[0], g = t[3], b = !u; if (!b) { r || Array.isArray(v) || (v = [v]); var w = {}, S = [], A = 3 === o ? "get" : 4 === o || d ? "set" : "value"; f ? (p || d ? w = { get: _setFunctionName(function () { return g(this); }, n, "get"), set: function set(e) { t[4](this, e); } } : w[A] = g, p || _setFunctionName(w[A], n, 2 === o ? "" : A)) : p || (w = Object.getOwnPropertyDescriptor(e, n)); } for (var P = e, j = v.length - 1; j >= 0; j -= r ? 2 : 1) { var D = v[j], E = r ? v[j - 1] : void 0, I = {}, O = { kind: ["field", "accessor", "method", "getter", "setter", "class"][o], name: n, metadata: a, addInitializer: function (e, t) { if (e.v) throw Error("attempted to call addInitializer after decoration was finished"); s(t, "An initializer", "be", !0), c.push(t); }.bind(null, I) }; try { if (b) (y = s(D.call(E, P, O), "class decorators", "return")) && (P = y);else { var k, F; O["static"] = l, O["private"] = f, f ? 2 === o ? k = function k(e) { return m(e), w.value; } : (o < 4 && (k = i(w, "get", m)), 3 !== o && (F = i(w, "set", m))) : (k = function k(e) { return e[n]; }, (o < 2 || 4 === o) && (F = function F(e, t) { e[n] = t; })); var N = O.access = { has: f ? h.bind() : function (e) { return n in e; } }; if (k && (N.get = k), F && (N.set = F), P = D.call(E, d ? { get: w.get, set: w.set } : w[A], O), d) { if ("object" == _typeof(P) && P) (y = s(P.get, "accessor.get")) && (w.get = y), (y = s(P.set, "accessor.set")) && (w.set = y), (y = s(P.init, "accessor.init")) && S.push(y);else if (void 0 !== P) throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0"); } else s(P, (p ? "field" : "method") + " decorators", "return") && (p ? S.push(P) : w[A] = P); } } finally { I.v = !0; } } return (p || d) && u.push(function (e, t) { for (var r = S.length - 1; r >= 0; r--) t = S[r].call(e, t); return t; }), p || b || (f ? d ? u.push(i(w, "get"), i(w, "set")) : u.push(2 === o ? w[A] : i.call.bind(w[A])) : Object.defineProperty(e, n, w)), P; } function u(e, t) { return Object.defineProperty(e, Symbol.metadata || Symbol["for"]("Symbol.metadata"), { configurable: !0, enumerable: !0, value: t }); } if (arguments.length >= 6) var l = a[Symbol.metadata || Symbol["for"]("Symbol.metadata")]; var f = Object.create(null == l ? null : l), p = function (e, t, r, n) { var o, a, i = [], s = function s(t) { return _checkInRHS(t) === e; }, u = new Map(); function l(e) { e && i.push(c.bind(null, e)); } for (var f = 0; f < t.length; f++) { var p = t[f]; if (Array.isArray(p)) { var d = p[1], h = p[2], m = p.length > 3, y = 16 & d, v = !!(8 & d), g = 0 == (d &= 7), b = h + "/" + v; if (!g && !m) { var w = u.get(b); if (!0 === w || 3 === w && 4 !== d || 4 === w && 3 !== d) throw Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + h); u.set(b, !(d > 2) || d); } applyDec(v ? e : e.prototype, p, y, m ? "#" + h : _toPropertyKey(h), d, n, v ? a = a || [] : o = o || [], i, v, m, g, 1 === d, v && m ? s : r); } } return l(o), l(a), i; }(e, t, o, f); return r.length || u(e, f), { e: p, get c() { var t = []; return r.length && [u(applyDec(e, [r], n, e.name, 5, f, t), f), c.bind(null, t, e)]; } }; }
|
|
78
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
79
|
-
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
80
|
-
function _setFunctionName(e, t, n) { "symbol" == _typeof(t) && (t = (t = t.description) ? "[" + t + "]" : ""); try { Object.defineProperty(e, "name", { configurable: !0, value: n ? n + " " + t : t }); } catch (e) {} return e; }
|
|
81
|
-
function _checkInRHS(e) { if (Object(e) !== e) throw TypeError("right-hand side of 'in' should be an object, got " + (null !== e ? _typeof(e) : "null")); return e; }
|
|
82
|
-
/**
|
|
83
|
-
* startShare
|
|
84
|
-
* - callback: share started
|
|
85
|
-
* - callback: share error occurred
|
|
86
|
-
* - callback error:
|
|
87
|
-
* 1. cannot publish
|
|
88
|
-
* 2. screen recording permission denied
|
|
89
|
-
* 3. error occurred during screen recording
|
|
90
|
-
* - remove screen stream, keep screen stream in sync
|
|
91
|
-
* stopShare
|
|
92
|
-
* - callback: share stopped
|
|
93
|
-
* replaceShare
|
|
94
|
-
* no callbacks
|
|
95
|
-
* Listen to stream events:
|
|
96
|
-
* local stream removed
|
|
97
|
-
* - callback: share stopped
|
|
98
|
-
*
|
|
99
|
-
* Error handle:
|
|
100
|
-
* 1. error occurred during screen recording
|
|
101
|
-
* - remove screen stream
|
|
102
|
-
* Track events handle:
|
|
103
|
-
* 1. track stopped
|
|
104
|
-
* - keep screen stream in sync
|
|
105
|
-
*/
|
|
106
|
-
var _A = /*#__PURE__*/new WeakMap();
|
|
107
|
-
var _B = /*#__PURE__*/new WeakMap();
|
|
108
|
-
var _C = /*#__PURE__*/new WeakMap();
|
|
109
|
-
var _D = /*#__PURE__*/new WeakMap();
|
|
110
|
-
var FcrUIScreenShareProviderImpl = exports.FcrUIScreenShareProviderImpl = /*#__PURE__*/function () {
|
|
111
|
-
function FcrUIScreenShareProviderImpl(_objectManager) {
|
|
112
|
-
var _this = this;
|
|
113
|
-
(0, _classCallCheck2["default"])(this, FcrUIScreenShareProviderImpl);
|
|
114
|
-
(0, _defineProperty2["default"])(this, "logger", (_initProto(this), (0, _logger.createLogger)({
|
|
115
|
-
prefix: 'FcrUIScreenShareProviderImpl'
|
|
116
|
-
})));
|
|
117
|
-
(0, _defineProperty2["default"])(this, "_observable", new _observable.AgoraObservable());
|
|
118
|
-
(0, _defineProperty2["default"])(this, "_isScreenShareStarted", false);
|
|
119
|
-
(0, _defineProperty2["default"])(this, "_windowList", []);
|
|
120
|
-
(0, _defineProperty2["default"])(this, "_displayList", []);
|
|
121
|
-
(0, _defineProperty2["default"])(this, "_selectionBounds", null);
|
|
122
|
-
(0, _defineProperty2["default"])(this, "_sharingDisplayBounds", null);
|
|
123
|
-
_classPrivateFieldInitSpec(this, _A, _init__isSharingWithAudio(this, false));
|
|
124
|
-
_classPrivateFieldInitSpec(this, _B, _init__isScreenSharing(this, false));
|
|
125
|
-
_classPrivateFieldInitSpec(this, _C, _init__shareStreamId(this, ''));
|
|
126
|
-
_classPrivateFieldInitSpec(this, _D, _init__sharingUser(this, null));
|
|
127
|
-
this._objectManager = _objectManager;
|
|
128
|
-
var currentRoomProvider = this._objectManager.getObject(_objectManager2.FcrUIObjectKeys.P_CURRENT_ROOM_CONTROL_PROVIDER);
|
|
129
|
-
var engine = this._objectManager.getObject(_objectManager2.FcrUIObjectKeys.CORE_ENGINE);
|
|
130
|
-
this._facilityProvider = this._objectManager.getObject(_objectManager2.FcrUIObjectKeys.P_FACILITY_PROVIDER);
|
|
131
|
-
this._renderer = this._objectManager.getObject(_objectManager2.FcrUIObjectKeys.RENDERER_WRAPPER);
|
|
132
|
-
this._streamControl = currentRoomProvider.currentRoomControl.getStreamControl();
|
|
133
|
-
this._sharingControl = currentRoomProvider.currentRoomControl.getSharingControl();
|
|
134
|
-
this._mediaControl = engine.getDesktopMediaControl();
|
|
135
|
-
|
|
136
|
-
// 根据平台选择策略
|
|
137
|
-
this._strategy = (0, _env.isElectron)() ? new _electron.FcrUIElectronScreenShareStrategy(this._objectManager) : new _browser.FcrUIBrowserScreenShareStrategy(this._objectManager);
|
|
138
|
-
this._screenStreamSync = new _streamStateSync.FcrUIScreenStreamSync(this._objectManager);
|
|
139
|
-
this._strategy.addObserver({
|
|
140
|
-
onScreenCaptureError: function onScreenCaptureError(sourceId, code) {
|
|
141
|
-
if (code === _type.FcrUIScreenShareCaptureError.NO_SCREEN_RECORDING_PERMISSION) {
|
|
142
|
-
_this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.NO_SCREEN_RECORDING_PERMISSION);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
});
|
|
146
|
-
var streamObserver = {
|
|
147
|
-
onStreamsRemoved: function onStreamsRemoved(roomId, events) {
|
|
148
|
-
_this._handleStreamRemove(events);
|
|
149
|
-
}
|
|
150
|
-
};
|
|
151
|
-
this._streamControl.addObserver(streamObserver);
|
|
152
|
-
this._streamObserver = streamObserver;
|
|
153
|
-
this.addObserver((0, _logger.generateLogObserver)(this.logger, ['onScreenShareErrorOccurred', 'onScreenShareStarted', 'onScreenShareStopped']));
|
|
154
|
-
}
|
|
155
|
-
return (0, _createClass2["default"])(FcrUIScreenShareProviderImpl, [{
|
|
156
|
-
key: "_isSharingWithAudio",
|
|
157
|
-
get: function get() {
|
|
158
|
-
return _classPrivateFieldGet(_A, this);
|
|
159
|
-
},
|
|
160
|
-
set: function set(v) {
|
|
161
|
-
_classPrivateFieldSet(_A, this, v);
|
|
162
|
-
}
|
|
163
|
-
}, {
|
|
164
|
-
key: "_isScreenSharing",
|
|
165
|
-
get: function get() {
|
|
166
|
-
return _classPrivateFieldGet(_B, this);
|
|
167
|
-
},
|
|
168
|
-
set: function set(v) {
|
|
169
|
-
_classPrivateFieldSet(_B, this, v);
|
|
170
|
-
}
|
|
171
|
-
}, {
|
|
172
|
-
key: "_shareStreamId",
|
|
173
|
-
get: function get() {
|
|
174
|
-
return _classPrivateFieldGet(_C, this);
|
|
175
|
-
},
|
|
176
|
-
set: function set(v) {
|
|
177
|
-
_classPrivateFieldSet(_C, this, v);
|
|
178
|
-
}
|
|
179
|
-
}, {
|
|
180
|
-
key: "_sharingUser",
|
|
181
|
-
get: function get() {
|
|
182
|
-
return _classPrivateFieldGet(_D, this);
|
|
183
|
-
},
|
|
184
|
-
set: function set(v) {
|
|
185
|
-
_classPrivateFieldSet(_D, this, v);
|
|
186
|
-
}
|
|
187
|
-
}, {
|
|
188
|
-
key: "selectionBounds",
|
|
189
|
-
get: function get() {
|
|
190
|
-
if (this._selectionBounds) {
|
|
191
|
-
return this._selectionBounds;
|
|
192
|
-
}
|
|
193
|
-
throw new Error('cannot get selection bounds while no selection made');
|
|
194
|
-
}
|
|
195
|
-
}, {
|
|
196
|
-
key: "sharingDisplayBounds",
|
|
197
|
-
get: function get() {
|
|
198
|
-
if (this._sharingDisplayBounds) {
|
|
199
|
-
return this._sharingDisplayBounds;
|
|
200
|
-
}
|
|
201
|
-
throw new Error('cannot get sharing display bounds while no one is sharing screen');
|
|
202
|
-
}
|
|
203
|
-
}, {
|
|
204
|
-
key: "isSharingWithAudio",
|
|
205
|
-
get: function get() {
|
|
206
|
-
return this._isSharingWithAudio;
|
|
207
|
-
}
|
|
208
|
-
}, {
|
|
209
|
-
key: "sharingUser",
|
|
210
|
-
get: function get() {
|
|
211
|
-
if (this._sharingUser) {
|
|
212
|
-
return this._sharingUser;
|
|
213
|
-
}
|
|
214
|
-
throw new Error('no user is sharing screen currently');
|
|
215
|
-
}
|
|
216
|
-
}, {
|
|
217
|
-
key: "shareStreamId",
|
|
218
|
-
get: function get() {
|
|
219
|
-
if (this._shareStreamId) {
|
|
220
|
-
return this._shareStreamId;
|
|
221
|
-
}
|
|
222
|
-
throw new Error('no screen stream exists currently');
|
|
223
|
-
}
|
|
224
|
-
}, {
|
|
225
|
-
key: "isScreenSharing",
|
|
226
|
-
get: function get() {
|
|
227
|
-
return this._isScreenSharing;
|
|
228
|
-
}
|
|
229
|
-
}, {
|
|
230
|
-
key: "addObserver",
|
|
231
|
-
value: function addObserver(observer) {
|
|
232
|
-
this._observable.addObserver(observer);
|
|
233
|
-
}
|
|
234
|
-
}, {
|
|
235
|
-
key: "removeObserver",
|
|
236
|
-
value: function removeObserver(observer) {
|
|
237
|
-
this._observable.removeObserver(observer);
|
|
238
|
-
}
|
|
239
|
-
}, {
|
|
240
|
-
key: "startShare",
|
|
241
|
-
value: function () {
|
|
242
|
-
var _startShare = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(_ref) {
|
|
243
|
-
var videoSourceId, _ref$captureType, captureType, _ref$excludeWindows, excludeWindows, createConfig, screenTrack, isScreenRecordingGranted, isScreenSharingPermitted, _t, _t2;
|
|
244
|
-
return _regenerator["default"].wrap(function (_context) {
|
|
245
|
-
while (1) switch (_context.prev = _context.next) {
|
|
246
|
-
case 0:
|
|
247
|
-
videoSourceId = _ref.videoSourceId, _ref$captureType = _ref.captureType, captureType = _ref$captureType === void 0 ? _type2.FcrScreenCaptureType.SCREEN : _ref$captureType, _ref$excludeWindows = _ref.excludeWindows, excludeWindows = _ref$excludeWindows === void 0 ? [] : _ref$excludeWindows;
|
|
248
|
-
createConfig = {
|
|
249
|
-
streamType: _fcrCore.FcrStreamType.BOTH,
|
|
250
|
-
videoSourceId: videoSourceId
|
|
251
|
-
};
|
|
252
|
-
screenTrack = this._strategy.getScreenTrack(); // check if there's a screen track exists
|
|
253
|
-
if (!screenTrack) {
|
|
254
|
-
_context.next = 1;
|
|
255
|
-
break;
|
|
256
|
-
}
|
|
257
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CONFLICT);
|
|
258
|
-
return _context.abrupt("return", Promise.reject('cannot start screen share twice: screen track already exists'));
|
|
259
|
-
case 1:
|
|
260
|
-
if (!this._screenStreamSync.checkIfMyScreenShareStreamExists()) {
|
|
261
|
-
_context.next = 2;
|
|
262
|
-
break;
|
|
263
|
-
}
|
|
264
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CONFLICT);
|
|
265
|
-
return _context.abrupt("return", Promise.reject('cannot start screen share twice: my screen stream already exists'));
|
|
266
|
-
case 2:
|
|
267
|
-
_context.next = 3;
|
|
268
|
-
return this._facilityProvider.hasScreenCapturePermission();
|
|
269
|
-
case 3:
|
|
270
|
-
isScreenRecordingGranted = _context.sent;
|
|
271
|
-
if (isScreenRecordingGranted) {
|
|
272
|
-
_context.next = 4;
|
|
273
|
-
break;
|
|
274
|
-
}
|
|
275
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.NO_SCREEN_RECORDING_PERMISSION);
|
|
276
|
-
return _context.abrupt("return", Promise.reject('no screen recording permission'));
|
|
277
|
-
case 4:
|
|
278
|
-
// check if screen sharing is permitted
|
|
279
|
-
isScreenSharingPermitted = true;
|
|
280
|
-
if (isScreenSharingPermitted) {
|
|
281
|
-
_context.next = 5;
|
|
282
|
-
break;
|
|
283
|
-
}
|
|
284
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.NO_PUBLISH_PRIVILIGE);
|
|
285
|
-
return _context.abrupt("return", Promise.reject('no screen sharing permission'));
|
|
286
|
-
case 5:
|
|
287
|
-
_context.prev = 5;
|
|
288
|
-
_context.next = 6;
|
|
289
|
-
return this._screenStreamSync.startScreenStream(createConfig, {
|
|
290
|
-
width: 0,
|
|
291
|
-
height: 0
|
|
292
|
-
});
|
|
293
|
-
case 6:
|
|
294
|
-
_context.next = 8;
|
|
295
|
-
break;
|
|
296
|
-
case 7:
|
|
297
|
-
_context.prev = 7;
|
|
298
|
-
_t = _context["catch"](5);
|
|
299
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CANNOT_CREATE_STREAM);
|
|
300
|
-
return _context.abrupt("return", Promise.reject("cannot create screen stream, error: ".concat(_t)));
|
|
301
|
-
case 8:
|
|
302
|
-
_context.prev = 8;
|
|
303
|
-
_context.next = 9;
|
|
304
|
-
return this._strategy.startScreenCapture({
|
|
305
|
-
sourceId: videoSourceId,
|
|
306
|
-
captureType: captureType,
|
|
307
|
-
excludeWindows: excludeWindows
|
|
308
|
-
});
|
|
309
|
-
case 9:
|
|
310
|
-
_context.next = 11;
|
|
311
|
-
break;
|
|
312
|
-
case 10:
|
|
313
|
-
_context.prev = 10;
|
|
314
|
-
_t2 = _context["catch"](8);
|
|
315
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CANNOT_START_SCREEN_CAPTURE);
|
|
316
|
-
return _context.abrupt("return", Promise.reject("cannot start screen capture, error: ".concat(_t2)));
|
|
317
|
-
case 11:
|
|
318
|
-
if (!this._isSharingWithAudio) {
|
|
319
|
-
_context.next = 12;
|
|
320
|
-
break;
|
|
321
|
-
}
|
|
322
|
-
_context.next = 12;
|
|
323
|
-
return this._strategy.startLoopbackCapture({});
|
|
324
|
-
case 12:
|
|
325
|
-
this._isScreenShareStarted = true;
|
|
326
|
-
this._sharingDisplayBounds = this._findSharingDisplayBounds();
|
|
327
|
-
this._observable.notifyObservers('onScreenShareStarted');
|
|
328
|
-
case 13:
|
|
329
|
-
case "end":
|
|
330
|
-
return _context.stop();
|
|
331
|
-
}
|
|
332
|
-
}, _callee, this, [[5, 7], [8, 10]]);
|
|
333
|
-
}));
|
|
334
|
-
function startShare(_x) {
|
|
335
|
-
return _startShare.apply(this, arguments);
|
|
336
|
-
}
|
|
337
|
-
return startShare;
|
|
338
|
-
}()
|
|
339
|
-
}, {
|
|
340
|
-
key: "stopShare",
|
|
341
|
-
value: function () {
|
|
342
|
-
var _stopShare = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
343
|
-
return _regenerator["default"].wrap(function (_context2) {
|
|
344
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
345
|
-
case 0:
|
|
346
|
-
_context2.next = 1;
|
|
347
|
-
return this._strategy.stopScreenCapture();
|
|
348
|
-
case 1:
|
|
349
|
-
_context2.next = 2;
|
|
350
|
-
return this._strategy.stopLoopbackCapture();
|
|
351
|
-
case 2:
|
|
352
|
-
this._observable.notifyObservers('onScreenShareStopped', _struct.FcrUIScreenShareStopReason.NORMAL_STOP);
|
|
353
|
-
|
|
354
|
-
// remove screen stream
|
|
355
|
-
_context2.next = 3;
|
|
356
|
-
return this._sharingControl.stop();
|
|
357
|
-
case 3:
|
|
358
|
-
this._isScreenShareStarted = false;
|
|
359
|
-
case 4:
|
|
360
|
-
case "end":
|
|
361
|
-
return _context2.stop();
|
|
362
|
-
}
|
|
363
|
-
}, _callee2, this);
|
|
364
|
-
}));
|
|
365
|
-
function stopShare() {
|
|
366
|
-
return _stopShare.apply(this, arguments);
|
|
367
|
-
}
|
|
368
|
-
return stopShare;
|
|
369
|
-
}()
|
|
370
|
-
}, {
|
|
371
|
-
key: "replaceShare",
|
|
372
|
-
value: function () {
|
|
373
|
-
var _replaceShare = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3(_ref2) {
|
|
374
|
-
var videoSourceId, captureType, excludeWindows, _t3;
|
|
375
|
-
return _regenerator["default"].wrap(function (_context3) {
|
|
376
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
377
|
-
case 0:
|
|
378
|
-
videoSourceId = _ref2.videoSourceId, captureType = _ref2.captureType, excludeWindows = _ref2.excludeWindows;
|
|
379
|
-
_context3.next = 1;
|
|
380
|
-
return this._strategy.stopScreenCapture();
|
|
381
|
-
case 1:
|
|
382
|
-
_context3.next = 2;
|
|
383
|
-
return this._strategy.stopLoopbackCapture();
|
|
384
|
-
case 2:
|
|
385
|
-
_context3.prev = 2;
|
|
386
|
-
_context3.next = 3;
|
|
387
|
-
return this._screenStreamSync.updateStream({
|
|
388
|
-
videoSourceId: videoSourceId
|
|
389
|
-
});
|
|
390
|
-
case 3:
|
|
391
|
-
_context3.next = 5;
|
|
392
|
-
break;
|
|
393
|
-
case 4:
|
|
394
|
-
_context3.prev = 4;
|
|
395
|
-
_t3 = _context3["catch"](2);
|
|
396
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CANNOT_UPDATE_STREAM);
|
|
397
|
-
return _context3.abrupt("return", Promise.reject("cannot update screen stream, error: ".concat(_t3)));
|
|
398
|
-
case 5:
|
|
399
|
-
_context3.next = 6;
|
|
400
|
-
return this._strategy.startScreenCapture({
|
|
401
|
-
sourceId: videoSourceId,
|
|
402
|
-
captureType: captureType,
|
|
403
|
-
excludeWindows: excludeWindows
|
|
404
|
-
});
|
|
405
|
-
case 6:
|
|
406
|
-
if (!this._isSharingWithAudio) {
|
|
407
|
-
_context3.next = 7;
|
|
408
|
-
break;
|
|
409
|
-
}
|
|
410
|
-
_context3.next = 7;
|
|
411
|
-
return this._strategy.startLoopbackCapture({});
|
|
412
|
-
case 7:
|
|
413
|
-
case "end":
|
|
414
|
-
return _context3.stop();
|
|
415
|
-
}
|
|
416
|
-
}, _callee3, this, [[2, 4]]);
|
|
417
|
-
}));
|
|
418
|
-
function replaceShare(_x2) {
|
|
419
|
-
return _replaceShare.apply(this, arguments);
|
|
420
|
-
}
|
|
421
|
-
return replaceShare;
|
|
422
|
-
}()
|
|
423
|
-
}, {
|
|
424
|
-
key: "setSelectionBounds",
|
|
425
|
-
value: function setSelectionBounds(bounds) {
|
|
426
|
-
this._selectionBounds = bounds;
|
|
427
|
-
}
|
|
428
|
-
}, {
|
|
429
|
-
key: "enableScreenShareAudio",
|
|
430
|
-
value: function () {
|
|
431
|
-
var _enableScreenShareAudio = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
432
|
-
var isScreenStreamCreated, _t4;
|
|
433
|
-
return _regenerator["default"].wrap(function (_context4) {
|
|
434
|
-
while (1) switch (_context4.prev = _context4.next) {
|
|
435
|
-
case 0:
|
|
436
|
-
this._isSharingWithAudio = true;
|
|
437
|
-
// check if screen share is started
|
|
438
|
-
isScreenStreamCreated = this._screenStreamSync.isLocalScreenStreamCreated();
|
|
439
|
-
if (isScreenStreamCreated) {
|
|
440
|
-
_context4.next = 1;
|
|
441
|
-
break;
|
|
442
|
-
}
|
|
443
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CANNOT_START_LOOPBACK_CAPTURE);
|
|
444
|
-
return _context4.abrupt("return", Promise.reject('cannot start screen share audio: no screen stream created'));
|
|
445
|
-
case 1:
|
|
446
|
-
_context4.prev = 1;
|
|
447
|
-
_context4.next = 2;
|
|
448
|
-
return this._screenStreamSync.updateStream({
|
|
449
|
-
audioPublishPrivilege: _fcrCore.FcrStreamPrivilegeOperation.HAS_PRIVILEGE
|
|
450
|
-
});
|
|
451
|
-
case 2:
|
|
452
|
-
_context4.next = 3;
|
|
453
|
-
return this._strategy.startLoopbackCapture({});
|
|
454
|
-
case 3:
|
|
455
|
-
_context4.next = 5;
|
|
456
|
-
break;
|
|
457
|
-
case 4:
|
|
458
|
-
_context4.prev = 4;
|
|
459
|
-
_t4 = _context4["catch"](1);
|
|
460
|
-
this.logger.warn('failed to start screen share audio', _t4);
|
|
461
|
-
this._observable.notifyObservers('onScreenShareErrorOccurred', _struct.FcrUIScreenShareErrorCode.CANNOT_START_LOOPBACK_CAPTURE);
|
|
462
|
-
return _context4.abrupt("return", Promise.reject("cannot start screen share audio, error: ".concat(_t4)));
|
|
463
|
-
case 5:
|
|
464
|
-
case "end":
|
|
465
|
-
return _context4.stop();
|
|
466
|
-
}
|
|
467
|
-
}, _callee4, this, [[1, 4]]);
|
|
468
|
-
}));
|
|
469
|
-
function enableScreenShareAudio() {
|
|
470
|
-
return _enableScreenShareAudio.apply(this, arguments);
|
|
471
|
-
}
|
|
472
|
-
return enableScreenShareAudio;
|
|
473
|
-
}()
|
|
474
|
-
}, {
|
|
475
|
-
key: "disableScreenShareAudio",
|
|
476
|
-
value: function () {
|
|
477
|
-
var _disableScreenShareAudio = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee5() {
|
|
478
|
-
var isScreenStreamCreated, _t5;
|
|
479
|
-
return _regenerator["default"].wrap(function (_context5) {
|
|
480
|
-
while (1) switch (_context5.prev = _context5.next) {
|
|
481
|
-
case 0:
|
|
482
|
-
this._isSharingWithAudio = false;
|
|
483
|
-
_context5.prev = 1;
|
|
484
|
-
_context5.next = 2;
|
|
485
|
-
return this._strategy.stopLoopbackCapture();
|
|
486
|
-
case 2:
|
|
487
|
-
isScreenStreamCreated = this._screenStreamSync.isLocalScreenStreamCreated();
|
|
488
|
-
if (!isScreenStreamCreated) {
|
|
489
|
-
_context5.next = 3;
|
|
490
|
-
break;
|
|
491
|
-
}
|
|
492
|
-
_context5.next = 3;
|
|
493
|
-
return this._screenStreamSync.updateStream({
|
|
494
|
-
audioPublishPrivilege: _fcrCore.FcrStreamPrivilegeOperation.NOPRIVILEGE
|
|
495
|
-
});
|
|
496
|
-
case 3:
|
|
497
|
-
_context5.next = 5;
|
|
498
|
-
break;
|
|
499
|
-
case 4:
|
|
500
|
-
_context5.prev = 4;
|
|
501
|
-
_t5 = _context5["catch"](1);
|
|
502
|
-
this.logger.warn('failed to update stream when stopping share audio', _t5);
|
|
503
|
-
case 5:
|
|
504
|
-
case "end":
|
|
505
|
-
return _context5.stop();
|
|
506
|
-
}
|
|
507
|
-
}, _callee5, this, [[1, 4]]);
|
|
508
|
-
}));
|
|
509
|
-
function disableScreenShareAudio() {
|
|
510
|
-
return _disableScreenShareAudio.apply(this, arguments);
|
|
511
|
-
}
|
|
512
|
-
return disableScreenShareAudio;
|
|
513
|
-
}()
|
|
514
|
-
}, {
|
|
515
|
-
key: "getDisplayList",
|
|
516
|
-
value: function () {
|
|
517
|
-
var _getDisplayList = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee6() {
|
|
518
|
-
return _regenerator["default"].wrap(function (_context6) {
|
|
519
|
-
while (1) switch (_context6.prev = _context6.next) {
|
|
520
|
-
case 0:
|
|
521
|
-
_context6.next = 1;
|
|
522
|
-
return this._mediaControl.getDisplayList();
|
|
523
|
-
case 1:
|
|
524
|
-
this._displayList = _context6.sent.map(function (item) {
|
|
525
|
-
return {
|
|
526
|
-
id: item.id,
|
|
527
|
-
title: item.title,
|
|
528
|
-
image: item.image,
|
|
529
|
-
imageWidth: item.imageWidth,
|
|
530
|
-
imageHeight: item.imageHeight,
|
|
531
|
-
bounds: item.bounds
|
|
532
|
-
};
|
|
533
|
-
});
|
|
534
|
-
return _context6.abrupt("return", this._displayList);
|
|
535
|
-
case 2:
|
|
536
|
-
case "end":
|
|
537
|
-
return _context6.stop();
|
|
538
|
-
}
|
|
539
|
-
}, _callee6, this);
|
|
540
|
-
}));
|
|
541
|
-
function getDisplayList() {
|
|
542
|
-
return _getDisplayList.apply(this, arguments);
|
|
543
|
-
}
|
|
544
|
-
return getDisplayList;
|
|
545
|
-
}()
|
|
546
|
-
}, {
|
|
547
|
-
key: "getWindowList",
|
|
548
|
-
value: function () {
|
|
549
|
-
var _getWindowList = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee7() {
|
|
550
|
-
return _regenerator["default"].wrap(function (_context7) {
|
|
551
|
-
while (1) switch (_context7.prev = _context7.next) {
|
|
552
|
-
case 0:
|
|
553
|
-
_context7.next = 1;
|
|
554
|
-
return this._mediaControl.getWindowList();
|
|
555
|
-
case 1:
|
|
556
|
-
this._windowList = _context7.sent.map(function (item) {
|
|
557
|
-
return {
|
|
558
|
-
id: item.id,
|
|
559
|
-
title: item.title,
|
|
560
|
-
image: item.image,
|
|
561
|
-
imageWidth: item.imageWidth,
|
|
562
|
-
imageHeight: item.imageHeight,
|
|
563
|
-
bounds: item.bounds
|
|
564
|
-
};
|
|
565
|
-
});
|
|
566
|
-
return _context7.abrupt("return", this._windowList);
|
|
567
|
-
case 2:
|
|
568
|
-
case "end":
|
|
569
|
-
return _context7.stop();
|
|
570
|
-
}
|
|
571
|
-
}, _callee7, this);
|
|
572
|
-
}));
|
|
573
|
-
function getWindowList() {
|
|
574
|
-
return _getWindowList.apply(this, arguments);
|
|
575
|
-
}
|
|
576
|
-
return getWindowList;
|
|
577
|
-
}()
|
|
578
|
-
}, {
|
|
579
|
-
key: "release",
|
|
580
|
-
value: function release() {
|
|
581
|
-
this._strategy.stopLoopbackCapture();
|
|
582
|
-
this._strategy.stopScreenCapture();
|
|
583
|
-
this._windowList = [];
|
|
584
|
-
this._displayList = [];
|
|
585
|
-
this._streamControl.removeObserver(this._streamObserver);
|
|
586
|
-
}
|
|
587
|
-
}, {
|
|
588
|
-
key: "_handleStreamRemove",
|
|
589
|
-
value: function _handleStreamRemove(events) {
|
|
590
|
-
var isMyScreenStreamBeingRemoved = true;
|
|
591
|
-
var isStoppedByOther = true;
|
|
592
|
-
if (isMyScreenStreamBeingRemoved && isStoppedByOther && this._isScreenShareStarted) {
|
|
593
|
-
this._isScreenShareStarted = false;
|
|
594
|
-
this._observable.notifyObservers('onScreenShareStopped', _struct.FcrUIScreenShareStopReason.STOPPED_BY_OTHER);
|
|
595
|
-
}
|
|
596
|
-
}
|
|
597
|
-
}, {
|
|
598
|
-
key: "_findSharingDisplayBounds",
|
|
599
|
-
value: function _findSharingDisplayBounds() {
|
|
600
|
-
var selectionBounds = this.selectionBounds;
|
|
601
|
-
var display = this._renderer.getDisplayNearestPoint(selectionBounds);
|
|
602
|
-
this.logger.info('found sharing display bounds:', display.bounds);
|
|
603
|
-
return display.bounds;
|
|
604
|
-
}
|
|
605
|
-
}]);
|
|
606
|
-
}();
|
|
607
|
-
_FcrUIScreenShareProviderImpl = FcrUIScreenShareProviderImpl;
|
|
608
|
-
var _applyDecs$e = _applyDecs(_FcrUIScreenShareProviderImpl, [[_mobx.observable, 1, "_isSharingWithAudio"], [_mobx.observable, 1, "_isScreenSharing"], [_mobx.observable, 1, "_shareStreamId"], [_mobx.observable, 1, "_sharingUser"], [_decorator.trace, 2, "startShare"], [_decorator.trace, 2, "stopShare"], [_decorator.trace, 2, "replaceShare"], [_decorator.trace, 2, "setSelectionBounds"], [_decorator.trace, 2, "enableScreenShareAudio"], [_decorator.trace, 2, "disableScreenShareAudio"], [_decorator.trace, 2, "getDisplayList"], [_decorator.trace, 2, "getWindowList"], [_decorator.trace, 2, "release"]], []).e;
|
|
609
|
-
var _applyDecs$e2 = (0, _slicedToArray2["default"])(_applyDecs$e, 5);
|
|
610
|
-
_init__isSharingWithAudio = _applyDecs$e2[0];
|
|
611
|
-
_init__isScreenSharing = _applyDecs$e2[1];
|
|
612
|
-
_init__shareStreamId = _applyDecs$e2[2];
|
|
613
|
-
_init__sharingUser = _applyDecs$e2[3];
|
|
614
|
-
_initProto = _applyDecs$e2[4];
|
|
615
|
-
_applyDecs$e;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
File without changes
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
File without changes
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
File without changes
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|