@netless/window-manager 1.0.0-canary.40 → 1.0.0-canary.43
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/index.cjs.js +8 -8
- package/dist/index.es.js +36 -21
- package/dist/index.umd.js +8 -8
- package/dist/src/index.d.ts +7 -6
- package/docs/mirgrate-to-1.0.md +34 -5
- package/package.json +2 -2
- package/pnpm-lock.yaml +4 -4
- package/src/index.ts +27 -14
package/dist/src/index.d.ts
CHANGED
@@ -84,18 +84,18 @@ export declare type MountParams = {
|
|
84
84
|
container?: HTMLElement;
|
85
85
|
/** 白板高宽比例, 默认为 9 / 16 */
|
86
86
|
containerSizeRatio?: number;
|
87
|
-
/** @deprecated */
|
88
|
-
chessboard?: boolean;
|
89
87
|
collectorContainer?: HTMLElement;
|
90
88
|
collectorStyles?: Partial<CSSStyleDeclaration>;
|
91
89
|
overwriteStyles?: string;
|
92
|
-
containerStyle?: string;
|
93
|
-
stageStyle?: string;
|
94
90
|
cursor?: boolean;
|
95
91
|
debug?: boolean;
|
96
92
|
disableCameraTransform?: boolean;
|
97
93
|
prefersColorScheme?: TeleBoxColorScheme;
|
94
|
+
/** @deprecated */
|
95
|
+
chessboard?: boolean;
|
98
96
|
applianceIcons?: ApplianceIcons;
|
97
|
+
containerStyle?: string;
|
98
|
+
stageStyle?: string;
|
99
99
|
fullscreen?: TeleBoxFullscreen;
|
100
100
|
/** Custom `style` attribute value for content area of all boxes. Can be overwritten by box. */
|
101
101
|
defaultBoxBodyStyle?: string | null;
|
@@ -126,6 +126,7 @@ export declare class WindowManager extends InvisiblePlugin<WindowMangerAttribute
|
|
126
126
|
private _pageState?;
|
127
127
|
private boxManager?;
|
128
128
|
private static params?;
|
129
|
+
private cameraUpdating;
|
129
130
|
containerSizeRatio: number;
|
130
131
|
constructor(context: InvisiblePluginContext);
|
131
132
|
static mount(params: MountParams): Promise<WindowManager>;
|
@@ -231,9 +232,9 @@ export declare class WindowManager extends InvisiblePlugin<WindowMangerAttribute
|
|
231
232
|
* 关闭 APP
|
232
233
|
*/
|
233
234
|
closeApp(appId: string): Promise<void>;
|
234
|
-
moveCamera:
|
235
|
+
moveCamera: (camera: Partial<Camera> & {
|
235
236
|
animationMode?: AnimationMode;
|
236
|
-
}) => void
|
237
|
+
}) => void;
|
237
238
|
convertToPointInWorld(point: Point): Point;
|
238
239
|
setCameraBound(cameraBound: CameraBound): void;
|
239
240
|
onDestroy(): void;
|
package/docs/mirgrate-to-1.0.md
CHANGED
@@ -18,18 +18,31 @@
|
|
18
18
|
|
19
19
|
```html
|
20
20
|
<div class="netless-window-manager-playground">
|
21
|
-
<div class="
|
21
|
+
<div class="telebox-manager-container">
|
22
|
+
<div class="telebox-manager-stage">
|
23
|
+
<div class="netless-window-manager-main-view"></div>
|
24
|
+
</div>
|
25
|
+
</div>
|
22
26
|
</div>
|
23
27
|
```
|
24
28
|
|
25
29
|
|
26
30
|
### `WindowManager.mount()` 迁移
|
27
31
|
|
28
|
-
|
32
|
+
废弃: `chessboard` 属性
|
29
33
|
|
30
|
-
添加: `containerStyle` 配置
|
31
|
-
|
32
|
-
添加: `
|
34
|
+
- 添加: `containerStyle` 配置
|
35
|
+
- 配置 `telebox-manager-container` 的样式
|
36
|
+
- 添加: `stageStyle` 配置**
|
37
|
+
- 配置 `telebox-manager-stage` 的样式
|
38
|
+
- 添加: `defaultBoxBodyStyle` 配置
|
39
|
+
- 配置应用窗口默认 `body` 的样式
|
40
|
+
- 添加: `defaultBoxStageStyle` 配置
|
41
|
+
- 配置应用窗口默认 `stage` 也就是内容区域的样式
|
42
|
+
- 添加: `fullscreen` 配置
|
43
|
+
- 控制应用是否以全屏模式进入
|
44
|
+
- 添加: `theme` 配置
|
45
|
+
- 配置默认的颜色变量
|
33
46
|
|
34
47
|
### `manager.setContainerSizeRatio()` 行为修改
|
35
48
|
|
@@ -37,3 +50,19 @@
|
|
37
50
|
|
38
51
|
1.0 之后重复修改 `containerSizeRatio` 不会导致内容一致缩小
|
39
52
|
|
53
|
+
### baseSize
|
54
|
+
|
55
|
+
`baseSize` 主白板会去匹配内容到此大小
|
56
|
+
|
57
|
+
添加: `manager.baseSize` 属性\
|
58
|
+
添加: `manager.setBaseSize()` 方法\
|
59
|
+
添加: `baseSizeChange` 回调
|
60
|
+
|
61
|
+
### baseCamera
|
62
|
+
|
63
|
+
主白板的 `camera` 会根据 `baseSize` 的值和 `baseCamera` 的值计算一个最终值
|
64
|
+
|
65
|
+
添加: `manager.baseSize` 属性\
|
66
|
+
添加: `baseCamera` 回调
|
67
|
+
|
68
|
+
修改 `baseCamera` 依旧通过 `manager.moveCamera` 来实现
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@netless/window-manager",
|
3
|
-
"version": "1.0.0-canary.
|
3
|
+
"version": "1.0.0-canary.43",
|
4
4
|
"description": "",
|
5
5
|
"main": "dist/index.cjs.js",
|
6
6
|
"module": "dist/index.es.js",
|
@@ -25,7 +25,7 @@
|
|
25
25
|
},
|
26
26
|
"dependencies": {
|
27
27
|
"@juggle/resize-observer": "^3.3.1",
|
28
|
-
"@netless/telebox-insider": "1.0.0-alpha.
|
28
|
+
"@netless/telebox-insider": "1.0.0-alpha.35",
|
29
29
|
"emittery": "^0.11.0",
|
30
30
|
"lodash": "^4.17.21",
|
31
31
|
"p-retry": "^4.6.2",
|
package/pnpm-lock.yaml
CHANGED
@@ -4,7 +4,7 @@ specifiers:
|
|
4
4
|
'@juggle/resize-observer': ^3.3.1
|
5
5
|
'@netless/app-docs-viewer': ^0.3.0
|
6
6
|
'@netless/app-plyr': 0.2.0
|
7
|
-
'@netless/telebox-insider': 1.0.0-alpha.
|
7
|
+
'@netless/telebox-insider': 1.0.0-alpha.35
|
8
8
|
'@playwright/test': ^1.23.2
|
9
9
|
'@rollup/plugin-commonjs': ^20.0.0
|
10
10
|
'@rollup/plugin-node-resolve': ^13.0.4
|
@@ -45,7 +45,7 @@ specifiers:
|
|
45
45
|
|
46
46
|
dependencies:
|
47
47
|
'@juggle/resize-observer': 3.3.1
|
48
|
-
'@netless/telebox-insider': 1.0.0-alpha.
|
48
|
+
'@netless/telebox-insider': 1.0.0-alpha.35
|
49
49
|
emittery: 0.11.0
|
50
50
|
lodash: 4.17.21
|
51
51
|
p-retry: 4.6.2
|
@@ -247,8 +247,8 @@ packages:
|
|
247
247
|
resolution: {integrity: sha512-7NzsJrba0R/mq/l10SkIZQwbrNVJyPxZYrjK6xL3Ts732iWAVuS2UB0u3s6iGeUVcqV39A679yva8APWRl4M0A==}
|
248
248
|
dev: true
|
249
249
|
|
250
|
-
/@netless/telebox-insider/1.0.0-alpha.
|
251
|
-
resolution: {integrity: sha512-
|
250
|
+
/@netless/telebox-insider/1.0.0-alpha.35:
|
251
|
+
resolution: {integrity: sha512-uX/PUEoG/+CoaigeoWH+U07io93n+T89VjJDl5FRnd3gc/QfYf3ASSDQ9+7GjbOBUDUFwYHqVIxEhU67mGXCbw==}
|
252
252
|
dependencies:
|
253
253
|
'@juggle/resize-observer': 3.3.1
|
254
254
|
'@types/shallowequal': 1.1.1
|
package/src/index.ts
CHANGED
@@ -10,7 +10,7 @@ import { emitter } from "./InternalEmitter";
|
|
10
10
|
import { Fields } from "./AttributesDelegate";
|
11
11
|
import { initDb } from "./Register/storage";
|
12
12
|
import { AnimationMode, InvisiblePlugin, isPlayer, isRoom, RoomPhase, ViewMode } from "white-web-sdk";
|
13
|
-
import { isEqual, isNull, isObject, isNumber
|
13
|
+
import { isEqual, isNull, isObject, isNumber } from "lodash";
|
14
14
|
import { log } from "./Utils/log";
|
15
15
|
import { PageStateImpl } from "./PageState";
|
16
16
|
import { ReconnectRefresher } from "./ReconnectRefresher";
|
@@ -135,18 +135,18 @@ export type MountParams = {
|
|
135
135
|
container?: HTMLElement;
|
136
136
|
/** 白板高宽比例, 默认为 9 / 16 */
|
137
137
|
containerSizeRatio?: number;
|
138
|
-
/** @deprecated */
|
139
|
-
chessboard?: boolean;
|
140
138
|
collectorContainer?: HTMLElement;
|
141
139
|
collectorStyles?: Partial<CSSStyleDeclaration>;
|
142
140
|
overwriteStyles?: string;
|
143
|
-
containerStyle?: string;
|
144
|
-
stageStyle?: string;
|
145
141
|
cursor?: boolean;
|
146
142
|
debug?: boolean;
|
147
143
|
disableCameraTransform?: boolean;
|
148
144
|
prefersColorScheme?: TeleBoxColorScheme;
|
145
|
+
/** @deprecated */
|
146
|
+
chessboard?: boolean;
|
149
147
|
applianceIcons?: ApplianceIcons;
|
148
|
+
containerStyle?: string;
|
149
|
+
stageStyle?: string;
|
150
150
|
fullscreen?: TeleBoxFullscreen;
|
151
151
|
/** Custom `style` attribute value for content area of all boxes. Can be overwritten by box. */
|
152
152
|
defaultBoxBodyStyle?: string | null;
|
@@ -184,6 +184,8 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> imple
|
|
184
184
|
private boxManager?: BoxManager;
|
185
185
|
private static params?: MountParams;
|
186
186
|
|
187
|
+
private cameraUpdating = 0;
|
188
|
+
|
187
189
|
public containerSizeRatio = WindowManager.containerSizeRatio;
|
188
190
|
|
189
191
|
constructor(context: InvisiblePluginContext) {
|
@@ -805,7 +807,7 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> imple
|
|
805
807
|
return this.appManager?.closeApp(appId);
|
806
808
|
}
|
807
809
|
|
808
|
-
public moveCamera =
|
810
|
+
public moveCamera = (camera: Partial<Camera> & { animationMode?: AnimationMode } ): void => {
|
809
811
|
const mainViewCamera = { ...this.mainView.camera };
|
810
812
|
const nextCamera = { ...mainViewCamera, ...camera };
|
811
813
|
if (isEqual(nextCamera, mainViewCamera)) return;
|
@@ -831,15 +833,26 @@ export class WindowManager extends InvisiblePlugin<WindowMangerAttributes> imple
|
|
831
833
|
this.mainView.moveCamera(camera);
|
832
834
|
}
|
833
835
|
this.appManager.dispatchInternalEvent(Events.MoveCamera, camera);
|
834
|
-
|
835
|
-
if (
|
836
|
-
|
837
|
-
|
838
|
-
|
839
|
-
|
840
|
-
|
836
|
+
const onCameraUpdated = () => {
|
837
|
+
if (this.cameraUpdating) {
|
838
|
+
clearTimeout(this.cameraUpdating);
|
839
|
+
}
|
840
|
+
this.cameraUpdating = setTimeout(() => {
|
841
|
+
this.mainView.callbacks.off("onCameraUpdated", onCameraUpdated);
|
842
|
+
clearTimeout(this.cameraUpdating);
|
843
|
+
this.cameraUpdating = 0;
|
844
|
+
if (!this.appManager) return;
|
845
|
+
this.appManager.mainViewProxy.storeCamera({
|
846
|
+
id: this.appManager.uid,
|
847
|
+
...nextCamera
|
848
|
+
});
|
849
|
+
}, 50);
|
850
|
+
}
|
851
|
+
this.mainView.callbacks.off("onCameraUpdated", onCameraUpdated);
|
852
|
+
this.mainView.callbacks.on("onCameraUpdated", onCameraUpdated);
|
853
|
+
|
841
854
|
}
|
842
|
-
}
|
855
|
+
};
|
843
856
|
|
844
857
|
public convertToPointInWorld(point: Point): Point {
|
845
858
|
return this.mainView.convertToPointInWorld(point);
|