@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.
Files changed (65) hide show
  1. package/dist/component.d.ts +227 -9
  2. package/dist/component.js +185 -38
  3. package/dist/component.js.map +1 -1
  4. package/dist/css.d.ts +4 -0
  5. package/dist/css.js +4 -0
  6. package/dist/css.js.map +1 -1
  7. package/dist/decorators/attribute.d.ts +15 -15
  8. package/dist/decorators/attribute.js +28 -9
  9. package/dist/decorators/attribute.js.map +1 -1
  10. package/dist/decorators/attribute.test.js +58 -6
  11. package/dist/decorators/attribute.test.js.map +1 -1
  12. package/dist/decorators/connect.d.ts +2 -0
  13. package/dist/decorators/connect.js.map +1 -1
  14. package/dist/decorators/connect.test.js +1 -1
  15. package/dist/decorators/connect.test.js.map +1 -1
  16. package/dist/decorators/reactive.d.ts +1 -1
  17. package/dist/decorators/reactive.js +1 -1
  18. package/dist/decorators/reactive.js.map +1 -1
  19. package/dist/decorators/reactive.test.js +1 -1
  20. package/dist/decorators/reactive.test.js.map +1 -1
  21. package/dist/decorators/require.test.js +1 -1
  22. package/dist/decorators/require.test.js.map +1 -1
  23. package/dist/dom.d.ts +43 -1
  24. package/dist/dom.js +63 -15
  25. package/dist/dom.js.map +1 -1
  26. package/dist/dom.test.d.ts +1 -0
  27. package/dist/dom.test.js +20 -0
  28. package/dist/dom.test.js.map +1 -0
  29. package/dist/emitter.d.ts +8 -0
  30. package/dist/emitter.js.map +1 -1
  31. package/dist/event.d.ts +4 -0
  32. package/dist/event.js.map +1 -1
  33. package/dist/geometry.d.ts +7 -0
  34. package/dist/geometry.js +4 -0
  35. package/dist/geometry.js.map +1 -1
  36. package/dist/index.d.ts +2 -1
  37. package/dist/index.js +2 -1
  38. package/dist/index.js.map +1 -1
  39. package/dist/signal.d.ts +12 -3
  40. package/dist/signal.js +7 -1
  41. package/dist/signal.js.map +1 -1
  42. package/dist/signal.test.js +2 -2
  43. package/dist/signal.test.js.map +1 -1
  44. package/dist/test.d.ts +17 -0
  45. package/dist/test.js +34 -0
  46. package/dist/test.js.map +1 -0
  47. package/package.json +27 -19
  48. package/src/component.ts +289 -53
  49. package/src/css.ts +5 -0
  50. package/src/decorators/attribute.test.ts +41 -14
  51. package/src/decorators/attribute.ts +57 -29
  52. package/src/decorators/reactive.test.ts +1 -1
  53. package/src/decorators/reactive.ts +4 -4
  54. package/src/decorators/require.test.ts +1 -1
  55. package/src/dom.test.ts +23 -0
  56. package/src/dom.ts +87 -15
  57. package/src/emitter.ts +8 -0
  58. package/src/event.ts +4 -0
  59. package/src/geometry.ts +8 -0
  60. package/src/index.ts +2 -1
  61. package/src/signal.test.ts +2 -2
  62. package/src/signal.ts +13 -2
  63. package/src/test.ts +38 -0
  64. package/src/decorators/connect.test.ts +0 -119
  65. 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
- }