openfig-cli 0.3.27 → 0.3.29
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.
- package/bin/commands/list-text.mjs +2 -2
- package/lib/rasterizer/svg-builder.mjs +21 -1
- package/manifest.json +1 -1
- package/mcp-server.mjs +3 -3
- package/package.json +1 -1
|
@@ -20,7 +20,7 @@ export async function run(args) {
|
|
|
20
20
|
for (const node of deck.message.nodeChanges) {
|
|
21
21
|
if (node.type === 'TEXT' && node.textData?.characters) {
|
|
22
22
|
const text = node.textData.characters;
|
|
23
|
-
const preview = text
|
|
23
|
+
const preview = text;
|
|
24
24
|
console.log(`[${nid(node)}] "${node.name || ''}" → ${JSON.stringify(preview)}`);
|
|
25
25
|
}
|
|
26
26
|
}
|
|
@@ -44,7 +44,7 @@ export async function run(args) {
|
|
|
44
44
|
|
|
45
45
|
if (ov.textData?.characters) {
|
|
46
46
|
const text = ov.textData.characters;
|
|
47
|
-
const preview = text
|
|
47
|
+
const preview = text;
|
|
48
48
|
console.log(` ${path} TEXT: ${JSON.stringify(preview)}`);
|
|
49
49
|
}
|
|
50
50
|
if (ov.fillPaints?.length) {
|
|
@@ -271,6 +271,8 @@ function esc(s) {
|
|
|
271
271
|
*/
|
|
272
272
|
function isStaleLayout(chars, baselines, glyphs) {
|
|
273
273
|
if (!chars) return false;
|
|
274
|
+
// No derivedTextData at all (e.g. programmatically created text)
|
|
275
|
+
if (!baselines?.length && !glyphs?.length) return true;
|
|
274
276
|
const len = chars.length;
|
|
275
277
|
|
|
276
278
|
if (baselines?.length) {
|
|
@@ -356,9 +358,27 @@ function fallbackTextTspans(dispChars, fontSize, node) {
|
|
|
356
358
|
: adjLineAscent;
|
|
357
359
|
}
|
|
358
360
|
|
|
361
|
+
// List marker support: read lineType from textData.lines
|
|
362
|
+
const linesMeta = node.textData?.lines ?? [];
|
|
363
|
+
let orderedCounter = 0;
|
|
364
|
+
|
|
359
365
|
const tspans = lines.map((line, i) => {
|
|
360
366
|
const y = startY + i * adjLineHeight;
|
|
361
|
-
|
|
367
|
+
const meta = linesMeta[i];
|
|
368
|
+
const lineType = meta?.lineType;
|
|
369
|
+
const indent = (meta?.indentationLevel ?? 0) * adjFontSize * 0.8;
|
|
370
|
+
let prefix = '';
|
|
371
|
+
if (lineType === 'UNORDERED_LIST') {
|
|
372
|
+
prefix = '\u2022 '; // bullet •
|
|
373
|
+
orderedCounter = 0;
|
|
374
|
+
} else if (lineType === 'ORDERED_LIST') {
|
|
375
|
+
orderedCounter++;
|
|
376
|
+
prefix = `${orderedCounter}. `;
|
|
377
|
+
} else {
|
|
378
|
+
orderedCounter = 0;
|
|
379
|
+
}
|
|
380
|
+
const x = startX + indent;
|
|
381
|
+
return `<tspan x="${x.toFixed(2)}" y="${y.toFixed(2)}" text-anchor="${anchor}">${esc(prefix + line) || ' '}</tspan>`;
|
|
362
382
|
}).join('');
|
|
363
383
|
|
|
364
384
|
return { tspans, fontSize: adjFontSize };
|
package/manifest.json
CHANGED
package/mcp-server.mjs
CHANGED
|
@@ -72,12 +72,12 @@ server.tool(
|
|
|
72
72
|
deck.walkTree(id, (node, depth) => {
|
|
73
73
|
if (depth === 0 || node.phase === 'REMOVED') return;
|
|
74
74
|
if (node.type === 'TEXT' && node.textData?.characters) {
|
|
75
|
-
directLines.push(` [text-node] ${nid(node)} "${node.name || ''}": ${node.textData.characters
|
|
75
|
+
directLines.push(` [text-node] ${nid(node)} "${node.name || ''}": ${node.textData.characters}`);
|
|
76
76
|
}
|
|
77
77
|
if (node.type === 'SHAPE_WITH_TEXT' && node.nodeGenerationData?.overrides) {
|
|
78
78
|
for (const override of node.nodeGenerationData.overrides) {
|
|
79
79
|
if (override.textData?.characters) {
|
|
80
|
-
directLines.push(` [shape-text] ${nid(node)} "${node.name || ''}": ${override.textData.characters
|
|
80
|
+
directLines.push(` [shape-text] ${nid(node)} "${node.name || ''}": ${override.textData.characters}`);
|
|
81
81
|
break;
|
|
82
82
|
}
|
|
83
83
|
}
|
|
@@ -96,7 +96,7 @@ server.tool(
|
|
|
96
96
|
const key = ov.guidPath?.guids?.[0];
|
|
97
97
|
const keyStr = key ? `${key.sessionID}:${key.localID}` : '?';
|
|
98
98
|
if (ov.textData?.characters) {
|
|
99
|
-
lines.push(` [text-override] ${keyStr}: ${ov.textData.characters
|
|
99
|
+
lines.push(` [text-override] ${keyStr}: ${ov.textData.characters}`);
|
|
100
100
|
}
|
|
101
101
|
if (ov.fillPaints?.length) {
|
|
102
102
|
for (const p of ov.fillPaints) {
|