pdfmake-acroforms 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 (115) hide show
  1. package/CHANGELOG.md +60 -0
  2. package/LICENSE +21 -0
  3. package/README.md +75 -0
  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 +67806 -0
  10. package/build/pdfmake.js.map +1 -0
  11. package/build/pdfmake.min.js +3 -0
  12. package/build/pdfmake.min.js.map +1 -0
  13. package/build/standard-fonts/Courier.js +27 -0
  14. package/build/standard-fonts/Helvetica.js +27 -0
  15. package/build/standard-fonts/Symbol.js +21 -0
  16. package/build/standard-fonts/Times.js +27 -0
  17. package/build/standard-fonts/ZapfDingbats.js +21 -0
  18. package/build/vfs_fonts.js +6 -0
  19. package/build-vfs.js +44 -0
  20. package/fonts/Roboto/Roboto-Italic.ttf +0 -0
  21. package/fonts/Roboto/Roboto-Medium.ttf +0 -0
  22. package/fonts/Roboto/Roboto-MediumItalic.ttf +0 -0
  23. package/fonts/Roboto/Roboto-Regular.ttf +0 -0
  24. package/fonts/Roboto.js +8 -0
  25. package/js/3rd-party/svg-to-pdfkit/source.js +3823 -0
  26. package/js/3rd-party/svg-to-pdfkit.js +7 -0
  27. package/js/DocMeasure.js +675 -0
  28. package/js/DocPreprocessor.js +258 -0
  29. package/js/DocumentContext.js +310 -0
  30. package/js/ElementWriter.js +399 -0
  31. package/js/LayoutBuilder.js +1202 -0
  32. package/js/Line.js +101 -0
  33. package/js/OutputDocument.js +64 -0
  34. package/js/OutputDocumentServer.js +29 -0
  35. package/js/PDFDocument.js +145 -0
  36. package/js/PageElementWriter.js +164 -0
  37. package/js/PageSize.js +74 -0
  38. package/js/Printer.js +288 -0
  39. package/js/Renderer.js +513 -0
  40. package/js/SVGMeasure.js +92 -0
  41. package/js/StyleContextStack.js +191 -0
  42. package/js/TableProcessor.js +562 -0
  43. package/js/TextBreaker.js +179 -0
  44. package/js/TextDecorator.js +152 -0
  45. package/js/TextInlines.js +212 -0
  46. package/js/URLResolver.js +43 -0
  47. package/js/base.js +59 -0
  48. package/js/browser-extensions/OutputDocumentBrowser.js +82 -0
  49. package/js/browser-extensions/fonts/Roboto.js +38 -0
  50. package/js/browser-extensions/index.js +53 -0
  51. package/js/browser-extensions/pdfMake.js +3 -0
  52. package/js/browser-extensions/standard-fonts/Courier.js +38 -0
  53. package/js/browser-extensions/standard-fonts/Helvetica.js +38 -0
  54. package/js/browser-extensions/standard-fonts/Symbol.js +23 -0
  55. package/js/browser-extensions/standard-fonts/Times.js +38 -0
  56. package/js/browser-extensions/standard-fonts/ZapfDingbats.js +23 -0
  57. package/js/browser-extensions/virtual-fs-cjs.js +3 -0
  58. package/js/columnCalculator.js +148 -0
  59. package/js/helpers/node.js +122 -0
  60. package/js/helpers/tools.js +46 -0
  61. package/js/helpers/variableType.js +59 -0
  62. package/js/index.js +15 -0
  63. package/js/qrEnc.js +721 -0
  64. package/js/standardPageSizes.js +56 -0
  65. package/js/tableLayouts.js +98 -0
  66. package/js/virtual-fs.js +60 -0
  67. package/package.json +94 -0
  68. package/src/3rd-party/svg-to-pdfkit/LICENSE +9 -0
  69. package/src/3rd-party/svg-to-pdfkit/source.js +2745 -0
  70. package/src/3rd-party/svg-to-pdfkit.js +3 -0
  71. package/src/DocMeasure.js +768 -0
  72. package/src/DocPreprocessor.js +289 -0
  73. package/src/DocumentContext.js +345 -0
  74. package/src/ElementWriter.js +468 -0
  75. package/src/LayoutBuilder.js +1366 -0
  76. package/src/Line.js +108 -0
  77. package/src/OutputDocument.js +64 -0
  78. package/src/OutputDocumentServer.js +32 -0
  79. package/src/PDFDocument.js +178 -0
  80. package/src/PageElementWriter.js +191 -0
  81. package/src/PageSize.js +53 -0
  82. package/src/Printer.js +306 -0
  83. package/src/Renderer.js +546 -0
  84. package/src/SVGMeasure.js +109 -0
  85. package/src/StyleContextStack.js +208 -0
  86. package/src/TableProcessor.js +620 -0
  87. package/src/TextBreaker.js +181 -0
  88. package/src/TextDecorator.js +175 -0
  89. package/src/TextInlines.js +229 -0
  90. package/src/URLResolver.js +43 -0
  91. package/src/base.js +70 -0
  92. package/src/browser-extensions/OutputDocumentBrowser.js +80 -0
  93. package/src/browser-extensions/fonts/Roboto.js +27 -0
  94. package/src/browser-extensions/index.js +55 -0
  95. package/src/browser-extensions/pdfMake.js +1 -0
  96. package/src/browser-extensions/standard-fonts/Courier.js +27 -0
  97. package/src/browser-extensions/standard-fonts/Helvetica.js +27 -0
  98. package/src/browser-extensions/standard-fonts/Symbol.js +21 -0
  99. package/src/browser-extensions/standard-fonts/Times.js +27 -0
  100. package/src/browser-extensions/standard-fonts/ZapfDingbats.js +21 -0
  101. package/src/browser-extensions/virtual-fs-cjs.js +1 -0
  102. package/src/columnCalculator.js +154 -0
  103. package/src/helpers/node.js +134 -0
  104. package/src/helpers/tools.js +44 -0
  105. package/src/helpers/variableType.js +50 -0
  106. package/src/index.js +16 -0
  107. package/src/qrEnc.js +796 -0
  108. package/src/standardPageSizes.js +52 -0
  109. package/src/tableLayouts.js +100 -0
  110. package/src/virtual-fs.js +66 -0
  111. package/standard-fonts/Courier.js +8 -0
  112. package/standard-fonts/Helvetica.js +8 -0
  113. package/standard-fonts/Symbol.js +5 -0
  114. package/standard-fonts/Times.js +8 -0
  115. package/standard-fonts/ZapfDingbats.js +5 -0
