@bodil/dom 0.1.9 → 0.2.0
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/component.d.ts +227 -9
- package/dist/component.js +185 -38
- package/dist/component.js.map +1 -1
- package/dist/css.d.ts +4 -0
- package/dist/css.js +4 -0
- package/dist/css.js.map +1 -1
- package/dist/decorators/attribute.d.ts +15 -15
- package/dist/decorators/attribute.js +28 -9
- package/dist/decorators/attribute.js.map +1 -1
- package/dist/decorators/attribute.test.js +58 -6
- package/dist/decorators/attribute.test.js.map +1 -1
- package/dist/decorators/connect.d.ts +2 -0
- package/dist/decorators/connect.js.map +1 -1
- package/dist/decorators/connect.test.js +1 -1
- package/dist/decorators/connect.test.js.map +1 -1
- package/dist/decorators/reactive.d.ts +1 -1
- package/dist/decorators/reactive.js +1 -1
- package/dist/decorators/reactive.js.map +1 -1
- package/dist/decorators/reactive.test.js +1 -1
- package/dist/decorators/reactive.test.js.map +1 -1
- package/dist/decorators/require.test.js +1 -1
- package/dist/decorators/require.test.js.map +1 -1
- package/dist/dom.d.ts +43 -1
- package/dist/dom.js +63 -15
- package/dist/dom.js.map +1 -1
- package/dist/dom.test.d.ts +1 -0
- package/dist/dom.test.js +20 -0
- package/dist/dom.test.js.map +1 -0
- package/dist/emitter.d.ts +8 -0
- package/dist/emitter.js.map +1 -1
- package/dist/event.d.ts +4 -0
- package/dist/event.js.map +1 -1
- package/dist/geometry.d.ts +7 -0
- package/dist/geometry.js +4 -0
- package/dist/geometry.js.map +1 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/signal.d.ts +12 -3
- package/dist/signal.js +7 -1
- package/dist/signal.js.map +1 -1
- package/dist/signal.test.js +2 -2
- package/dist/signal.test.js.map +1 -1
- package/dist/test.d.ts +17 -0
- package/dist/test.js +34 -0
- package/dist/test.js.map +1 -0
- package/package.json +27 -19
- package/src/component.ts +289 -53
- package/src/css.ts +5 -0
- package/src/decorators/attribute.test.ts +41 -14
- package/src/decorators/attribute.ts +57 -29
- package/src/decorators/reactive.test.ts +1 -1
- package/src/decorators/reactive.ts +4 -4
- package/src/decorators/require.test.ts +1 -1
- package/src/dom.test.ts +23 -0
- package/src/dom.ts +87 -15
- package/src/emitter.ts +8 -0
- package/src/event.ts +4 -0
- package/src/geometry.ts +8 -0
- package/src/index.ts +2 -1
- package/src/signal.test.ts +2 -2
- package/src/signal.ts +13 -2
- package/src/test.ts +38 -0
- package/src/decorators/connect.test.ts +0 -119
- package/src/decorators/connect.ts +0 -85
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import { sleep } from "@bodil/core/async";
|
|
2
|
-
import { Signal } from "@bodil/signal";
|
|
3
|
-
import { customElement } from "lit/decorators.js";
|
|
4
|
-
import { expect, test } from "vitest";
|
|
5
|
-
|
|
6
|
-
import { Component, connect, connectEffect } from "../component";
|
|
7
|
-
import type { ConnectFunction } from "./connect";
|
|
8
|
-
|
|
9
|
-
test("@connect", () => {
|
|
10
|
-
let methodConnected = 0,
|
|
11
|
-
methodDisconnected = 0;
|
|
12
|
-
let fieldConnected = 0,
|
|
13
|
-
fieldDisconnected = 0;
|
|
14
|
-
|
|
15
|
-
@customElement("connected-test-class")
|
|
16
|
-
class ConnectedTestClass extends Component {
|
|
17
|
-
@connect onConnected() {
|
|
18
|
-
methodConnected++;
|
|
19
|
-
return () => {
|
|
20
|
-
methodDisconnected++;
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
@connect field: ConnectFunction = () => {
|
|
25
|
-
fieldConnected++;
|
|
26
|
-
return () => {
|
|
27
|
-
fieldDisconnected++;
|
|
28
|
-
};
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const c = document.createElement("connected-test-class") as ConnectedTestClass;
|
|
33
|
-
expect(methodConnected).toBe(0);
|
|
34
|
-
expect(methodDisconnected).toBe(0);
|
|
35
|
-
expect(fieldConnected).toEqual(methodConnected);
|
|
36
|
-
expect(fieldDisconnected).toEqual(methodDisconnected);
|
|
37
|
-
document.body.append(c);
|
|
38
|
-
expect(methodConnected).toBe(1);
|
|
39
|
-
expect(methodDisconnected).toBe(0);
|
|
40
|
-
expect(fieldConnected).toEqual(methodConnected);
|
|
41
|
-
expect(fieldDisconnected).toEqual(methodDisconnected);
|
|
42
|
-
c.remove();
|
|
43
|
-
expect(methodConnected).toBe(1);
|
|
44
|
-
expect(methodDisconnected).toBe(1);
|
|
45
|
-
expect(fieldConnected).toEqual(methodConnected);
|
|
46
|
-
expect(fieldDisconnected).toEqual(methodDisconnected);
|
|
47
|
-
document.body.append(c);
|
|
48
|
-
expect(methodConnected).toBe(2);
|
|
49
|
-
expect(methodDisconnected).toBe(1);
|
|
50
|
-
expect(fieldConnected).toEqual(methodConnected);
|
|
51
|
-
expect(fieldDisconnected).toEqual(methodDisconnected);
|
|
52
|
-
c.remove();
|
|
53
|
-
expect(methodConnected).toBe(2);
|
|
54
|
-
expect(methodDisconnected).toBe(2);
|
|
55
|
-
expect(fieldConnected).toEqual(methodConnected);
|
|
56
|
-
expect(fieldDisconnected).toEqual(methodDisconnected);
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
test("@connectEffect", async () => {
|
|
60
|
-
let methodRun = 0,
|
|
61
|
-
methodDisposed = 0;
|
|
62
|
-
let fieldRun = 0,
|
|
63
|
-
fieldDisposed = 0;
|
|
64
|
-
const signal = Signal(1);
|
|
65
|
-
|
|
66
|
-
@customElement("connect-effect-test-class")
|
|
67
|
-
class ConnectEffectTestClass extends Component {
|
|
68
|
-
@connectEffect onConnected() {
|
|
69
|
-
methodRun += signal.get();
|
|
70
|
-
return () => {
|
|
71
|
-
methodDisposed++;
|
|
72
|
-
};
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
@connectEffect field: ConnectFunction = () => {
|
|
76
|
-
fieldRun += signal.get();
|
|
77
|
-
return () => {
|
|
78
|
-
fieldDisposed++;
|
|
79
|
-
};
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
const c = document.createElement("connect-effect-test-class") as ConnectEffectTestClass;
|
|
84
|
-
expect(methodRun).toBe(0);
|
|
85
|
-
expect(methodDisposed).toBe(0);
|
|
86
|
-
expect(fieldRun).toEqual(methodRun);
|
|
87
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
88
|
-
document.body.append(c);
|
|
89
|
-
await c.updateComplete;
|
|
90
|
-
expect(methodRun).toBe(1);
|
|
91
|
-
expect(methodDisposed).toBe(0);
|
|
92
|
-
expect(fieldRun).toEqual(methodRun);
|
|
93
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
94
|
-
c.remove();
|
|
95
|
-
expect(methodRun).toBe(1);
|
|
96
|
-
expect(methodDisposed).toBe(1);
|
|
97
|
-
expect(fieldRun).toEqual(methodRun);
|
|
98
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
99
|
-
document.body.append(c);
|
|
100
|
-
expect(methodRun).toBe(2);
|
|
101
|
-
expect(methodDisposed).toBe(1);
|
|
102
|
-
expect(fieldRun).toEqual(methodRun);
|
|
103
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
104
|
-
signal.set(2);
|
|
105
|
-
// wait for the effect to run
|
|
106
|
-
await sleep(1);
|
|
107
|
-
// run should be bumped by 2, the new value of the signal, and
|
|
108
|
-
// disposed should be bumped by 1 because the previous effect is
|
|
109
|
-
// disposed.
|
|
110
|
-
expect(methodRun).toBe(4);
|
|
111
|
-
expect(methodDisposed).toBe(2);
|
|
112
|
-
expect(fieldRun).toEqual(methodRun);
|
|
113
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
114
|
-
c.remove();
|
|
115
|
-
expect(methodRun).toBe(4);
|
|
116
|
-
expect(methodDisposed).toBe(3);
|
|
117
|
-
expect(fieldRun).toEqual(methodRun);
|
|
118
|
-
expect(fieldDisposed).toEqual(methodDisposed);
|
|
119
|
-
});
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import type { Disposifiable } from "@bodil/core/disposable";
|
|
2
|
-
import { Signal } from "@bodil/signal";
|
|
3
|
-
|
|
4
|
-
import type { Component } from "../component";
|
|
5
|
-
|
|
6
|
-
export type ConnectFunctionReturnValue =
|
|
7
|
-
| Disposifiable
|
|
8
|
-
| Iterable<Disposifiable | undefined>
|
|
9
|
-
| undefined
|
|
10
|
-
| void;
|
|
11
|
-
|
|
12
|
-
export type ConnectFunction = () => ConnectFunctionReturnValue;
|
|
13
|
-
|
|
14
|
-
const connectedCache = new WeakMap<Component, Set<ConnectFunction>>();
|
|
15
|
-
|
|
16
|
-
function addConnectedJob(obj: Component, job: ConnectFunction) {
|
|
17
|
-
let jobs = connectedCache.get(obj);
|
|
18
|
-
if (jobs === undefined) {
|
|
19
|
-
jobs = new Set();
|
|
20
|
-
connectedCache.set(obj, jobs);
|
|
21
|
-
}
|
|
22
|
-
jobs.add(job);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export function connectedJobs(obj: Component): Iterable<ConnectFunction> {
|
|
26
|
-
return connectedCache.get(obj) ?? [];
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function connect<C extends Component>(
|
|
30
|
-
value: ConnectFunction,
|
|
31
|
-
context: ClassMethodDecoratorContext<C, ConnectFunction>,
|
|
32
|
-
): undefined;
|
|
33
|
-
export function connect<C extends Component>(
|
|
34
|
-
value: undefined,
|
|
35
|
-
context: ClassFieldDecoratorContext<C, ConnectFunction>,
|
|
36
|
-
): (value: ConnectFunction) => ConnectFunction;
|
|
37
|
-
export function connect<C extends Component>(
|
|
38
|
-
value: ConnectFunction | undefined,
|
|
39
|
-
context:
|
|
40
|
-
| ClassMethodDecoratorContext<C, ConnectFunction>
|
|
41
|
-
| ClassFieldDecoratorContext<C, ConnectFunction>,
|
|
42
|
-
): ((value: ConnectFunction) => void) | undefined {
|
|
43
|
-
switch (context.kind) {
|
|
44
|
-
case "method":
|
|
45
|
-
context.addInitializer(function (this: C) {
|
|
46
|
-
addConnectedJob(this, value!.bind(this));
|
|
47
|
-
});
|
|
48
|
-
return;
|
|
49
|
-
case "field":
|
|
50
|
-
return function (this: C, value: ConnectFunction) {
|
|
51
|
-
addConnectedJob(this, value.bind(this));
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export function connectEffect<C extends Component>(
|
|
57
|
-
value: ConnectFunction,
|
|
58
|
-
context: ClassMethodDecoratorContext<C, ConnectFunction>,
|
|
59
|
-
): undefined;
|
|
60
|
-
export function connectEffect<C extends Component>(
|
|
61
|
-
value: undefined,
|
|
62
|
-
context: ClassFieldDecoratorContext<C, ConnectFunction>,
|
|
63
|
-
): (value: ConnectFunction) => ConnectFunction;
|
|
64
|
-
export function connectEffect<C extends Component>(
|
|
65
|
-
value: ConnectFunction | undefined,
|
|
66
|
-
context:
|
|
67
|
-
| ClassMethodDecoratorContext<C, ConnectFunction>
|
|
68
|
-
| ClassFieldDecoratorContext<C, ConnectFunction>,
|
|
69
|
-
): ((value: ConnectFunction) => void) | undefined {
|
|
70
|
-
switch (context.kind) {
|
|
71
|
-
case "method":
|
|
72
|
-
context.addInitializer(function (this: C) {
|
|
73
|
-
addConnectedJob(this, function (this: Component) {
|
|
74
|
-
return Signal.effect(value!.bind(this) as any);
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
return;
|
|
78
|
-
case "field":
|
|
79
|
-
return function (this: C, value: ConnectFunction) {
|
|
80
|
-
addConnectedJob(this, function (this: Component) {
|
|
81
|
-
return Signal.effect(value.bind(this) as any);
|
|
82
|
-
});
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
}
|