@pdfme/schemas 6.1.0 → 6.1.1-dev.11
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/dist/{builtins-C0BvXHWr.js → builtins-Clh58o_b.js} +313 -483
- package/dist/builtins-Clh58o_b.js.map +1 -0
- package/dist/builtins.d.ts +1 -1
- package/dist/builtins.js +1 -1
- package/dist/checkbox/index.d.ts +2 -2
- package/dist/dynamicLayout.d.ts +4 -0
- package/dist/dynamicLayout.js +20 -0
- package/dist/dynamicLayout.js.map +1 -0
- package/dist/dynamicTemplate-CB2Hj9cN.js +65 -0
- package/dist/dynamicTemplate-CB2Hj9cN.js.map +1 -0
- package/dist/{dynamicTemplate-Dsrw11aL.js → dynamicTemplate-CjbGepw4.js} +24 -358
- package/dist/dynamicTemplate-CjbGepw4.js.map +1 -0
- package/dist/dynamicTemplate-Fn7mpUsu.js +114 -0
- package/dist/dynamicTemplate-Fn7mpUsu.js.map +1 -0
- package/dist/graphics/image.d.ts +1 -1
- package/dist/graphics/signature.d.ts +1 -1
- package/dist/helper-BJzBqIT4.js +40 -0
- package/dist/helper-BJzBqIT4.js.map +1 -0
- package/dist/index.d.ts +5 -2
- package/dist/index.js +847 -205
- package/dist/index.js.map +1 -1
- package/dist/list/constants.d.ts +10 -0
- package/dist/list/dynamicTemplate.d.ts +2 -0
- package/dist/list/helper.d.ts +15 -0
- package/dist/list/index.d.ts +4 -0
- package/dist/list/pdfRender.d.ts +3 -0
- package/dist/list/propPanel.d.ts +3 -0
- package/dist/list/types.d.ts +31 -0
- package/dist/list/uiRender.d.ts +3 -0
- package/dist/lists.d.ts +4 -0
- package/dist/lists.js +3 -0
- package/dist/measure-Bjmh9Ro3.js +585 -0
- package/dist/measure-Bjmh9Ro3.js.map +1 -0
- package/dist/multiVariableText/dynamicTemplate.d.ts +2 -0
- package/dist/radioGroup/index.d.ts +2 -2
- package/dist/select/index.d.ts +2 -2
- package/dist/shapes/line.d.ts +1 -1
- package/dist/shapes/rectAndEllipse.d.ts +1 -2
- package/dist/splitRange-CpXivbmJ.js +398 -0
- package/dist/splitRange-CpXivbmJ.js.map +1 -0
- package/dist/splitRange.d.ts +16 -0
- package/dist/tables/dynamicTemplate.d.ts +2 -1
- package/dist/tables/helper.d.ts +8 -8
- package/dist/tables.d.ts +2 -1
- package/dist/tables.js +3 -2
- package/dist/text/constants.d.ts +3 -0
- package/dist/text/dynamicTemplate.d.ts +2 -0
- package/dist/text/linkAnnotation.d.ts +14 -0
- package/dist/text/measure.d.ts +26 -0
- package/dist/text/overflow.d.ts +7 -0
- package/dist/text/richTextPdfRender.d.ts +2 -1
- package/dist/text/types.d.ts +3 -0
- package/dist/texts.d.ts +5 -0
- package/dist/texts.js +4 -0
- package/dist/types.d.ts +15 -0
- package/dist/types.js +0 -0
- package/dist/utils.d.ts +1 -0
- package/dist/utils.js +3 -2
- package/dist/utils.js.map +1 -1
- package/package.json +21 -1
- package/dist/builtins-C0BvXHWr.js.map +0 -1
- package/dist/dynamicTemplate-Dsrw11aL.js.map +0 -1
|
@@ -1,357 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import { Buffer } from "buffer";
|
|
4
|
-
//#region src/text/constants.ts
|
|
5
|
-
var ALIGN_LEFT = "left";
|
|
6
|
-
var ALIGN_CENTER = "center";
|
|
7
|
-
var ALIGN_RIGHT = "right";
|
|
8
|
-
var ALIGN_JUSTIFY = "justify";
|
|
9
|
-
var DEFAULT_ALIGNMENT = ALIGN_LEFT;
|
|
10
|
-
var VERTICAL_ALIGN_MIDDLE = "middle";
|
|
11
|
-
var VERTICAL_ALIGN_BOTTOM = "bottom";
|
|
12
|
-
var DEFAULT_FONT_COLOR = "#000000";
|
|
13
|
-
var PLACEHOLDER_FONT_COLOR = "#A0A0A0";
|
|
14
|
-
var TEXT_FORMAT_PLAIN = "plain";
|
|
15
|
-
var TEXT_FORMAT_INLINE_MARKDOWN = "inline-markdown";
|
|
16
|
-
var DEFAULT_TEXT_FORMAT = TEXT_FORMAT_PLAIN;
|
|
17
|
-
var FONT_VARIANT_FALLBACK_SYNTHETIC = "synthetic";
|
|
18
|
-
var FONT_VARIANT_FALLBACK_PLAIN = "plain";
|
|
19
|
-
var FONT_VARIANT_FALLBACK_ERROR = "error";
|
|
20
|
-
var DEFAULT_FONT_VARIANT_FALLBACK = FONT_VARIANT_FALLBACK_SYNTHETIC;
|
|
21
|
-
var SYNTHETIC_BOLD_OFFSET_RATIO = .03;
|
|
22
|
-
var SYNTHETIC_BOLD_CSS_TEXT_SHADOW = "0.025em 0 0 currentColor";
|
|
23
|
-
var CODE_BACKGROUND_COLOR = "#f2f3f5";
|
|
24
|
-
var CODE_HORIZONTAL_PADDING = 1.5;
|
|
25
|
-
var DYNAMIC_FIT_VERTICAL = "vertical";
|
|
26
|
-
var DYNAMIC_FIT_HORIZONTAL = "horizontal";
|
|
27
|
-
var DEFAULT_DYNAMIC_FIT = DYNAMIC_FIT_VERTICAL;
|
|
28
|
-
var FONT_SIZE_ADJUSTMENT = .25;
|
|
29
|
-
var LINE_START_FORBIDDEN_CHARS = [
|
|
30
|
-
"、",
|
|
31
|
-
"。",
|
|
32
|
-
",",
|
|
33
|
-
".",
|
|
34
|
-
"」",
|
|
35
|
-
"』",
|
|
36
|
-
")",
|
|
37
|
-
"}",
|
|
38
|
-
"】",
|
|
39
|
-
">",
|
|
40
|
-
"≫",
|
|
41
|
-
"]",
|
|
42
|
-
"・",
|
|
43
|
-
"ー",
|
|
44
|
-
"―",
|
|
45
|
-
"-",
|
|
46
|
-
"!",
|
|
47
|
-
"!",
|
|
48
|
-
"?",
|
|
49
|
-
"?",
|
|
50
|
-
":",
|
|
51
|
-
":",
|
|
52
|
-
";",
|
|
53
|
-
";",
|
|
54
|
-
"/",
|
|
55
|
-
"/",
|
|
56
|
-
"ゝ",
|
|
57
|
-
"々",
|
|
58
|
-
"〃",
|
|
59
|
-
"ぁ",
|
|
60
|
-
"ぃ",
|
|
61
|
-
"ぅ",
|
|
62
|
-
"ぇ",
|
|
63
|
-
"ぉ",
|
|
64
|
-
"っ",
|
|
65
|
-
"ゃ",
|
|
66
|
-
"ゅ",
|
|
67
|
-
"ょ",
|
|
68
|
-
"ァ",
|
|
69
|
-
"ィ",
|
|
70
|
-
"ゥ",
|
|
71
|
-
"ェ",
|
|
72
|
-
"ォ",
|
|
73
|
-
"ッ",
|
|
74
|
-
"ャ",
|
|
75
|
-
"ュ",
|
|
76
|
-
"ョ"
|
|
77
|
-
];
|
|
78
|
-
var LINE_END_FORBIDDEN_CHARS = [
|
|
79
|
-
"「",
|
|
80
|
-
"『",
|
|
81
|
-
"(",
|
|
82
|
-
"{",
|
|
83
|
-
"【",
|
|
84
|
-
"<",
|
|
85
|
-
"≪",
|
|
86
|
-
"[",
|
|
87
|
-
"〘",
|
|
88
|
-
"〖",
|
|
89
|
-
"〝",
|
|
90
|
-
"‘",
|
|
91
|
-
"“",
|
|
92
|
-
"⦅",
|
|
93
|
-
"«"
|
|
94
|
-
];
|
|
95
|
-
//#endregion
|
|
96
|
-
//#region src/text/helper.ts
|
|
97
|
-
var getBrowserVerticalFontAdjustments = (fontKitFont, fontSize, lineHeight, verticalAlignment) => {
|
|
98
|
-
const { ascent, descent, unitsPerEm } = fontKitFont;
|
|
99
|
-
const fontBaseLineHeight = (ascent - descent) / unitsPerEm;
|
|
100
|
-
const topAdjustment = (fontBaseLineHeight * fontSize - fontSize) / 2;
|
|
101
|
-
if (verticalAlignment === "top") return {
|
|
102
|
-
topAdj: pt2px(topAdjustment),
|
|
103
|
-
bottomAdj: 0
|
|
104
|
-
};
|
|
105
|
-
let bottomAdjustment = 0;
|
|
106
|
-
if (lineHeight < fontBaseLineHeight) bottomAdjustment = (fontBaseLineHeight - lineHeight) * fontSize / 2;
|
|
107
|
-
return {
|
|
108
|
-
topAdj: 0,
|
|
109
|
-
bottomAdj: pt2px(bottomAdjustment)
|
|
110
|
-
};
|
|
111
|
-
};
|
|
112
|
-
var getFontDescentInPt = (fontKitFont, fontSize) => {
|
|
113
|
-
const { descent, unitsPerEm } = fontKitFont;
|
|
114
|
-
return descent / unitsPerEm * fontSize;
|
|
115
|
-
};
|
|
116
|
-
var heightOfFontAtSize = (fontKitFont, fontSize) => {
|
|
117
|
-
const { ascent, descent, bbox, unitsPerEm } = fontKitFont;
|
|
118
|
-
const scale = 1e3 / unitsPerEm;
|
|
119
|
-
let height = (ascent || bbox.maxY) * scale - (descent || bbox.minY) * scale;
|
|
120
|
-
height -= Math.abs(descent * scale) || 0;
|
|
121
|
-
return height / 1e3 * fontSize;
|
|
122
|
-
};
|
|
123
|
-
var calculateCharacterSpacing = (textContent, textCharacterSpacing) => {
|
|
124
|
-
return (textContent.length - 1) * textCharacterSpacing;
|
|
125
|
-
};
|
|
126
|
-
var widthOfTextAtSize = (text, fontKitFont, fontSize, characterSpacing) => {
|
|
127
|
-
const { glyphs } = fontKitFont.layout(text);
|
|
128
|
-
const scale = 1e3 / fontKitFont.unitsPerEm;
|
|
129
|
-
return glyphs.reduce((totalWidth, glyph) => totalWidth + glyph.advanceWidth * scale, 0) * (fontSize / 1e3) + calculateCharacterSpacing(text, characterSpacing);
|
|
130
|
-
};
|
|
131
|
-
var getFallbackFont = (font) => {
|
|
132
|
-
return font[getFallbackFontName(font)];
|
|
133
|
-
};
|
|
134
|
-
var getCacheKey = (fontName) => `getFontKitFont-${fontName}`;
|
|
135
|
-
var fetchRemoteFontData = async (url) => {
|
|
136
|
-
if (!isUrlSafeToFetch(url)) throw Error("[@pdfme/schemas] Invalid or unsafe URL for font data. Only http: and https: URLs pointing to public hosts are allowed.");
|
|
137
|
-
try {
|
|
138
|
-
const response = await fetch(url);
|
|
139
|
-
if (!response.ok) throw new Error(`HTTP ${response.status}`);
|
|
140
|
-
return await response.arrayBuffer();
|
|
141
|
-
} catch (error) {
|
|
142
|
-
const reason = error instanceof Error ? error.message : String(error);
|
|
143
|
-
throw Error(`[@pdfme/schemas] Failed to fetch remote font data from ${url}. ${reason}`);
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
|
-
var getFontKitFont = async (fontName, font, _cache) => {
|
|
147
|
-
const fntNm = fontName || getFallbackFontName(font);
|
|
148
|
-
const cacheKey = getCacheKey(fntNm);
|
|
149
|
-
if (_cache.has(cacheKey)) return _cache.get(cacheKey);
|
|
150
|
-
let fontData = (font[fntNm] || getFallbackFont(font) || getDefaultFont()[DEFAULT_FONT_NAME]).data;
|
|
151
|
-
if (typeof fontData === "string") if (fontData.startsWith("http")) fontData = await fetchRemoteFontData(fontData);
|
|
152
|
-
else fontData = b64toUint8Array(fontData);
|
|
153
|
-
let fontDataBuffer;
|
|
154
|
-
if (fontData instanceof Buffer) fontDataBuffer = fontData;
|
|
155
|
-
else fontDataBuffer = Buffer.from(fontData);
|
|
156
|
-
const fontKitFont = fontkit.create(fontDataBuffer);
|
|
157
|
-
_cache.set(cacheKey, fontKitFont);
|
|
158
|
-
return fontKitFont;
|
|
159
|
-
};
|
|
160
|
-
/**
|
|
161
|
-
* If using dynamic font size, iteratively increment or decrement the
|
|
162
|
-
* font size to fit the containing box.
|
|
163
|
-
* Calculating space usage involves splitting lines where they exceed
|
|
164
|
-
* the box width based on the proposed size.
|
|
165
|
-
*/
|
|
166
|
-
var calculateDynamicFontSize = ({ textSchema, fontKitFont, value, startingFontSize }) => {
|
|
167
|
-
const { fontSize: schemaFontSize, dynamicFontSize: dynamicFontSizeSetting, characterSpacing: schemaCharacterSpacing, width: boxWidth, height: boxHeight, lineHeight = 1 } = textSchema;
|
|
168
|
-
const fontSize = startingFontSize || schemaFontSize || 13;
|
|
169
|
-
if (!dynamicFontSizeSetting) return fontSize;
|
|
170
|
-
if (dynamicFontSizeSetting.max < dynamicFontSizeSetting.min) return fontSize;
|
|
171
|
-
const characterSpacing = schemaCharacterSpacing ?? 0;
|
|
172
|
-
const paragraphs = value.split("\n");
|
|
173
|
-
let dynamicFontSize = fontSize;
|
|
174
|
-
if (dynamicFontSize < dynamicFontSizeSetting.min) dynamicFontSize = dynamicFontSizeSetting.min;
|
|
175
|
-
else if (dynamicFontSize > dynamicFontSizeSetting.max) dynamicFontSize = dynamicFontSizeSetting.max;
|
|
176
|
-
const dynamicFontFit = dynamicFontSizeSetting.fit ?? "vertical";
|
|
177
|
-
const calculateConstraints = (size) => {
|
|
178
|
-
let totalWidthInMm = 0;
|
|
179
|
-
let totalHeightInMm = 0;
|
|
180
|
-
const boxWidthInPt = mm2pt(boxWidth);
|
|
181
|
-
const firstLineHeightInMm = pt2mm(heightOfFontAtSize(fontKitFont, size) * lineHeight);
|
|
182
|
-
const otherRowHeightInMm = pt2mm(size * lineHeight);
|
|
183
|
-
paragraphs.forEach((paragraph, paraIndex) => {
|
|
184
|
-
getSplittedLinesBySegmenter(paragraph, {
|
|
185
|
-
font: fontKitFont,
|
|
186
|
-
fontSize: size,
|
|
187
|
-
characterSpacing,
|
|
188
|
-
boxWidthInPt
|
|
189
|
-
}).forEach((line, lineIndex) => {
|
|
190
|
-
if (dynamicFontFit === "vertical") {
|
|
191
|
-
const textWidthInMm = pt2mm(widthOfTextAtSize(line.replace("\n", ""), fontKitFont, size, characterSpacing));
|
|
192
|
-
totalWidthInMm = Math.max(totalWidthInMm, textWidthInMm);
|
|
193
|
-
}
|
|
194
|
-
if (paraIndex + lineIndex === 0) totalHeightInMm += firstLineHeightInMm;
|
|
195
|
-
else totalHeightInMm += otherRowHeightInMm;
|
|
196
|
-
});
|
|
197
|
-
if (dynamicFontFit === "horizontal") {
|
|
198
|
-
const textWidthInMm = pt2mm(widthOfTextAtSize(paragraph, fontKitFont, size, characterSpacing));
|
|
199
|
-
totalWidthInMm = Math.max(totalWidthInMm, textWidthInMm);
|
|
200
|
-
}
|
|
201
|
-
});
|
|
202
|
-
return {
|
|
203
|
-
totalWidthInMm,
|
|
204
|
-
totalHeightInMm
|
|
205
|
-
};
|
|
206
|
-
};
|
|
207
|
-
const shouldFontGrowToFit = (totalWidthInMm, totalHeightInMm) => {
|
|
208
|
-
if (dynamicFontSize >= dynamicFontSizeSetting.max) return false;
|
|
209
|
-
if (dynamicFontFit === "horizontal") return totalWidthInMm < boxWidth;
|
|
210
|
-
return totalHeightInMm < boxHeight;
|
|
211
|
-
};
|
|
212
|
-
const shouldFontShrinkToFit = (totalWidthInMm, totalHeightInMm) => {
|
|
213
|
-
if (dynamicFontSize <= dynamicFontSizeSetting.min || dynamicFontSize <= 0) return false;
|
|
214
|
-
return totalWidthInMm > boxWidth || totalHeightInMm > boxHeight;
|
|
215
|
-
};
|
|
216
|
-
let { totalWidthInMm, totalHeightInMm } = calculateConstraints(dynamicFontSize);
|
|
217
|
-
while (shouldFontGrowToFit(totalWidthInMm, totalHeightInMm)) {
|
|
218
|
-
dynamicFontSize += FONT_SIZE_ADJUSTMENT;
|
|
219
|
-
const { totalWidthInMm: newWidth, totalHeightInMm: newHeight } = calculateConstraints(dynamicFontSize);
|
|
220
|
-
if (newHeight < boxHeight) {
|
|
221
|
-
totalWidthInMm = newWidth;
|
|
222
|
-
totalHeightInMm = newHeight;
|
|
223
|
-
} else {
|
|
224
|
-
dynamicFontSize -= FONT_SIZE_ADJUSTMENT;
|
|
225
|
-
break;
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
while (shouldFontShrinkToFit(totalWidthInMm, totalHeightInMm)) {
|
|
229
|
-
dynamicFontSize -= FONT_SIZE_ADJUSTMENT;
|
|
230
|
-
({totalWidthInMm, totalHeightInMm} = calculateConstraints(dynamicFontSize));
|
|
231
|
-
}
|
|
232
|
-
return dynamicFontSize;
|
|
233
|
-
};
|
|
234
|
-
var splitTextToSize = (arg) => {
|
|
235
|
-
const { value, characterSpacing, fontSize, fontKitFont, boxWidthInPt } = arg;
|
|
236
|
-
const fontWidthCalcValues = {
|
|
237
|
-
font: fontKitFont,
|
|
238
|
-
fontSize,
|
|
239
|
-
characterSpacing,
|
|
240
|
-
boxWidthInPt
|
|
241
|
-
};
|
|
242
|
-
let lines = [];
|
|
243
|
-
value.split(/\r\n|\r|\n|\f|\v/g).forEach((line) => {
|
|
244
|
-
lines = lines.concat(getSplittedLinesBySegmenter(line, fontWidthCalcValues));
|
|
245
|
-
});
|
|
246
|
-
return lines;
|
|
247
|
-
};
|
|
248
|
-
var isFirefox = () => navigator.userAgent.toLowerCase().indexOf("firefox") > -1;
|
|
249
|
-
var getSplittedLinesBySegmenter = (line, calcValues) => {
|
|
250
|
-
if (line.trim() === "") return [""];
|
|
251
|
-
const { font, fontSize, characterSpacing, boxWidthInPt } = calcValues;
|
|
252
|
-
const iterator = new Intl.Segmenter(void 0, { granularity: "word" }).segment(line.trimEnd())[Symbol.iterator]();
|
|
253
|
-
let lines = [];
|
|
254
|
-
let lineCounter = 0;
|
|
255
|
-
let currentTextSize = 0;
|
|
256
|
-
while (true) {
|
|
257
|
-
const chunk = iterator.next();
|
|
258
|
-
if (chunk.done) break;
|
|
259
|
-
const segment = chunk.value.segment;
|
|
260
|
-
const textWidth = widthOfTextAtSize(segment, font, fontSize, characterSpacing);
|
|
261
|
-
if (currentTextSize + textWidth <= boxWidthInPt) if (lines[lineCounter]) {
|
|
262
|
-
lines[lineCounter] += segment;
|
|
263
|
-
currentTextSize += textWidth + characterSpacing;
|
|
264
|
-
} else {
|
|
265
|
-
lines[lineCounter] = segment;
|
|
266
|
-
currentTextSize = textWidth + characterSpacing;
|
|
267
|
-
}
|
|
268
|
-
else if (segment.trim() === "") {
|
|
269
|
-
lines[++lineCounter] = "";
|
|
270
|
-
currentTextSize = 0;
|
|
271
|
-
} else if (textWidth <= boxWidthInPt) {
|
|
272
|
-
lines[++lineCounter] = segment;
|
|
273
|
-
currentTextSize = textWidth + characterSpacing;
|
|
274
|
-
} else for (const char of segment) {
|
|
275
|
-
const size = widthOfTextAtSize(char, font, fontSize, characterSpacing);
|
|
276
|
-
if (currentTextSize + size <= boxWidthInPt) if (lines[lineCounter]) {
|
|
277
|
-
lines[lineCounter] += char;
|
|
278
|
-
currentTextSize += size + characterSpacing;
|
|
279
|
-
} else {
|
|
280
|
-
lines[lineCounter] = char;
|
|
281
|
-
currentTextSize = size + characterSpacing;
|
|
282
|
-
}
|
|
283
|
-
else {
|
|
284
|
-
lines[++lineCounter] = char;
|
|
285
|
-
currentTextSize = size + characterSpacing;
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
if (lines.some(containsJapanese)) return adjustEndOfLine(filterEndJP(filterStartJP(lines)));
|
|
290
|
-
else return adjustEndOfLine(lines);
|
|
291
|
-
};
|
|
292
|
-
var adjustEndOfLine = (lines) => {
|
|
293
|
-
return lines.map((line, index) => {
|
|
294
|
-
if (index === lines.length - 1) return line.trimEnd() + "\n";
|
|
295
|
-
else return line.trimEnd();
|
|
296
|
-
});
|
|
297
|
-
};
|
|
298
|
-
function containsJapanese(text) {
|
|
299
|
-
return /[\p{Script=Hiragana}\p{Script=Katakana}\p{Script=Han}]/u.test(text);
|
|
300
|
-
}
|
|
301
|
-
var filterStartJP = (lines) => {
|
|
302
|
-
const filtered = [];
|
|
303
|
-
let charToAppend = null;
|
|
304
|
-
lines.slice().reverse().forEach((line) => {
|
|
305
|
-
if (line.trim().length === 0) filtered.push("");
|
|
306
|
-
else {
|
|
307
|
-
const charAtStart = line.charAt(0);
|
|
308
|
-
if (LINE_START_FORBIDDEN_CHARS.includes(charAtStart)) if (line.trim().length === 1) {
|
|
309
|
-
filtered.push(line);
|
|
310
|
-
charToAppend = null;
|
|
311
|
-
} else {
|
|
312
|
-
if (charToAppend) filtered.push(line.slice(1) + charToAppend);
|
|
313
|
-
else filtered.push(line.slice(1));
|
|
314
|
-
charToAppend = charAtStart;
|
|
315
|
-
}
|
|
316
|
-
else if (charToAppend) {
|
|
317
|
-
filtered.push(line + charToAppend);
|
|
318
|
-
charToAppend = null;
|
|
319
|
-
} else filtered.push(line);
|
|
320
|
-
}
|
|
321
|
-
});
|
|
322
|
-
if (charToAppend) {
|
|
323
|
-
const firstItem = filtered.length > 0 ? filtered[0] : "";
|
|
324
|
-
return [String(charToAppend) + String(firstItem), ...filtered.slice(1)].reverse();
|
|
325
|
-
} else return filtered.reverse();
|
|
326
|
-
};
|
|
327
|
-
var filterEndJP = (lines) => {
|
|
328
|
-
const filtered = [];
|
|
329
|
-
let charToPrepend = null;
|
|
330
|
-
lines.forEach((line) => {
|
|
331
|
-
if (line.trim().length === 0) filtered.push("");
|
|
332
|
-
else {
|
|
333
|
-
const chartAtEnd = line.slice(-1);
|
|
334
|
-
if (LINE_END_FORBIDDEN_CHARS.includes(chartAtEnd)) if (line.trim().length === 1) {
|
|
335
|
-
filtered.push(line);
|
|
336
|
-
charToPrepend = null;
|
|
337
|
-
} else {
|
|
338
|
-
if (charToPrepend) filtered.push(charToPrepend + line.slice(0, -1));
|
|
339
|
-
else filtered.push(line.slice(0, -1));
|
|
340
|
-
charToPrepend = chartAtEnd;
|
|
341
|
-
}
|
|
342
|
-
else if (charToPrepend) {
|
|
343
|
-
filtered.push(charToPrepend + line);
|
|
344
|
-
charToPrepend = null;
|
|
345
|
-
} else filtered.push(line);
|
|
346
|
-
}
|
|
347
|
-
});
|
|
348
|
-
if (charToPrepend) {
|
|
349
|
-
const lastItem = filtered.length > 0 ? filtered[filtered.length - 1] : "";
|
|
350
|
-
const combinedItem = String(lastItem) + String(charToPrepend);
|
|
351
|
-
return [...filtered.slice(0, -1), combinedItem];
|
|
352
|
-
} else return filtered;
|
|
353
|
-
};
|
|
354
|
-
//#endregion
|
|
1
|
+
import { C as ALIGN_RIGHT, E as DEFAULT_ALIGNMENT, G as VERTICAL_ALIGN_BOTTOM, K as VERTICAL_ALIGN_MIDDLE, O as DEFAULT_FONT_COLOR, S as ALIGN_LEFT, b as ALIGN_CENTER, h as getFontKitFont, l as getTableBodyRange, o as createTableBodySplitRange, v as splitTextToSize, y as widthOfTextAtSize } from "./splitRange-CpXivbmJ.js";
|
|
2
|
+
import { cloneDeep, getDefaultFont, getFallbackFontName, isBlankPdf, mm2pt, pt2mm } from "@pdfme/common";
|
|
355
3
|
//#region \0@oxc-project+runtime@0.127.0/helpers/typeof.js
|
|
356
4
|
function _typeof(o) {
|
|
357
5
|
"@babel/helpers - typeof";
|
|
@@ -831,7 +479,7 @@ function createSingleTable(body, args) {
|
|
|
831
479
|
const { options, _cache, basePdf } = args;
|
|
832
480
|
if (!isBlankPdf(basePdf)) console.warn("[@pdfme/schema/table]When specifying a custom PDF for basePdf, you cannot use features such as page breaks or re-layout of other elements.To utilize these features, please define basePdf as follows:\n{ width: number; height: number; padding: [number, number, number, number]; }");
|
|
833
481
|
const schema = cloneDeep(args.schema);
|
|
834
|
-
const { start } = schema
|
|
482
|
+
const { start } = getTableBodyRange(schema) || { start: 0 };
|
|
835
483
|
if (start % 2 === 1) {
|
|
836
484
|
const alternateBackgroundColor = schema.bodyStyles.alternateBackgroundColor;
|
|
837
485
|
schema.bodyStyles.alternateBackgroundColor = schema.bodyStyles.backgroundColor;
|
|
@@ -1082,12 +730,14 @@ var getBodyWithRange = (value, range) => {
|
|
|
1082
730
|
if (!range) return body;
|
|
1083
731
|
return body.slice(range.start, range.end);
|
|
1084
732
|
};
|
|
733
|
+
var getBodyWithSchemaRange = (value, schema, range = getTableBodyRange(schema)) => getBodyWithRange(value, range);
|
|
1085
734
|
//#endregion
|
|
1086
735
|
//#region src/tables/dynamicTemplate.ts
|
|
1087
736
|
var getDynamicHeightsForTable = async (value, args) => {
|
|
1088
737
|
if (args.schema.type !== "table") return Promise.resolve([args.schema.height]);
|
|
1089
738
|
const schema = args.schema;
|
|
1090
|
-
const
|
|
739
|
+
const bodyRange = getTableBodyRange(schema);
|
|
740
|
+
const table = await createSingleTable(bodyRange?.start === 0 ? getBody(value) : getBodyWithRange(value, bodyRange), args);
|
|
1091
741
|
const baseHeights = schema.showHead ? table.allRows().map((row) => row.height) : [0].concat(table.body.map((row) => row.height));
|
|
1092
742
|
const headerHeight = schema.showHead ? table.getHeadHeight() : 0;
|
|
1093
743
|
if (!(schema.repeatHead && isBlankPdf(args.basePdf) && headerHeight > 0)) return baseHeights;
|
|
@@ -1134,7 +784,23 @@ var getDynamicHeightsForTable = async (value, args) => {
|
|
|
1134
784
|
}
|
|
1135
785
|
return result;
|
|
1136
786
|
};
|
|
787
|
+
var getDynamicLayoutForTable = async (value, args) => {
|
|
788
|
+
return {
|
|
789
|
+
heights: await getDynamicHeightsForTable(value, args),
|
|
790
|
+
avoidFirstUnitOnly: true,
|
|
791
|
+
patchSplitSchema: ({ start, end, isSplit }) => {
|
|
792
|
+
const range = {
|
|
793
|
+
start: start === 0 ? 0 : start - 1,
|
|
794
|
+
end: end - 1
|
|
795
|
+
};
|
|
796
|
+
return {
|
|
797
|
+
__splitRange: createTableBodySplitRange(range.start, range.end),
|
|
798
|
+
__isSplit: isSplit
|
|
799
|
+
};
|
|
800
|
+
}
|
|
801
|
+
};
|
|
802
|
+
};
|
|
1137
803
|
//#endregion
|
|
1138
|
-
export {
|
|
804
|
+
export { getCellPropPanelSchema as a, HEX_COLOR_PATTERN as c, getBodyWithSchemaRange as i, createSingleTable as l, getDynamicLayoutForTable as n, getColumnStylesPropPanelSchema as o, getBody as r, getDefaultCellStyles as s, getDynamicHeightsForTable as t };
|
|
1139
805
|
|
|
1140
|
-
//# sourceMappingURL=dynamicTemplate-
|
|
806
|
+
//# sourceMappingURL=dynamicTemplate-CjbGepw4.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dynamicTemplate-CjbGepw4.js","names":[],"sources":["../src/tables/classes.ts","../src/tables/tableHelper.ts","../src/constants.ts","../src/tables/helper.ts","../src/tables/dynamicTemplate.ts"],"sourcesContent":["import { Font, mm2pt, pt2mm } from '@pdfme/common';\nimport type { Font as FontKitFont } from 'fontkit';\nimport { splitTextToSize, getFontKitFont, widthOfTextAtSize } from '../text/helper.js';\nimport type { Styles, TableInput, Settings, Section, StylesProps } from './types.js';\n\ntype ContentSettings = { body: Row[]; head: Row[]; columns: Column[] };\n\nexport class Cell {\n raw: string;\n text: string[];\n styles: Styles;\n section: Section;\n contentHeight = 0;\n contentWidth = 0;\n wrappedWidth = 0;\n minReadableWidth = 0;\n minWidth = 0;\n\n width = 0;\n height = 0;\n x = 0;\n y = 0;\n\n constructor(raw: string, styles: Styles, section: Section) {\n this.styles = styles;\n this.section = section;\n this.raw = raw;\n const splitRegex = /\\r\\n|\\r|\\n/g;\n this.text = raw.split(splitRegex);\n }\n\n getContentHeight() {\n const lineCount = Array.isArray(this.text) ? this.text.length : 1;\n const lineHeight = pt2mm(this.styles.fontSize) * this.styles.lineHeight;\n const vPadding = this.padding('top') + this.padding('bottom');\n const height = lineCount * lineHeight + vPadding;\n return Math.max(height, this.styles.minCellHeight);\n }\n\n padding(name: 'top' | 'bottom' | 'left' | 'right') {\n return this.styles.cellPadding[name];\n }\n}\n\nexport class Column {\n index: number;\n wrappedWidth = 0;\n minReadableWidth = 0;\n minWidth = 0;\n width = 0;\n\n constructor(index: number) {\n this.index = index;\n }\n\n getMaxCustomCellWidth(table: Table) {\n let max = 0;\n for (const row of table.allRows()) {\n const cell: Cell = row.cells[this.index];\n max = Math.max(max, cell.styles.cellWidth);\n }\n return max;\n }\n}\n\nexport class Row {\n readonly raw: string[];\n readonly index: number;\n readonly section: Section;\n readonly cells: { [key: string]: Cell };\n\n height = 0;\n\n constructor(raw: string[], index: number, section: Section, cells: { [key: string]: Cell }) {\n this.raw = raw;\n this.index = index;\n this.section = section;\n this.cells = cells;\n }\n\n getMaxCellHeight(columns: Column[]) {\n return columns.reduce((acc, column) => Math.max(acc, this.cells[column.index]?.height || 0), 0);\n }\n\n getMinimumRowHeight(columns: Column[]) {\n return columns.reduce((acc: number, column: Column) => {\n const cell = this.cells[column.index];\n if (!cell) return 0;\n const vPadding = cell.padding('top') + cell.padding('bottom');\n const oneRowHeight = vPadding + cell.styles.lineHeight;\n return oneRowHeight > acc ? oneRowHeight : acc;\n }, 0);\n }\n}\n\nexport class Table {\n readonly settings: Settings;\n readonly styles: StylesProps;\n\n readonly columns: Column[];\n readonly head: Row[];\n readonly body: Row[];\n\n constructor(input: TableInput, content: ContentSettings) {\n this.settings = input.settings;\n this.styles = input.styles;\n\n this.columns = content.columns;\n this.head = content.head;\n this.body = content.body;\n }\n\n static async create(arg: {\n input: TableInput;\n content: ContentSettings;\n font: Font;\n _cache: Map<string | number, FontKitFont>;\n }) {\n const { input, content, font, _cache } = arg;\n const table = new Table(input, content);\n\n await calculateWidths({ table, font, _cache });\n\n return table;\n }\n\n getHeadHeight() {\n return this.head.reduce((acc, row) => acc + row.getMaxCellHeight(this.columns), 0);\n }\n\n getBodyHeight() {\n return this.body.reduce((acc, row) => acc + row.getMaxCellHeight(this.columns), 0);\n }\n\n allRows() {\n return this.head.concat(this.body);\n }\n\n getWidth() {\n return this.settings.tableWidth;\n }\n\n getHeight() {\n return (this.settings.showHead ? this.getHeadHeight() : 0) + this.getBodyHeight();\n }\n}\n\nasync function calculateWidths(arg: {\n table: Table;\n font: Font;\n _cache: Map<string | number, FontKitFont>;\n}) {\n const { table, font, _cache } = arg;\n\n const getFontKitFontByFontName = (fontName: string | undefined) =>\n getFontKitFont(fontName, font, _cache);\n\n await calculate(table, getFontKitFontByFontName);\n\n const resizableColumns: Column[] = [];\n let initialTableWidth = 0;\n\n table.columns.forEach((column) => {\n const customWidth = column.getMaxCustomCellWidth(table);\n if (customWidth) {\n // final column width\n column.width = customWidth;\n } else {\n // initial column width (will be resized)\n column.width = column.wrappedWidth;\n resizableColumns.push(column);\n }\n initialTableWidth += column.width;\n });\n\n // width difference that needs to be distributed\n let resizeWidth = table.getWidth() - initialTableWidth;\n\n // first resize attempt: with respect to minReadableWidth and minWidth\n if (resizeWidth) {\n resizeWidth = resizeColumns(resizableColumns, resizeWidth, (column) =>\n Math.max(column.minReadableWidth, column.minWidth),\n );\n }\n\n // second resize attempt: ignore minReadableWidth but respect minWidth\n if (resizeWidth) {\n resizeWidth = resizeColumns(resizableColumns, resizeWidth, (column) => column.minWidth);\n }\n\n resizeWidth = Math.abs(resizeWidth);\n\n applyColSpans(table);\n await fitContent(table, getFontKitFontByFontName);\n applyRowSpans(table);\n}\n\nfunction applyRowSpans(table: Table) {\n const rowSpanCells: {\n [key: string]: { cell: Cell; left: number; row: Row };\n } = {};\n let colRowSpansLeft = 1;\n const all = table.allRows();\n for (let rowIndex = 0; rowIndex < all.length; rowIndex++) {\n const row = all[rowIndex];\n for (const column of table.columns) {\n const data = rowSpanCells[column.index];\n if (colRowSpansLeft > 1) {\n colRowSpansLeft--;\n delete row.cells[column.index];\n } else if (data) {\n data.cell.height += row.height;\n colRowSpansLeft = 1;\n delete row.cells[column.index];\n data.left--;\n if (data.left <= 1) {\n delete rowSpanCells[column.index];\n }\n } else {\n const cell = row.cells[column.index];\n if (!cell) {\n continue;\n }\n cell.height = row.height;\n }\n }\n }\n}\n\nfunction applyColSpans(table: Table) {\n const all = table.allRows();\n for (let rowIndex = 0; rowIndex < all.length; rowIndex++) {\n const row = all[rowIndex];\n\n let colSpanCell = null;\n let combinedColSpanWidth = 0;\n let colSpansLeft = 0;\n for (let columnIndex = 0; columnIndex < table.columns.length; columnIndex++) {\n const column = table.columns[columnIndex];\n\n // Width and colspan\n colSpansLeft -= 1;\n if (colSpansLeft > 1 && table.columns[columnIndex + 1]) {\n combinedColSpanWidth += column.width;\n delete row.cells[column.index];\n } else if (colSpanCell) {\n const cell: Cell = colSpanCell;\n delete row.cells[column.index];\n colSpanCell = null;\n cell.width = column.width + combinedColSpanWidth;\n } else {\n const cell = row.cells[column.index];\n if (!cell) continue;\n colSpansLeft = 1;\n combinedColSpanWidth = 0;\n cell.width = column.width + combinedColSpanWidth;\n }\n }\n }\n}\n\nasync function fitContent(\n table: Table,\n getFontKitFontByFontName: (fontName: string | undefined) => Promise<FontKitFont>,\n) {\n const rowSpanHeight = { count: 0, height: 0 };\n for (const row of table.allRows()) {\n for (const column of table.columns) {\n const cell: Cell = row.cells[column.index];\n if (!cell) continue;\n\n const fontKitFont = await getFontKitFontByFontName(cell.styles.fontName);\n cell.text = splitTextToSize({\n value: cell.raw,\n characterSpacing: cell.styles.characterSpacing,\n boxWidthInPt: mm2pt(cell.width),\n fontSize: cell.styles.fontSize,\n fontKitFont,\n });\n\n cell.contentHeight = cell.getContentHeight();\n\n let realContentHeight = cell.contentHeight;\n if (rowSpanHeight && rowSpanHeight.count > 0) {\n if (rowSpanHeight.height > realContentHeight) {\n realContentHeight = rowSpanHeight.height;\n }\n }\n if (realContentHeight > row.height) {\n row.height = realContentHeight;\n }\n }\n rowSpanHeight.count--;\n }\n}\n\nfunction resizeColumns(\n columns: Column[],\n resizeWidth: number,\n getMinWidth: (column: Column) => number,\n) {\n const initialResizeWidth = resizeWidth;\n const sumWrappedWidth = columns.reduce((acc, column) => acc + column.wrappedWidth, 0);\n\n for (let i = 0; i < columns.length; i++) {\n const column = columns[i];\n\n const ratio = column.wrappedWidth / sumWrappedWidth;\n const suggestedChange = initialResizeWidth * ratio;\n const suggestedWidth = column.width + suggestedChange;\n\n const minWidth = getMinWidth(column);\n const newWidth = suggestedWidth < minWidth ? minWidth : suggestedWidth;\n\n resizeWidth -= newWidth - column.width;\n column.width = newWidth;\n }\n\n resizeWidth = Math.round(resizeWidth * 1e10) / 1e10;\n\n // Run the resizer again if there's remaining width needs\n // to be distributed and there're columns that can be resized\n if (resizeWidth) {\n const resizableColumns = columns.filter((column) => {\n return resizeWidth < 0\n ? column.width > getMinWidth(column) // check if column can shrink\n : true; // check if column can grow\n });\n\n if (resizableColumns.length) {\n resizeWidth = resizeColumns(resizableColumns, resizeWidth, getMinWidth);\n }\n }\n\n return resizeWidth;\n}\n\nasync function calculate(\n table: Table,\n getFontKitFontByFontName: (fontName: string | undefined) => Promise<FontKitFont>,\n) {\n for (const row of table.allRows()) {\n for (const column of table.columns) {\n const cell = row.cells[column.index];\n if (!cell) continue;\n\n const hPadding = cell.padding('right') + cell.padding('left');\n const fontKitFont = await getFontKitFontByFontName(cell.styles.fontName);\n\n cell.contentWidth = getStringWidth(cell, fontKitFont) + hPadding;\n\n const longestWordWidth = getStringWidth(\n Object.assign(cell, { text: cell.text.join(' ').split(/\\s+/) }),\n fontKitFont,\n );\n cell.minReadableWidth = longestWordWidth + hPadding;\n\n cell.minWidth = cell.styles.cellWidth;\n cell.wrappedWidth = cell.styles.cellWidth;\n }\n }\n\n for (const row of table.allRows()) {\n for (const column of table.columns) {\n const cell = row.cells[column.index];\n\n // For now we ignore the minWidth and wrappedWidth of colspan cells when calculating colspan widths.\n // Could probably be improved upon however.\n if (cell) {\n column.wrappedWidth = Math.max(column.wrappedWidth, cell.wrappedWidth);\n column.minWidth = Math.max(column.minWidth, cell.minWidth);\n column.minReadableWidth = Math.max(column.minReadableWidth, cell.minReadableWidth);\n } else {\n // Respect cellWidth set in columnStyles even if there is no cells for this column\n // or if the column only have colspan cells. Since the width of colspan cells\n // does not affect the width of columns, setting columnStyles cellWidth enables the\n // user to at least do it manually.\n\n // Note that this is not perfect for now since for example row and table styles are\n // not accounted for\n const columnStyles = table.styles.columnStyles[column.index] || {};\n const cellWidth = columnStyles.cellWidth || columnStyles.minCellWidth;\n if (cellWidth) {\n column.minWidth = cellWidth;\n column.wrappedWidth = cellWidth;\n }\n }\n }\n }\n}\n\nfunction getStringWidth(cell: Cell, fontKitFont: FontKitFont) {\n const text = cell.text;\n const textArr: string[] = Array.isArray(text) ? text : [text];\n const fontSize = cell.styles.fontSize;\n const characterSpacing = cell.styles.characterSpacing;\n const widestLineWidth = textArr\n .map((text) => widthOfTextAtSize(text, fontKitFont, fontSize, characterSpacing))\n .reduce((a, b) => Math.max(a, b), 0);\n\n return widestLineWidth;\n}\n","import {\n Schema,\n isBlankPdf,\n BasePdf,\n CommonOptions,\n getDefaultFont,\n getFallbackFontName,\n cloneDeep,\n} from '@pdfme/common';\nimport type { Font as FontKitFont } from 'fontkit';\nimport type {\n TableSchema,\n CellStyle,\n Styles,\n Spacing,\n TableInput,\n StylesProps,\n Section,\n} from './types.js';\nimport { Cell, Column, Row, Table } from './classes.js';\nimport { getTableBodyRange } from '../splitRange.js';\n\ntype StyleProp = 'styles' | 'headStyles' | 'bodyStyles' | 'alternateRowStyles' | 'columnStyles';\n\ninterface CreateTableArgs {\n schema: Schema;\n basePdf: BasePdf;\n options: CommonOptions;\n _cache: Map<string | number, unknown>;\n}\n\ninterface UserOptions {\n startY: number;\n tableWidth: number;\n margin: Spacing;\n showHead: boolean;\n tableLineWidth?: number;\n tableLineColor?: string;\n head?: string[][];\n body?: string[][];\n\n styles?: Partial<Styles>;\n bodyStyles?: Partial<Styles>;\n headStyles?: Partial<Styles>;\n alternateRowStyles?: Partial<Styles>;\n columnStyles?: {\n [key: string]: Partial<Styles>;\n };\n}\n\nfunction parseSection(\n sectionName: Section,\n sectionRows: string[][],\n columns: Column[],\n styleProps: StylesProps,\n fallbackFontName: string,\n): Row[] {\n const rowSpansLeftForColumn: { [key: string]: { left: number; times: number } } = {};\n const result = sectionRows.map((rawRow, rowIndex) => {\n let skippedRowForRowSpans = 0;\n const cells: { [key: string]: Cell } = {};\n\n let colSpansAdded = 0;\n let columnSpansLeft = 0;\n for (const column of columns) {\n if (\n rowSpansLeftForColumn[column.index] == null ||\n rowSpansLeftForColumn[column.index].left === 0\n ) {\n if (columnSpansLeft === 0) {\n let rawCell;\n if (Array.isArray(rawRow)) {\n rawCell = rawRow[column.index - colSpansAdded - skippedRowForRowSpans];\n } else {\n rawCell = rawRow[column.index];\n }\n const styles = cellStyles(sectionName, column, rowIndex, styleProps, fallbackFontName);\n const cell = new Cell(rawCell, styles, sectionName);\n cells[column.index] = cell;\n\n columnSpansLeft = 0;\n rowSpansLeftForColumn[column.index] = {\n left: 0,\n times: columnSpansLeft,\n };\n } else {\n columnSpansLeft--;\n colSpansAdded++;\n }\n } else {\n rowSpansLeftForColumn[column.index].left--;\n columnSpansLeft = rowSpansLeftForColumn[column.index].times;\n skippedRowForRowSpans++;\n }\n }\n return new Row(rawRow, rowIndex, sectionName, cells);\n });\n return result;\n}\n\nfunction parseContent4Table(input: TableInput, fallbackFontName: string) {\n const content = input.content;\n const columns = content.columns.map((index) => new Column(index));\n const styles = input.styles;\n return {\n columns,\n head: parseSection('head', content.head, columns, styles, fallbackFontName),\n body: parseSection('body', content.body, columns, styles, fallbackFontName),\n };\n}\n\nfunction cellStyles(\n sectionName: Section,\n column: Column,\n rowIndex: number,\n styles: StylesProps,\n fallbackFontName: string,\n) {\n let sectionStyles;\n if (sectionName === 'head') {\n sectionStyles = styles.headStyles;\n } else if (sectionName === 'body') {\n sectionStyles = styles.bodyStyles;\n }\n const otherStyles = Object.assign({}, styles.styles, sectionStyles);\n\n const colStyles = styles.columnStyles[column.index] || {};\n\n const rowStyles =\n sectionName === 'body' && rowIndex % 2 === 0\n ? Object.assign({}, styles.alternateRowStyles)\n : {};\n\n const defaultStyle = {\n fontName: fallbackFontName,\n backgroundColor: '',\n textColor: '#000000',\n lineHeight: 1,\n characterSpacing: 0,\n alignment: 'left',\n verticalAlignment: 'middle',\n fontSize: 10,\n cellPadding: 5,\n lineColor: '#000000',\n lineWidth: 0,\n minCellHeight: 0,\n minCellWidth: 0,\n };\n return Object.assign(defaultStyle, otherStyles, rowStyles, colStyles) as Styles;\n}\n\nfunction mapCellStyle(style: CellStyle): Partial<Styles> {\n return {\n fontName: style.fontName,\n alignment: style.alignment,\n verticalAlignment: style.verticalAlignment,\n fontSize: style.fontSize,\n lineHeight: style.lineHeight,\n characterSpacing: style.characterSpacing,\n backgroundColor: style.backgroundColor,\n // ---\n textColor: style.fontColor,\n lineColor: style.borderColor,\n lineWidth: style.borderWidth,\n cellPadding: style.padding,\n };\n}\n\nfunction getTableOptions(schema: TableSchema, body: string[][]): UserOptions {\n const columnStylesWidth = schema.headWidthPercentages.reduce(\n (acc, cur, i) => ({ ...acc, [i]: { cellWidth: schema.width * (cur / 100) } }),\n {} as Record<number, Partial<Styles>>,\n );\n\n const columnStylesAlignment = Object.entries(schema.columnStyles.alignment || {}).reduce(\n (acc, [key, value]) => ({ ...acc, [key]: { alignment: value } }),\n {} as Record<number, Partial<Styles>>,\n );\n\n const allKeys = new Set([\n ...Object.keys(columnStylesWidth).map(Number),\n ...Object.keys(columnStylesAlignment).map(Number),\n ]);\n const columnStyles = Array.from(allKeys).reduce(\n (acc, key) => {\n const widthStyle = columnStylesWidth[key] || {};\n const alignmentStyle = columnStylesAlignment[key] || {};\n return { ...acc, [key]: { ...widthStyle, ...alignmentStyle } };\n },\n {} as Record<number, Partial<Styles>>,\n );\n\n return {\n head: [schema.head],\n body,\n showHead: schema.showHead,\n startY: schema.position.y,\n tableWidth: schema.width,\n tableLineColor: schema.tableStyles.borderColor,\n tableLineWidth: schema.tableStyles.borderWidth,\n headStyles: mapCellStyle(schema.headStyles),\n bodyStyles: mapCellStyle(schema.bodyStyles),\n alternateRowStyles: { backgroundColor: schema.bodyStyles.alternateBackgroundColor },\n columnStyles,\n margin: { top: 0, right: 0, left: schema.position.x, bottom: 0 },\n };\n}\n\nfunction parseStyles(cInput: UserOptions) {\n const styleOptions: StylesProps = {\n styles: {},\n headStyles: {},\n bodyStyles: {},\n alternateRowStyles: {},\n columnStyles: {},\n };\n for (const prop of Object.keys(styleOptions) as StyleProp[]) {\n if (prop === 'columnStyles') {\n const current = cInput[prop];\n styleOptions.columnStyles = Object.assign({}, current);\n } else {\n const allOptions = [cInput];\n const styles = allOptions.map((opts) => opts[prop] || {});\n styleOptions[prop] = Object.assign({}, styles[0], styles[1], styles[2]);\n }\n }\n return styleOptions;\n}\n\nfunction parseContent4Input(options: UserOptions) {\n const head = options.head || [];\n const body = options.body || [];\n const columns = (head[0] || body[0] || []).map((_, index) => index);\n return { columns, head, body };\n}\n\nfunction parseInput(schema: TableSchema, body: string[][]): TableInput {\n const options = getTableOptions(schema, body);\n const styles = parseStyles(options);\n const settings = {\n startY: options.startY,\n margin: options.margin,\n tableWidth: options.tableWidth,\n showHead: options.showHead,\n tableLineWidth: options.tableLineWidth ?? 0,\n tableLineColor: options.tableLineColor ?? '',\n };\n\n const content = parseContent4Input(options);\n\n return { content, styles, settings };\n}\n\nexport function createSingleTable(body: string[][], args: CreateTableArgs) {\n const { options, _cache, basePdf } = args;\n if (!isBlankPdf(basePdf)) {\n console.warn(\n '[@pdfme/schema/table]' +\n 'When specifying a custom PDF for basePdf, ' +\n 'you cannot use features such as page breaks or re-layout of other elements.' +\n 'To utilize these features, please define basePdf as follows:\\n' +\n '{ width: number; height: number; padding: [number, number, number, number]; }',\n );\n }\n\n const schema = cloneDeep(args.schema) as TableSchema;\n const { start } = getTableBodyRange(schema) || { start: 0 };\n if (start % 2 === 1) {\n const alternateBackgroundColor = schema.bodyStyles.alternateBackgroundColor;\n schema.bodyStyles.alternateBackgroundColor = schema.bodyStyles.backgroundColor;\n schema.bodyStyles.backgroundColor = alternateBackgroundColor;\n }\n schema.showHead =\n schema.showHead === false ? false : !schema.__isSplit || schema.repeatHead === true;\n\n const input = parseInput(schema, body);\n\n const font = options.font || getDefaultFont();\n\n const fallbackFontName = getFallbackFontName(font);\n\n const content = parseContent4Table(input, fallbackFontName);\n\n return Table.create({\n input,\n content,\n font,\n _cache: _cache as unknown as Map<string | number, FontKitFont>,\n });\n}\n","export const DEFAULT_OPACITY = 1;\nexport const HEX_COLOR_PATTERN = '^#(?:[A-Fa-f0-9]{6})$';\n","import {\n DEFAULT_ALIGNMENT,\n DEFAULT_FONT_SIZE,\n DEFAULT_LINE_HEIGHT,\n DEFAULT_CHARACTER_SPACING,\n DEFAULT_FONT_COLOR,\n ALIGN_RIGHT,\n ALIGN_CENTER,\n ALIGN_LEFT,\n VERTICAL_ALIGN_TOP,\n VERTICAL_ALIGN_MIDDLE,\n VERTICAL_ALIGN_BOTTOM,\n} from '../text/constants.js';\nimport { HEX_COLOR_PATTERN } from '../constants.js';\nimport type { TableSchema } from './types.js';\nimport { getTableBodyRange } from '../splitRange.js';\nimport type { DynamicLayoutRange } from '@pdfme/common';\n\nexport const getDefaultCellStyles = () => ({\n fontName: undefined,\n alignment: DEFAULT_ALIGNMENT,\n verticalAlignment: VERTICAL_ALIGN_MIDDLE,\n fontSize: DEFAULT_FONT_SIZE,\n lineHeight: DEFAULT_LINE_HEIGHT,\n characterSpacing: DEFAULT_CHARACTER_SPACING,\n fontColor: DEFAULT_FONT_COLOR,\n backgroundColor: '',\n borderColor: '#888888',\n borderWidth: { top: 0.1, bottom: 0.1, left: 0.1, right: 0.1 },\n padding: { top: 5, bottom: 5, left: 5, right: 5 },\n});\n\nconst getBoxDimensionProp = (step = 1) => {\n const getCommonProp = () => ({\n type: 'number',\n widget: 'inputNumber',\n props: { min: 0, step },\n span: 6,\n });\n return {\n top: { title: 'Top', ...getCommonProp() },\n right: { title: 'Right', ...getCommonProp() },\n bottom: { title: 'Bottom', ...getCommonProp() },\n left: { title: 'Left', ...getCommonProp() },\n };\n};\n\nexport const getCellPropPanelSchema = (arg: {\n i18n: (key: string) => string;\n fallbackFontName: string;\n fontNames: string[];\n isBody?: boolean;\n}) => {\n const { i18n, fallbackFontName, fontNames, isBody } = arg;\n\n return {\n fontName: {\n title: i18n('schemas.text.fontName'),\n type: 'string',\n widget: 'select',\n default: fallbackFontName,\n placeholder: fallbackFontName,\n props: { options: fontNames.map((name) => ({ label: name, value: name })) },\n span: 12,\n },\n fontSize: {\n title: i18n('schemas.text.size'),\n type: 'number',\n widget: 'inputNumber',\n props: { min: 0 },\n span: 6,\n },\n characterSpacing: {\n title: i18n('schemas.text.spacing'),\n type: 'number',\n widget: 'inputNumber',\n props: { min: 0 },\n span: 6,\n },\n alignment: {\n title: i18n('schemas.text.textAlign'),\n type: 'string',\n widget: 'select',\n props: {\n options: [\n { label: i18n('schemas.left'), value: ALIGN_LEFT },\n { label: i18n('schemas.center'), value: ALIGN_CENTER },\n { label: i18n('schemas.right'), value: ALIGN_RIGHT },\n ],\n },\n span: 8,\n },\n verticalAlignment: {\n title: i18n('schemas.text.verticalAlign'),\n type: 'string',\n widget: 'select',\n props: {\n options: [\n { label: i18n('schemas.top'), value: VERTICAL_ALIGN_TOP },\n { label: i18n('schemas.middle'), value: VERTICAL_ALIGN_MIDDLE },\n { label: i18n('schemas.bottom'), value: VERTICAL_ALIGN_BOTTOM },\n ],\n },\n span: 8,\n },\n lineHeight: {\n title: i18n('schemas.text.lineHeight'),\n type: 'number',\n widget: 'inputNumber',\n props: { step: 0.1, min: 0 },\n span: 8,\n },\n fontColor: {\n title: i18n('schemas.textColor'),\n type: 'string',\n widget: 'color',\n props: {\n disabledAlpha: true,\n },\n rules: [{ pattern: HEX_COLOR_PATTERN, message: i18n('validation.hexColor') }],\n },\n borderColor: {\n title: i18n('schemas.borderColor'),\n type: 'string',\n widget: 'color',\n props: {\n disabledAlpha: true,\n },\n rules: [{ pattern: HEX_COLOR_PATTERN, message: i18n('validation.hexColor') }],\n },\n backgroundColor: {\n title: i18n('schemas.backgroundColor'),\n type: 'string',\n widget: 'color',\n props: {\n disabledAlpha: true,\n },\n rules: [{ pattern: HEX_COLOR_PATTERN, message: i18n('validation.hexColor') }],\n },\n ...(isBody\n ? {\n alternateBackgroundColor: {\n title: i18n('schemas.table.alternateBackgroundColor'),\n type: 'string',\n widget: 'color',\n props: {\n disabledAlpha: true,\n },\n rules: [{ pattern: HEX_COLOR_PATTERN, message: i18n('validation.hexColor') }],\n },\n }\n : {}),\n '-': { type: 'void', widget: 'Divider' },\n borderWidth: {\n title: i18n('schemas.borderWidth'),\n type: 'object',\n widget: 'lineTitle',\n span: 24,\n properties: getBoxDimensionProp(0.1),\n },\n '--': { type: 'void', widget: 'Divider' },\n padding: {\n title: i18n('schemas.padding'),\n type: 'object',\n widget: 'lineTitle',\n span: 24,\n properties: getBoxDimensionProp(),\n },\n };\n};\n\nexport const getColumnStylesPropPanelSchema = ({\n head,\n i18n,\n}: {\n head: string[];\n i18n: (key: string) => string;\n}) => ({\n alignment: {\n type: 'object',\n widget: 'lineTitle',\n title: i18n('schemas.text.textAlign'),\n column: 3,\n properties: head.reduce(\n (acc, cur, i) =>\n Object.assign(acc, {\n [i]: {\n title: cur || 'Column ' + String(i + 1),\n type: 'string',\n widget: 'select',\n props: {\n options: [\n { label: i18n('schemas.left'), value: ALIGN_LEFT },\n { label: i18n('schemas.center'), value: ALIGN_CENTER },\n { label: i18n('schemas.right'), value: ALIGN_RIGHT },\n ],\n },\n },\n }),\n {},\n ),\n },\n});\n\nexport const getBody = (value: string | string[][]): string[][] => {\n if (typeof value === 'string') {\n return JSON.parse(value || '[]') as string[][];\n }\n return value || [];\n};\n\nexport const getBodyWithRange = (value: string | string[][], range?: DynamicLayoutRange) => {\n const body = getBody(value);\n if (!range) return body;\n return body.slice(range.start, range.end);\n};\n\nexport const getBodyWithSchemaRange = (\n value: string | string[][],\n schema: TableSchema,\n range = getTableBodyRange(schema),\n) => getBodyWithRange(value, range);\n","import {\n Schema,\n BasePdf,\n BlankPdf,\n CommonOptions,\n DynamicLayoutArgs,\n DynamicLayoutResult,\n isBlankPdf,\n} from '@pdfme/common';\nimport { createSingleTable } from './tableHelper.js';\nimport { getBodyWithRange, getBody } from './helper.js';\nimport { TableSchema } from './types.js';\nimport { createTableBodySplitRange, getTableBodyRange } from '../splitRange.js';\n\nexport const getDynamicHeightsForTable = async (\n value: string,\n args: {\n schema: Schema;\n basePdf: BasePdf;\n options: CommonOptions;\n _cache: Map<string | number, unknown>;\n },\n): Promise<number[]> => {\n if (args.schema.type !== 'table') return Promise.resolve([args.schema.height]);\n const schema = args.schema as TableSchema;\n const bodyRange = getTableBodyRange(schema);\n const body = bodyRange?.start === 0 ? getBody(value) : getBodyWithRange(value, bodyRange);\n const table = await createSingleTable(body, args);\n\n const baseHeights = schema.showHead\n ? table.allRows().map((row) => row.height)\n : [0].concat(table.body.map((row) => row.height));\n\n const headerHeight = schema.showHead ? table.getHeadHeight() : 0;\n const shouldRepeatHeader = schema.repeatHead && isBlankPdf(args.basePdf) && headerHeight > 0;\n\n if (!shouldRepeatHeader) {\n return baseHeights;\n }\n\n const basePdf = args.basePdf as BlankPdf;\n const [paddingTop, , paddingBottom] = basePdf.padding;\n const pageContentHeight = basePdf.height - paddingTop - paddingBottom;\n const getPageStartY = (pageIndex: number) => pageIndex * pageContentHeight + paddingTop;\n\n const initialPageIndex = Math.max(\n 0,\n Math.floor((schema.position.y - paddingTop) / pageContentHeight),\n );\n const headRowCount = schema.showHead ? table.head.length : 0;\n const SAFETY_MARGIN = 0.5;\n\n let currentPageIndex = initialPageIndex;\n let currentPageY = schema.position.y;\n let rowsOnCurrentPage = 0;\n\n const result: number[] = [];\n\n for (let i = 0; i < baseHeights.length; i++) {\n const isBodyRow = i >= headRowCount;\n const rowHeight = baseHeights[i];\n\n while (true) {\n const currentPageStartY = getPageStartY(currentPageIndex);\n const remainingHeight = currentPageStartY + pageContentHeight - currentPageY;\n const needsHeader =\n isBodyRow && rowsOnCurrentPage === 0 && currentPageIndex > initialPageIndex;\n const totalRowHeight = rowHeight + (needsHeader ? headerHeight : 0);\n\n if (totalRowHeight > remainingHeight - SAFETY_MARGIN) {\n if (rowsOnCurrentPage === 0 && Math.abs(currentPageY - currentPageStartY) < SAFETY_MARGIN) {\n result.push(totalRowHeight);\n currentPageY += totalRowHeight;\n rowsOnCurrentPage++;\n break;\n }\n currentPageIndex++;\n currentPageY = getPageStartY(currentPageIndex);\n rowsOnCurrentPage = 0;\n continue;\n }\n\n result.push(totalRowHeight);\n currentPageY += totalRowHeight;\n rowsOnCurrentPage++;\n\n if (currentPageY >= currentPageStartY + pageContentHeight - SAFETY_MARGIN) {\n currentPageIndex++;\n currentPageY = getPageStartY(currentPageIndex);\n rowsOnCurrentPage = 0;\n }\n break;\n }\n }\n\n return result;\n};\n\nexport const getDynamicLayoutForTable = async (\n value: string,\n args: DynamicLayoutArgs,\n): Promise<DynamicLayoutResult> => {\n const heights = await getDynamicHeightsForTable(value, args);\n\n return {\n heights,\n avoidFirstUnitOnly: true,\n patchSplitSchema: ({ start, end, isSplit }) => {\n const range = {\n start: start === 0 ? 0 : start - 1,\n end: end - 1,\n };\n return {\n __splitRange: createTableBodySplitRange(range.start, range.end),\n __isSplit: isSplit,\n };\n },\n };\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { a as createListItemSplitRange, h as getFontKitFont, v as splitTextToSize } from "./splitRange-CpXivbmJ.js";
|
|
2
|
+
import { getDefaultFont, mm2pt, pt2mm } from "@pdfme/common";
|
|
3
|
+
//#region src/list/constants.ts
|
|
4
|
+
var LIST_STYLE_BULLET = "bullet";
|
|
5
|
+
var LIST_STYLE_ORDERED = "ordered";
|
|
6
|
+
var DEFAULT_LIST_STYLE = LIST_STYLE_BULLET;
|
|
7
|
+
//#endregion
|
|
8
|
+
//#region src/list/helper.ts
|
|
9
|
+
var normalizeListItems = (value) => {
|
|
10
|
+
if (Array.isArray(value)) return value.map((item) => String(item));
|
|
11
|
+
if (typeof value !== "string") return value == null ? [] : [String(value)];
|
|
12
|
+
const trimmed = value.trim();
|
|
13
|
+
if (!trimmed) return [];
|
|
14
|
+
try {
|
|
15
|
+
const parsed = JSON.parse(trimmed);
|
|
16
|
+
if (Array.isArray(parsed)) return parsed.map((item) => String(item));
|
|
17
|
+
} catch {}
|
|
18
|
+
return value.split(/\r\n|\r|\n/g);
|
|
19
|
+
};
|
|
20
|
+
var parseListItem = (value) => {
|
|
21
|
+
const indent = value.match(/^\t+/)?.[0].length ?? 0;
|
|
22
|
+
return {
|
|
23
|
+
level: Math.min(indent, 8),
|
|
24
|
+
text: value.slice(indent)
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
var normalizeListItemEntries = (value) => normalizeListItems(value).map(parseListItem);
|
|
28
|
+
var formatListItem = (item) => `${" ".repeat(Math.max(0, item.level))}${item.text}`;
|
|
29
|
+
var serializeListItems = (items) => {
|
|
30
|
+
const lines = items.map(formatListItem);
|
|
31
|
+
return JSON.stringify(lines);
|
|
32
|
+
};
|
|
33
|
+
var getListMarkers = (schema, items) => {
|
|
34
|
+
if ((schema.listStyle ?? "bullet") !== "ordered") return items.map(() => "•");
|
|
35
|
+
const counters = Array.from({ length: 9 }, () => 0);
|
|
36
|
+
return items.map((rawItem) => {
|
|
37
|
+
const { level } = parseListItem(rawItem);
|
|
38
|
+
counters[level] += 1;
|
|
39
|
+
counters.fill(0, level + 1);
|
|
40
|
+
return `${counters[level]}.`;
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
var calculateListLayout = async (arg) => {
|
|
44
|
+
const { schema, items, markerItems, startIndex, options, _cache } = arg;
|
|
45
|
+
const markerWidth = schema.markerWidth ?? 6;
|
|
46
|
+
const markerGap = schema.markerGap ?? 2;
|
|
47
|
+
const indentSize = schema.indentSize ?? 6;
|
|
48
|
+
const font = options.font || getDefaultFont();
|
|
49
|
+
const fontKitFont = await getFontKitFont(schema.fontName, font, _cache);
|
|
50
|
+
const fontSize = schema.fontSize ?? 13;
|
|
51
|
+
const lineHeight = schema.lineHeight ?? 1;
|
|
52
|
+
const characterSpacing = schema.characterSpacing ?? 0;
|
|
53
|
+
const itemSpacing = schema.itemSpacing ?? 1;
|
|
54
|
+
const lineHeightMm = pt2mm(fontSize * lineHeight);
|
|
55
|
+
const markers = markerItems ? getListMarkers(schema, markerItems).slice(startIndex, startIndex + items.length) : getListMarkers(schema, items);
|
|
56
|
+
const layoutItems = items.map((rawItem, index) => {
|
|
57
|
+
const item = parseListItem(rawItem);
|
|
58
|
+
const markerX = item.level * indentSize;
|
|
59
|
+
const bodyX = markerX + markerWidth + markerGap;
|
|
60
|
+
const bodyWidth = Math.max(schema.width - bodyX, 0);
|
|
61
|
+
const lines = splitTextToSize({
|
|
62
|
+
value: item.text,
|
|
63
|
+
characterSpacing,
|
|
64
|
+
boxWidthInPt: mm2pt(Math.max(bodyWidth, .1)),
|
|
65
|
+
fontSize,
|
|
66
|
+
fontKitFont
|
|
67
|
+
});
|
|
68
|
+
const height = Math.max(lines.length, 1) * lineHeightMm + (index === items.length - 1 ? 0 : itemSpacing);
|
|
69
|
+
return {
|
|
70
|
+
item: item.text,
|
|
71
|
+
itemIndex: startIndex + index,
|
|
72
|
+
level: item.level,
|
|
73
|
+
marker: markers[index],
|
|
74
|
+
lines,
|
|
75
|
+
height,
|
|
76
|
+
markerX,
|
|
77
|
+
bodyX,
|
|
78
|
+
bodyWidth
|
|
79
|
+
};
|
|
80
|
+
});
|
|
81
|
+
return {
|
|
82
|
+
items: layoutItems,
|
|
83
|
+
totalHeight: layoutItems.reduce((sum, item) => sum + item.height, 0),
|
|
84
|
+
markerWidth,
|
|
85
|
+
markerGap,
|
|
86
|
+
indentSize
|
|
87
|
+
};
|
|
88
|
+
};
|
|
89
|
+
//#endregion
|
|
90
|
+
//#region src/list/dynamicTemplate.ts
|
|
91
|
+
var getDynamicLayoutForList = async (value, args) => {
|
|
92
|
+
if (args.schema.type !== "list") return { heights: [args.schema.height] };
|
|
93
|
+
const schema = args.schema;
|
|
94
|
+
const items = normalizeListItems(value);
|
|
95
|
+
if (items.length === 0) return { heights: [0] };
|
|
96
|
+
return {
|
|
97
|
+
heights: (await calculateListLayout({
|
|
98
|
+
schema,
|
|
99
|
+
items,
|
|
100
|
+
startIndex: 0,
|
|
101
|
+
options: args.options,
|
|
102
|
+
_cache: args._cache
|
|
103
|
+
})).items.map((item) => item.height),
|
|
104
|
+
avoidFirstUnitOnly: false,
|
|
105
|
+
patchSplitSchema: ({ start, end, isSplit }) => ({
|
|
106
|
+
__splitRange: createListItemSplitRange(start, end),
|
|
107
|
+
__isSplit: isSplit
|
|
108
|
+
})
|
|
109
|
+
};
|
|
110
|
+
};
|
|
111
|
+
//#endregion
|
|
112
|
+
export { normalizeListItems as a, LIST_STYLE_BULLET as c, normalizeListItemEntries as i, LIST_STYLE_ORDERED as l, calculateListLayout as n, serializeListItems as o, getListMarkers as r, DEFAULT_LIST_STYLE as s, getDynamicLayoutForList as t };
|
|
113
|
+
|
|
114
|
+
//# sourceMappingURL=dynamicTemplate-Fn7mpUsu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dynamicTemplate-Fn7mpUsu.js","names":[],"sources":["../src/list/constants.ts","../src/list/helper.ts","../src/list/dynamicTemplate.ts"],"sourcesContent":["import type { LIST_STYLE } from './types.js';\n\nexport const LIST_STYLE_BULLET = 'bullet' as LIST_STYLE;\nexport const LIST_STYLE_ORDERED = 'ordered' as LIST_STYLE;\nexport const DEFAULT_LIST_STYLE = LIST_STYLE_BULLET;\nexport const DEFAULT_MARKER = '\\u2022';\nexport const DEFAULT_MARKER_WIDTH = 6;\nexport const DEFAULT_MARKER_GAP = 2;\nexport const DEFAULT_INDENT_SIZE = 6;\nexport const DEFAULT_ITEM_SPACING = 1;\nexport const MAX_INDENT_LEVEL = 8;\n","import { CommonOptions, getDefaultFont, mm2pt, pt2mm } from '@pdfme/common';\nimport {\n DEFAULT_CHARACTER_SPACING,\n DEFAULT_FONT_SIZE,\n DEFAULT_LINE_HEIGHT,\n} from '../text/constants.js';\nimport { getFontKitFont, splitTextToSize } from '../text/helper.js';\nimport type { ListItem, ListItemLayout, ListLayout, ListSchema } from './types.js';\nimport {\n DEFAULT_INDENT_SIZE,\n DEFAULT_ITEM_SPACING,\n DEFAULT_LIST_STYLE,\n DEFAULT_MARKER,\n DEFAULT_MARKER_GAP,\n DEFAULT_MARKER_WIDTH,\n LIST_STYLE_ORDERED,\n MAX_INDENT_LEVEL,\n} from './constants.js';\n\nexport const normalizeListItems = (value: unknown): string[] => {\n if (Array.isArray(value)) return value.map((item) => String(item));\n\n if (typeof value !== 'string') {\n return value == null ? [] : [String(value)];\n }\n\n const trimmed = value.trim();\n if (!trimmed) return [];\n\n try {\n const parsed = JSON.parse(trimmed) as unknown;\n if (Array.isArray(parsed)) return parsed.map((item) => String(item));\n } catch {\n // Fall through to newline parsing.\n }\n\n return value.split(/\\r\\n|\\r|\\n/g);\n};\n\nexport const parseListItem = (value: string): ListItem => {\n const indent = value.match(/^\\t+/)?.[0].length ?? 0;\n return {\n level: Math.min(indent, MAX_INDENT_LEVEL),\n text: value.slice(indent),\n };\n};\n\nexport const normalizeListItemEntries = (value: unknown): ListItem[] =>\n normalizeListItems(value).map(parseListItem);\n\nconst formatListItem = (item: ListItem): string =>\n `${'\\t'.repeat(Math.max(0, item.level))}${item.text}`;\n\nexport const serializeListItems = (items: ListItem[]): string => {\n const lines = items.map(formatListItem);\n return JSON.stringify(lines);\n};\n\nexport const getListMarkers = (schema: ListSchema, items: string[]): string[] => {\n if ((schema.listStyle ?? DEFAULT_LIST_STYLE) !== LIST_STYLE_ORDERED) {\n return items.map(() => DEFAULT_MARKER);\n }\n\n const counters = Array.from({ length: MAX_INDENT_LEVEL + 1 }, () => 0);\n return items.map((rawItem) => {\n const { level } = parseListItem(rawItem);\n counters[level] += 1;\n counters.fill(0, level + 1);\n return `${counters[level]}.`;\n });\n};\n\nexport const calculateListLayout = async (arg: {\n schema: ListSchema;\n items: string[];\n markerItems?: string[];\n startIndex: number;\n options: CommonOptions;\n _cache: Map<string | number, unknown>;\n}): Promise<ListLayout> => {\n const { schema, items, markerItems, startIndex, options, _cache } = arg;\n const markerWidth = schema.markerWidth ?? DEFAULT_MARKER_WIDTH;\n const markerGap = schema.markerGap ?? DEFAULT_MARKER_GAP;\n const indentSize = schema.indentSize ?? DEFAULT_INDENT_SIZE;\n const font = options.font || getDefaultFont();\n const fontKitFont = await getFontKitFont(\n schema.fontName,\n font,\n _cache as Map<string | number, import('fontkit').Font>,\n );\n\n const fontSize = schema.fontSize ?? DEFAULT_FONT_SIZE;\n const lineHeight = schema.lineHeight ?? DEFAULT_LINE_HEIGHT;\n const characterSpacing = schema.characterSpacing ?? DEFAULT_CHARACTER_SPACING;\n const itemSpacing = schema.itemSpacing ?? DEFAULT_ITEM_SPACING;\n const lineHeightMm = pt2mm(fontSize * lineHeight);\n const markers = markerItems\n ? getListMarkers(schema, markerItems).slice(startIndex, startIndex + items.length)\n : getListMarkers(schema, items);\n\n const layoutItems: ListItemLayout[] = items.map((rawItem, index) => {\n const item = parseListItem(rawItem);\n const markerX = item.level * indentSize;\n const bodyX = markerX + markerWidth + markerGap;\n const bodyWidth = Math.max(schema.width - bodyX, 0);\n const lines = splitTextToSize({\n value: item.text,\n characterSpacing,\n boxWidthInPt: mm2pt(Math.max(bodyWidth, 0.1)),\n fontSize,\n fontKitFont,\n });\n const height =\n Math.max(lines.length, 1) * lineHeightMm + (index === items.length - 1 ? 0 : itemSpacing);\n\n return {\n item: item.text,\n itemIndex: startIndex + index,\n level: item.level,\n marker: markers[index],\n lines,\n height,\n markerX,\n bodyX,\n bodyWidth,\n };\n });\n\n return {\n items: layoutItems,\n totalHeight: layoutItems.reduce((sum, item) => sum + item.height, 0),\n markerWidth,\n markerGap,\n indentSize,\n };\n};\n","import type { DynamicLayoutArgs, DynamicLayoutResult } from '@pdfme/common';\nimport type { ListSchema } from './types.js';\nimport { calculateListLayout, normalizeListItems } from './helper.js';\nimport { createListItemSplitRange } from '../splitRange.js';\n\nexport const getDynamicLayoutForList = async (\n value: string,\n args: DynamicLayoutArgs,\n): Promise<DynamicLayoutResult> => {\n if (args.schema.type !== 'list') return { heights: [args.schema.height] };\n\n const schema = args.schema as ListSchema;\n const items = normalizeListItems(value);\n if (items.length === 0) return { heights: [0] };\n\n const layout = await calculateListLayout({\n schema,\n items,\n startIndex: 0,\n options: args.options,\n _cache: args._cache,\n });\n\n return {\n heights: layout.items.map((item) => item.height),\n avoidFirstUnitOnly: false,\n patchSplitSchema: ({ start, end, isSplit }) => ({\n __splitRange: createListItemSplitRange(start, end),\n __isSplit: isSplit,\n }),\n };\n};\n"],"mappings":"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"}
|
package/dist/graphics/image.d.ts
CHANGED