@adobe/data 0.5.14 → 0.5.17

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 (94) hide show
  1. package/dist/ecs/database/create-database.test.js +11 -0
  2. package/dist/ecs/database/create-database.test.js.map +1 -1
  3. package/dist/math/aabb/aabb.d.ts +42 -42
  4. package/dist/math/aabb/aabb.js +65 -62
  5. package/dist/math/aabb/aabb.js.map +1 -1
  6. package/dist/math/aabb-face/aabb-face.d.ts +59 -0
  7. package/dist/math/aabb-face/aabb-face.js +145 -0
  8. package/dist/math/aabb-face/aabb-face.js.map +1 -0
  9. package/dist/math/aabb-face/aabb-face.test.d.ts +1 -0
  10. package/dist/math/aabb-face/aabb-face.test.js +54 -0
  11. package/dist/math/aabb-face/aabb-face.test.js.map +1 -0
  12. package/dist/math/f32/f32.d.ts +8 -6
  13. package/dist/math/f32/f32.js +4 -1
  14. package/dist/math/f32/f32.js.map +1 -1
  15. package/dist/math/i32/i32.d.ts +9 -6
  16. package/dist/math/i32/i32.js +5 -2
  17. package/dist/math/i32/i32.js.map +1 -1
  18. package/dist/math/index.d.ts +13 -22
  19. package/dist/math/index.js +13 -22
  20. package/dist/math/index.js.map +1 -1
  21. package/dist/math/line2/line2.d.ts +36 -36
  22. package/dist/math/line2/line2.js +55 -52
  23. package/dist/math/line2/line2.js.map +1 -1
  24. package/dist/math/line3/line3.d.ts +48 -43
  25. package/dist/math/line3/line3.js +64 -52
  26. package/dist/math/line3/line3.js.map +1 -1
  27. package/dist/math/mat4x4/mat4x4.d.ts +34 -34
  28. package/dist/math/mat4x4/mat4x4.js +216 -213
  29. package/dist/math/mat4x4/mat4x4.js.map +1 -1
  30. package/dist/math/picking/get-closest-entity-to-line.d.ts +4 -0
  31. package/dist/math/picking/get-closest-entity-to-line.js +30 -0
  32. package/dist/math/picking/get-closest-entity-to-line.js.map +1 -0
  33. package/dist/math/picking/get-closest-entity-to-point.d.ts +4 -0
  34. package/dist/math/picking/get-closest-entity-to-point.js +27 -0
  35. package/dist/math/picking/get-closest-entity-to-point.js.map +1 -0
  36. package/dist/math/picking/get-intersecting-entities.d.ts +12 -0
  37. package/dist/math/picking/get-intersecting-entities.js +15 -0
  38. package/dist/math/picking/get-intersecting-entities.js.map +1 -0
  39. package/dist/math/picking/index.d.ts +4 -0
  40. package/dist/math/picking/index.js +4 -0
  41. package/dist/math/picking/index.js.map +1 -1
  42. package/dist/math/picking/pick-from-tables.d.ts +1 -0
  43. package/dist/math/picking/pick-from-tables.js +7 -98
  44. package/dist/math/picking/pick-from-tables.js.map +1 -1
  45. package/dist/math/picking/pick-result.d.ts +5 -2
  46. package/dist/math/plane/plane.d.ts +43 -0
  47. package/dist/math/plane/plane.js +70 -0
  48. package/dist/math/plane/plane.js.map +1 -0
  49. package/dist/math/plane/plane.test.d.ts +1 -0
  50. package/dist/math/plane/plane.test.js +132 -0
  51. package/dist/math/plane/plane.test.js.map +1 -0
  52. package/dist/math/quat/quat.d.ts +49 -39
  53. package/dist/math/quat/quat.js +225 -185
  54. package/dist/math/quat/quat.js.map +1 -1
  55. package/dist/math/u32/u32.d.ts +9 -7
  56. package/dist/math/u32/u32.js +4 -1
  57. package/dist/math/u32/u32.js.map +1 -1
  58. package/dist/math/vec2/vec2.d.ts +61 -61
  59. package/dist/math/vec2/vec2.js +93 -90
  60. package/dist/math/vec2/vec2.js.map +1 -1
  61. package/dist/math/vec3/vec3.d.ts +66 -63
  62. package/dist/math/vec3/vec3.js +137 -129
  63. package/dist/math/vec3/vec3.js.map +1 -1
  64. package/dist/math/vec4/vec4.d.ts +61 -61
  65. package/dist/math/vec4/vec4.js +132 -129
  66. package/dist/math/vec4/vec4.js.map +1 -1
  67. package/dist/observe/to-async-generator.js +4 -4
  68. package/dist/observe/to-async-generator.js.map +1 -1
  69. package/dist/old-ecs/action-ecs/action-ecs.test.js +1 -1
  70. package/dist/old-ecs/action-ecs/action-ecs.test.js.map +1 -1
  71. package/dist/old-ecs/action-ecs/action-types.d.ts +7 -0
  72. package/dist/old-ecs/action-ecs/action-types.js.map +1 -1
  73. package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js +205 -1
  74. package/dist/old-ecs/core-ecs/core-ecs-serialization.test.js.map +1 -1
  75. package/dist/old-ecs/core-ecs/core-ecs-types.d.ts +4 -1
  76. package/dist/old-ecs/core-ecs/core-ecs.d.ts +2 -0
  77. package/dist/old-ecs/core-ecs/core-ecs.js +23 -9
  78. package/dist/old-ecs/core-ecs/core-ecs.js.map +1 -1
  79. package/dist/old-ecs/ecs/ecs-types.d.ts +7 -0
  80. package/dist/old-ecs/ecs/ecs.test.js +1 -1
  81. package/dist/old-ecs/ecs/ecs.test.js.map +1 -1
  82. package/dist/old-ecs/privacy/helper-functions.d.ts +43 -0
  83. package/dist/old-ecs/privacy/helper-functions.js +76 -0
  84. package/dist/old-ecs/privacy/helper-functions.js.map +1 -0
  85. package/dist/old-ecs/privacy/helper-functions.test.d.ts +1 -0
  86. package/dist/old-ecs/privacy/helper-functions.test.js +173 -0
  87. package/dist/old-ecs/privacy/helper-functions.test.js.map +1 -0
  88. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js +1 -1
  89. package/dist/old-ecs/transaction-ecs/transaction-ecs.test.js.map +1 -1
  90. package/dist/old-ecs/transaction-ecs/transaction-types.d.ts +7 -0
  91. package/dist/samples/todo/services/state-service/create-todo-database.d.ts +2 -2
  92. package/dist/samples/todo/services/state-service/create-todo-store.d.ts +2 -2
  93. package/dist/tsconfig.tsbuildinfo +1 -1
  94. package/package.json +6 -3
