@pooder/kit 4.0.0 → 4.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 (44) hide show
  1. package/.test-dist/src/CanvasService.js +83 -0
  2. package/.test-dist/src/ViewportSystem.js +75 -0
  3. package/.test-dist/src/background.js +203 -0
  4. package/.test-dist/src/constraints.js +153 -0
  5. package/.test-dist/src/coordinate.js +74 -0
  6. package/.test-dist/src/dieline.js +758 -0
  7. package/.test-dist/src/feature.js +687 -0
  8. package/.test-dist/src/featureComplete.js +31 -0
  9. package/.test-dist/src/featureDraft.js +31 -0
  10. package/.test-dist/src/film.js +167 -0
  11. package/.test-dist/src/geometry.js +292 -0
  12. package/.test-dist/src/image.js +421 -0
  13. package/.test-dist/src/index.js +31 -0
  14. package/.test-dist/src/mirror.js +104 -0
  15. package/.test-dist/src/ruler.js +383 -0
  16. package/.test-dist/src/tracer.js +448 -0
  17. package/.test-dist/src/units.js +30 -0
  18. package/.test-dist/src/white-ink.js +310 -0
  19. package/.test-dist/tests/run.js +60 -0
  20. package/CHANGELOG.md +12 -0
  21. package/dist/index.d.mts +54 -5
  22. package/dist/index.d.ts +54 -5
  23. package/dist/index.js +584 -190
  24. package/dist/index.mjs +581 -189
  25. package/package.json +3 -2
  26. package/src/CanvasService.ts +7 -0
  27. package/src/ViewportSystem.ts +92 -0
  28. package/src/background.ts +230 -230
  29. package/src/constraints.ts +207 -0
  30. package/src/coordinate.ts +106 -106
  31. package/src/dieline.ts +194 -75
  32. package/src/feature.ts +239 -147
  33. package/src/featureComplete.ts +45 -0
  34. package/src/film.ts +194 -194
  35. package/src/geometry.ts +4 -0
  36. package/src/image.ts +512 -512
  37. package/src/index.ts +1 -0
  38. package/src/mirror.ts +128 -128
  39. package/src/ruler.ts +508 -500
  40. package/src/tracer.ts +570 -570
  41. package/src/units.ts +27 -0
  42. package/src/white-ink.ts +373 -373
  43. package/tests/run.ts +81 -0
  44. package/tsconfig.test.json +15 -0
package/src/index.ts CHANGED
@@ -6,4 +6,5 @@ export * from "./image";
6
6
  export * from "./white-ink";
7
7
  export * from "./ruler";
8
8
  export * from "./mirror";
9
+ export * from "./units";
9
10
  export { default as CanvasService } from "./CanvasService";
