@netless/window-manager 0.3.10-canary.0 → 0.3.12-canary.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/dist/AppManager.d.ts +2 -2
- package/dist/BoxManager.d.ts +9 -5
- package/dist/index.d.ts +7 -1
- package/dist/index.es.js +1 -1
- package/dist/index.es.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/dist/style.css +1 -1
- package/package.json +3 -3
- package/src/AppManager.ts +2 -2
- package/src/BoxManager.ts +41 -16
- package/src/Utils/RoomHacker.ts +3 -0
- package/src/index.ts +24 -2
- package/src/style.css +1 -0
package/dist/style.css
CHANGED
@@ -1 +1 @@
|
|
1
|
-
.netless-window-manager-playground{width:100%;height:100%;position:relative;z-index:1;overflow:hidden}.netless-window-manager-sizer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden;display:flex}.netless-window-manager-sizer-horizontal{flex-direction:column}.netless-window-manager-sizer:before,.netless-window-manager-sizer:after{flex:1;content:"";display:block}.netless-window-manager-chess-sizer:before,.netless-window-manager-chess-sizer:after{background-image:linear-gradient(45deg,#b0b0b0 25%,transparent 25%),linear-gradient(-45deg,#b0b0b0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#b0b0b0 75%),linear-gradient(-45deg,transparent 75%,#b0b0b0 75%);background-color:#fff;background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.netless-window-manager-wrapper{position:relative;z-index:1;width:100%;height:100%;overflow:hidden}.netless-window-manager-main-view{width:100%;height:100%}.netless-window-manager-cursor-pencil-image{width:26px;height:26px}.netless-window-manager-cursor-eraser-image{width:26px;height:26px}.netless-window-manager-cursor-selector-image{width:24px;height:24px}.netless-window-manager-cursor-selector-avatar{border-radius:50%;border-style:solid;border-width:2px;border-color:#fff;margin-bottom:2px}.netless-window-manager-cursor-selector-avatar img{width:12px}.netless-window-manager-cursor-inner{border-radius:4px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:4px;padding-right:4px;font-size:12px}.netless-window-manager-cursor-inner-mellow{height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:16px;padding-right:16px}.netless-window-manager-cursor-tag-name{font-size:12px;margin-left:4px;padding:2px 8px;border-radius:4px}.netless-window-manager-cursor-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .05s;transform-origin:0 0;user-select:none}.netless-window-manager-cursor-pencil-offset{margin-left:-20px}.netless-window-manager-cursor-selector-offset{margin-left:-22px;margin-top:56px}.netless-window-manager-cursor-text-offset{margin-left:-30px;margin-top:18px}.netless-window-manager-cursor-shape-offset{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;width:180px;height:64px;margin-left:-30px;margin-top:12px}.netless-window-manager-cursor-name{width:100%;height:48px;display:flex;align-items:center;justify-content:center;position:absolute;top:-40px}.cursor-image-wrapper{display:flex;justify-content:center}.tele-fancy-scrollbar{overscroll-behavior:contain;overflow:auto;overflow-y:scroll;overflow-y:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.tele-fancy-scrollbar::-webkit-scrollbar{height:8px;width:8px}.tele-fancy-scrollbar::-webkit-scrollbar-track{background-color:transparent}.tele-fancy-scrollbar::-webkit-scrollbar-thumb{background-color:#444e601a;background-color:transparent;border-radius:4px;transition:background-color .4s}.tele-fancy-scrollbar:hover::-webkit-scrollbar-thumb{background-color:#444e601a}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:active{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:vertical{min-height:50px}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-box{position:absolute;top:0;left:0;z-index:100;will-change:transform;transition:width .4s cubic-bezier(.4,.9,.71,1.02),height .4s cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .4s ease}.telebox-box-main{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:#f9f9fc;box-shadow:0 4px 10px #2f419226;border-radius:6px;border:1px solid #e3e3ec}.telebox-titlebar-wrap{flex-shrink:0;position:relative;z-index:1}.telebox-content-wrap{flex:1;width:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.telebox-content{width:100%;height:100%;position:relative}.telebox-footer-wrap{flex-shrink:0;display:flex;flex-direction:column}.telebox-footer-wrap:before{content:"";display:block;flex:1}.telebox-resize-handle{position:absolute;z-index:2147483647}.telebox-n{width:100%;height:5px;left:0;top:-5px;cursor:n-resize}.telebox-s{width:100%;height:5px;left:0;bottom:-5px;cursor:s-resize}.telebox-w{width:5px;height:100%;left:-5px;top:0;cursor:w-resize}.telebox-e{width:5px;height:100%;right:-5px;top:0;cursor:e-resize}.telebox-nw{width:15px;height:15px;top:-5px;left:-5px;cursor:nw-resize}.telebox-ne{width:15px;height:15px;top:-5px;right:-5px;cursor:ne-resize}.telebox-se{width:15px;height:15px;bottom:-5px;right:-5px;cursor:se-resize}.telebox-sw{width:15px;height:15px;bottom:-5px;left:-5px;cursor:sw-resize}.telebox-track-mask{position:fixed;top:0;left:0;z-index:2147483647;width:100%;height:100%;background:rgba(0,0,0,.0001);cursor:move}.telebox-cursor-n{cursor:n-resize}.telebox-cursor-s{cursor:s-resize}.telebox-cursor-w{cursor:w-resize}.telebox-cursor-e{cursor:e-resize}.telebox-cursor-nw{cursor:nw-resize}.telebox-cursor-ne{cursor:ne-resize}.telebox-cursor-se{cursor:se-resize}.telebox-cursor-sw{cursor:sw-resize}.telebox-maximized .telebox-resize-handles,.telebox-no-resize .telebox-resize-handles{display:none}.telebox-maximized{box-shadow:none;transition:none}.telebox-minimized{will-change:transform;transition:width 50ms cubic-bezier(.4,.9,.71,1.02),height 50ms cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .6s ease;opacity:0;pointer-events:none;user-select:none}.telebox-transforming{will-change:transform;transition:opacity .6s cubic-bezier(.7,0,.84,0)}.telebox-readonly .telebox-resize-handle{cursor:initial!important;pointer-events:none!important}.telebox-titlebar{box-sizing:border-box;height:26px;display:flex;align-items:center;padding:0 16px;background:#fff;user-select:none;border-bottom:1px solid #eeeef7}.telebox-title{overflow:hidden;margin:0 24px 0 0;padding:0;font-size:14px;font-weight:400;font-family:PingFangSC-Regular,PingFang SC;white-space:nowrap;word-break:keep-all;text-overflow:ellipsis;color:#191919}.telebox-titlebar-btns{white-space:nowrap;word-break:keep-all;margin-left:auto;font-size:0}.telebox-titlebar-btn{width:22px;height:22px;padding:0;outline:0;border:none;background:0 0;cursor:pointer}.telebox-titlebar-btn~.telebox-titlebar-btn{margin-left:10px}.telebox-titlebar-btn-icon{width:22px;height:22px}.telebox-readonly .telebox-titlebar-btn{cursor:not-allowed}.telebox-titlebar-icon-minimize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize.is-active{background-image:url()}.telebox-titlebar-icon-close{background:center/cover no-repeat url()}.telebox-collector{visibility:hidden;display:block;position:absolute;z-index:200;width:40px;height:40px;margin:0;padding:0;border:none;outline:0;font-size:0;border-radius:50%;background:#fff;box-shadow:0 2px 6px #2f419226;cursor:pointer;user-select:none;pointer-events:none}.telebox-collector-icon{width:18px;height:16px}.telebox-collector-visible{visibility:visible;pointer-events:initial}.telebox-collector-readonly{cursor:not-allowed}.telebox-max-titlebar{display:none;position:absolute;top:0;left:0;z-index:50000;user-select:none}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{flex:1;height:100%;margin:0 16px 0 -16px;overflow-y:hidden;overflow-x:scroll;overflow-x:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.telebox-titles::-webkit-scrollbar{height:8px;width:8px}.telebox-titles::-webkit-scrollbar-track{background-color:transparent}.telebox-titles::-webkit-scrollbar-thumb{background-color:#eeeef7cc;background-color:transparent;border-radius:4px;transition:background-color .4s}.telebox-titles:hover::-webkit-scrollbar-thumb{background-color:#eeeef7cc}.telebox-titles::-webkit-scrollbar-thumb:hover{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:active{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:vertical{min-height:50px}.telebox-titles::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-titles-content{height:100%;display:flex;flex-wrap:nowrap;align-items:center;padding:0}.telebox-titles-tab{overflow:hidden;max-width:182px;min-width:50px;padding:0 26px 0 16px;outline:0;font-size:13px;font-family:PingFangSC-Regular,PingFang SC;font-weight:400;text-overflow:ellipsis;white-space:nowrap;word-break:keep-all;border:none;border-right:1px solid #e5e5f0;color:#7b88a0;background:0 0;cursor:pointer}.telebox-titles-tab~.telebox-titles-tab{margin-left:2px}.telebox-titles-tab-focus{color:#357bf6}.telebox-readonly .telebox-titles-tab{cursor:not-allowed}
|
1
|
+
.netless-window-manager-playground{width:100%;height:100%;position:relative;z-index:1;overflow:hidden;user-select:none}.netless-window-manager-sizer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden;display:flex}.netless-window-manager-sizer-horizontal{flex-direction:column}.netless-window-manager-sizer:before,.netless-window-manager-sizer:after{flex:1;content:"";display:block}.netless-window-manager-chess-sizer:before,.netless-window-manager-chess-sizer:after{background-image:linear-gradient(45deg,#b0b0b0 25%,transparent 25%),linear-gradient(-45deg,#b0b0b0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#b0b0b0 75%),linear-gradient(-45deg,transparent 75%,#b0b0b0 75%);background-color:#fff;background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px}.netless-window-manager-wrapper{position:relative;z-index:1;width:100%;height:100%;overflow:hidden}.netless-window-manager-main-view{width:100%;height:100%}.netless-window-manager-cursor-pencil-image{width:26px;height:26px}.netless-window-manager-cursor-eraser-image{width:26px;height:26px}.netless-window-manager-cursor-selector-image{width:24px;height:24px}.netless-window-manager-cursor-selector-avatar{border-radius:50%;border-style:solid;border-width:2px;border-color:#fff;margin-bottom:2px}.netless-window-manager-cursor-selector-avatar img{width:12px}.netless-window-manager-cursor-inner{border-radius:4px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:4px;padding-right:4px;font-size:12px}.netless-window-manager-cursor-inner-mellow{height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-direction:row;padding-left:16px;padding-right:16px}.netless-window-manager-cursor-tag-name{font-size:12px;margin-left:4px;padding:2px 8px;border-radius:4px}.netless-window-manager-cursor-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .05s;transform-origin:0 0;user-select:none}.netless-window-manager-cursor-pencil-offset{margin-left:-20px}.netless-window-manager-cursor-selector-offset{margin-left:-22px;margin-top:56px}.netless-window-manager-cursor-text-offset{margin-left:-30px;margin-top:18px}.netless-window-manager-cursor-shape-offset{display:flex;flex-direction:column;align-items:center;justify-content:center;position:absolute;width:180px;height:64px;margin-left:-30px;margin-top:12px}.netless-window-manager-cursor-name{width:100%;height:48px;display:flex;align-items:center;justify-content:center;position:absolute;top:-40px}.cursor-image-wrapper{display:flex;justify-content:center}.tele-fancy-scrollbar{overscroll-behavior:contain;overflow:auto;overflow-y:scroll;overflow-y:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.tele-fancy-scrollbar::-webkit-scrollbar{height:8px;width:8px}.tele-fancy-scrollbar::-webkit-scrollbar-track{background-color:transparent}.tele-fancy-scrollbar::-webkit-scrollbar-thumb{background-color:#444e601a;background-color:transparent;border-radius:4px;transition:background-color .4s}.tele-fancy-scrollbar:hover::-webkit-scrollbar-thumb{background-color:#444e601a}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:active{background-color:#444e6033}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:vertical{min-height:50px}.tele-fancy-scrollbar::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-box{position:absolute;top:0;left:0;z-index:100;will-change:transform;transition:width .4s cubic-bezier(.4,.9,.71,1.02),height .4s cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .4s ease}.telebox-box-main{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:#f9f9fc;box-shadow:0 4px 10px #2f419226;border-radius:6px;border:1px solid #e3e3ec}.telebox-titlebar-wrap{flex-shrink:0;position:relative;z-index:1}.telebox-content-wrap{flex:1;width:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.telebox-content{width:100%;height:100%;position:relative}.telebox-footer-wrap{flex-shrink:0;display:flex;flex-direction:column}.telebox-footer-wrap:before{content:"";display:block;flex:1}.telebox-resize-handle{position:absolute;z-index:2147483647}.telebox-n{width:100%;height:5px;left:0;top:-5px;cursor:n-resize}.telebox-s{width:100%;height:5px;left:0;bottom:-5px;cursor:s-resize}.telebox-w{width:5px;height:100%;left:-5px;top:0;cursor:w-resize}.telebox-e{width:5px;height:100%;right:-5px;top:0;cursor:e-resize}.telebox-nw{width:15px;height:15px;top:-5px;left:-5px;cursor:nw-resize}.telebox-ne{width:15px;height:15px;top:-5px;right:-5px;cursor:ne-resize}.telebox-se{width:15px;height:15px;bottom:-5px;right:-5px;cursor:se-resize}.telebox-sw{width:15px;height:15px;bottom:-5px;left:-5px;cursor:sw-resize}.telebox-track-mask{position:fixed;top:0;left:0;z-index:2147483647;width:100%;height:100%;background:rgba(0,0,0,.0001);cursor:move}.telebox-cursor-n{cursor:n-resize}.telebox-cursor-s{cursor:s-resize}.telebox-cursor-w{cursor:w-resize}.telebox-cursor-e{cursor:e-resize}.telebox-cursor-nw{cursor:nw-resize}.telebox-cursor-ne{cursor:ne-resize}.telebox-cursor-se{cursor:se-resize}.telebox-cursor-sw{cursor:sw-resize}.telebox-maximized .telebox-resize-handles,.telebox-no-resize .telebox-resize-handles{display:none}.telebox-maximized{box-shadow:none;transition:none}.telebox-minimized{will-change:transform;transition:width 50ms cubic-bezier(.4,.9,.71,1.02),height 50ms cubic-bezier(.55,.82,.63,.95),opacity .6s cubic-bezier(.7,0,.84,0),transform .6s ease;opacity:0;pointer-events:none;user-select:none}.telebox-transforming{will-change:transform;transition:opacity .6s cubic-bezier(.7,0,.84,0)}.telebox-readonly .telebox-resize-handle{cursor:initial!important;pointer-events:none!important}.telebox-color-scheme-dark .telebox-box-main{color:#e9e9e9;background:#212126;border-color:#43434d}.telebox-titlebar{box-sizing:border-box;height:26px;display:flex;align-items:center;padding:0 16px;background:#fff;user-select:none;border-bottom:1px solid #eeeef7}.telebox-title{overflow:hidden;margin:0 24px 0 0;padding:0;font-size:14px;font-weight:400;font-family:PingFangSC-Regular,PingFang SC;white-space:nowrap;word-break:keep-all;text-overflow:ellipsis;color:#191919}.telebox-titlebar-btns{white-space:nowrap;word-break:keep-all;margin-left:auto;font-size:0}.telebox-titlebar-btn{width:22px;height:22px;padding:0;outline:0;border:none;background:0 0;cursor:pointer}.telebox-titlebar-btn~.telebox-titlebar-btn{margin-left:10px}.telebox-titlebar-btn-icon{width:22px;height:22px}.telebox-readonly .telebox-titlebar-btn{cursor:not-allowed}.telebox-titlebar-icon-minimize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize{background:center/cover no-repeat url()}.telebox-titlebar-icon-maximize.is-active{background-image:url()}.telebox-titlebar-icon-close{background:center/cover no-repeat url()}.telebox-color-scheme-dark .telebox-titlebar{color:#e9e9e9;background:#43434d;border-bottom:none}.telebox-collector{visibility:hidden;display:block;position:absolute;z-index:200;width:40px;height:40px;margin:0;padding:0;border:none;outline:0;font-size:0;border-radius:50%;background:#fff;box-shadow:0 2px 6px #2f419226;cursor:pointer;user-select:none;pointer-events:none;background-repeat:no-repeat;background-size:18px 16px;background-position:center}.telebox-collector-visible{visibility:visible;pointer-events:initial}.telebox-collector-readonly{cursor:not-allowed}.telebox-color-scheme-dark.telebox-collector{background-color:#43434d}.telebox-max-titlebar{display:none;position:absolute;top:0;left:0;z-index:50000;user-select:none}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{flex:1;height:100%;margin:0 16px 0 -16px;overflow-y:hidden;overflow-x:scroll;overflow-x:overlay;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar;scrollbar-width:auto}.telebox-titles::-webkit-scrollbar{height:8px;width:8px}.telebox-titles::-webkit-scrollbar-track{background-color:transparent}.telebox-titles::-webkit-scrollbar-thumb{background-color:#eeeef7cc;background-color:transparent;border-radius:4px;transition:background-color .4s}.telebox-titles:hover::-webkit-scrollbar-thumb{background-color:#eeeef7cc}.telebox-titles::-webkit-scrollbar-thumb:hover{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:active{background-color:#eeeef7}.telebox-titles::-webkit-scrollbar-thumb:vertical{min-height:50px}.telebox-titles::-webkit-scrollbar-thumb:horizontal{min-width:50px}.telebox-titles-content{height:100%;display:flex;flex-wrap:nowrap;align-items:center;padding:0}.telebox-titles-tab{overflow:hidden;max-width:182px;min-width:50px;padding:0 26px 0 16px;outline:0;font-size:13px;font-family:PingFangSC-Regular,PingFang SC;font-weight:400;text-overflow:ellipsis;white-space:nowrap;word-break:keep-all;border:none;border-right:1px solid #e5e5f0;color:#7b88a0;background:0 0;cursor:pointer}.telebox-titles-tab~.telebox-titles-tab{margin-left:2px}.telebox-titles-tab-focus{color:#357bf6}.telebox-readonly .telebox-titles-tab{cursor:not-allowed}.telebox-color-scheme-dark{color-scheme:dark}.telebox-color-scheme-dark.telebox-titlebar{color:#e9e9e9;background:#43434d;border-bottom:none}.telebox-color-scheme-dark .telebox-titles-tab{border-right-color:#7b88a0}.telebox-color-scheme-dark .telebox-title{color:#e9e9e9}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@netless/window-manager",
|
3
|
-
"version": "0.3.
|
3
|
+
"version": "0.3.12-canary.1",
|
4
4
|
"description": "",
|
5
5
|
"main": "dist/index.es.js",
|
6
6
|
"module": "dist/index.es.js",
|
@@ -22,9 +22,9 @@
|
|
22
22
|
},
|
23
23
|
"dependencies": {
|
24
24
|
"@juggle/resize-observer": "^3.3.1",
|
25
|
-
"@netless/app-docs-viewer": "
|
25
|
+
"@netless/app-docs-viewer": "0.1.22",
|
26
26
|
"@netless/app-media-player": "0.1.0-beta.5",
|
27
|
-
"@netless/telebox-insider": "0.2.
|
27
|
+
"@netless/telebox-insider": "0.2.9",
|
28
28
|
"emittery": "^0.9.2",
|
29
29
|
"lodash": "^4.17.21",
|
30
30
|
"p-retry": "^4.6.1",
|
package/src/AppManager.ts
CHANGED
@@ -25,7 +25,7 @@ import { onObjectRemoved, safeListenPropsUpdated } from "./Utils/Reactive";
|
|
25
25
|
import { ReconnectRefresher } from "./ReconnectRefresher";
|
26
26
|
import { ViewManager } from "./ViewManager";
|
27
27
|
import type { Displayer, DisplayerState, Room } from "white-web-sdk";
|
28
|
-
import type {
|
28
|
+
import type { CreateTeleBoxManagerConfig } from "./BoxManager";
|
29
29
|
import type {
|
30
30
|
AddAppParams,
|
31
31
|
BaseInsertParams,
|
@@ -47,7 +47,7 @@ export class AppManager {
|
|
47
47
|
|
48
48
|
private appListeners: AppListeners;
|
49
49
|
|
50
|
-
constructor(public windowManger: WindowManager, options:
|
50
|
+
constructor(public windowManger: WindowManager, options: CreateTeleBoxManagerConfig) {
|
51
51
|
this.displayer = windowManger.displayer;
|
52
52
|
this.cameraStore = new CameraStore();
|
53
53
|
this.mainViewProxy = new MainViewProxy(this);
|
package/src/BoxManager.ts
CHANGED
@@ -1,23 +1,19 @@
|
|
1
1
|
import { callbacks, emitter, WindowManager } from "./index";
|
2
2
|
import { debounce, maxBy } from "lodash";
|
3
|
-
import {
|
4
|
-
DEFAULT_COLLECTOR_STYLE,
|
5
|
-
Events,
|
6
|
-
MIN_HEIGHT,
|
7
|
-
MIN_WIDTH
|
8
|
-
} from "./constants";
|
9
|
-
import type { AddAppOptions, AppInitState } from "./index";
|
3
|
+
import { DEFAULT_COLLECTOR_STYLE, Events, MIN_HEIGHT, MIN_WIDTH } from "./constants";
|
10
4
|
import {
|
11
5
|
TELE_BOX_MANAGER_EVENT,
|
12
6
|
TELE_BOX_STATE,
|
13
7
|
TeleBoxCollector,
|
14
8
|
TeleBoxManager,
|
15
9
|
} from "@netless/telebox-insider";
|
10
|
+
import type { AddAppOptions, AppInitState } from "./index";
|
16
11
|
import type {
|
17
12
|
TeleBoxManagerUpdateConfig,
|
18
13
|
TeleBoxManagerCreateConfig,
|
19
14
|
ReadonlyTeleBox,
|
20
15
|
TeleBoxManagerConfig,
|
16
|
+
TeleBoxColorScheme,
|
21
17
|
} from "@netless/telebox-insider";
|
22
18
|
import type Emittery from "emittery";
|
23
19
|
import type { AppManager } from "./AppManager";
|
@@ -45,9 +41,10 @@ type SetBoxMinSizeParams = AppId & { minWidth: number; minHeight: number };
|
|
45
41
|
|
46
42
|
type SetBoxTitleParams = AppId & { title: string };
|
47
43
|
|
48
|
-
export type
|
44
|
+
export type CreateTeleBoxManagerConfig = {
|
49
45
|
collectorContainer?: HTMLElement;
|
50
46
|
collectorStyles?: Partial<CSSStyleDeclaration>;
|
47
|
+
prefersColorScheme?: TeleBoxColorScheme;
|
51
48
|
};
|
52
49
|
|
53
50
|
export class BoxManager {
|
@@ -57,9 +54,9 @@ export class BoxManager {
|
|
57
54
|
|
58
55
|
constructor(
|
59
56
|
private manager: AppManager,
|
60
|
-
|
57
|
+
createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
|
61
58
|
) {
|
62
|
-
this.teleBoxManager = this.setupBoxManager(
|
59
|
+
this.teleBoxManager = this.setupBoxManager(createTeleBoxManagerConfig);
|
63
60
|
this.teleBoxManager.events.on(TELE_BOX_MANAGER_EVENT.State, state => {
|
64
61
|
if (state) {
|
65
62
|
callbacks.emit("boxStateChange", state);
|
@@ -69,7 +66,7 @@ export class BoxManager {
|
|
69
66
|
this.teleBoxManager.events.on("minimized", minimized => {
|
70
67
|
this.manager.safeSetAttributes({ minimized });
|
71
68
|
});
|
72
|
-
this.teleBoxManager.events.on("maximized",
|
69
|
+
this.teleBoxManager.events.on("maximized", maximized => {
|
73
70
|
this.manager.safeSetAttributes({ maximized });
|
74
71
|
});
|
75
72
|
this.teleBoxManager.events.on("removed", boxes => {
|
@@ -86,7 +83,11 @@ export class BoxManager {
|
|
86
83
|
this.teleBoxManager.events.on(
|
87
84
|
"intrinsic_resize",
|
88
85
|
debounce((box: ReadonlyTeleBox): void => {
|
89
|
-
emitter.emit("resize", {
|
86
|
+
emitter.emit("resize", {
|
87
|
+
appId: box.id,
|
88
|
+
width: box.intrinsicWidth,
|
89
|
+
height: box.intrinsicHeight,
|
90
|
+
});
|
90
91
|
}, 200)
|
91
92
|
);
|
92
93
|
this.teleBoxManager.events.on("focused", box => {
|
@@ -100,6 +101,12 @@ export class BoxManager {
|
|
100
101
|
this.blurFocusBox();
|
101
102
|
}
|
102
103
|
});
|
104
|
+
this.teleBoxManager.events.on("dark_mode", darkMode => {
|
105
|
+
callbacks.emit("darkModeChange", darkMode);
|
106
|
+
});
|
107
|
+
this.teleBoxManager.events.on("prefers_color_scheme", colorScheme => {
|
108
|
+
callbacks.emit("prefersColorSchemeChange", colorScheme);
|
109
|
+
});
|
103
110
|
}
|
104
111
|
|
105
112
|
public get boxState() {
|
@@ -114,6 +121,14 @@ export class BoxManager {
|
|
114
121
|
return this.teleBoxManager.minimized;
|
115
122
|
}
|
116
123
|
|
124
|
+
public get darkMode() {
|
125
|
+
return this.teleBoxManager.darkMode;
|
126
|
+
}
|
127
|
+
|
128
|
+
public get prefersColorScheme(): TeleBoxColorScheme {
|
129
|
+
return this.teleBoxManager.prefersColorScheme;
|
130
|
+
}
|
131
|
+
|
117
132
|
public createBox(params: CreateBoxParams): void {
|
118
133
|
if (!this.teleBoxManager) return;
|
119
134
|
let { minwidth = MIN_WIDTH, minheight = MIN_HEIGHT } = params.app.config ?? {};
|
@@ -156,7 +171,9 @@ export class BoxManager {
|
|
156
171
|
}
|
157
172
|
}
|
158
173
|
|
159
|
-
public setupBoxManager(
|
174
|
+
public setupBoxManager(
|
175
|
+
createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
|
176
|
+
): TeleBoxManager {
|
160
177
|
const root = WindowManager.wrapper ? WindowManager.wrapper : document.body;
|
161
178
|
const rect = root.getBoundingClientRect();
|
162
179
|
const initManagerState: TeleBoxManagerConfig = {
|
@@ -168,9 +185,13 @@ export class BoxManager {
|
|
168
185
|
height: rect.height,
|
169
186
|
},
|
170
187
|
fence: false,
|
188
|
+
prefersColorScheme: createTeleBoxManagerConfig?.prefersColorScheme,
|
189
|
+
};
|
190
|
+
const container = createTeleBoxManagerConfig?.collectorContainer || WindowManager.wrapper;
|
191
|
+
const styles = {
|
192
|
+
...DEFAULT_COLLECTOR_STYLE,
|
193
|
+
...createTeleBoxManagerConfig?.collectorStyles,
|
171
194
|
};
|
172
|
-
const container = collectorConfig?.collectorContainer || WindowManager.wrapper;
|
173
|
-
const styles = { ...DEFAULT_COLLECTOR_STYLE, ...collectorConfig?.collectorStyles };
|
174
195
|
const teleBoxCollector = new TeleBoxCollector({
|
175
196
|
styles: styles,
|
176
197
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
@@ -224,7 +245,7 @@ export class BoxManager {
|
|
224
245
|
if (state.maximized != null) {
|
225
246
|
this.teleBoxManager.setMaximized(Boolean(state.maximized), true);
|
226
247
|
this.teleBoxManager.setMinimized(Boolean(state.minimized), true);
|
227
|
-
}
|
248
|
+
}
|
228
249
|
setTimeout(() => {
|
229
250
|
if (state.focus) {
|
230
251
|
this.teleBoxManager.update(box.id, { focus: true }, true);
|
@@ -298,6 +319,10 @@ export class BoxManager {
|
|
298
319
|
this.teleBoxManager.setReadonly(readonly);
|
299
320
|
}
|
300
321
|
|
322
|
+
public setPrefersColorScheme(colorScheme: TeleBoxColorScheme) {
|
323
|
+
this.teleBoxManager.setPrefersColorScheme(colorScheme);
|
324
|
+
}
|
325
|
+
|
301
326
|
public destroy() {
|
302
327
|
this.teleBoxManager.destroy();
|
303
328
|
}
|
package/src/Utils/RoomHacker.ts
CHANGED
@@ -33,6 +33,9 @@ export const replaceRoomFunction = (room: Room, manager: AppManager) => {
|
|
33
33
|
room.moveCameraToContain = (...args) => manager.mainView.moveCameraToContain(...args);
|
34
34
|
room.convertToPointInWorld = (...args) => manager.mainView.convertToPointInWorld(...args);
|
35
35
|
room.setCameraBound = (...args) => manager.mainView.setCameraBound(...args);
|
36
|
+
room.scenePreview = (...args) => manager.mainView.scenePreview(...args);
|
37
|
+
room.fillSceneSnapshot = (...args) => manager.mainView.fillSceneSnapshot(...args);
|
38
|
+
room.generateScreenshot = (...args) => manager.mainView.generateScreenshot(...args);
|
36
39
|
}
|
37
40
|
|
38
41
|
};
|
package/src/index.ts
CHANGED
@@ -54,7 +54,7 @@ import type {
|
|
54
54
|
} from "white-web-sdk";
|
55
55
|
import type { AppListeners } from "./AppListener";
|
56
56
|
import type { NetlessApp, RegisterParams } from "./typings";
|
57
|
-
import type { TeleBoxState } from "@netless/telebox-insider";
|
57
|
+
import type { TeleBoxColorScheme, TeleBoxState } from "@netless/telebox-insider";
|
58
58
|
import type { AppProxy } from "./AppProxy";
|
59
59
|
|
60
60
|
const ResizeObserver = window.ResizeObserver || ResizeObserverPolyfill;
|
@@ -141,6 +141,8 @@ export const emitter: Emittery<EmitterEvent> = new Emittery();
|
|
141
141
|
export type PublicEvent = {
|
142
142
|
mainViewModeChange: ViewVisionMode;
|
143
143
|
boxStateChange: `${TELE_BOX_STATE}`;
|
144
|
+
darkModeChange: boolean;
|
145
|
+
prefersColorSchemeChange: TeleBoxColorScheme;
|
144
146
|
};
|
145
147
|
|
146
148
|
export type MountParams = {
|
@@ -156,6 +158,7 @@ export type MountParams = {
|
|
156
158
|
cursor?: boolean;
|
157
159
|
debug?: boolean;
|
158
160
|
disableCameraTransform?: boolean;
|
161
|
+
prefersColorScheme?: TeleBoxColorScheme;
|
159
162
|
};
|
160
163
|
|
161
164
|
export const callbacks: Emittery<PublicEvent> = new Emittery();
|
@@ -170,7 +173,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
170
173
|
public static containerSizeRatio = DEFAULT_CONTAINER_RATIO;
|
171
174
|
private static isCreated = false;
|
172
175
|
|
173
|
-
public version = "0.3.
|
176
|
+
public version = "0.3.12-canary.1";
|
174
177
|
|
175
178
|
public appListeners?: AppListeners;
|
176
179
|
|
@@ -225,6 +228,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
225
228
|
let overwriteStyles: string | undefined;
|
226
229
|
let cursor: boolean | undefined;
|
227
230
|
let disableCameraTransform = false;
|
231
|
+
let prefersColorScheme: TeleBoxColorScheme | undefined = "light";
|
228
232
|
if ("room" in params) {
|
229
233
|
room = params.room;
|
230
234
|
container = params.container;
|
@@ -238,6 +242,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
238
242
|
overwriteStyles = params.overwriteStyles;
|
239
243
|
cursor = params.cursor;
|
240
244
|
disableCameraTransform = Boolean(params?.disableCameraTransform);
|
245
|
+
prefersColorScheme = params.prefersColorScheme;
|
241
246
|
} else {
|
242
247
|
room = params;
|
243
248
|
containerSizeRatio = options?.containerSizeRatio;
|
@@ -303,6 +308,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
303
308
|
manager.appManager = new AppManager(manager, {
|
304
309
|
collectorContainer: collectorContainer,
|
305
310
|
collectorStyles: collectorStyles,
|
311
|
+
prefersColorScheme: prefersColorScheme,
|
306
312
|
});
|
307
313
|
manager.observePlaygroundSize(playground, sizer, wrapper);
|
308
314
|
if (cursor) {
|
@@ -521,6 +527,18 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
521
527
|
}
|
522
528
|
}
|
523
529
|
|
530
|
+
public get darkMode(): boolean {
|
531
|
+
return Boolean(this.appManager?.boxManager.darkMode);
|
532
|
+
}
|
533
|
+
|
534
|
+
public get prefersColorScheme(): TeleBoxColorScheme {
|
535
|
+
if (this.appManager) {
|
536
|
+
return this.appManager.boxManager.prefersColorScheme;
|
537
|
+
} else {
|
538
|
+
throw new AppManagerNotInitError();
|
539
|
+
}
|
540
|
+
}
|
541
|
+
|
524
542
|
/**
|
525
543
|
* 查询所有的 App
|
526
544
|
*/
|
@@ -620,6 +638,10 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
|
|
620
638
|
}
|
621
639
|
}
|
622
640
|
|
641
|
+
public setPrefersColorScheme(scheme: TeleBoxColorScheme): void {
|
642
|
+
this.appManager?.boxManager.setPrefersColorScheme(scheme);
|
643
|
+
}
|
644
|
+
|
623
645
|
private isDynamicPPT(scenes: SceneDefinition[]) {
|
624
646
|
const sceneSrc = scenes[0]?.ppt?.src;
|
625
647
|
return sceneSrc?.startsWith("pptx://");
|