@@ -0,0 +1,399 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.default = void 0;
5
+ var _variableType = require("./helpers/variableType");
6
+ var _tools = require("./helpers/tools");
7
+ var _DocumentContext = _interopRequireDefault(require("./DocumentContext"));
8
+ var _events = require("events");
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
10
+ /**
11
+ * A line/vector writer, which adds elements to current page and sets
12
+ * their positions based on the context
13
+ */
14
+ class ElementWriter extends _events.EventEmitter {
15
+ /**
16
+ * @param {DocumentContext} context
17
+ */
18
+ constructor(context) {
19
+ super();
20
+ this._context = context;
21
+ this.contextStack = [];
22
+ }
23
+
24
+ /**
25
+ * @returns {DocumentContext}
26
+ */
27
+ context() {
28
+ return this._context;
29
+ }
30
+ addLine(line, dontUpdateContextPosition, index) {
31
+ let height = line.getHeight();
32
+ let context = this.context();
33
+ let page = context.getCurrentPage();
34
+ let position = this.getCurrentPositionOnPage();
35
+ if (context.availableHeight < height || !page) {
36
+ return false;
37
+ }
38
+ line.x = context.x + (line.x || 0);
39
+ line.y = context.y + (line.y || 0);
40
+ this.alignLine(line);
41
+ addPageItem(page, {
42
+ type: 'line',
43
+ item: line
44
+ }, index);
45
+ this.emit('lineAdded', line);
46
+ if (!dontUpdateContextPosition) {
47
+ context.moveDown(height);
48
+ }
49
+ return position;
50
+ }
51
+ alignLine(line) {
52
+ let width = this.context().availableWidth;
53
+ let lineWidth = line.getWidth();
54
+ let alignment = line.inlines && line.inlines.length > 0 && line.inlines[0].alignment;
55
+ let offset = 0;
56
+ switch (alignment) {
57
+ case 'right':
58
+ offset = width - lineWidth;
59
+ break;
60
+ case 'center':
61
+ offset = (width - lineWidth) / 2;
62
+ break;
63
+ }
64
+ if (offset) {
65
+ line.x = (line.x || 0) + offset;
66
+ }
67
+ if (alignment === 'justify' && !line.newLineForced && !line.lastLineInParagraph && line.inlines.length > 1) {
68
+ let additionalSpacing = (width - lineWidth) / (line.inlines.length - 1);
69
+ for (let i = 1, l = line.inlines.length; i < l; i++) {
70
+ offset = i * additionalSpacing;
71
+ line.inlines[i].x += offset;
72
+ line.inlines[i].justifyShift = additionalSpacing;
73
+ }
74
+ }
75
+ }
76
+ addImage(image, index) {
77
+ let context = this.context();
78
+ let page = context.getCurrentPage();
79
+ let position = this.getCurrentPositionOnPage();
80
+ if (!page || image.absolutePosition === undefined && context.availableHeight < image._height && page.items.length > 0) {
81
+ return false;
82
+ }
83
+ if (image._x === undefined) {
84
+ image._x = image.x || 0;
85
+ }
86
+ image.x = context.x + image._x;
87
+ image.y = context.y;
88
+ this.alignImage(image);
89
+ addPageItem(page, {
90
+ type: 'image',
91
+ item: image
92
+ }, index);
93
+ context.moveDown(image._height);
94
+ return position;
95
+ }
96
+ addCanvas(node, index) {
97
+ let context = this.context();
98
+ let page = context.getCurrentPage();
99
+ let positions = [];
100
+ let height = node._minHeight;
101
+ if (!page || node.absolutePosition === undefined && context.availableHeight < height) {
102
+ // TODO: support for canvas larger than a page
103
+ // TODO: support for other overflow methods
104
+
105
+ return false;
106
+ }
107
+ this.alignCanvas(node);
108
+ node.canvas.forEach(function (vector) {
109
+ let position = this.addVector(vector, false, false, index);
110
+ positions.push(position);
111
+ if (index !== undefined) {
112
+ index++;
113
+ }
114
+ }, this);
115
+ context.moveDown(height);
116
+ return positions;
117
+ }
118
+ addSVG(image, index) {
119
+ // TODO: same as addImage
120
+ let context = this.context();
121
+ let page = context.getCurrentPage();
122
+ let position = this.getCurrentPositionOnPage();
123
+ if (!page || image.absolutePosition === undefined && context.availableHeight < image._height && page.items.length > 0) {
124
+ return false;
125
+ }
126
+ if (image._x === undefined) {
127
+ image._x = image.x || 0;
128
+ }
129
+ image.x = context.x + image._x;
130
+ image.y = context.y;
131
+ this.alignImage(image);
132
+ addPageItem(page, {
133
+ type: 'svg',
134
+ item: image
135
+ }, index);
136
+ context.moveDown(image._height);
137
+ return position;
138
+ }
139
+ addQr(qr, index) {
140
+ let context = this.context();
141
+ let page = context.getCurrentPage();
142
+ let position = this.getCurrentPositionOnPage();
143
+ if (!page || qr.absolutePosition === undefined && context.availableHeight < qr._height) {
144
+ return false;
145
+ }
146
+ if (qr._x === undefined) {
147
+ qr._x = qr.x || 0;
148
+ }
149
+ qr.x = context.x + qr._x;
150
+ qr.y = context.y;
151
+ this.alignImage(qr);
152
+ for (let i = 0, l = qr._canvas.length; i < l; i++) {
153
+ let vector = qr._canvas[i];
154
+ vector.x += qr.x;
155
+ vector.y += qr.y;
156
+ this.addVector(vector, true, true, index);
157
+ }
158
+ context.moveDown(qr._height);
159
+ return position;
160
+ }
161
+ addAcroForm(node, index) {
162
+ let context = this.context();
163
+ let page = context.getCurrentPage();
164
+ let position = this.getCurrentPositionOnPage();
165
+ if (!page) {
166
+ return false;
167
+ }
168
+ if (node._x === undefined) {
169
+ node._x = node.x || 0;
170
+ }
171
+ addPageItem(page, {
172
+ type: 'acroform',
173
+ item: node
174
+ }, index);
175
+ node.x = context.x + node._x;
176
+ node.y = context.y;
177
+ context.moveDown(node.height || node._minHeight);
178
+ return position;
179
+ }
180
+ addAttachment(attachment, index) {
181
+ let context = this.context();
182
+ let page = context.getCurrentPage();
183
+ let position = this.getCurrentPositionOnPage();
184
+ if (!page || attachment.absolutePosition === undefined && context.availableHeight < attachment._height && page.items.length > 0) {
185
+ return false;
186
+ }
187
+ if (attachment._x === undefined) {
188
+ attachment._x = attachment.x || 0;
189
+ }
190
+ attachment.x = context.x + attachment._x;
191
+ attachment.y = context.y;
192
+ addPageItem(page, {
193
+ type: 'attachment',
194
+ item: attachment
195
+ }, index);
196
+ context.moveDown(attachment._height);
197
+ return position;
198
+ }
199
+ alignImage(image) {
200
+ let width = this.context().availableWidth;
201
+ let imageWidth = image._minWidth;
202
+ let offset = 0;
203
+ switch (image._alignment) {
204
+ case 'right':
205
+ offset = width - imageWidth;
206
+ break;
207
+ case 'center':
208
+ offset = (width - imageWidth) / 2;
209
+ break;
210
+ }
211
+ if (offset) {
212
+ image.x = (image.x || 0) + offset;
213
+ }
214
+ }
215
+ alignCanvas(node) {
216
+ let width = this.context().availableWidth;
217
+ let canvasWidth = node._minWidth;
218
+ let offset = 0;
219
+ switch (node._alignment) {
220
+ case 'right':
221
+ offset = width - canvasWidth;
222
+ break;
223
+ case 'center':
224
+ offset = (width - canvasWidth) / 2;
225
+ break;
226
+ }
227
+ if (offset) {
228
+ node.canvas.forEach(vector => {
229
+ (0, _tools.offsetVector)(vector, offset, 0);
230
+ });
231
+ }
232
+ }
233
+ addVector(vector, ignoreContextX, ignoreContextY, index, forcePage) {
234
+ let context = this.context();
235
+ let page = context.getCurrentPage();
236
+ if ((0, _variableType.isNumber)(forcePage)) {
237
+ page = context.pages[forcePage];
238
+ }
239
+ let position = this.getCurrentPositionOnPage();
240
+ if (page) {
241
+ (0, _tools.offsetVector)(vector, ignoreContextX ? 0 : context.x, ignoreContextY ? 0 : context.y);
242
+ addPageItem(page, {
243
+ type: 'vector',
244
+ item: vector
245
+ }, index);
246
+ return position;
247
+ }
248
+ }
249
+ beginClip(width, height) {
250
+ let ctx = this.context();
251
+ let page = ctx.getCurrentPage();
252
+ page.items.push({
253
+ type: 'beginClip',
254
+ item: {
255
+ x: ctx.x,
256
+ y: ctx.y,
257
+ width: width,
258
+ height: height
259
+ }
260
+ });
261
+ return true;
262
+ }
263
+ endClip() {
264
+ let ctx = this.context();
265
+ let page = ctx.getCurrentPage();
266
+ page.items.push({
267
+ type: 'endClip'
268
+ });
269
+ return true;
270
+ }
271
+ beginVerticalAlignment(verticalAlignment) {
272
+ let page = this.context().getCurrentPage();
273
+ let item = {
274
+ type: 'beginVerticalAlignment',
275
+ item: {
276
+ verticalAlignment: verticalAlignment
277
+ }
278
+ };
279
+ page.items.push(item);
280
+ return item;
281
+ }
282
+ endVerticalAlignment(verticalAlignment) {
283
+ let page = this.context().getCurrentPage();
284
+ let item = {
285
+ type: 'endVerticalAlignment',
286
+ item: {
287
+ verticalAlignment: verticalAlignment
288
+ }
289
+ };
290
+ page.items.push(item);
291
+ return item;
292
+ }
293
+ addFragment(block, useBlockXOffset, useBlockYOffset, dontUpdateContextPosition) {
294
+ let ctx = this.context();
295
+ let page = ctx.getCurrentPage();
296
+ if (!useBlockXOffset && block.height > ctx.availableHeight) {
297
+ return false;
298
+ }
299
+ block.items.forEach(item => {
300
+ switch (item.type) {
301
+ case 'line':
302
+ var l = item.item.clone();
303
+ if (l._node) {
304
+ l._node.positions[0].pageNumber = ctx.page + 1;
305
+ }
306
+ l.x = (l.x || 0) + (useBlockXOffset ? block.xOffset || 0 : ctx.x);
307
+ l.y = (l.y || 0) + (useBlockYOffset ? block.yOffset || 0 : ctx.y);
308
+ page.items.push({
309
+ type: 'line',
310
+ item: l
311
+ });
312
+ break;
313
+ case 'vector':
314
+ var v = (0, _tools.pack)(item.item);
315
+ (0, _tools.offsetVector)(v, useBlockXOffset ? block.xOffset || 0 : ctx.x, useBlockYOffset ? block.yOffset || 0 : ctx.y);
316
+ if (v._isFillColorFromUnbreakable) {
317
+ // If the item is a fillColor from an unbreakable block
318
+ // We have to add it at the beginning of the items body array of the page
319
+ delete v._isFillColorFromUnbreakable;
320
+ const endOfBackgroundItemsIndex = ctx.backgroundLength[ctx.page];
321
+ page.items.splice(endOfBackgroundItemsIndex, 0, {
322
+ type: 'vector',
323
+ item: v
324
+ });
325
+ } else {
326
+ page.items.push({
327
+ type: 'vector',
328
+ item: v
329
+ });
330
+ }
331
+ break;
332
+ case 'image':
333
+ case 'svg':
334
+ case 'beginClip':
335
+ case 'endClip':
336
+ case 'beginVerticalAlignment':
337
+ case 'endVerticalAlignment':
338
+ var img = (0, _tools.pack)(item.item);
339
+ img.x = (img.x || 0) + (useBlockXOffset ? block.xOffset || 0 : ctx.x);
340
+ img.y = (img.y || 0) + (useBlockYOffset ? block.yOffset || 0 : ctx.y);
341
+ page.items.push({
342
+ type: item.type,
343
+ item: img
344
+ });
345
+ break;
346
+ }
347
+ });
348
+ if (!dontUpdateContextPosition) {
349
+ ctx.moveDown(block.height);
350
+ }
351
+ return true;
352
+ }
353
+
354
+ /**
355
+ * Pushes the provided context onto the stack or creates a new one
356
+ *
357
+ * pushContext(context) - pushes the provided context and makes it current
358
+ * pushContext(width, height) - creates and pushes a new context with the specified width and height
359
+ * pushContext() - creates a new context for unbreakable blocks (with current availableWidth and full-page-height)
360
+ *
361
+ * @param {DocumentContext|number} contextOrWidth
362
+ * @param {number} height
363
+ */
364
+ pushContext(contextOrWidth, height) {
365
+ if (contextOrWidth === undefined) {
366
+ height = this.context().getCurrentPage().height - this.context().pageMargins.top - this.context().pageMargins.bottom;
367
+ contextOrWidth = this.context().availableWidth;
368
+ }
369
+ if ((0, _variableType.isNumber)(contextOrWidth)) {
370
+ let width = contextOrWidth;
371
+ contextOrWidth = new _DocumentContext.default();
372
+ contextOrWidth.addPage({
373
+ width: width,
374
+ height: height
375
+ }, {
376
+ left: 0,
377
+ right: 0,
378
+ top: 0,
379
+ bottom: 0
380
+ });
381
+ }
382
+ this.contextStack.push(this.context());
383
+ this._context = contextOrWidth;
384
+ }
385
+ popContext() {
386
+ this._context = this.contextStack.pop();
387
+ }
388
+ getCurrentPositionOnPage() {
389
+ return (this.contextStack[0] || this.context()).getCurrentPosition();
390
+ }
391
+ }
392
+ function addPageItem(page, item, index) {
393
+ if (index === null || index === undefined || index < 0 || index > page.items.length) {
394
+ page.items.push(item);
395
+ } else {
396
+ page.items.splice(index, 0, item);
397
+ }
398
+ }
399
+ var _default = exports.default = ElementWriter;