@pooder/kit 5.3.1 → 6.0.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/.test-dist/src/extensions/background.js +475 -131
  2. package/.test-dist/src/extensions/dieline.js +283 -180
  3. package/.test-dist/src/extensions/dielineShape.js +66 -0
  4. package/.test-dist/src/extensions/feature.js +388 -303
  5. package/.test-dist/src/extensions/film.js +133 -74
  6. package/.test-dist/src/extensions/geometry.js +120 -56
  7. package/.test-dist/src/extensions/image.js +296 -212
  8. package/.test-dist/src/extensions/index.js +1 -3
  9. package/.test-dist/src/extensions/maskOps.js +75 -20
  10. package/.test-dist/src/extensions/ruler.js +312 -215
  11. package/.test-dist/src/extensions/sceneLayoutModel.js +9 -3
  12. package/.test-dist/src/extensions/sceneVisibility.js +3 -10
  13. package/.test-dist/src/extensions/tracer.js +229 -58
  14. package/.test-dist/src/extensions/white-ink.js +139 -129
  15. package/.test-dist/src/services/CanvasService.js +888 -126
  16. package/.test-dist/src/services/index.js +1 -0
  17. package/.test-dist/src/services/visibility.js +54 -0
  18. package/.test-dist/tests/run.js +58 -4
  19. package/CHANGELOG.md +12 -0
  20. package/dist/index.d.mts +377 -82
  21. package/dist/index.d.ts +377 -82
  22. package/dist/index.js +3920 -2178
  23. package/dist/index.mjs +3992 -2247
  24. package/package.json +1 -1
  25. package/src/extensions/background.ts +631 -145
  26. package/src/extensions/dieline.ts +280 -187
  27. package/src/extensions/dielineShape.ts +109 -0
  28. package/src/extensions/feature.ts +485 -366
  29. package/src/extensions/film.ts +152 -76
  30. package/src/extensions/geometry.ts +203 -104
  31. package/src/extensions/image.ts +319 -238
  32. package/src/extensions/index.ts +0 -1
  33. package/src/extensions/ruler.ts +481 -268
  34. package/src/extensions/sceneLayoutModel.ts +18 -6
  35. package/src/extensions/white-ink.ts +157 -171
  36. package/src/services/CanvasService.ts +1126 -140
  37. package/src/services/index.ts +1 -0
  38. package/src/services/renderSpec.ts +69 -4
  39. package/src/services/visibility.ts +78 -0
  40. package/tests/run.ts +139 -4
  41. package/.test-dist/src/CanvasService.js +0 -249
  42. package/.test-dist/src/ViewportSystem.js +0 -75
  43. package/.test-dist/src/background.js +0 -203
  44. package/.test-dist/src/bridgeSelection.js +0 -20
  45. package/.test-dist/src/constraints.js +0 -237
  46. package/.test-dist/src/dieline.js +0 -818
  47. package/.test-dist/src/edgeScale.js +0 -12
  48. package/.test-dist/src/feature.js +0 -826
  49. package/.test-dist/src/featureComplete.js +0 -32
  50. package/.test-dist/src/film.js +0 -167
  51. package/.test-dist/src/geometry.js +0 -506
  52. package/.test-dist/src/image.js +0 -1250
  53. package/.test-dist/src/maskOps.js +0 -270
  54. package/.test-dist/src/mirror.js +0 -104
  55. package/.test-dist/src/renderSpec.js +0 -2
  56. package/.test-dist/src/ruler.js +0 -343
  57. package/.test-dist/src/sceneLayout.js +0 -99
  58. package/.test-dist/src/sceneLayoutModel.js +0 -196
  59. package/.test-dist/src/sceneView.js +0 -40
  60. package/.test-dist/src/sceneVisibility.js +0 -42
  61. package/.test-dist/src/size.js +0 -332
  62. package/.test-dist/src/tracer.js +0 -544
  63. package/.test-dist/src/white-ink.js +0 -829
  64. package/.test-dist/src/wrappedOffsets.js +0 -33
  65. package/src/extensions/sceneVisibility.ts +0 -71
@@ -21,4 +21,5 @@ exports.CanvasService = void 0;
21
21
  var CanvasService_1 = require("./CanvasService");
22
22
  Object.defineProperty(exports, "CanvasService", { enumerable: true, get: function () { return __importDefault(CanvasService_1).default; } });
23
23
  __exportStar(require("./renderSpec"), exports);
