@adobe/data 0.5.14 → 0.5.16

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 (130) hide show
  1. package/dist/ecs/entity/entity.d.ts +8 -0
  2. package/dist/ecs/entity/entity.js +3 -0
  3. package/dist/ecs/entity/entity.js.map +1 -0
  4. package/dist/ecs/entity/u32.d.ts +8 -0
  5. package/dist/{lit/elements/service-context.js → ecs/entity/u32.js} +3 -3
  6. package/dist/ecs/entity/u32.js.map +1 -0
  7. package/dist/graphics/frame.d.ts +1 -22
  8. package/dist/graphics/frame.js +14 -11
  9. package/dist/graphics/frame.js.map +1 -1
  10. package/dist/graphics/get-web-gpu-device-and-context.d.ts +1 -2
  11. package/dist/graphics/get-web-gpu-device-and-context.js +23 -20
  12. package/dist/graphics/get-web-gpu-device-and-context.js.map +1 -1
  13. package/dist/graphics/graphics-context.d.ts +1 -5
  14. package/dist/graphics/graphics-context.js +5 -0
  15. package/dist/graphics/graphics-context.js.map +1 -1
  16. package/dist/math/aabb/aabb.d.ts +42 -42
  17. package/dist/math/aabb/aabb.js +65 -62
  18. package/dist/math/aabb/aabb.js.map +1 -1
  19. package/dist/math/aabb-face/aabb-face.d.ts +59 -0
  20. package/dist/math/aabb-face/aabb-face.js +145 -0
  21. package/dist/math/aabb-face/aabb-face.js.map +1 -0
  22. package/dist/math/aabb-face/aabb-face.test.d.ts +1 -0
  23. package/dist/math/aabb-face/aabb-face.test.js +54 -0
  24. package/dist/math/aabb-face/aabb-face.test.js.map +1 -0
  25. package/dist/math/aabb-face/face.d.ts +51 -0
  26. package/dist/math/aabb-face/face.js +110 -0
  27. package/dist/math/aabb-face/face.js.map +1 -0
  28. package/dist/math/aabb-face/face.test.d.ts +1 -0
  29. package/dist/math/aabb-face/face.test.js +94 -0
  30. package/dist/math/aabb-face/face.test.js.map +1 -0
  31. package/dist/math/box/box.d.ts +50 -0
  32. package/dist/math/box/box.js +23 -0
  33. package/dist/math/box/box.js.map +1 -0
  34. package/dist/math/f32/f32.d.ts +8 -6
  35. package/dist/math/f32/f32.js +4 -1
  36. package/dist/math/f32/f32.js.map +1 -1
  37. package/dist/math/face/face.d.ts +51 -0
  38. package/dist/math/face/face.js +110 -0
  39. package/dist/math/face/face.js.map +1 -0
  40. package/dist/math/face/face.test.d.ts +1 -0
  41. package/dist/math/face/face.test.js +94 -0
  42. package/dist/math/face/face.test.js.map +1 -0
  43. package/dist/math/i32/i32.d.ts +9 -6
  44. package/dist/math/i32/i32.js +5 -2
  45. package/dist/math/i32/i32.js.map +1 -1
  46. package/dist/math/index.d.ts +13 -22
  47. package/dist/math/index.js +13 -22
  48. package/dist/math/index.js.map +1 -1
  49. package/dist/math/line2/line2.d.ts +36 -36
  50. package/dist/math/line2/line2.js +55 -52
  51. package/dist/math/line2/line2.js.map +1 -1
  52. package/dist/math/line3/line3.d.ts +48 -43
  53. package/dist/math/line3/line3.js +64 -52
  54. package/dist/math/line3/line3.js.map +1 -1
  55. package/dist/math/mat4x4/mat4x4.d.ts +34 -34
  56. package/dist/math/mat4x4/mat4x4.js +216 -213
  57. package/dist/math/mat4x4/mat4x4.js.map +1 -1
  58. package/dist/math/picking/face.d.ts +1 -0
  59. package/dist/math/picking/face.js +2 -0
  60. package/dist/math/picking/face.js.map +1 -0
  61. package/dist/math/picking/get-closest-entity-to-line.d.ts +4 -0
  62. package/dist/math/picking/get-closest-entity-to-line.js +30 -0
  63. package/dist/math/picking/get-closest-entity-to-line.js.map +1 -0
  64. package/dist/math/picking/get-closest-entity-to-point.d.ts +4 -0
  65. package/dist/math/picking/get-closest-entity-to-point.js +27 -0
  66. package/dist/math/picking/get-closest-entity-to-point.js.map +1 -0
  67. package/dist/math/picking/get-intersecting-entities.d.ts +12 -0
  68. package/dist/math/picking/get-intersecting-entities.js +15 -0
  69. package/dist/math/picking/get-intersecting-entities.js.map +1 -0
  70. package/dist/math/picking/getClosestEntityToLine.d.ts +4 -0
  71. package/dist/math/picking/getClosestEntityToLine.js +29 -0
  72. package/dist/math/picking/getClosestEntityToLine.js.map +1 -0
  73. package/dist/math/picking/getClosestEntityToPoint.d.ts +4 -0
  74. package/dist/math/picking/getClosestEntityToPoint.js +27 -0
  75. package/dist/math/picking/getClosestEntityToPoint.js.map +1 -0
  76. package/dist/math/picking/getIntersectingEntities.d.ts +12 -0
  77. package/dist/math/picking/getIntersectingEntities.js +15 -0
  78. package/dist/math/picking/getIntersectingEntities.js.map +1 -0
  79. package/dist/math/picking/index.d.ts +4 -0
  80. package/dist/math/picking/index.js +4 -0
  81. package/dist/math/picking/index.js.map +1 -1
  82. package/dist/math/picking/pick-from-tables.d.ts +1 -0
  83. package/dist/math/picking/pick-from-tables.js +7 -98
  84. package/dist/math/picking/pick-from-tables.js.map +1 -1
  85. package/dist/math/picking/pick-result.d.ts +5 -2
  86. package/dist/math/plane/plane.d.ts +43 -0
  87. package/dist/math/plane/plane.js +70 -0
  88. package/dist/math/plane/plane.js.map +1 -0
  89. package/dist/math/plane/plane.test.d.ts +1 -0
  90. package/dist/math/plane/plane.test.js +132 -0
  91. package/dist/math/plane/plane.test.js.map +1 -0
  92. package/dist/math/quat/quat.d.ts +49 -39
  93. package/dist/math/quat/quat.js +225 -185
  94. package/dist/math/quat/quat.js.map +1 -1
  95. package/dist/math/u32/u32.d.ts +9 -7
  96. package/dist/math/u32/u32.js +4 -1
  97. package/dist/math/u32/u32.js.map +1 -1
  98. package/dist/math/vec2/vec2.d.ts +61 -61
  99. package/dist/math/vec2/vec2.js +93 -90
  100. package/dist/math/vec2/vec2.js.map +1 -1
  101. package/dist/math/vec3/vec3.d.ts +66 -63
  102. package/dist/math/vec3/vec3.js +137 -129
  103. package/dist/math/vec3/vec3.js.map +1 -1
  104. package/dist/math/vec4/vec4.d.ts +61 -61
  105. package/dist/math/vec4/vec4.js +132 -129
  106. package/dist/math/vec4/vec4.js.map +1 -1
  107. package/dist/observe/to-async-generator.js +4 -4
  108. package/dist/observe/to-async-generator.js.map +1 -1
  109. package/dist/old-ecs/action-ecs/action-ecs.test.js +1 -1
  110. package/dist/old-ecs/action-ecs/action-ecs.test.js.map +1 -1
  111. package/dist/old-ecs/action-ecs/action-types.d.ts +7 -0
  112. package/dist/old-ecs/action-ecs/action-types.js.map +1 -1
  113. package/dist/old-ecs/ecs/ecs-types.d.ts +7 -0
  114. package/dist/old-ecs/ecs/ecs.test.js +1 -1
  115. package/dist/old-ecs/ecs/ecs.test.js.map +1 -1
  116. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js +1 -1
  117. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js.map +1 -1
  118. package/dist/old-ecs/transaction-ecs/transaction-types.d.ts +7 -0
  119. package/dist/samples/todo/services/state-service/create-todo-database.d.ts +2 -2
  120. package/dist/samples/todo/services/state-service/create-todo-store.d.ts +2 -2
  121. package/dist/tsconfig.tsbuildinfo +1 -1
  122. package/package.json +6 -3
  123. package/dist/lit/elements/service-application.d.ts +0 -9
  124. package/dist/lit/elements/service-application.js +0 -55
  125. package/dist/lit/elements/service-application.js.map +0 -1
  126. package/dist/lit/elements/service-context.d.ts +0 -1
  127. package/dist/lit/elements/service-context.js.map +0 -1
  128. package/dist/lit/elements/service-element.d.ts +0 -6
  129. package/dist/lit/elements/service-element.js +0 -43
  130. package/dist/lit/elements/service-element.js.map +0 -1