@@ -0,0 +1,145 @@
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 { Aabb } from "../index.js";
23
+ export var AabbFace;
24
+ (function (AabbFace) {
25
+ AabbFace.schema = {
26
+ type: 'number',
27
+ minimum: 0,
28
+ maximum: 5,
29
+ };
30
+ /**
31
+ * AABB face direction constants for cube faces
32
+ */
33
+ AabbFace.POS_Z = 0;
34
+ AabbFace.POS_X = 1;
35
+ AabbFace.NEG_Z = 2;
36
+ AabbFace.NEG_X = 3;
37
+ AabbFace.POS_Y = 4;
38
+ AabbFace.NEG_Y = 5;
39
+ /**
40
+ * Array of all face directions
41
+ */
42
+ AabbFace.ALL_FACES = [AabbFace.POS_Z, AabbFace.POS_X, AabbFace.NEG_Z, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y];
43
+ /**
44
+ * AABB face direction names for debugging/logging
45
+ */
46
+ AabbFace.FACE_NAMES = [
47
+ 'POS_Z', 'POS_X', 'NEG_Z', 'NEG_X', 'POS_Y', 'NEG_Y'
48
+ ];
49
+ /**
50
+ * Get the AABB face name for debugging/logging
51
+ */
52
+ AabbFace.getName = (face) => {
53
+ return AabbFace.FACE_NAMES[face];
54
+ };
55
+ /**
56
+ * Get the normal vector for a given AABB face
57
+ */
58
+ AabbFace.getNormal = (face) => {
59
+ switch (face) {
60
+ case AabbFace.POS_Z: return [0, 0, 1];
61
+ case AabbFace.NEG_Z: return [0, 0, -1];
62
+ case AabbFace.POS_X: return [1, 0, 0];
63
+ case AabbFace.NEG_X: return [-1, 0, 0];
64
+ case AabbFace.POS_Y: return [0, 1, 0];
65
+ case AabbFace.NEG_Y: return [0, -1, 0];
66
+ default: throw new Error(`Invalid face index: ${face}`);
67
+ }
68
+ };
69
+ /**
70
+ * Get the opposite AABB face
71
+ */
72
+ AabbFace.getOpposite = (face) => {
73
+ switch (face) {
74
+ case AabbFace.POS_Z: return AabbFace.NEG_Z;
75
+ case AabbFace.NEG_Z: return AabbFace.POS_Z;
76
+ case AabbFace.POS_X: return AabbFace.NEG_X;
77
+ case AabbFace.NEG_X: return AabbFace.POS_X;
78
+ case AabbFace.POS_Y: return AabbFace.NEG_Y;
79
+ case AabbFace.NEG_Y: return AabbFace.POS_Y;
80
+ default: throw new Error(`Invalid face index: ${face}`);
81
+ }
82
+ };
83
+ /**
84
+ * Check if two AABB faces are opposite
85
+ */
86
+ AabbFace.isOpposite = (face1, face2) => {
87
+ return AabbFace.getOpposite(face1) === face2;
88
+ };
89
+ /**
90
+ * Get all AABB faces adjacent to the given face (faces that share an edge)
91
+ */
92
+ AabbFace.getAdjacent = (face) => {
93
+ switch (face) {
94
+ case AabbFace.POS_Z:
95
+ case AabbFace.NEG_Z:
96
+ return [AabbFace.POS_X, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y];
97
+ case AabbFace.POS_X:
98
+ case AabbFace.NEG_X:
99
+ return [AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_Y, AabbFace.NEG_Y];
100
+ case AabbFace.POS_Y:
101
+ case AabbFace.NEG_Y:
102
+ return [AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_X, AabbFace.NEG_X];
103
+ default:
104
+ throw new Error(`Invalid face index: ${face}`);
105
+ }
106
+ };
107
+ /**
108
+ * Check if two AABB faces are adjacent (share an edge)
109
+ */
110
+ AabbFace.isAdjacent = (face1, face2) => {
111
+ return AabbFace.getAdjacent(face1).includes(face2);
112
+ };
113
+ /**
114
+ * Determines which AABB face a position is closest to.
115
+ * Assumes the position is in normalized coordinate space - a cube with size 1 centered on the origin.
116
+ * @param position World position of the intersection point
117
+ * @param aabb Bounding box of the cube
118
+ * @returns AabbFace index: 0=POS_Z, 1=POS_X, 2=NEG_Z, 3=NEG_X, 4=POS_Y, 5=NEG_Y
119
+ */
120
+ AabbFace.fromPosition = (position, aabb) => {
121
+ const aabbCenter = Aabb.center(aabb);
122
+ const localPos = [
123
+ position[0] - aabbCenter[0],
124
+ position[1] - aabbCenter[1],
125
+ position[2] - aabbCenter[2]
126
+ ];
127
+ // Find the face with the largest absolute coordinate (closest to cube surface)
128
+ const absX = Math.abs(localPos[0]);
129
+ const absY = Math.abs(localPos[1]);
130
+ const absZ = Math.abs(localPos[2]);
131
+ if (absX >= absY && absX >= absZ) {
132
+ // X-axis face (NEG_X or POS_X)
133
+ return localPos[0] > 0 ? AabbFace.POS_X : AabbFace.NEG_X;
134
+ }
135
+ else if (absY >= absZ) {
136
+ // Y-axis face (NEG_Y or POS_Y)
137
+ return localPos[1] > 0 ? AabbFace.POS_Y : AabbFace.NEG_Y;
138
+ }
139
+ else {
140
+ // Z-axis face (NEG_Z or POS_Z)
141
+ return localPos[2] > 0 ? AabbFace.POS_Z : AabbFace.NEG_Z;
142
+ }
143
+ };
144
+ })(AabbFace || (AabbFace = {}));
145
+ //# sourceMappingURL=aabb-face.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aabb-face.js","sourceRoot":"","sources":["../../../src/math/aabb-face/aabb-face.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,54 @@
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 { AabbFace } from './aabb-face.js';
24
+ describe('AabbFace', () => {
25
+ it('should get correct opposite faces', () => {
26
+ expect(AabbFace.getOpposite(AabbFace.POS_Z)).toBe(AabbFace.NEG_Z);
27
+ expect(AabbFace.getOpposite(AabbFace.POS_X)).toBe(AabbFace.NEG_X);
28
+ expect(AabbFace.getOpposite(AabbFace.POS_Y)).toBe(AabbFace.NEG_Y);
29
+ });
30
+ it('should get correct adjacent faces for each axis', () => {
31
+ const posZAdjacent = AabbFace.getAdjacent(AabbFace.POS_Z);
32
+ expect(posZAdjacent).toEqual([AabbFace.POS_X, AabbFace.NEG_X, AabbFace.POS_Y, AabbFace.NEG_Y]);
33
+ const posXAdjacent = AabbFace.getAdjacent(AabbFace.POS_X);
34
+ expect(posXAdjacent).toEqual([AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_Y, AabbFace.NEG_Y]);
35
+ const posYAdjacent = AabbFace.getAdjacent(AabbFace.POS_Y);
36
+ expect(posYAdjacent).toEqual([AabbFace.POS_Z, AabbFace.NEG_Z, AabbFace.POS_X, AabbFace.NEG_X]);
37
+ });
38
+ it('should throw error for invalid face indices', () => {
39
+ expect(() => AabbFace.getNormal(6)).toThrow('Invalid face index: 6');
40
+ expect(() => AabbFace.getOpposite(6)).toThrow('Invalid face index: 6');
41
+ expect(() => AabbFace.getAdjacent(6)).toThrow('Invalid face index: 6');
42
+ });
43
+ it('should determine face from position correctly', () => {
44
+ const aabb = { min: [-1, -1, -1], max: [1, 1, 1] }; // Unit cube centered at origin
45
+ // Test positions on each face
46
+ expect(AabbFace.fromPosition([1, 0, 0], aabb)).toBe(AabbFace.POS_X);
47
+ expect(AabbFace.fromPosition([-1, 0, 0], aabb)).toBe(AabbFace.NEG_X);
48
+ expect(AabbFace.fromPosition([0, 1, 0], aabb)).toBe(AabbFace.POS_Y);
49
+ expect(AabbFace.fromPosition([0, -1, 0], aabb)).toBe(AabbFace.NEG_Y);
50
+ expect(AabbFace.fromPosition([0, 0, 1], aabb)).toBe(AabbFace.POS_Z);
51
+ expect(AabbFace.fromPosition([0, 0, -1], aabb)).toBe(AabbFace.NEG_Z);
52
+ });
53
+ });
54
+ //# sourceMappingURL=aabb-face.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aabb-face.test.js","sourceRoot":"","sources":["../../../src/math/aabb-face/aabb-face.test.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,9 @@
1
1
  import { FromSchema } from "../../schema/index.js";
