@rpgjs/client 5.0.0-beta.10 → 5.0.0-beta.11
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 +12 -0
- package/dist/Game/ProjectileManager.d.ts +89 -0
- package/dist/Game/ProjectileManager.js +179 -0
- package/dist/Game/ProjectileManager.js.map +1 -0
- package/dist/Game/ProjectileManager.spec.d.ts +1 -0
- package/dist/RpgClient.d.ts +53 -13
- package/dist/RpgClientEngine.d.ts +25 -4
- package/dist/RpgClientEngine.js +197 -48
- package/dist/RpgClientEngine.js.map +1 -1
- package/dist/components/animations/hit.ce.js.map +1 -1
- package/dist/components/character.ce.js +32 -30
- package/dist/components/character.ce.js.map +1 -1
- package/dist/components/dynamics/bar.ce.js +4 -3
- package/dist/components/dynamics/bar.ce.js.map +1 -1
- package/dist/components/dynamics/image.ce.js +2 -1
- package/dist/components/dynamics/image.ce.js.map +1 -1
- package/dist/components/dynamics/shape.ce.js +3 -2
- package/dist/components/dynamics/shape.ce.js.map +1 -1
- package/dist/components/dynamics/text.ce.js +9 -8
- package/dist/components/dynamics/text.ce.js.map +1 -1
- package/dist/components/gui/dialogbox/index.ce.js +3 -2
- package/dist/components/gui/dialogbox/index.ce.js.map +1 -1
- package/dist/components/gui/gameover.ce.js +3 -2
- package/dist/components/gui/gameover.ce.js.map +1 -1
- package/dist/components/gui/hud/hud.ce.js.map +1 -1
- package/dist/components/gui/menu/equip-menu.ce.js +2 -1
- package/dist/components/gui/menu/equip-menu.ce.js.map +1 -1
- package/dist/components/gui/menu/exit-menu.ce.js +2 -1
- package/dist/components/gui/menu/exit-menu.ce.js.map +1 -1
- package/dist/components/gui/menu/items-menu.ce.js +3 -2
- package/dist/components/gui/menu/items-menu.ce.js.map +1 -1
- package/dist/components/gui/menu/main-menu.ce.js +3 -2
- package/dist/components/gui/menu/main-menu.ce.js.map +1 -1
- package/dist/components/gui/menu/options-menu.ce.js.map +1 -1
- package/dist/components/gui/menu/skills-menu.ce.js.map +1 -1
- package/dist/components/gui/mobile/mobile.ce.js.map +1 -1
- package/dist/components/gui/notification/notification.ce.js.map +1 -1
- package/dist/components/gui/save-load.ce.js +2 -1
- package/dist/components/gui/save-load.ce.js.map +1 -1
- package/dist/components/gui/shop/shop.ce.js +3 -2
- package/dist/components/gui/shop/shop.ce.js.map +1 -1
- package/dist/components/gui/title-screen.ce.js +3 -2
- package/dist/components/gui/title-screen.ce.js.map +1 -1
- package/dist/components/index.d.ts +2 -1
- package/dist/components/index.js +1 -0
- package/dist/components/player-components.ce.js +11 -10
- package/dist/components/player-components.ce.js.map +1 -1
- package/dist/components/prebuilt/hp-bar.ce.js +4 -3
- package/dist/components/prebuilt/hp-bar.ce.js.map +1 -1
- package/dist/components/prebuilt/light-halo.ce.js +2 -1
- package/dist/components/prebuilt/light-halo.ce.js.map +1 -1
- package/dist/components/scenes/canvas.ce.js +12 -4
- package/dist/components/scenes/canvas.ce.js.map +1 -1
- package/dist/components/scenes/draw-map.ce.js +6 -3
- package/dist/components/scenes/draw-map.ce.js.map +1 -1
- package/dist/components/scenes/event-layer.ce.js.map +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.js +9 -5
- package/dist/module.js +11 -0
- package/dist/module.js.map +1 -1
- package/dist/services/actionInput.d.ts +12 -0
- package/dist/services/actionInput.js +27 -0
- package/dist/services/actionInput.js.map +1 -0
- package/dist/services/actionInput.spec.d.ts +1 -0
- package/dist/services/mmorpg-connection.d.ts +5 -0
- package/dist/services/mmorpg-connection.js +50 -0
- package/dist/services/mmorpg-connection.js.map +1 -0
- package/dist/services/mmorpg-connection.spec.d.ts +1 -0
- package/dist/services/mmorpg.d.ts +10 -4
- package/dist/services/mmorpg.js +48 -30
- package/dist/services/mmorpg.js.map +1 -1
- package/dist/services/pointerContext.d.ts +11 -0
- package/dist/services/pointerContext.js +48 -0
- package/dist/services/pointerContext.js.map +1 -0
- package/dist/services/pointerContext.spec.d.ts +1 -0
- package/dist/services/standalone-message.d.ts +1 -0
- package/dist/services/standalone-message.js +9 -0
- package/dist/services/standalone-message.js.map +1 -0
- package/dist/services/standalone.js +3 -2
- package/dist/services/standalone.js.map +1 -1
- package/dist/services/standalone.spec.d.ts +1 -0
- package/package.json +7 -7
- package/src/Game/ProjectileManager.spec.ts +338 -0
- package/src/Game/ProjectileManager.ts +324 -0
- package/src/RpgClient.ts +62 -15
- package/src/RpgClientEngine.ts +287 -65
- package/src/components/character.ce +34 -32
- package/src/components/dynamics/bar.ce +4 -3
- package/src/components/dynamics/image.ce +2 -1
- package/src/components/dynamics/shape.ce +3 -2
- package/src/components/dynamics/text.ce +9 -8
- package/src/components/gui/dialogbox/index.ce +3 -2
- package/src/components/gui/gameover.ce +2 -1
- package/src/components/gui/menu/equip-menu.ce +2 -1
- package/src/components/gui/menu/exit-menu.ce +2 -1
- package/src/components/gui/menu/items-menu.ce +3 -2
- package/src/components/gui/menu/main-menu.ce +2 -1
- package/src/components/gui/save-load.ce +2 -1
- package/src/components/gui/shop/shop.ce +3 -2
- package/src/components/gui/title-screen.ce +2 -1
- package/src/components/index.ts +2 -1
- package/src/components/player-components.ce +11 -10
- package/src/components/prebuilt/hp-bar.ce +4 -3
- package/src/components/prebuilt/light-halo.ce +2 -2
- package/src/components/scenes/canvas.ce +10 -2
- package/src/components/scenes/draw-map.ce +17 -3
- package/src/index.ts +3 -0
- package/src/module.ts +13 -0
- package/src/services/actionInput.spec.ts +101 -0
- package/src/services/actionInput.ts +53 -0
- package/src/services/mmorpg-connection.spec.ts +99 -0
- package/src/services/mmorpg-connection.ts +69 -0
- package/src/services/mmorpg.ts +60 -34
- package/src/services/pointerContext.spec.ts +36 -0
- package/src/services/pointerContext.ts +84 -0
- package/src/services/standalone-message.ts +7 -0
- package/src/services/standalone.spec.ts +34 -0
- package/src/services/standalone.ts +3 -2
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
export interface ClientPointerPosition {
|
|
2
|
+
x: number;
|
|
3
|
+
y: number;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
export interface ClientPointerContext {
|
|
7
|
+
screen(): ClientPointerPosition | null;
|
|
8
|
+
world(): ClientPointerPosition | null;
|
|
9
|
+
update(screen: ClientPointerPosition | null, world?: ClientPointerPosition | null): ClientPointerPosition | null;
|
|
10
|
+
updateFromEvent(event: any): ClientPointerPosition | null;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
function toPosition(point: any): ClientPointerPosition | null {
|
|
14
|
+
const x = Number(point?.x);
|
|
15
|
+
const y = Number(point?.y);
|
|
16
|
+
|
|
17
|
+
if (!Number.isFinite(x) || !Number.isFinite(y)) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return { x, y };
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function extractGlobalPoint(event: any): ClientPointerPosition | null {
|
|
25
|
+
return toPosition(event?.global)
|
|
26
|
+
?? toPosition(event?.data?.global)
|
|
27
|
+
?? toPosition(event);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
function extractWorldPoint(event: any, global: ClientPointerPosition | null): ClientPointerPosition | null {
|
|
31
|
+
const target = event?.currentTarget ?? event?.target;
|
|
32
|
+
|
|
33
|
+
if (target && global && typeof target.toLocal === "function") {
|
|
34
|
+
return toPosition(target.toLocal(global));
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
if (typeof event?.getLocalPosition === "function") {
|
|
38
|
+
return toPosition(event.getLocalPosition(target));
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if (typeof event?.data?.getLocalPosition === "function") {
|
|
42
|
+
return toPosition(event.data.getLocalPosition(target));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return global;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export function createClientPointerContext(): ClientPointerContext {
|
|
49
|
+
let lastScreen: ClientPointerPosition | null = null;
|
|
50
|
+
let lastWorld: ClientPointerPosition | null = null;
|
|
51
|
+
|
|
52
|
+
const update = (screen: ClientPointerPosition | null, world?: ClientPointerPosition | null) => {
|
|
53
|
+
const nextScreen = toPosition(screen);
|
|
54
|
+
const nextWorld = toPosition(world) ?? nextScreen;
|
|
55
|
+
|
|
56
|
+
if (nextScreen) {
|
|
57
|
+
lastScreen = nextScreen;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (nextWorld) {
|
|
61
|
+
lastWorld = nextWorld;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return lastWorld ? { ...lastWorld } : null;
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
return {
|
|
68
|
+
screen() {
|
|
69
|
+
return lastScreen ? { ...lastScreen } : null;
|
|
70
|
+
},
|
|
71
|
+
|
|
72
|
+
world() {
|
|
73
|
+
return lastWorld ? { ...lastWorld } : null;
|
|
74
|
+
},
|
|
75
|
+
|
|
76
|
+
update,
|
|
77
|
+
|
|
78
|
+
updateFromEvent(event: any) {
|
|
79
|
+
const global = extractGlobalPoint(event);
|
|
80
|
+
const world = extractWorldPoint(event, global);
|
|
81
|
+
return update(global, world);
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { describe, expect, test, vi } from "vitest";
|
|
2
|
+
import { normalizeStandaloneMessage } from "./standalone-message";
|
|
3
|
+
|
|
4
|
+
describe("standalone websocket bridge", () => {
|
|
5
|
+
test("dispatches mock room object broadcasts to named listeners", () => {
|
|
6
|
+
const onSpawn = vi.fn();
|
|
7
|
+
const object = normalizeStandaloneMessage({
|
|
8
|
+
type: "projectile:spawnBatch",
|
|
9
|
+
value: {
|
|
10
|
+
projectiles: [{ id: "p1", type: "bolt" }],
|
|
11
|
+
},
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
if (object.type === "projectile:spawnBatch") {
|
|
15
|
+
onSpawn(object.value);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
expect(onSpawn).toHaveBeenCalledWith({
|
|
19
|
+
projectiles: [{ id: "p1", type: "bolt" }],
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
test("still accepts browser-style string messages", () => {
|
|
24
|
+
expect(normalizeStandaloneMessage({
|
|
25
|
+
data: JSON.stringify({
|
|
26
|
+
type: "projectile:spawnBatch",
|
|
27
|
+
value: { projectiles: [] },
|
|
28
|
+
}),
|
|
29
|
+
})).toEqual({
|
|
30
|
+
type: "projectile:spawnBatch",
|
|
31
|
+
value: { projectiles: [] },
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
});
|
|
@@ -7,6 +7,7 @@ import { LoadMapToken } from "./loadMap";
|
|
|
7
7
|
import { RpgGui } from "../Gui/Gui";
|
|
8
8
|
import { provideKeyboardControls } from "./keyboardControls";
|
|
9
9
|
import { provideSaveClient } from "./save";
|
|
10
|
+
import { normalizeStandaloneMessage } from "./standalone-message";
|
|
10
11
|
|
|
11
12
|
type ServerIo = any;
|
|
12
13
|
type ClientIo = any;
|
|
@@ -58,16 +59,16 @@ class BridgeWebsocket extends AbstractWebsocket {
|
|
|
58
59
|
}
|
|
59
60
|
})
|
|
60
61
|
listeners?.(this.socket)
|
|
61
|
-
await this.serverInstance.onConnect(this.socket.conn as any, { request } as any);
|
|
62
62
|
this.room.clients.set(this.socket.id, this.socket);
|
|
63
63
|
this.pendingOn.forEach(({ event, callback }) => this.socket.addEventListener(event, callback));
|
|
64
64
|
this.pendingOn = [];
|
|
65
|
+
await this.serverInstance.onConnect(this.socket.conn as any, { request } as any);
|
|
65
66
|
return this.socket
|
|
66
67
|
}
|
|
67
68
|
|
|
68
69
|
on(key: string, callback: (data: any) => void) {
|
|
69
70
|
const handler = (event) => {
|
|
70
|
-
const object =
|
|
71
|
+
const object = normalizeStandaloneMessage(event);
|
|
71
72
|
if (object.type === key) {
|
|
72
73
|
callback(object.value);
|
|
73
74
|
}
|