@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/CHANGELOG.md +14 -0
- package/dist/Cursor/Cursor.d.ts +1 -0
- package/dist/Cursor/index.d.ts +3 -0
- package/dist/index.d.ts +11 -1
- package/dist/index.es.js +5 -5
- package/dist/index.es.js.map +1 -1
- package/dist/index.umd.js +5 -5
- package/dist/index.umd.js.map +1 -1
- package/dist/style.css +1 -1
- package/docs/api.md +9 -0
- package/package.json +2 -2
- package/src/App/Storage/index.ts +1 -1
- package/src/Cursor/Cursor.svelte +2 -2
- package/src/Cursor/Cursor.ts +6 -1
- package/src/Cursor/index.ts +35 -21
- package/src/Utils/RoomHacker.ts +10 -0
- package/src/View/ViewManager.ts +10 -2
- package/src/index.ts +47 -21
- package/vite.config.js +2 -2
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.
|
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",
|
package/src/App/Storage/index.ts
CHANGED
@@ -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
|
204
|
+
return this._context.getAttributes() ?? defaultValue;
|
205
205
|
} else {
|
206
206
|
return get(this._context.getAttributes(), [STORAGE_NS, this.id], defaultValue);
|
207
207
|
}
|
package/src/Cursor/Cursor.svelte
CHANGED
@@ -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;
|
package/src/Cursor/Cursor.ts
CHANGED
@@ -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
|
|
package/src/Cursor/index.ts
CHANGED
@@ -34,31 +34,42 @@ export class CursorManager {
|
|
34
34
|
if (wrapper) {
|
35
35
|
this.setupWrapper(wrapper);
|
36
36
|
}
|
37
|
-
|
38
|
-
|
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
|
-
|
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:
|
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
|
|
package/src/Utils/RoomHacker.ts
CHANGED
@@ -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
|
};
|
package/src/View/ViewManager.ts
CHANGED
@@ -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
|
-
|
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
|
-
|
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
|
-
},
|
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
|
-
},
|
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
|
-
|
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
|
-
|
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
|
-
|
790
|
-
|
791
|
-
|
792
|
-
|
793
|
-
|
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
|
},
|