2
- export declare const schema: {
3
- readonly type: "number";
4
- readonly precision: 1;
5
- readonly default: number;
6
- };
7
- export type Type = FromSchema<typeof schema>;
2
+ export type F32 = FromSchema<typeof F32.schema>;
3
+ export declare namespace F32 {
4
+ const schema: {
5
+ readonly type: "number";
6
+ readonly precision: 1;
7
+ readonly default: number;
8
+ };
9
+ }
@@ -20,5 +20,8 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
20
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
21
  SOFTWARE.*/
22
22
  import { F32Schema } from "../../schema/index.js";
23
- export const schema = F32Schema;
23
+ export var F32;
24
+ (function (F32) {
25
+ F32.schema = F32Schema;
26
+ })(F32 || (F32 = {}));
24
27
  //# sourceMappingURL=f32.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"f32.js","sourceRoot":"","sources":["../../../src/math/f32/f32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAC9D,MAAM,CAAC,MAAM,MAAM,GAAG,SAAS,CAAA"}
1
+ {"version":3,"file":"f32.js","sourceRoot":"","sources":["../../../src/math/f32/f32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAI9D,MAAM,KAAW,GAAG,CAEnB;AAFD,WAAiB,GAAG;IACH,UAAM,GAAG,SAAS,CAAC;AACpC,CAAC,EAFgB,GAAG,KAAH,GAAG,QAEnB"}
@@ -1,7 +1,10 @@
1
1
  import { FromSchema } from "../../schema/index.js";
2
- export declare const schema: {
3
- readonly type: "number";
4
- readonly precision: 1;
5
- readonly default: number;
6
- };
7
- export type Type = FromSchema<typeof schema>;
2
+ export type I32 = FromSchema<typeof I32.schema>;
3
+ export declare namespace I32 {
4
+ const schema: {
5
+ readonly type: "integer";
6
+ readonly minimum: -2147483648;
7
+ readonly maximum: 2147483647;
8
+ readonly default: number;
9
+ };
10
+ }
@@ -19,6 +19,9 @@ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
19
  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
20
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
21
  SOFTWARE.*/
22
- import { F32Schema } from "../../schema/index.js";
23
- export const schema = F32Schema;
22
+ import { I32Schema } from "../../schema/index.js";
23
+ export var I32;
24
+ (function (I32) {
25
+ I32.schema = I32Schema;
26
+ })(I32 || (I32 = {}));
24
27
  //# sourceMappingURL=i32.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"i32.js","sourceRoot":"","sources":["../../../src/math/i32/i32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAC9D,MAAM,CAAC,MAAM,MAAM,GAAG,SAAS,CAAA"}
1
+ {"version":3,"file":"i32.js","sourceRoot":"","sources":["../../../src/math/i32/i32.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,OAAO,EAAE,SAAS,EAAc,MAAM,uBAAuB,CAAC;AAI9D,MAAM,KAAW,GAAG,CAEnB;AAFD,WAAiB,GAAG;IACH,UAAM,GAAG,SAAS,CAAC;AACpC,CAAC,EAFgB,GAAG,KAAH,GAAG,QAEnB"}
@@ -1,24 +1,15 @@
1
1
  export * from "./constants.js";
2
- export type Mat4x4 = import("./mat4x4/mat4x4.js").Type;
3
- export * as Mat4x4 from "./mat4x4/mat4x4.js";
4
- export type F32 = import("./f32/f32.js").Type;
5
- export * as F32 from "./f32/f32.js";
6
- export type U32 = import("./u32/u32.js").Type;
7
- export * as U32 from "./u32/u32.js";
8
- export type I32 = import("./i32/i32.js").Type;
9
- export * as I32 from "./i32/i32.js";
10
- export type Vec2 = import("./vec2/vec2.js").Type;
11
- export * as Vec2 from "./vec2/vec2.js";
12
- export type Vec3 = import("./vec3/vec3.js").Type;
13
- export * as Vec3 from "./vec3/vec3.js";
14
- export type Vec4 = import("./vec4/vec4.js").Type;
15
- export * as Vec4 from "./vec4/vec4.js";
16
- export type Quat = import("./quat/quat.js").Type;
17
- export * as Quat from "./quat/quat.js";
18
- export type Aabb = import("./aabb/aabb.js").Type;
19
- export * as Aabb from "./aabb/aabb.js";
20
- export type Line2 = import("./line2/line2.js").Type;
21
- export * as Line2 from "./line2/line2.js";
22
- export type Line3 = import("./line3/line3.js").Type;
23
- export * as Line3 from "./line3/line3.js";
2
+ export * from "./mat4x4/mat4x4.js";
3
+ export * from "./f32/f32.js";
4
+ export * from "./u32/u32.js";
5
+ export * from "./i32/i32.js";
6
+ export * from "./vec2/vec2.js";
7
+ export * from "./vec3/vec3.js";
8
+ export * from "./vec4/vec4.js";
9
+ export * from "./quat/quat.js";
10
+ export * from "./aabb/aabb.js";
11
+ export * from "./line2/line2.js";
12
+ export * from "./line3/line3.js";
13
+ export * from "./aabb-face/aabb-face.js";
14
+ export * from "./plane/plane.js";
24
15
  export * from "./picking/index.js";
@@ -20,27 +20,18 @@ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
20
  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
21
  SOFTWARE.*/
22
22
  export * from "./constants.js";
23
- // Export the namespace Mat4x4
24
- export * as Mat4x4 from "./mat4x4/mat4x4.js";
25
- // Export the namespace F32
26
- export * as F32 from "./f32/f32.js";
27
- // Export the namespace F32
28
- export * as U32 from "./u32/u32.js";
29
- // Export the namespace F32
30
- export * as I32 from "./i32/i32.js";
31
- // Export the namespace Vec2
32
- export * as Vec2 from "./vec2/vec2.js";
33
- // Export the namespace Vec3
34
- export * as Vec3 from "./vec3/vec3.js";
35
- // Export the namespace Vec4
36
- export * as Vec4 from "./vec4/vec4.js";
37
- // Export the namespace Quat
38
- export * as Quat from "./quat/quat.js";
39
- // Export the namespace Aabb
40
- export * as Aabb from "./aabb/aabb.js";
41
- // Export the namespace Line2
42
- export * as Line2 from "./line2/line2.js";
43
- // Export the namespace Line3
44
- export * as Line3 from "./line3/line3.js";
23
+ export * from "./mat4x4/mat4x4.js";
24
+ export * from "./f32/f32.js";
25
+ export * from "./u32/u32.js";
26
+ export * from "./i32/i32.js";
27
+ export * from "./vec2/vec2.js";
28
+ export * from "./vec3/vec3.js";
29
+ export * from "./vec4/vec4.js";
30
+ export * from "./quat/quat.js";
31
+ export * from "./aabb/aabb.js";
32
+ export * from "./line2/line2.js";
33
+ export * from "./line3/line3.js";
34
+ export * from "./aabb-face/aabb-face.js";
35
+ export * from "./plane/plane.js";
45
36
  export * from "./picking/index.js";
46
37
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/math/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,cAAc,gBAAgB,CAAC;AAG/B,8BAA8B;AAC9B,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAI7C,2BAA2B;AAC3B,OAAO,KAAK,GAAG,MAAM,cAAc,CAAC;AAIpC,2BAA2B;AAC3B,OAAO,KAAK,GAAG,MAAM,cAAc,CAAC;AAIpC,2BAA2B;AAC3B,OAAO,KAAK,GAAG,MAAM,cAAc,CAAC;AAIpC,4BAA4B;AAC5B,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AAIvC,4BAA4B;AAC5B,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AAGvC,4BAA4B;AAC5B,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AAIvC,4BAA4B;AAC5B,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AAIvC,4BAA4B;AAC5B,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AAIvC,6BAA6B;AAC7B,OAAO,KAAK,KAAK,MAAM,kBAAkB,CAAC;AAI1C,6BAA6B;AAC7B,OAAO,KAAK,KAAK,MAAM,kBAAkB,CAAC;AAC1C,cAAc,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/math/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;WAoBW;AAEX,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC"}
@@ -1,42 +1,42 @@
1
1
  import { FromSchema } from "../../schema/index.js";
2
2
  import { Vec2 } from "../index.js";
3
- export declare const schema: {
4
- readonly type: "object";
5
- readonly properties: {
6
- readonly a: {
7
- readonly type: "array";
8
- readonly items: {
9
- readonly type: "number";
10
- readonly precision: 1;
11
- readonly default: number;
3
+ export type Line2 = FromSchema<typeof Line2.schema>;
4
+ export declare namespace Line2 {
5
+ const schema: {
6
+ readonly type: "object";
7
+ readonly properties: {
8
+ readonly a: {
9
+ readonly type: "array";
10
+ readonly items: {
11
+ readonly type: "number";
12
+ readonly precision: 1;
13
+ readonly default: number;
14
+ };
15
+ readonly minItems: 2;
16
+ readonly maxItems: 2;
17
+ readonly default: readonly [0, 0];
12
18
  };
13
- readonly minItems: 2;
14
- readonly maxItems: 2;
15
- readonly default: readonly [0, 0];
16
- };
17
- readonly b: {
18
- readonly type: "array";
19
- readonly items: {
20
- readonly type: "number";
21
- readonly precision: 1;
22
- readonly default: number;
19
+ readonly b: {
20
+ readonly type: "array";
21
+ readonly items: {
22
+ readonly type: "number";
23
+ readonly precision: 1;
24
+ readonly default: number;
25
+ };
26
+ readonly minItems: 2;
27
+ readonly maxItems: 2;
28
+ readonly default: readonly [0, 0];
23
29
  };
24
- readonly minItems: 2;
25
- readonly maxItems: 2;
26
- readonly default: readonly [0, 0];
30
+ };
31
+ readonly required: readonly ["a", "b"];
32
+ readonly additionalProperties: false;
33
+ readonly default: {
34
+ readonly a: readonly [0, 0];
35
+ readonly b: readonly [0, 0];
27
36
  };
28
37
  };
29
- readonly required: readonly ["a", "b"];
30
- readonly additionalProperties: false;
31
- readonly default: {
32
- readonly a: readonly [0, 0];
33
- readonly b: readonly [0, 0];
34
- };
35
- };
36
- export type Type = FromSchema<typeof schema>;
37
- type Line2 = Type;
38
- export declare const layout: import("../../typed-buffer/index.js").StructLayout;
39
- export declare const interpolate: (line: Line2, alpha: number) => Vec2;
40
- export declare const intersects: (line1: Line2, line2: Line2, includeEndpoints?: boolean) => boolean;
41
- export declare const subLine: (line: Line2, alpha: number, beta: number) => Line2;
42
- export {};
38
+ const layout: import("../../typed-buffer/index.js").StructLayout;
39
+ const interpolate: (line: Line2, alpha: number) => Vec2;
40
+ const intersects: (line1: Line2, line2: Line2, includeEndpoints?: boolean) => boolean;
41
+ const subLine: (line: Line2, alpha: number, beta: number) => Line2;
42
+ }
@@ -22,57 +22,60 @@ SOFTWARE.*/
22
22
  import { getStructLayout } from "../../typed-buffer/index.js";
23
23
  import { Vec2 } from "../index.js";
24
24
  import { epsilon } from "../constants.js";
25
- const { schema: Vec2Schema } = Vec2;
26
- export const schema = {
27
- type: 'object',
28
- properties: {
29
- a: Vec2Schema,
30
- b: Vec2Schema,
31
- },
32
- required: ['a', 'b'],
33
- additionalProperties: false,
34
- default: {
35
- a: Vec2Schema.default,
36
- b: Vec2Schema.default,
37
- }
38
- };
39
- export const layout = getStructLayout(schema);
40
- // Line2 utility functions
41
- export const interpolate = (line, alpha) => {
42
- const a = line.a;
43
- const b = line.b;
44
- return [a[0] + alpha * (b[0] - a[0]), a[1] + alpha * (b[1] - a[1])];
45
- };
46
- export const intersects = (line1, line2, includeEndpoints = false) => {
47
- const a = line1.a;
48
- const b = line1.b;
49
- const c = line2.a;
50
- const d = line2.b;
51
- // Check for endpoint intersections
52
- if (includeEndpoints && ((Math.abs(a[0] - c[0]) < epsilon && Math.abs(a[1] - c[1]) < epsilon) ||
53
- (Math.abs(a[0] - d[0]) < epsilon && Math.abs(a[1] - d[1]) < epsilon) ||
54
- (Math.abs(b[0] - c[0]) < epsilon && Math.abs(b[1] - c[1]) < epsilon) ||
55
- (Math.abs(b[0] - d[0]) < epsilon && Math.abs(b[1] - d[1]) < epsilon))) {
56
- return true;
57
- }
58
- // Calculate the denominator
59
- const denominator = (d[0] - c[0]) * (b[1] - a[1]) - (d[1] - c[1]) * (b[0] - a[0]);
60
- // Check if lines are parallel or collinear
61
- if (Math.abs(denominator) < epsilon) {
62
- return false;
63
- }
64
- // Calculate intersection parameters
65
- const numerator1 = (d[1] - c[1]) * (a[0] - c[0]) - (d[0] - c[0]) * (a[1] - c[1]);
66
- const numerator2 = (b[1] - a[1]) * (a[0] - c[0]) - (b[0] - a[0]) * (a[1] - c[1]);
67
- const ua = numerator1 / denominator;
68
- const ub = numerator2 / denominator;
69
- // Check if intersection point lies within both line segments
70
- return ua >= -epsilon && ua <= 1 + epsilon && ub >= -epsilon && ub <= 1 + epsilon;
71
- };
72
- export const subLine = (line, alpha, beta) => {
73
- return {
74
- a: interpolate(line, alpha),
75
- b: interpolate(line, beta),
25
+ export var Line2;
26
+ (function (Line2) {
27
+ const { schema: Vec2Schema } = Vec2;
28
+ Line2.schema = {
29
+ type: 'object',
30
+ properties: {
31
+ a: Vec2Schema,
32
+ b: Vec2Schema,
33
+ },
34
+ required: ['a', 'b'],
35
+ additionalProperties: false,
36
+ default: {
37
+ a: Vec2Schema.default,
38
+ b: Vec2Schema.default,
39
+ }
76
40
  };
77
- };
41
+ Line2.layout = getStructLayout(Line2.schema);
42
+ // Line2 utility functions
43
+ Line2.interpolate = (line, alpha) => {
44
+ const a = line.a;
45
+ const b = line.b;
46
+ return [a[0] + alpha * (b[0] - a[0]), a[1] + alpha * (b[1] - a[1])];
47
+ };
48
+ Line2.intersects = (line1, line2, includeEndpoints = false) => {
49
+ const a = line1.a;
50
+ const b = line1.b;
51
+ const c = line2.a;
52
+ const d = line2.b;
53
+ // Check for endpoint intersections
54
+ if (includeEndpoints && ((Math.abs(a[0] - c[0]) < epsilon && Math.abs(a[1] - c[1]) < epsilon) ||
55
+ (Math.abs(a[0] - d[0]) < epsilon && Math.abs(a[1] - d[1]) < epsilon) ||
56
+ (Math.abs(b[0] - c[0]) < epsilon && Math.abs(b[1] - c[1]) < epsilon) ||
57
+ (Math.abs(b[0] - d[0]) < epsilon && Math.abs(b[1] - d[1]) < epsilon))) {
58
+ return true;
59
+ }
60
+ // Calculate the denominator
61
+ const denominator = (d[0] - c[0]) * (b[1] - a[1]) - (d[1] - c[1]) * (b[0] - a[0]);
62
+ // Check if lines are parallel or collinear
63
+ if (Math.abs(denominator) < epsilon) {
64
+ return false;
65
+ }
66
+ // Calculate intersection parameters
67
+ const numerator1 = (d[1] - c[1]) * (a[0] - c[0]) - (d[0] - c[0]) * (a[1] - c[1]);
68
+ const numerator2 = (b[1] - a[1]) * (a[0] - c[0]) - (b[0] - a[0]) * (a[1] - c[1]);
69
+ const ua = numerator1 / denominator;
70
+ const ub = numerator2 / denominator;
71
+ // Check if intersection point lies within both line segments
72
+ return ua >= -epsilon && ua <= 1 + epsilon && ub >= -epsilon && ub <= 1 + epsilon;
73
+ };
74
+ Line2.subLine = (line, alpha, beta) => {
75
+ return {
76
+ a: Line2.interpolate(line, alpha),
77
+ b: Line2.interpolate(line, beta),
78
+ };
79
+ };
80
+ })(Line2 || (Line2 = {}));
78
81
  //# sourceMappingURL=line2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"line2.js","sourceRoot":"","sources":["../../../src/math/line2/line2.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"line2.js","sourceRoot":"","sources":["../../../src/math/line2/line2.ts"],"names":[],"mappings":"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"}