@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/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.10-canary.0",
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": "^0.1.21",
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.7",
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 { CreateCollectorConfig } from "./BoxManager";
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: CreateCollectorConfig) {
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 CreateCollectorConfig = {
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
- collectorConfig?: CreateCollectorConfig
57
+ createTeleBoxManagerConfig?: CreateTeleBoxManagerConfig
61
58
  ) {
62
- this.teleBoxManager = this.setupBoxManager(collectorConfig);
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", 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", { appId: box.id, width: box.intrinsicWidth, height: box.intrinsicHeight });
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(collectorConfig?: CreateCollectorConfig): TeleBoxManager {
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
  }
@@ -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.10-canary.0";
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://");
package/src/style.css CHANGED
@@ -4,6 +4,7 @@
4
4
  position: relative;
5
5
  z-index: 1;
6
6
  overflow: hidden;
7
+ user-select: none;
7
8
  }
8
9
 
9
10
  .netless-window-manager-sizer {