@@ -0,0 +1,132 @@
1
+ /*MIT License
2
+
3
+ © Copyright 2025 Adobe. All rights reserved.
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.*/
22
+ import { describe, it, expect } from "vitest";
23
+ import { Plane } from "../index.js";
24
+ describe("Plane", () => {
25
+ const xyPlane = {
26
+ normal: [0, 0, 1], // pointing up
27
+ distance: 0 // plane at origin
28
+ };
29
+ const xyPlaneOffset = {
30
+ normal: [0, 0, 1], // pointing up
31
+ distance: 5 // plane 5 units above origin
32
+ };
33
+ describe("signedDistance", () => {
34
+ it("should return 0 for points on the plane", () => {
35
+ expect(Plane.signedDistance(xyPlane, [0, 0, 0])).toBe(0);
36
+ expect(Plane.signedDistance(xyPlane, [5, 3, 0])).toBe(0);
37
+ });
38
+ it("should return positive distance for points in front of plane", () => {
39
+ expect(Plane.signedDistance(xyPlane, [0, 0, 1])).toBe(1);
40
+ expect(Plane.signedDistance(xyPlane, [0, 0, 5])).toBe(5);
41
+ });
42
+ it("should return negative distance for points behind plane", () => {
43
+ expect(Plane.signedDistance(xyPlane, [0, 0, -1])).toBe(-1);
44
+ expect(Plane.signedDistance(xyPlane, [0, 0, -3])).toBe(-3);
45
+ });
46
+ it("should work with offset planes", () => {
47
+ expect(Plane.signedDistance(xyPlaneOffset, [0, 0, 5])).toBe(0); // on plane
48
+ expect(Plane.signedDistance(xyPlaneOffset, [0, 0, 7])).toBe(2); // 2 units above
49
+ expect(Plane.signedDistance(xyPlaneOffset, [0, 0, 3])).toBe(-2); // 2 units below
50
+ });
51
+ });
52
+ describe("distance", () => {
53
+ it("should return absolute distance", () => {
54
+ expect(Plane.distance(xyPlane, [0, 0, 3])).toBe(3);
55
+ expect(Plane.distance(xyPlane, [0, 0, -3])).toBe(3);
56
+ expect(Plane.distance(xyPlane, [0, 0, 0])).toBe(0);
57
+ });
58
+ });
59
+ describe("containsPoint", () => {
60
+ it("should return true for points on the plane", () => {
61
+ expect(Plane.containsPoint(xyPlane, [0, 0, 0])).toBe(true);
62
+ expect(Plane.containsPoint(xyPlane, [5, 3, 0])).toBe(true);
63
+ });
64
+ it("should return false for points off the plane", () => {
65
+ expect(Plane.containsPoint(xyPlane, [0, 0, 0.001])).toBe(false);
66
+ expect(Plane.containsPoint(xyPlane, [0, 0, -0.001])).toBe(false);
67
+ });
68
+ });
69
+ describe("isPointInFront", () => {
70
+ it("should return true for points in front of plane", () => {
71
+ expect(Plane.isPointInFront(xyPlane, [0, 0, 1])).toBe(true);
72
+ expect(Plane.isPointInFront(xyPlane, [0, 0, 5])).toBe(true);
73
+ });
74
+ it("should return false for points behind or on plane", () => {
75
+ expect(Plane.isPointInFront(xyPlane, [0, 0, 0])).toBe(false);
76
+ expect(Plane.isPointInFront(xyPlane, [0, 0, -1])).toBe(false);
77
+ });
78
+ });
79
+ describe("isPointBehind", () => {
80
+ it("should return true for points behind plane", () => {
81
+ expect(Plane.isPointBehind(xyPlane, [0, 0, -1])).toBe(true);
82
+ expect(Plane.isPointBehind(xyPlane, [0, 0, -5])).toBe(true);
83
+ });
84
+ it("should return false for points in front or on plane", () => {
85
+ expect(Plane.isPointBehind(xyPlane, [0, 0, 0])).toBe(false);
86
+ expect(Plane.isPointBehind(xyPlane, [0, 0, 1])).toBe(false);
87
+ });
88
+ });
89
+ describe("lineIntersection", () => {
90
+ it("should find intersection alpha for line crossing plane", () => {
91
+ const line = { a: [0, 0, -1], b: [0, 0, 1] }; // vertical line
92
+ const alpha = Plane.lineIntersection(xyPlane, line);
93
+ expect(alpha).toBe(0.5); // intersects at midpoint
94
+ });
95
+ it("should find intersection alpha for diagonal line", () => {
96
+ const line = { a: [1, 1, -1], b: [1, 1, 1] }; // diagonal line
97
+ const alpha = Plane.lineIntersection(xyPlane, line);
98
+ expect(alpha).toBe(0.5); // intersects at midpoint
99
+ });
100
+ it("should find intersection alpha for offset plane", () => {
101
+ const line = { a: [0, 0, 3], b: [0, 0, 7] }; // line above offset plane
102
+ const alpha = Plane.lineIntersection(xyPlaneOffset, line);
103
+ expect(alpha).toBe(0.5); // intersects at midpoint (z=5)
104
+ });
105
+ it("should return null for line parallel to plane", () => {
106
+ const line = { a: [0, 0, 1], b: [1, 0, 1] }; // horizontal line
107
+ const alpha = Plane.lineIntersection(xyPlane, line);
108
+ expect(alpha).toBeNull();
109
+ });
110
+ it("should return null for line in the plane", () => {
111
+ const line = { a: [0, 0, 0], b: [1, 0, 0] }; // line in xy plane
112
+ const alpha = Plane.lineIntersection(xyPlane, line);
113
+ expect(alpha).toBeNull();
114
+ });
115
+ it("should handle line that doesn't intersect within segment", () => {
116
+ const line = { a: [0, 0, 2], b: [0, 0, 4] }; // line above plane
117
+ const alpha = Plane.lineIntersection(xyPlane, line);
118
+ expect(alpha).toBe(-1); // intersection exists but before segment start
119
+ });
120
+ it("should handle alpha values outside segment", () => {
121
+ const line = { a: [0, 0, 2], b: [0, 0, 6] }; // line from z=2 to z=6
122
+ const alpha = Plane.lineIntersection(xyPlane, line);
123
+ expect(alpha).toBe(-0.5); // intersects at z=0, which is before segment start
124
+ });
125
+ it("should handle alpha values after segment end", () => {
126
+ const line = { a: [0, 0, -2], b: [0, 0, -1] }; // line from z=-2 to z=-1
127
+ const alpha = Plane.lineIntersection(xyPlane, line);
128
+ expect(alpha).toBe(2); // intersects at z=0, which is after segment end
129
+ });
130
+ });
131
+ });
132
+ //# sourceMappingURL=plane.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plane.test.js","sourceRoot":"","sources":["../../../src/math/plane/plane.test.ts"],"names":[],"mappings":"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"}
@@ -1,42 +1,52 @@
1
1
  import { FromSchema } from "../../schema/index.js";
