pdfmake 0.2.1 → 0.3.0-beta.1

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