24
+ __exportStar(require("./visibility"), exports);
24
25
  __exportStar(require("./ViewportSystem"), exports);
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.evaluateVisibilityExpr = evaluateVisibilityExpr;
4
+ function compareLayerObjectCount(actual, cmp, expected) {
5
+ if (cmp === ">")
6
+ return actual > expected;
7
+ if (cmp === ">=")
8
+ return actual >= expected;
9
+ if (cmp === "<")
10
+ return actual < expected;
11
+ if (cmp === "<=")
12
+ return actual <= expected;
13
+ return actual === expected;
14
+ }
15
+ function layerState(context, layerId) {
16
+ return context.layers.get(layerId) || { exists: false, objectCount: 0 };
17
+ }
18
+ function evaluateVisibilityExpr(expr, context) {
19
+ if (!expr)
20
+ return true;
21
+ if (expr.op === "const") {
22
+ return Boolean(expr.value);
23
+ }
24
+ if (expr.op === "activeToolIn") {
25
+ const activeToolId = context.activeToolId ?? null;
26
+ return !!activeToolId && expr.ids.includes(activeToolId);
27
+ }
28
+ if (expr.op === "sessionActive") {
29
+ const toolId = String(expr.toolId || "").trim();
30
+ if (!toolId)
31
+ return false;
32
+ return context.isSessionActive ? context.isSessionActive(toolId) : false;
33
+ }
34
+ if (expr.op === "layerExists") {
35
+ return layerState(context, expr.layerId).exists === true;
36
+ }
37
+ if (expr.op === "layerObjectCount") {
38
+ const expected = Number(expr.value);
39
+ if (!Number.isFinite(expected))
40
+ return false;
41
+ const count = layerState(context, expr.layerId).objectCount;
42
+ return compareLayerObjectCount(count, expr.cmp, expected);
43
+ }
44
+ if (expr.op === "not") {
45
+ return !evaluateVisibilityExpr(expr.expr, context);
46
+ }
47
+ if (expr.op === "all") {
48
+ return expr.exprs.every((item) => evaluateVisibilityExpr(item, context));
49
+ }
50
+ if (expr.op === "any") {
51
+ return expr.exprs.some((item) => evaluateVisibilityExpr(item, context));
52
+ }
53
+ return true;
54
+ }
@@ -1,9 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const bridgeSelection_1 = require("../src/bridgeSelection");
4
- const wrappedOffsets_1 = require("../src/wrappedOffsets");
5
- const maskOps_1 = require("../src/maskOps");
6
- const edgeScale_1 = require("../src/edgeScale");
3
+ const bridgeSelection_1 = require("../src/extensions/bridgeSelection");
4
+ const wrappedOffsets_1 = require("../src/extensions/wrappedOffsets");
5
+ const maskOps_1 = require("../src/extensions/maskOps");
6
+ const edgeScale_1 = require("../src/extensions/edgeScale");
7
+ const visibility_1 = require("../src/services/visibility");
7
8
  function assert(condition, message) {
8
9
  if (!condition)
9
10
  throw new Error(message);
@@ -84,11 +85,64 @@ function testEdgeScale() {
84
85
  assert(width === 140, `expected width 140, got ${width}`);
85
86
  assert(height === 80, `expected height 80, got ${height}`);
86
87
  }
88
+ function testVisibilityDsl() {
89
+ const layers = new Map([
90
+ ["ruler-overlay", { exists: true, objectCount: 2 }],
91
+ ["feature-overlay", { exists: true, objectCount: 0 }],
92
+ ]);
93
+ const context = {
94
+ activeToolId: "pooder.kit.image",
95
+ isSessionActive: (toolId) => toolId === "pooder.kit.feature",
96
+ layers,
97
+ };
98
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "const", value: true }, context) === true, "const true failed");
99
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "const", value: false }, context) === false, "const false failed");
100
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "activeToolIn", ids: ["pooder.kit.image"] }, context) === true, "activeToolIn true failed");
101
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "activeToolIn", ids: ["pooder.kit.white-ink"] }, context) === false, "activeToolIn false failed");
102
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "sessionActive", toolId: "pooder.kit.feature" }, context) === true, "sessionActive true failed");
103
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "sessionActive", toolId: "pooder.kit.ruler" }, context) === false, "sessionActive false failed");
104
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "layerExists", layerId: "ruler-overlay" }, context) === true, "layerExists true failed");
105
+ assert((0, visibility_1.evaluateVisibilityExpr)({ op: "layerExists", layerId: "missing-layer" }, context) === false, "layerExists false failed");
106
+ const comparisons = [
107
+ { cmp: ">", value: 1, expected: true },
108
+ { cmp: ">=", value: 2, expected: true },
109
+ { cmp: "==", value: 2, expected: true },
110
+ { cmp: "<", value: 2, expected: false },
111
+ { cmp: "<=", value: 1, expected: false },
112
+ ];
113
+ comparisons.forEach((entry) => {
114
+ assert((0, visibility_1.evaluateVisibilityExpr)({
115
+ op: "layerObjectCount",
116
+ layerId: "ruler-overlay",
117
+ cmp: entry.cmp,
118
+ value: entry.value,
119
+ }, context) === entry.expected, `layerObjectCount ${entry.cmp} failed`);
120
+ });
121
+ assert((0, visibility_1.evaluateVisibilityExpr)({
122
+ op: "not",
123
+ expr: { op: "activeToolIn", ids: ["pooder.kit.white-ink"] },
124
+ }, context) === true, "not failed");
125
+ assert((0, visibility_1.evaluateVisibilityExpr)({
126
+ op: "all",
127
+ exprs: [
128
+ { op: "layerExists", layerId: "ruler-overlay" },
129
+ { op: "sessionActive", toolId: "pooder.kit.feature" },
130
+ ],
131
+ }, context) === true, "all failed");
132
+ assert((0, visibility_1.evaluateVisibilityExpr)({
133
+ op: "any",
134
+ exprs: [
135
+ { op: "layerExists", layerId: "missing-layer" },
136
+ { op: "activeToolIn", ids: ["pooder.kit.image"] },
137
+ ],
138
+ }, context) === true, "any failed");
139
+ }
87
140
  function main() {
88
141
  testWrappedOffsets();
89
142
  testBridgeSelection();
90
143
  testMaskOps();
91
144
  testEdgeScale();
145
+ testVisibilityDsl();
92
146
  console.log("ok");
93
147
  }
94
148
  main();
package/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @pooder/kit
2
2
 
3
+ ## 6.0.0
4
+
5
+ ### Major Changes
6
+
7
+ - pass compositor
8
+
9
+ ## 5.4.0
10
+
11
+ ### Minor Changes
12
+
13
+ - spec framework
14
+
3
15
  ## 5.3.1
4
16
 
5
17
  ### Patch Changes