pdfmake 0.3.2 → 0.3.4

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 (94) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/LICENSE +21 -21
  3. package/README.md +75 -78
  4. package/build/fonts/Roboto/Roboto-Italic.ttf +0 -0
  5. package/build/fonts/Roboto/Roboto-Medium.ttf +0 -0
  6. package/build/fonts/Roboto/Roboto-MediumItalic.ttf +0 -0
  7. package/build/fonts/Roboto/Roboto-Regular.ttf +0 -0
  8. package/build/fonts/Roboto.js +27 -0
  9. package/build/pdfmake.js +64813 -64584
  10. package/build/pdfmake.js.map +1 -1
  11. package/build/pdfmake.min.js +2 -2
  12. package/build/pdfmake.min.js.map +1 -1
  13. package/build/standard-fonts/Courier.js +27 -27
  14. package/build/standard-fonts/Helvetica.js +27 -27
  15. package/build/standard-fonts/Symbol.js +21 -21
  16. package/build/standard-fonts/Times.js +27 -27
  17. package/build/standard-fonts/ZapfDingbats.js +21 -21
  18. package/build/vfs_fonts.js +5 -5
  19. package/build-vfs.js +44 -44
  20. package/fonts/Roboto.js +8 -8
  21. package/js/3rd-party/svg-to-pdfkit/source.js +1 -1
  22. package/js/DocMeasure.js +11 -6
  23. package/js/DocumentContext.js +8 -3
  24. package/js/ElementWriter.js +42 -16
  25. package/js/LayoutBuilder.js +144 -78
  26. package/js/Line.js +16 -16
  27. package/js/OutputDocument.js +10 -10
  28. package/js/OutputDocumentServer.js +3 -3
  29. package/js/PDFDocument.js +3 -3
  30. package/js/PageElementWriter.js +15 -9
  31. package/js/Printer.js +28 -28
  32. package/js/Renderer.js +40 -8
  33. package/js/SVGMeasure.js +10 -10
  34. package/js/StyleContextStack.js +74 -51
  35. package/js/TableProcessor.js +14 -0
  36. package/js/TextBreaker.js +17 -17
  37. package/js/TextDecorator.js +12 -3
  38. package/js/TextInlines.js +34 -33
  39. package/js/base.js +4 -4
  40. package/js/browser-extensions/OutputDocumentBrowser.js +24 -24
  41. package/js/columnCalculator.js +2 -2
  42. package/js/helpers/node.js +47 -23
  43. package/js/helpers/variableType.js +18 -18
  44. package/js/qrEnc.js +38 -38
  45. package/js/virtual-fs.js +11 -11
  46. package/package.json +12 -12
  47. package/src/3rd-party/svg-to-pdfkit/LICENSE +9 -9
  48. package/src/3rd-party/svg-to-pdfkit/source.js +2745 -2745
  49. package/src/3rd-party/svg-to-pdfkit.js +3 -3
  50. package/src/DocMeasure.js +745 -738
  51. package/src/DocPreprocessor.js +283 -283
  52. package/src/DocumentContext.js +345 -338
  53. package/src/ElementWriter.js +441 -417
  54. package/src/LayoutBuilder.js +1336 -1258
  55. package/src/Line.js +114 -114
  56. package/src/OutputDocument.js +64 -64
  57. package/src/OutputDocumentServer.js +32 -32
  58. package/src/PDFDocument.js +174 -174
  59. package/src/PageElementWriter.js +187 -179
  60. package/src/PageSize.js +53 -53
  61. package/src/Printer.js +306 -306
  62. package/src/Renderer.js +445 -409
  63. package/src/SVGMeasure.js +109 -109
  64. package/src/StyleContextStack.js +208 -179
  65. package/src/TableProcessor.js +620 -602
  66. package/src/TextBreaker.js +168 -168
  67. package/src/TextDecorator.js +175 -161
  68. package/src/TextInlines.js +224 -223
  69. package/src/URLResolver.js +43 -43
  70. package/src/base.js +70 -70
  71. package/src/browser-extensions/OutputDocumentBrowser.js +80 -80
  72. package/src/browser-extensions/fonts/Roboto.js +27 -27
  73. package/src/browser-extensions/index.js +55 -55
  74. package/src/browser-extensions/pdfMake.js +1 -1
  75. package/src/browser-extensions/standard-fonts/Courier.js +27 -27
  76. package/src/browser-extensions/standard-fonts/Helvetica.js +27 -27
  77. package/src/browser-extensions/standard-fonts/Symbol.js +21 -21
  78. package/src/browser-extensions/standard-fonts/Times.js +27 -27
  79. package/src/browser-extensions/standard-fonts/ZapfDingbats.js +21 -21
  80. package/src/browser-extensions/virtual-fs-cjs.js +1 -1
  81. package/src/columnCalculator.js +154 -154
  82. package/src/helpers/node.js +134 -110
  83. package/src/helpers/tools.js +44 -44
  84. package/src/helpers/variableType.js +50 -50
  85. package/src/index.js +16 -16
  86. package/src/qrEnc.js +796 -796
  87. package/src/standardPageSizes.js +52 -52
  88. package/src/tableLayouts.js +100 -100
  89. package/src/virtual-fs.js +66 -66
  90. package/standard-fonts/Courier.js +8 -8
  91. package/standard-fonts/Helvetica.js +8 -8
  92. package/standard-fonts/Symbol.js +5 -5
  93. package/standard-fonts/Times.js +8 -8
  94. package/standard-fonts/ZapfDingbats.js +5 -5