2
2
  import { Vec3, Mat4x4 } from "../index.js";
3
- export declare const schema: {
4
- readonly type: "array";
5
- readonly items: {
6
- readonly type: "number";
7
- readonly precision: 1;
8
- readonly default: number;
3
+ export type Quat = FromSchema<typeof Quat.schema>;
4
+ export declare namespace Quat {
5
+ const schema: {
6
+ readonly type: "array";
7
+ readonly items: {
8
+ readonly type: "number";
9
+ readonly precision: 1;
10
+ readonly default: number;
11
+ };
12
+ readonly minItems: 4;
13
+ readonly maxItems: 4;
14
+ readonly default: readonly [0, 0, 0, 1];
9
15
  };
10
- readonly minItems: 4;
11
- readonly maxItems: 4;
12
- readonly default: readonly [0, 0, 0, 1];
13
- };
14
- export type Type = FromSchema<typeof schema>;
15
- type Quat = Type;
16
- export declare const layout: import("../../typed-buffer/index.js").StructLayout;
17
- export declare const add: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
18
- export declare const subtract: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
19
- export declare const scale: ([x, y, z, w]: Quat, s: number) => Quat;
20
- export declare const negate: ([x, y, z, w]: Quat) => Quat;
21
- export declare const conjugate: ([x, y, z, w]: Quat) => Quat;
22
- export declare const multiply: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
23
- export declare const length: ([x, y, z, w]: Quat) => number;
24
- export declare const lengthSquared: ([x, y, z, w]: Quat) => number;
25
- export declare const normalize: (q: Quat) => Quat;
26
- export declare const dot: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => number;
27
- export declare const distance: (a: Quat, b: Quat) => number;
28
- export declare const fromAxisAngle: (axis: Vec3, angle: number) => Quat;
29
- export declare const toAxisAngle: ([x, y, z, w]: Quat) => {
30
- axis: Vec3;
31
- angle: number;
32
- };
33
- export declare const fromEuler: (x: number, y: number, z: number) => Quat;
34
- export declare const toEuler: ([x, y, z, w]: Quat) => Vec3;
35
- export declare const rotateVec3: ([x, y, z, w]: Quat, v: Vec3) => Vec3;
36
- export declare const slerp: (q1: Quat, q2: Quat, t: number) => Quat;
37
- export declare const lerp: (q1: Quat, q2: Quat, t: number) => Quat;
38
- export declare const toMat4: ([x, y, z, w]: Quat) => Mat4x4;
39
- export declare const identity: () => Quat;
40
- export declare const inverse: (q: Quat) => Quat;
41
- export declare const lookAt: (forward: Vec3, up: Vec3) => Quat;
42
- export {};
16
+ const layout: import("../../typed-buffer/index.js").StructLayout;
17
+ const add: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
18
+ const subtract: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
19
+ const scale: ([x, y, z, w]: Quat, s: number) => Quat;
20
+ const negate: ([x, y, z, w]: Quat) => Quat;
21
+ const conjugate: ([x, y, z, w]: Quat) => Quat;
22
+ const multiply: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => Quat;
23
+ const length: ([x, y, z, w]: Quat) => number;
24
+ const lengthSquared: ([x, y, z, w]: Quat) => number;
25
+ const normalize: (q: Quat) => Quat;
26
+ const dot: ([x1, y1, z1, w1]: Quat, [x2, y2, z2, w2]: Quat) => number;
27
+ const distance: (a: Quat, b: Quat) => number;
28
+ const fromAxisAngle: (axis: Vec3, angle: number) => Quat;
29
+ const toAxisAngle: ([x, y, z, w]: Quat) => {
30
+ axis: Vec3;
31
+ angle: number;
32
+ };
33
+ const fromEuler: (x: number, y: number, z: number) => Quat;
34
+ const toEuler: ([x, y, z, w]: Quat) => Vec3;
35
+ const rotateVec3: ([x, y, z, w]: Quat, v: Vec3) => Vec3;
36
+ const slerp: (q1: Quat, q2: Quat, t: number) => Quat;
37
+ const lerp: (q1: Quat, q2: Quat, t: number) => Quat;
38
+ const toMat4: ([x, y, z, w]: Quat) => Mat4x4;
39
+ const identity: Quat;
40
+ const inverse: (q: Quat) => Quat;
41
+ const lookAt: (forward: Vec3, up: Vec3) => Quat;
42
+ /**
43
+ * Returns a quaternion that aligns the local Z-axis to the given direction via the shortest arc,
44
+ * then applies an additional twist around that aligned Z-axis.
45
+ *
46
+ * Note: This aligns the Z axis.
47
+ *
48
+ * @param direction - Target world-space direction for local Z. If zero-length, returns identity.
49
+ * @param twistRadians - Extra rotation around the aligned Z-axis, in radians. Defaults to 0.
50
+ */
51
+ const alignTo: (direction: Vec3, twistRadians?: number) => Quat;
52
+ }