@netless/window-manager 0.4.1 → 0.4.5

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;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:absolute;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .1s;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-laserPointer-image{margin-left:-22px;margin-top:3px}.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}.telebox-collector{position:absolute;right:10px;bottom:15px}.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;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{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;touch-action:manipulation}.telebox-title-area{overflow:hidden;position:relative;height:100%;flex:1;display:flex;align-items:center}.telebox-title{overflow:hidden;margin: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-drag-area{position:absolute;top:0;left:0;right:0;bottom:0;margin:auto;z-index:10}.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 .telebox-drag-area{height:100%;min-width:16px;position:static;margin:0;flex-grow:1;flex-shrink:0}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{height:100%;margin:0;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{height:100%;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;user-select:none}.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}
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:absolute;width:26px;height:26px;z-index:2147483647;left:0;top:0;will-change:transform;transition:transform .1s;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-laserPointer-image{margin-left:-22px;margin-top:3px}.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}.telebox-collector{position:absolute;right:10px;bottom:15px}.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;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{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;touch-action:manipulation}.telebox-title-area{overflow:hidden;position:relative;height:100%;flex:1;display:flex;align-items:center}.telebox-title{overflow:hidden;margin: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-drag-area{position:absolute;top:0;left:0;right:0;bottom:0;margin:auto;z-index:10}.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;-webkit-tap-highlight-color:transparent}.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 .telebox-drag-area{height:100%;min-width:16px;position:static;margin:0;flex-grow:1;flex-shrink:0}.telebox-max-titlebar-maximized{display:flex}.telebox-titles{height:100%;margin:0;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{height:100%;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;user-select:none}.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/docs/api.md CHANGED
@@ -14,6 +14,15 @@
14
14
  - [`cleanCurrentScene`](#cleanCurrentScene)
15
15
  - [`redo`](#redo)
16
16
  - [`undo`](#undo)
17
+ - [`copy`](#copy)
18
+ - [`paste`](#paste)
19
+ - [`delete`](#delete)
20
+ - [`duplicate`](#duplicate)
21
+ - [`insertText`](#insertText)
22
+ - [`insertImage`](#insertImage)
23
+ - [`completeImageUpload`](#completeImageUpload)
24
+ - [`lockImage`](#lockImage)
25
+ - [`lockImages`](#lockImages)
17
26
  - [实例属性](#prototypes)
18
27
  - [事件回调](#events)
19
28
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@netless/window-manager",
3
- "version": "0.4.1",
3
+ "version": "0.4.5",
4
4
  "description": "",
5
5
  "main": "dist/index.es.js",
6
6
  "module": "dist/index.es.js",
@@ -22,6 +22,7 @@
22
22
  },
23
23
  "dependencies": {
24
24
  "@juggle/resize-observer": "^3.3.1",
25
+ "@netless/telebox-insider": "0.2.23",
25
26
  "emittery": "^0.9.2",
26
27
  "lodash": "^4.17.21",
27
28
  "p-retry": "^4.6.1",
@@ -32,7 +33,6 @@
32
33
  "devDependencies": {
33
34
  "@netless/app-docs-viewer": "^0.2.6",
34
35
  "@netless/app-media-player": "0.1.0-beta.5",
35
- "@netless/telebox-insider": "0.2.22",
36
36
  "@rollup/plugin-commonjs": "^20.0.0",
37
37
  "@rollup/plugin-node-resolve": "^13.0.4",
38
38
  "@rollup/plugin-url": "^6.1.0",
@@ -201,7 +201,7 @@ export class Storage<TState extends Record<string, any> = any> implements Storag
201
201
  private _getRawState(defaultValue: TState): TState
202
202
  private _getRawState(defaultValue?: TState): TState | undefined {
203
203
  if (this.id === null) {
204
- return get(this._context.getAttributes(), [], defaultValue);
204
+ return this._context.getAttributes() ?? defaultValue;
205
205
  } else {
206
206
  return get(this._context.getAttributes(), [STORAGE_NS, this.id], defaultValue);
207
207
  }
@@ -3,12 +3,12 @@
3
3
  import { ApplianceNames } from "white-web-sdk";
4
4
 
5
5
  export let cursorName: string;
6
- export let tagName: string;
6
+ export let tagName: string | undefined;
7
7
  export let backgroundColor: string;
8
8
  export let appliance: string;
9
9
  export let x: number;
10
10
  export let y: number;
11
- export let src: string;
11
+ export let src: string | undefined;
12
12
  export let visible: boolean;
13
13
  export let avatar: string;
14
14
  export let theme: string;
@@ -116,6 +116,10 @@ export class Cursor {
116
116
  }
117
117
  }
118
118
 
119
+ private get memberTagName(): string | undefined {
120
+ return this.payload?.cursorTagName;
121
+ }
122
+
119
123
  private autoHidden() {
120
124
  if (this.timer) {
121
125
  clearTimeout(this.timer);
@@ -138,7 +142,7 @@ export class Cursor {
138
142
  return {
139
143
  x: 0,
140
144
  y: 0,
141
- appliance: this.memberApplianceName,
145
+ appliance: this.memberApplianceName as string,
142
146
  avatar: this.memberAvatar,
143
147
  src: this.getIcon(),
144
148
  visible: false,
@@ -148,6 +152,7 @@ export class Cursor {
148
152
  color: this.memberCursorTextColor,
149
153
  cursorTagBackgroundColor: this.memberCursorTagBackgroundColor,
150
154
  opacity: this.memberOpacity,
155
+ tagName: this.memberTagName,
151
156
  };
152
157
  }
153
158
 
@@ -34,31 +34,42 @@ export class CursorManager {
34
34
  if (wrapper) {
35
35
  this.setupWrapper(wrapper);
36
36
  }
37
- emitter.on("cursorMove", payload => {
38
- let cursorInstance = this.cursorInstances.get(payload.uid);
39
- if (!cursorInstance) {
40
- cursorInstance = new Cursor(this.manager, payload.uid, this, WindowManager.wrapper);
41
- this.cursorInstances.set(payload.uid, cursorInstance);
42
- }
43
- if (payload.state === CursorState.Leave) {
44
- cursorInstance.leave();
45
- } else {
46
- const member = cursorInstance.updateMember();
47
- const isLaserPointer =
48
- member?.memberState.currentApplianceName === ApplianceNames.laserPointer;
49
- if (this.enableCursor || isLaserPointer) {
50
- cursorInstance.move(payload.position);
51
- }
52
- }
37
+ this.sideEffectManager.add(() => {
38
+ return emitter.on("cursorMove", this.onCursorMove);
53
39
  });
40
+
54
41
  this.sideEffectManager.add(() => {
55
- const unsubscribe = emitter.on("playgroundSizeChange", () => {
56
- this.updateContainerRect();
57
- });
58
- return unsubscribe;
42
+ return emitter.on("playgroundSizeChange", () => this.updateContainerRect());
59
43
  });
60
44
  }
61
45
 
46
+ private onCursorMove = (payload: CursorMovePayload) => {
47
+ const cursorInstance = this.initCursorInstance(payload.uid);
48
+ if (payload.state === CursorState.Leave) {
49
+ cursorInstance.leave();
50
+ } else {
51
+ const member = cursorInstance.updateMember();
52
+ if (this.canMoveCursor(member)) {
53
+ cursorInstance.move(payload.position);
54
+ }
55
+ }
56
+ };
57
+
58
+ private initCursorInstance = (uid: string) => {
59
+ let cursorInstance = this.cursorInstances.get(uid);
60
+ if (!cursorInstance) {
61
+ cursorInstance = new Cursor(this.manager, uid, this, WindowManager.wrapper);
62
+ this.cursorInstances.set(uid, cursorInstance);
63
+ }
64
+ return cursorInstance;
65
+ };
66
+
67
+ private canMoveCursor(member: RoomMember | undefined) {
68
+ const isLaserPointer = member?.memberState.currentApplianceName === ApplianceNames.laserPointer;
69
+ // 激光笔教具在不开启光标的情况下也要显示
70
+ return this.enableCursor || isLaserPointer;
71
+ }
72
+
62
73
  public setupWrapper(wrapper: HTMLElement) {
63
74
  this.sideEffectManager.add(() => {
64
75
  wrapper.addEventListener("pointerenter", this.mouseMoveListener);
@@ -86,7 +97,10 @@ export class CursorManager {
86
97
  return this.manager.focusApp?.view;
87
98
  }
88
99
 
89
- private mouseMoveListener = throttle((event: MouseEvent) => {
100
+ private mouseMoveListener = throttle((event: PointerEvent) => {
101
+ if (event.pointerType === "touch") {
102
+ if (!event.isPrimary) return;
103
+ }
90
104
  this.updateCursor(this.getType(event), event.clientX, event.clientY);
91
105
  }, 16);
92
106
 
@@ -44,6 +44,16 @@ export const replaceRoomFunction = (room: Room | Player, manager: WindowManager)
44
44
  room.redo = () => manager.redo();
45
45
  room.undo = () => manager.undo();
46
46
  room.cleanCurrentScene = () => manager.cleanCurrentScene();
47
+ room.delete = () => manager.delete();
48
+ room.copy = () => manager.copy();
49
+ room.paste = () => manager.paste();
50
+ room.duplicate = () => manager.duplicate();
51
+ room.insertImage = (...args) => manager.insertImage(...args);
52
+ room.completeImageUpload = (...args) => manager.completeImageUpload(...args);
53
+ room.insertText = (...args) => manager.insertText(...args);
54
+ room.lockImage = (...args) => manager.lockImage(...args);
55
+ room.lockImages = (...args) => manager.lockImages(...args);
56
+
47
57
  delegateRemoveScenes(room);
48
58
  }
49
59
  };
@@ -18,7 +18,11 @@ export class ViewManager {
18
18
  public destroyView(id: string): void {
19
19
  const view = this.views.get(id);
20
20
  if (view) {
21
- view.release();
21
+ try {
22
+ view.release();
23
+ } catch {
24
+ // ignore
25
+ }
22
26
  this.views.delete(id);
23
27
  }
24
28
  }
@@ -32,7 +36,11 @@ export class ViewManager {
32
36
 
33
37
  public destroy() {
34
38
  this.views.forEach(view => {
35
- view.release();
39
+ try {
40
+ view.release();
41
+ } catch {
42
+ // ignore
43
+ }
36
44
  });
37
45
  this.views.clear();
38
46
  }
package/src/index.ts CHANGED
@@ -47,6 +47,7 @@ import type {
47
47
  ViewVisionMode,
48
48
  CameraState,
49
49
  Player,
50
+ ImageInformation,
50
51
  } from "white-web-sdk";
51
52
  import type { AppListeners } from "./AppListener";
52
53
  import type { NetlessApp, RegisterParams } from "./typings";
@@ -218,7 +219,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
218
219
 
219
220
  const cursor = params.cursor;
220
221
  WindowManager.params = params;
221
-
222
+ WindowManager.displayer = params.room;
222
223
  checkVersion();
223
224
  let manager: WindowManager | undefined = undefined;
224
225
  if (isRoom(room)) {
@@ -614,6 +615,10 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
614
615
  return this.attributes.focus;
615
616
  }
616
617
 
618
+ public get focusedView(): View | undefined {
619
+ return this.appManager?.focusApp?.view || this.mainView;
620
+ }
621
+
617
622
  public get mainViewSceneIndex(): number {
618
623
  return this.appManager?.store.getMainViewSceneIndex();
619
624
  }
@@ -683,7 +688,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
683
688
  this.appManager?.dispatchInternalEvent(Events.MoveCamera, camera);
684
689
  setTimeout(() => {
685
690
  this.appManager?.mainViewProxy.setCameraAndSize();
686
- }, 100);
691
+ }, 500);
687
692
  }
688
693
 
689
694
  public moveCameraToContain(
@@ -696,7 +701,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
696
701
  this.appManager?.dispatchInternalEvent(Events.MoveCameraToContain, rectangle);
697
702
  setTimeout(() => {
698
703
  this.appManager?.mainViewProxy.setCameraAndSize();
699
- }, 100);
704
+ }, 500);
700
705
  }
701
706
 
702
707
  public convertToPointInWorld(point: Point): Point {
@@ -768,30 +773,51 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> {
768
773
  }
769
774
 
770
775
  public cleanCurrentScene(): void {
771
- const focused = this.focused;
772
- if (focused) {
773
- this.appManager?.focusApp?.view?.cleanCurrentScene();
774
- } else {
775
- this.mainView.cleanCurrentScene();
776
- }
776
+ this.focusedView?.cleanCurrentScene();
777
777
  }
778
778
 
779
779
  public redo(): number {
780
- const focused = this.focused;
781
- if (focused) {
782
- return this.appManager?.focusApp?.view?.redo() || 0;
783
- } else {
784
- return this.mainView.redo();
785
- }
780
+ return this.focusedView?.redo() || 0;
786
781
  }
787
782
 
788
783
  public undo(): number {
789
- const focused = this.focused;
790
- if (focused) {
791
- return this.appManager?.focusApp?.view?.undo() || 0;
792
- } else {
793
- return this.mainView.undo();
794
- }
784
+ return this.focusedView?.undo() || 0;
785
+ }
786
+
787
+ public delete(): void {
788
+ this.focusedView?.delete();
789
+ }
790
+
791
+ public copy(): void {
792
+ this.focusedView?.copy();
793
+ }
794
+
795
+ public paste(): void {
796
+ this.focusedView?.paste();
797
+ }
798
+
799
+ public duplicate(): void {
800
+ this.focusedView?.duplicate();
801
+ }
802
+
803
+ public insertText(x: number, y: number, text: string | undefined): string {
804
+ return this.focusedView?.insertText(x, y, text) || "";
805
+ }
806
+
807
+ public insertImage(info: ImageInformation): void {
808
+ return this.focusedView?.insertImage(info);
809
+ }
810
+
811
+ public completeImageUpload(uuid: string, url: string): void {
812
+ return this.focusedView?.completeImageUpload(uuid, url);
813
+ }
814
+
815
+ public lockImage(uuid: string, locked: boolean): void {
816
+ return this.focusedView?.lockImage(uuid, locked);
817
+ }
818
+
819
+ public lockImages(locked: boolean): void {
820
+ return this.focusedView?.lockImages(locked);
795
821
  }
796
822
 
797
823
  private isDynamicPPT(scenes: SceneDefinition[]) {
package/vite.config.js CHANGED
@@ -2,7 +2,7 @@ import path from "path";
2
2
  import { defineConfig } from "vite";
3
3
  import { svelte } from "@sveltejs/vite-plugin-svelte";
4
4
  import { dependencies, peerDependencies, version, devDependencies } from "./package.json"
5
-
5
+ import { omit } from "lodash";
6
6
 
7
7
  export default defineConfig(({ mode }) => {
8
8
  const isProd = mode === "production";
@@ -34,7 +34,7 @@ export default defineConfig(({ mode }) => {
34
34
  sourcemap: true,
35
35
  rollupOptions: {
36
36
  external: Object.keys({
37
- ...dependencies,
37
+ ...omit(dependencies, ["@netless/telebox-insider"]),
38
38
  ...peerDependencies,
39
39
  }),
40
40
  },