@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.
Files changed (62) hide show
  1. package/dist/{builtins-C0BvXHWr.js → builtins-Clh58o_b.js} +313 -483
  2. package/dist/builtins-Clh58o_b.js.map +1 -0
  3. package/dist/builtins.d.ts +1 -1
  4. package/dist/builtins.js +1 -1
  5. package/dist/checkbox/index.d.ts +2 -2
  6. package/dist/dynamicLayout.d.ts +4 -0
  7. package/dist/dynamicLayout.js +20 -0
  8. package/dist/dynamicLayout.js.map +1 -0
  9. package/dist/dynamicTemplate-CB2Hj9cN.js +65 -0
  10. package/dist/dynamicTemplate-CB2Hj9cN.js.map +1 -0
  11. package/dist/{dynamicTemplate-Dsrw11aL.js → dynamicTemplate-CjbGepw4.js} +24 -358
  12. package/dist/dynamicTemplate-CjbGepw4.js.map +1 -0
  13. package/dist/dynamicTemplate-Fn7mpUsu.js +114 -0
  14. package/dist/dynamicTemplate-Fn7mpUsu.js.map +1 -0
  15. package/dist/graphics/image.d.ts +1 -1
  16. package/dist/graphics/signature.d.ts +1 -1
  17. package/dist/helper-BJzBqIT4.js +40 -0
  18. package/dist/helper-BJzBqIT4.js.map +1 -0
  19. package/dist/index.d.ts +5 -2
  20. package/dist/index.js +847 -205
  21. package/dist/index.js.map +1 -1
  22. package/dist/list/constants.d.ts +10 -0
  23. package/dist/list/dynamicTemplate.d.ts +2 -0
  24. package/dist/list/helper.d.ts +15 -0
  25. package/dist/list/index.d.ts +4 -0
  26. package/dist/list/pdfRender.d.ts +3 -0
  27. package/dist/list/propPanel.d.ts +3 -0
  28. package/dist/list/types.d.ts +31 -0
  29. package/dist/list/uiRender.d.ts +3 -0
  30. package/dist/lists.d.ts +4 -0
  31. package/dist/lists.js +3 -0
  32. package/dist/measure-Bjmh9Ro3.js +585 -0
  33. package/dist/measure-Bjmh9Ro3.js.map +1 -0
  34. package/dist/multiVariableText/dynamicTemplate.d.ts +2 -0
  35. package/dist/radioGroup/index.d.ts +2 -2
  36. package/dist/select/index.d.ts +2 -2
  37. package/dist/shapes/line.d.ts +1 -1
  38. package/dist/shapes/rectAndEllipse.d.ts +1 -2
  39. package/dist/splitRange-CpXivbmJ.js +398 -0
  40. package/dist/splitRange-CpXivbmJ.js.map +1 -0
  41. package/dist/splitRange.d.ts +16 -0
  42. package/dist/tables/dynamicTemplate.d.ts +2 -1
  43. package/dist/tables/helper.d.ts +8 -8
  44. package/dist/tables.d.ts +2 -1
  45. package/dist/tables.js +3 -2
  46. package/dist/text/constants.d.ts +3 -0
  47. package/dist/text/dynamicTemplate.d.ts +2 -0
  48. package/dist/text/linkAnnotation.d.ts +14 -0
  49. package/dist/text/measure.d.ts +26 -0
  50. package/dist/text/overflow.d.ts +7 -0
  51. package/dist/text/richTextPdfRender.d.ts +2 -1
  52. package/dist/text/types.d.ts +3 -0
  53. package/dist/texts.d.ts +5 -0
  54. package/dist/texts.js +4 -0
  55. package/dist/types.d.ts +15 -0
  56. package/dist/types.js +0 -0
  57. package/dist/utils.d.ts +1 -0
  58. package/dist/utils.js +3 -2
  59. package/dist/utils.js.map +1 -1
  60. package/package.json +21 -1
  61. package/dist/builtins-C0BvXHWr.js.map +0 -1
  62. package/dist/dynamicTemplate-Dsrw11aL.js.map +0 -1
@@ -1,357 +1,5 @@
1
- import { DEFAULT_FONT_NAME, b64toUint8Array, cloneDeep, getDefaultFont, getFallbackFontName, isBlankPdf, isUrlSafeToFetch, mm2pt, pt2mm, pt2px } from "@pdfme/common";
2
- import * as fontkit from "fontkit";
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.__bodyRange || { start: 0 };
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 table = await createSingleTable(schema.__bodyRange?.start === 0 ? getBody(value) : getBodyWithRange(value, schema.__bodyRange), args);
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 { FONT_SIZE_ADJUSTMENT as A, VERTICAL_ALIGN_MIDDLE as B, DEFAULT_ALIGNMENT as C, DEFAULT_TEXT_FORMAT as D, DEFAULT_FONT_VARIANT_FALLBACK as E, SYNTHETIC_BOLD_CSS_TEXT_SHADOW as F, SYNTHETIC_BOLD_OFFSET_RATIO as I, TEXT_FORMAT_INLINE_MARKDOWN as L, FONT_VARIANT_FALLBACK_PLAIN as M, FONT_VARIANT_FALLBACK_SYNTHETIC as N, DYNAMIC_FIT_HORIZONTAL as O, PLACEHOLDER_FONT_COLOR as P, TEXT_FORMAT_PLAIN as R, CODE_HORIZONTAL_PADDING as S, DEFAULT_FONT_COLOR as T, widthOfTextAtSize as _, getColumnStylesPropPanelSchema as a, ALIGN_RIGHT as b, createSingleTable as c, getBrowserVerticalFontAdjustments as d, getFontDescentInPt as f, splitTextToSize as g, isFirefox as h, getCellPropPanelSchema as i, FONT_VARIANT_FALLBACK_ERROR as j, DYNAMIC_FIT_VERTICAL as k, calculateDynamicFontSize as l, heightOfFontAtSize as m, getBody as n, getDefaultCellStyles as o, getFontKitFont as p, getBodyWithRange as r, HEX_COLOR_PATTERN as s, getDynamicHeightsForTable as t, fetchRemoteFontData as u, ALIGN_CENTER as v, DEFAULT_DYNAMIC_FIT as w, CODE_BACKGROUND_COLOR as x, ALIGN_JUSTIFY as y, VERTICAL_ALIGN_BOTTOM as z };
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-Dsrw11aL.js.map
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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"}
@@ -1,5 +1,5 @@
1
1
  import type { Plugin } from '@pdfme/common';
2
2
  import type { Schema } from '@pdfme/common';
3
- type ImageSchema = Schema;
3
+ export type ImageSchema = Schema;
4
4
  declare const imageSchema: Plugin<ImageSchema>;
5
5
  export default imageSchema;