package/src/mirror.ts CHANGED
@@ -1,128 +1,128 @@
1
- import {
2
- Extension,
3
- ExtensionContext,
4
- ContributionPointIds,
5
- CommandContribution,
6
- ConfigurationContribution,
7
- } from "@pooder/core";
8
- import CanvasService from "./CanvasService";
9
-
10
- export class MirrorTool implements Extension {
11
- id = "pooder.kit.mirror";
12
-
13
- public metadata = {
14
- name: "MirrorTool",
15
- };
16
- private enabled = false;
17
-
18
- private canvasService?: CanvasService;
19
-
20
- constructor(
21
- options?: Partial<{
22
- enabled: boolean;
23
- }>,
24
- ) {
25
- if (options) {
26
- Object.assign(this, options);
27
- }
28
- }
29
-
30
- toJSON() {
31
- return {
32
- enabled: this.enabled,
33
- };
34
- }
35
-
36
- loadFromJSON(json: any) {
37
- this.enabled = json.enabled;
38
- }
39
-
40
- activate(context: ExtensionContext) {
41
- this.canvasService = context.services.get<CanvasService>("CanvasService");
42
- if (!this.canvasService) {
43
- console.warn("CanvasService not found for MirrorTool");
44
- return;
45
- }
46
-
47
- const configService = context.services.get<any>("ConfigurationService");
48
- if (configService) {
49
- // Load initial config
50
- this.enabled = configService.get("mirror.enabled", this.enabled);
51
-
52
- // Listen for changes
53
- configService.onAnyChange((e: { key: string; value: any }) => {
54
- if (e.key === "mirror.enabled") {
55
- this.applyMirror(e.value);
56
- }
57
- });
58
- }
59
-
60
- // Initialize with current state (if enabled was persisted)
61
- if (this.enabled) {
62
- this.applyMirror(true);
63
- }
64
- }
65
-
66
- deactivate(context: ExtensionContext) {
67
- this.applyMirror(false);
68
- this.canvasService = undefined;
69
- }
70
-
71
- contribute() {
72
- return {
73
- [ContributionPointIds.CONFIGURATIONS]: [
74
- {
75
- id: "mirror.enabled",
76
- type: "boolean",
77
- label: "Enable Mirror",
78
- default: false,
79
- },
80
- ] as ConfigurationContribution[],
81
- [ContributionPointIds.COMMANDS]: [
82
- {
83
- command: "setMirror",
84
- title: "Set Mirror",
85
- handler: (enabled: boolean) => {
86
- this.applyMirror(enabled);
87
- return true;
88
- },
89
- },
90
- ] as CommandContribution[],
91
- };
92
- }
93
-
94
- private applyMirror(enabled: boolean) {
95
- if (!this.canvasService) return;
96
- const canvas = this.canvasService.canvas;
97
- if (!canvas) return;
98
-
99
- const width = canvas.width || 800;
100
-
101
- // Fabric.js v6+ uses viewportTransform property
102
- let vpt = canvas.viewportTransform || [1, 0, 0, 1, 0, 0];
103
- // Create a copy to avoid mutating the reference directly before setting
104
- vpt = [...vpt];
105
-
106
- // If we are enabling and currently not flipped (scaleX > 0)
107
- // Or disabling and currently flipped (scaleX < 0)
108
- const isFlipped = vpt[0] < 0;
109
-
110
- if (enabled && !isFlipped) {
111
- // Flip scale X
112
- vpt[0] = -vpt[0]; // Flip scale
113
- vpt[4] = width - vpt[4]; // Adjust pan X
114
-
115
- canvas.setViewportTransform(vpt as any);
116
- canvas.requestRenderAll();
117
- this.enabled = true;
118
- } else if (!enabled && isFlipped) {
119
- // Restore
120
- vpt[0] = -vpt[0]; // Unflip scale
121
- vpt[4] = width - vpt[4]; // Restore pan X
122
-
123
- canvas.setViewportTransform(vpt as any);
124
- canvas.requestRenderAll();
125
- this.enabled = false;
126
- }
127
- }
128
- }
1
+ import {
2
+ Extension,
3
+ ExtensionContext,
4
+ ContributionPointIds,
5
+ CommandContribution,
6
+ ConfigurationContribution,
7
+ } from "@pooder/core";
8
+ import CanvasService from "./CanvasService";
9
+
10
+ export class MirrorTool implements Extension {
11
+ id = "pooder.kit.mirror";
12
+
13
+ public metadata = {
14
+ name: "MirrorTool",
15
+ };
16
+ private enabled = false;
17
+
18
+ private canvasService?: CanvasService;
19
+
20
+ constructor(
21
+ options?: Partial<{
22
+ enabled: boolean;
23
+ }>,
24
+ ) {
25
+ if (options) {
26
+ Object.assign(this, options);
27
+ }
28
+ }
29
+
30
+ toJSON() {
31
+ return {
32
+ enabled: this.enabled,
33
+ };
34
+ }
35
+
36
+ loadFromJSON(json: any) {
37
+ this.enabled = json.enabled;
38
+ }
39
+
40
+ activate(context: ExtensionContext) {
41
+ this.canvasService = context.services.get<CanvasService>("CanvasService");
42
+ if (!this.canvasService) {
43
+ console.warn("CanvasService not found for MirrorTool");
44
+ return;
45
+ }
46
+
47
+ const configService = context.services.get<any>("ConfigurationService");
48
+ if (configService) {
49
+ // Load initial config
50
+ this.enabled = configService.get("mirror.enabled", this.enabled);
51
+
52
+ // Listen for changes
53
+ configService.onAnyChange((e: { key: string; value: any }) => {
54
+ if (e.key === "mirror.enabled") {
55
+ this.applyMirror(e.value);
56
+ }
57
+ });
58
+ }
59
+
60
+ // Initialize with current state (if enabled was persisted)
61
+ if (this.enabled) {
62
+ this.applyMirror(true);
63
+ }
64
+ }
65
+
66
+ deactivate(context: ExtensionContext) {
67
+ this.applyMirror(false);
68
+ this.canvasService = undefined;
69
+ }
70
+
71
+ contribute() {
72
+ return {
73
+ [ContributionPointIds.CONFIGURATIONS]: [
74
+ {
75
+ id: "mirror.enabled",
76
+ type: "boolean",
77
+ label: "Enable Mirror",
78
+ default: false,
79
+ },
80
+ ] as ConfigurationContribution[],
81
+ [ContributionPointIds.COMMANDS]: [
82
+ {
83
+ command: "setMirror",
84
+ title: "Set Mirror",
85
+ handler: (enabled: boolean) => {
86
+ this.applyMirror(enabled);
87
+ return true;
88
+ },
89
+ },
90
+ ] as CommandContribution[],
91
+ };
92
+ }
93
+
94
+ private applyMirror(enabled: boolean) {
95
+ if (!this.canvasService) return;
96
+ const canvas = this.canvasService.canvas;
97
+ if (!canvas) return;
98
+
99
+ const width = canvas.width || 800;
100
+
101
+ // Fabric.js v6+ uses viewportTransform property
102
+ let vpt = canvas.viewportTransform || [1, 0, 0, 1, 0, 0];
103
+ // Create a copy to avoid mutating the reference directly before setting
104
+ vpt = [...vpt];
105
+
106
+ // If we are enabling and currently not flipped (scaleX > 0)
107
+ // Or disabling and currently flipped (scaleX < 0)
108
+ const isFlipped = vpt[0] < 0;
109
+
110
+ if (enabled && !isFlipped) {
111
+ // Flip scale X
112
+ vpt[0] = -vpt[0]; // Flip scale
113
+ vpt[4] = width - vpt[4]; // Adjust pan X
114
+
115
+ canvas.setViewportTransform(vpt as any);
116
+ canvas.requestRenderAll();
117
+ this.enabled = true;
118
+ } else if (!enabled && isFlipped) {
119
+ // Restore
120
+ vpt[0] = -vpt[0]; // Unflip scale
121
+ vpt[4] = width - vpt[4]; // Restore pan X
122
+
123
+ canvas.setViewportTransform(vpt as any);
124
+ canvas.requestRenderAll();
125
+ this.enabled = false;
126
+ }
127
+ }
128
+ }