package/src/Printer.js CHANGED
@@ -1,306 +1,306 @@
1
- import PDFDocument from './PDFDocument';
2
- import LayoutBuilder from './LayoutBuilder';
3
- import SVGMeasure from './SVGMeasure';
4
- import { normalizePageSize, normalizePageMargin } from './PageSize';
5
- import { tableLayouts } from './tableLayouts';
6
- import Renderer from './Renderer';
7
- import { isNumber, isValue } from './helpers/variableType';
8
- import { convertToDynamicContent } from './helpers/tools';
9
-
10
- /**
11
- * Printer which turns document definition into a pdf
12
- *
13
- * @example
14
- * var fontDescriptors = {
15
- * Roboto: {
16
- * normal: 'fonts/Roboto-Regular.ttf',
17
- * bold: 'fonts/Roboto-Medium.ttf',
18
- * italics: 'fonts/Roboto-Italic.ttf',
19
- * bolditalics: 'fonts/Roboto-MediumItalic.ttf'
20
- * }
21
- * };
22
- *
23
- * var printer = new PdfPrinter(fontDescriptors);
24
- */
25
- class PdfPrinter {
26
-
27
- /**
28
- * @param {object} fontDescriptors font definition dictionary
29
- * @param {object} virtualfs
30
- * @param {object} urlResolver
31
- */
32
- constructor(fontDescriptors, virtualfs = null, urlResolver = null) {
33
- this.fontDescriptors = fontDescriptors;
34
- this.virtualfs = virtualfs;
35
- this.urlResolver = urlResolver;
36
- }
37
-
38
- /**
39
- * Executes layout engine for the specified document and renders it into a pdfkit document
40
- * ready to be saved.
41
- *
42
- * @param {object} docDefinition
43
- * @param {object} options
44
- * @returns {Promise<PDFDocument>} resolved promise return a pdfkit document
45
- */
46
- async createPdfKitDocument(docDefinition, options = {}) {
47
- await this.resolveUrls(docDefinition);
48
-
49
- docDefinition.version = docDefinition.version || '1.3';
50
- docDefinition.subset = docDefinition.subset || undefined;
51
- docDefinition.tagged = typeof docDefinition.tagged === 'boolean' ? docDefinition.tagged : false;
52
- docDefinition.displayTitle = typeof docDefinition.displayTitle === 'boolean' ? docDefinition.displayTitle : false;
53
- docDefinition.compress = typeof docDefinition.compress === 'boolean' ? docDefinition.compress : true;
54
- docDefinition.images = docDefinition.images || {};
55
- docDefinition.attachments = docDefinition.attachments || {};
56
- docDefinition.pageMargins = isValue(docDefinition.pageMargins) ? docDefinition.pageMargins : 40;
57
- docDefinition.patterns = docDefinition.patterns || {};
58
-
59
- if (docDefinition.header && typeof docDefinition.header !== 'function') {
60
- docDefinition.header = convertToDynamicContent(docDefinition.header);
61
- }
62
-
63
- if (docDefinition.footer && typeof docDefinition.footer !== 'function') {
64
- docDefinition.footer = convertToDynamicContent(docDefinition.footer);
65
- }
66
-
67
- let pageSize = normalizePageSize(docDefinition.pageSize, docDefinition.pageOrientation);
68
-
69
- let pdfOptions = {
70
- size: [pageSize.width, pageSize.height],
71
- pdfVersion: docDefinition.version,
72
- subset: docDefinition.subset,
73
- tagged: docDefinition.tagged,
74
- displayTitle: docDefinition.displayTitle,
75
- compress: docDefinition.compress,
76
- userPassword: docDefinition.userPassword,
77
- ownerPassword: docDefinition.ownerPassword,
78
- permissions: docDefinition.permissions,
79
- lang: docDefinition.language,
80
- fontLayoutCache: typeof options.fontLayoutCache === 'boolean' ? options.fontLayoutCache : true,
81
- bufferPages: options.bufferPages || false,
82
- autoFirstPage: false,
83
- info: createMetadata(docDefinition),
84
- font: null
85
- };
86
-
87
- this.pdfKitDoc = new PDFDocument(this.fontDescriptors, docDefinition.images, docDefinition.patterns, docDefinition.attachments, pdfOptions, this.virtualfs);
88
- embedFiles(docDefinition, this.pdfKitDoc);
89
-
90
- const builder = new LayoutBuilder(pageSize, normalizePageMargin(docDefinition.pageMargins), new SVGMeasure());
91
-
92
- builder.registerTableLayouts(tableLayouts);
93
- if (options.tableLayouts) {
94
- builder.registerTableLayouts(options.tableLayouts);
95
- }
96
-
97
- let pages = builder.layoutDocument(docDefinition.content, this.pdfKitDoc, docDefinition.styles || {}, docDefinition.defaultStyle || { fontSize: 12, font: 'Roboto' }, docDefinition.background, docDefinition.header, docDefinition.footer, docDefinition.watermark, docDefinition.pageBreakBefore);
98
- let maxNumberPages = docDefinition.maxPagesNumber || -1;
99
- if (isNumber(maxNumberPages) && maxNumberPages > -1) {
100
- pages = pages.slice(0, maxNumberPages);
101
- }
102
-
103
- // if pageSize.height is set to Infinity, calculate the actual height of the page that
104
- // was laid out using the height of each of the items in the page.
105
- pages.forEach(page => {
106
- if (page.pageSize.height === Infinity) {
107
- page.pageSize.height = calculatePageHeight(page, page.pageMargins);
108
- }
109
- });
110
-
111
- const renderer = new Renderer(this.pdfKitDoc, options.progressCallback);
112
- renderer.renderPages(pages);
113
-
114
- return this.pdfKitDoc;
115
- }
116
-
117
- /**
118
- * @param {object} docDefinition
119
- * @returns {Promise}
120
- */
121
- async resolveUrls(docDefinition) {
122
- const getExtendedUrl = url => {
123
- if (typeof url === 'object') {
124
- return { url: url.url, headers: url.headers };
125
- }
126
-
127
- return { url: url, headers: {} };
128
- };
129
-
130
- if (this.urlResolver === null) {
131
- return;
132
- }
133
-
134
- for (let font in this.fontDescriptors) {
135
- if (this.fontDescriptors.hasOwnProperty(font)) {
136
- if (this.fontDescriptors[font].normal) {
137
- if (Array.isArray(this.fontDescriptors[font].normal)) { // TrueType Collection
138
- let url = getExtendedUrl(this.fontDescriptors[font].normal[0]);
139
- this.urlResolver.resolve(url.url, url.headers);
140
- this.fontDescriptors[font].normal[0] = url.url;
141
- } else {
142
- let url = getExtendedUrl(this.fontDescriptors[font].normal);
143
- this.urlResolver.resolve(url.url, url.headers);
144
- this.fontDescriptors[font].normal = url.url;
145
- }
146
- }
147
- if (this.fontDescriptors[font].bold) {
148
- if (Array.isArray(this.fontDescriptors[font].bold)) { // TrueType Collection
149
- let url = getExtendedUrl(this.fontDescriptors[font].bold[0]);
150
- this.urlResolver.resolve(url.url, url.headers);
151
- this.fontDescriptors[font].bold[0] = url.url;
152
- } else {
153
- let url = getExtendedUrl(this.fontDescriptors[font].bold);
154
- this.urlResolver.resolve(url.url, url.headers);
155
- this.fontDescriptors[font].bold = url.url;
156
- }
157
- }
158
- if (this.fontDescriptors[font].italics) {
159
- if (Array.isArray(this.fontDescriptors[font].italics)) { // TrueType Collection
160
- let url = getExtendedUrl(this.fontDescriptors[font].italics[0]);
161
- this.urlResolver.resolve(url.url, url.headers);
162
- this.fontDescriptors[font].italics[0] = url.url;
163
- } else {
164
- let url = getExtendedUrl(this.fontDescriptors[font].italics);
165
- this.urlResolver.resolve(url.url, url.headers);
166
- this.fontDescriptors[font].italics = url.url;
167
- }
168
- }
169
- if (this.fontDescriptors[font].bolditalics) {
170
- if (Array.isArray(this.fontDescriptors[font].bolditalics)) { // TrueType Collection
171
- let url = getExtendedUrl(this.fontDescriptors[font].bolditalics[0]);
172
- this.urlResolver.resolve(url.url, url.headers);
173
- this.fontDescriptors[font].bolditalics[0] = url.url;
174
- } else {
175
- let url = getExtendedUrl(this.fontDescriptors[font].bolditalics);
176
- this.urlResolver.resolve(url.url, url.headers);
177
- this.fontDescriptors[font].bolditalics = url.url;
178
- }
179
- }
180
- }
181
- }
182
-
183
- if (docDefinition.images) {
184
- for (let image in docDefinition.images) {
185
- if (docDefinition.images.hasOwnProperty(image)) {
186
- let url = getExtendedUrl(docDefinition.images[image]);
187
- this.urlResolver.resolve(url.url, url.headers);
188
- docDefinition.images[image] = url.url;
189
- }
190
- }
191
- }
192
-
193
- if (docDefinition.attachments) {
194
- for (let attachment in docDefinition.attachments) {
195
- if (docDefinition.attachments.hasOwnProperty(attachment) && docDefinition.attachments[attachment].src) {
196
- let url = getExtendedUrl(docDefinition.attachments[attachment].src);
197
- this.urlResolver.resolve(url.url, url.headers);
198
- docDefinition.attachments[attachment].src = url.url;
199
- }
200
- }
201
- }
202
-
203
- if (docDefinition.files) {
204
- for (let file in docDefinition.files) {
205
- if (docDefinition.files.hasOwnProperty(file) && docDefinition.files[file].src) {
206
- let url = getExtendedUrl(docDefinition.files[file].src);
207
- this.urlResolver.resolve(url.url, url.headers);
208
- docDefinition.files[file].src = url.url;
209
- }
210
- }
211
- }
212
-
213
- await this.urlResolver.resolved();
214
- }
215
- }
216
-
217
- function createMetadata(docDefinition) {
218
- // PDF standard has these properties reserved: Title, Author, Subject, Keywords,
219
- // Creator, Producer, CreationDate, ModDate, Trapped.
220
- // To keep the pdfmake api consistent, the info field are defined lowercase.
221
- // Custom properties don't contain a space.
222
- function standardizePropertyKey(key) {
223
- let standardProperties = ['Title', 'Author', 'Subject', 'Keywords',
224
- 'Creator', 'Producer', 'CreationDate', 'ModDate', 'Trapped'];
225
- let standardizedKey = key.charAt(0).toUpperCase() + key.slice(1);
226
- if (standardProperties.includes(standardizedKey)) {
227
- return standardizedKey;
228
- }
229
-
230
- return key.replace(/\s+/g, '');
231
- }
232
-
233
- let info = {
234
- Producer: 'pdfmake',
235
- Creator: 'pdfmake'
236
- };
237
-
238
- if (docDefinition.info) {
239
- for (let key in docDefinition.info) {
240
- let value = docDefinition.info[key];
241
- if (value) {
242
- key = standardizePropertyKey(key);
243
- info[key] = value;
244
- }
245
- }
246
- }
247
- return info;
248
- }
249
-
250
- function embedFiles(docDefinition, pdfKitDoc) {
251
- if (docDefinition.files) {
252
- for (const key in docDefinition.files) {
253
- const file = docDefinition.files[key];
254
-
255
- if (!file.src) return;
256
-
257
- if (pdfKitDoc.virtualfs && pdfKitDoc.virtualfs.existsSync(file.src)) {
258
- file.src = pdfKitDoc.virtualfs.readFileSync(file.src);
259
- }
260
-
261
- file.name = file.name || key;
262
- pdfKitDoc.file(file.src, file);
263
- }
264
- }
265
- }
266
-
267
- function calculatePageHeight(page, margins) {
268
- function getItemHeight(item) {
269
- if (typeof item.item.getHeight === 'function') {
270
- return item.item.getHeight();
271
- } else if (item.item._height) {
272
- return item.item._height;
273
- } else if (item.type === 'vector') {
274
- if (typeof item.item.y1 !== 'undefined') {
275
- return item.item.y1 > item.item.y2 ? item.item.y1 : item.item.y2;
276
- } else {
277
- return item.item.h;
278
- }
279
- } else {
280
- // TODO: add support for next item types
281
- return 0;
282
- }
283
- }
284
-
285
- function getBottomPosition(item) {
286
- let top = item.item.y || 0;
287
- let height = getItemHeight(item);
288
- return top + height;
289
- }
290
-
291
- let fixedMargins = normalizePageMargin(margins || 40);
292
- let height = fixedMargins.top;
293
-
294
- page.items.forEach(item => {
295
- let bottomPosition = getBottomPosition(item);
296
- if (bottomPosition > height) {
297
- height = bottomPosition;
298
- }
299
- });
300
-
301
- height += fixedMargins.bottom;
302
-
303
- return height;
304
- }
305
-
306
- export default PdfPrinter;
1
+ import PDFDocument from './PDFDocument';
2
+ import LayoutBuilder from './LayoutBuilder';
3
+ import SVGMeasure from './SVGMeasure';
4
+ import { normalizePageSize, normalizePageMargin } from './PageSize';
5
+ import { tableLayouts } from './tableLayouts';
6
+ import Renderer from './Renderer';
7
+ import { isNumber, isValue } from './helpers/variableType';
8
+ import { convertToDynamicContent } from './helpers/tools';
9
+
10
+ /**
11
+ * Printer which turns document definition into a pdf
12
+ *
13
+ * @example
14
+ * var fontDescriptors = {
15
+ * Roboto: {
16
+ * normal: 'fonts/Roboto-Regular.ttf',
17
+ * bold: 'fonts/Roboto-Medium.ttf',
18
+ * italics: 'fonts/Roboto-Italic.ttf',
19
+ * bolditalics: 'fonts/Roboto-MediumItalic.ttf'
20
+ * }
21
+ * };
22
+ *
23
+ * var printer = new PdfPrinter(fontDescriptors);
24
+ */
25
+ class PdfPrinter {
26
+
27
+ /**
28
+ * @param {object} fontDescriptors font definition dictionary
29
+ * @param {object} virtualfs
30
+ * @param {object} urlResolver
31
+ */
32
+ constructor(fontDescriptors, virtualfs = null, urlResolver = null) {
33
+ this.fontDescriptors = fontDescriptors;
34
+ this.virtualfs = virtualfs;
35
+ this.urlResolver = urlResolver;
36
+ }
37
+
38
+ /**
39
+ * Executes layout engine for the specified document and renders it into a pdfkit document
40
+ * ready to be saved.
41
+ *
42
+ * @param {object} docDefinition
43
+ * @param {object} options
44
+ * @returns {Promise<PDFDocument>} resolved promise return a pdfkit document
45
+ */
46
+ async createPdfKitDocument(docDefinition, options = {}) {
47
+ await this.resolveUrls(docDefinition);
48
+
49
+ docDefinition.version = docDefinition.version || '1.3';
50
+ docDefinition.subset = docDefinition.subset || undefined;
51
+ docDefinition.tagged = typeof docDefinition.tagged === 'boolean' ? docDefinition.tagged : false;
52
+ docDefinition.displayTitle = typeof docDefinition.displayTitle === 'boolean' ? docDefinition.displayTitle : false;
53
+ docDefinition.compress = typeof docDefinition.compress === 'boolean' ? docDefinition.compress : true;
54
+ docDefinition.images = docDefinition.images || {};
55
+ docDefinition.attachments = docDefinition.attachments || {};
56
+ docDefinition.pageMargins = isValue(docDefinition.pageMargins) ? docDefinition.pageMargins : 40;
57
+ docDefinition.patterns = docDefinition.patterns || {};
58
+
59
+ if (docDefinition.header && typeof docDefinition.header !== 'function') {
60
+ docDefinition.header = convertToDynamicContent(docDefinition.header);
61
+ }
62
+
63
+ if (docDefinition.footer && typeof docDefinition.footer !== 'function') {
64
+ docDefinition.footer = convertToDynamicContent(docDefinition.footer);
65
+ }
66
+
67
+ let pageSize = normalizePageSize(docDefinition.pageSize, docDefinition.pageOrientation);
68
+
69
+ let pdfOptions = {
70
+ size: [pageSize.width, pageSize.height],
71
+ pdfVersion: docDefinition.version,
72
+ subset: docDefinition.subset,
73
+ tagged: docDefinition.tagged,
74
+ displayTitle: docDefinition.displayTitle,
75
+ compress: docDefinition.compress,
76
+ userPassword: docDefinition.userPassword,
77
+ ownerPassword: docDefinition.ownerPassword,
78
+ permissions: docDefinition.permissions,
79
+ lang: docDefinition.language,
80
+ fontLayoutCache: typeof options.fontLayoutCache === 'boolean' ? options.fontLayoutCache : true,
81
+ bufferPages: options.bufferPages || false,
82
+ autoFirstPage: false,
83
+ info: createMetadata(docDefinition),
84
+ font: null
85
+ };
86
+
87
+ this.pdfKitDoc = new PDFDocument(this.fontDescriptors, docDefinition.images, docDefinition.patterns, docDefinition.attachments, pdfOptions, this.virtualfs);
88
+ embedFiles(docDefinition, this.pdfKitDoc);
89
+
90
+ const builder = new LayoutBuilder(pageSize, normalizePageMargin(docDefinition.pageMargins), new SVGMeasure());
91
+
92
+ builder.registerTableLayouts(tableLayouts);
93
+ if (options.tableLayouts) {
94
+ builder.registerTableLayouts(options.tableLayouts);
95
+ }
96
+
97
+ let pages = builder.layoutDocument(docDefinition.content, this.pdfKitDoc, docDefinition.styles || {}, docDefinition.defaultStyle || { fontSize: 12, font: 'Roboto' }, docDefinition.background, docDefinition.header, docDefinition.footer, docDefinition.watermark, docDefinition.pageBreakBefore);
98
+ let maxNumberPages = docDefinition.maxPagesNumber || -1;
99
+ if (isNumber(maxNumberPages) && maxNumberPages > -1) {
100
+ pages = pages.slice(0, maxNumberPages);
101
+ }
102
+
103
+ // if pageSize.height is set to Infinity, calculate the actual height of the page that
104
+ // was laid out using the height of each of the items in the page.
105
+ pages.forEach(page => {
106
+ if (page.pageSize.height === Infinity) {
107
+ page.pageSize.height = calculatePageHeight(page, page.pageMargins);
108
+ }
109
+ });
110
+
111
+ const renderer = new Renderer(this.pdfKitDoc, options.progressCallback);
112
+ renderer.renderPages(pages);
113
+
114
+ return this.pdfKitDoc;
115
+ }
116
+
117
+ /**
118
+ * @param {object} docDefinition
119
+ * @returns {Promise}
120
+ */
121
+ async resolveUrls(docDefinition) {
122
+ const getExtendedUrl = url => {
123
+ if (typeof url === 'object') {
124
+ return { url: url.url, headers: url.headers };
125
+ }
126
+
127
+ return { url: url, headers: {} };
128
+ };
129
+
130
+ if (this.urlResolver === null) {
131
+ return;
132
+ }
133
+
134
+ for (let font in this.fontDescriptors) {
135
+ if (this.fontDescriptors.hasOwnProperty(font)) {
136
+ if (this.fontDescriptors[font].normal) {
137
+ if (Array.isArray(this.fontDescriptors[font].normal)) { // TrueType Collection
138
+ let url = getExtendedUrl(this.fontDescriptors[font].normal[0]);
139
+ this.urlResolver.resolve(url.url, url.headers);
140
+ this.fontDescriptors[font].normal[0] = url.url;
141
+ } else {
142
+ let url = getExtendedUrl(this.fontDescriptors[font].normal);
143
+ this.urlResolver.resolve(url.url, url.headers);
144
+ this.fontDescriptors[font].normal = url.url;
145
+ }
146
+ }
147
+ if (this.fontDescriptors[font].bold) {
148
+ if (Array.isArray(this.fontDescriptors[font].bold)) { // TrueType Collection
149
+ let url = getExtendedUrl(this.fontDescriptors[font].bold[0]);
150
+ this.urlResolver.resolve(url.url, url.headers);
151
+ this.fontDescriptors[font].bold[0] = url.url;
152
+ } else {
153
+ let url = getExtendedUrl(this.fontDescriptors[font].bold);
154
+ this.urlResolver.resolve(url.url, url.headers);
155
+ this.fontDescriptors[font].bold = url.url;
156
+ }
157
+ }
158
+ if (this.fontDescriptors[font].italics) {
159
+ if (Array.isArray(this.fontDescriptors[font].italics)) { // TrueType Collection
160
+ let url = getExtendedUrl(this.fontDescriptors[font].italics[0]);
161
+ this.urlResolver.resolve(url.url, url.headers);
162
+ this.fontDescriptors[font].italics[0] = url.url;
163
+ } else {
164
+ let url = getExtendedUrl(this.fontDescriptors[font].italics);
165
+ this.urlResolver.resolve(url.url, url.headers);
166
+ this.fontDescriptors[font].italics = url.url;
167
+ }
168
+ }
169
+ if (this.fontDescriptors[font].bolditalics) {
170
+ if (Array.isArray(this.fontDescriptors[font].bolditalics)) { // TrueType Collection
171
+ let url = getExtendedUrl(this.fontDescriptors[font].bolditalics[0]);
172
+ this.urlResolver.resolve(url.url, url.headers);
173
+ this.fontDescriptors[font].bolditalics[0] = url.url;
174
+ } else {
175
+ let url = getExtendedUrl(this.fontDescriptors[font].bolditalics);
176
+ this.urlResolver.resolve(url.url, url.headers);
177
+ this.fontDescriptors[font].bolditalics = url.url;
178
+ }
179
+ }
180
+ }
181
+ }
182
+
183
+ if (docDefinition.images) {
184
+ for (let image in docDefinition.images) {
185
+ if (docDefinition.images.hasOwnProperty(image)) {
186
+ let url = getExtendedUrl(docDefinition.images[image]);
187
+ this.urlResolver.resolve(url.url, url.headers);
188
+ docDefinition.images[image] = url.url;
189
+ }
190
+ }
191
+ }
192
+
193
+ if (docDefinition.attachments) {
194
+ for (let attachment in docDefinition.attachments) {
195
+ if (docDefinition.attachments.hasOwnProperty(attachment) && docDefinition.attachments[attachment].src) {
196
+ let url = getExtendedUrl(docDefinition.attachments[attachment].src);
197
+ this.urlResolver.resolve(url.url, url.headers);
198
+ docDefinition.attachments[attachment].src = url.url;
199
+ }
200
+ }
201
+ }
202
+
203
+ if (docDefinition.files) {
204
+ for (let file in docDefinition.files) {
205
+ if (docDefinition.files.hasOwnProperty(file) && docDefinition.files[file].src) {
206
+ let url = getExtendedUrl(docDefinition.files[file].src);
207
+ this.urlResolver.resolve(url.url, url.headers);
208
+ docDefinition.files[file].src = url.url;
209
+ }
210
+ }
211
+ }
212
+
213
+ await this.urlResolver.resolved();
214
+ }
215
+ }
216
+
217
+ function createMetadata(docDefinition) {
218
+ // PDF standard has these properties reserved: Title, Author, Subject, Keywords,
219
+ // Creator, Producer, CreationDate, ModDate, Trapped.
220
+ // To keep the pdfmake api consistent, the info field are defined lowercase.
221
+ // Custom properties don't contain a space.
222
+ function standardizePropertyKey(key) {
223
+ let standardProperties = ['Title', 'Author', 'Subject', 'Keywords',
224
+ 'Creator', 'Producer', 'CreationDate', 'ModDate', 'Trapped'];
225
+ let standardizedKey = key.charAt(0).toUpperCase() + key.slice(1);
226
+ if (standardProperties.includes(standardizedKey)) {
227
+ return standardizedKey;
228
+ }
229
+
230
+ return key.replace(/\s+/g, '');
231
+ }
232
+
233
+ let info = {
234
+ Producer: 'pdfmake',
235
+ Creator: 'pdfmake'
236
+ };
237
+
238
+ if (docDefinition.info) {
239
+ for (let key in docDefinition.info) {
240
+ let value = docDefinition.info[key];
241
+ if (value) {
242
+ key = standardizePropertyKey(key);
243
+ info[key] = value;
244
+ }
245
+ }
246
+ }
247
+ return info;
248
+ }
249
+
250
+ function embedFiles(docDefinition, pdfKitDoc) {
251
+ if (docDefinition.files) {
252
+ for (const key in docDefinition.files) {
253
+ const file = docDefinition.files[key];
254
+
255
+ if (!file.src) return;
256
+
257
+ if (pdfKitDoc.virtualfs && pdfKitDoc.virtualfs.existsSync(file.src)) {
258
+ file.src = pdfKitDoc.virtualfs.readFileSync(file.src);
259
+ }
260
+
261
+ file.name = file.name || key;
262
+ pdfKitDoc.file(file.src, file);
263
+ }
264
+ }
265
+ }
266
+
267
+ function calculatePageHeight(page, margins) {
268
+ function getItemHeight(item) {
269
+ if (typeof item.item.getHeight === 'function') {
270
+ return item.item.getHeight();
271
+ } else if (item.item._height) {
272
+ return item.item._height;
273
+ } else if (item.type === 'vector') {
274
+ if (typeof item.item.y1 !== 'undefined') {
275
+ return item.item.y1 > item.item.y2 ? item.item.y1 : item.item.y2;
276
+ } else {
277
+ return item.item.h;
278
+ }
279
+ } else {
280
+ // TODO: add support for next item types
281
+ return 0;
282
+ }
283
+ }
284
+
285
+ function getBottomPosition(item) {
286
+ let top = item.item.y || 0;
287
+ let height = getItemHeight(item);
288
+ return top + height;
289
+ }
290
+
291
+ let fixedMargins = normalizePageMargin(margins || 40);
292
+ let height = fixedMargins.top;
293
+
294
+ page.items.forEach(item => {
295
+ let bottomPosition = getBottomPosition(item);
296
+ if (bottomPosition > height) {
297
+ height = bottomPosition;
298
+ }
299
+ });
300
+
301
+ height += fixedMargins.bottom;
302
+
303
+ return height;
304
+ }
305
+
306
+ export default PdfPrinter;