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.
- package/CHANGELOG.md +18 -0
- package/LICENSE +21 -21
- package/README.md +75 -78
- package/build/fonts/Roboto/Roboto-Italic.ttf +0 -0
- package/build/fonts/Roboto/Roboto-Medium.ttf +0 -0
- package/build/fonts/Roboto/Roboto-MediumItalic.ttf +0 -0
- package/build/fonts/Roboto/Roboto-Regular.ttf +0 -0
- package/build/fonts/Roboto.js +27 -0
- package/build/pdfmake.js +64813 -64584
- package/build/pdfmake.js.map +1 -1
- package/build/pdfmake.min.js +2 -2
- package/build/pdfmake.min.js.map +1 -1
- package/build/standard-fonts/Courier.js +27 -27
- package/build/standard-fonts/Helvetica.js +27 -27
- package/build/standard-fonts/Symbol.js +21 -21
- package/build/standard-fonts/Times.js +27 -27
- package/build/standard-fonts/ZapfDingbats.js +21 -21
- package/build/vfs_fonts.js +5 -5
- package/build-vfs.js +44 -44
- package/fonts/Roboto.js +8 -8
- package/js/3rd-party/svg-to-pdfkit/source.js +1 -1
- package/js/DocMeasure.js +11 -6
- package/js/DocumentContext.js +8 -3
- package/js/ElementWriter.js +42 -16
- package/js/LayoutBuilder.js +144 -78
- package/js/Line.js +16 -16
- package/js/OutputDocument.js +10 -10
- package/js/OutputDocumentServer.js +3 -3
- package/js/PDFDocument.js +3 -3
- package/js/PageElementWriter.js +15 -9
- package/js/Printer.js +28 -28
- package/js/Renderer.js +40 -8
- package/js/SVGMeasure.js +10 -10
- package/js/StyleContextStack.js +74 -51
- package/js/TableProcessor.js +14 -0
- package/js/TextBreaker.js +17 -17
- package/js/TextDecorator.js +12 -3
- package/js/TextInlines.js +34 -33
- package/js/base.js +4 -4
- package/js/browser-extensions/OutputDocumentBrowser.js +24 -24
- package/js/columnCalculator.js +2 -2
- package/js/helpers/node.js +47 -23
- package/js/helpers/variableType.js +18 -18
- package/js/qrEnc.js +38 -38
- package/js/virtual-fs.js +11 -11
- package/package.json +12 -12
- package/src/3rd-party/svg-to-pdfkit/LICENSE +9 -9
- package/src/3rd-party/svg-to-pdfkit/source.js +2745 -2745
- package/src/3rd-party/svg-to-pdfkit.js +3 -3
- package/src/DocMeasure.js +745 -738
- package/src/DocPreprocessor.js +283 -283
- package/src/DocumentContext.js +345 -338
- package/src/ElementWriter.js +441 -417
- package/src/LayoutBuilder.js +1336 -1258
- package/src/Line.js +114 -114
- package/src/OutputDocument.js +64 -64
- package/src/OutputDocumentServer.js +32 -32
- package/src/PDFDocument.js +174 -174
- package/src/PageElementWriter.js +187 -179
- package/src/PageSize.js +53 -53
- package/src/Printer.js +306 -306
- package/src/Renderer.js +445 -409
- package/src/SVGMeasure.js +109 -109
- package/src/StyleContextStack.js +208 -179
- package/src/TableProcessor.js +620 -602
- package/src/TextBreaker.js +168 -168
- package/src/TextDecorator.js +175 -161
- package/src/TextInlines.js +224 -223
- package/src/URLResolver.js +43 -43
- package/src/base.js +70 -70
- package/src/browser-extensions/OutputDocumentBrowser.js +80 -80
- package/src/browser-extensions/fonts/Roboto.js +27 -27
- package/src/browser-extensions/index.js +55 -55
- package/src/browser-extensions/pdfMake.js +1 -1
- package/src/browser-extensions/standard-fonts/Courier.js +27 -27
- package/src/browser-extensions/standard-fonts/Helvetica.js +27 -27
- package/src/browser-extensions/standard-fonts/Symbol.js +21 -21
- package/src/browser-extensions/standard-fonts/Times.js +27 -27
- package/src/browser-extensions/standard-fonts/ZapfDingbats.js +21 -21
- package/src/browser-extensions/virtual-fs-cjs.js +1 -1
- package/src/columnCalculator.js +154 -154
- package/src/helpers/node.js +134 -110
- package/src/helpers/tools.js +44 -44
- package/src/helpers/variableType.js +50 -50
- package/src/index.js +16 -16
- package/src/qrEnc.js +796 -796
- package/src/standardPageSizes.js +52 -52
- package/src/tableLayouts.js +100 -100
- package/src/virtual-fs.js +66 -66
- package/standard-fonts/Courier.js +8 -8
- package/standard-fonts/Helvetica.js +8 -8
- package/standard-fonts/Symbol.js +5 -5
- package/standard-fonts/Times.js +8 -8
- package/standard-fonts/ZapfDingbats.js +5 -5
package/src/TextBreaker.js
CHANGED
|
@@ -1,168 +1,168 @@
|
|
|
1
|
-
import LineBreaker from 'linebreak';
|
|
2
|
-
import { isObject } from './helpers/variableType';
|
|
3
|
-
import StyleContextStack from './StyleContextStack';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* @param {string} text
|
|
7
|
-
* @param {boolean} noWrap
|
|
8
|
-
* @param {boolean} breakAll
|
|
9
|
-
* @returns {Array}
|
|
10
|
-
*/
|
|
11
|
-
const splitWords = (text, noWrap, breakAll = false) => {
|
|
12
|
-
let words = [];
|
|
13
|
-
if (text === undefined || text === null) {
|
|
14
|
-
text = '';
|
|
15
|
-
} else {
|
|
16
|
-
text = String(text);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
if (noWrap) {
|
|
20
|
-
words.push({ text: text });
|
|
21
|
-
return words;
|
|
22
|
-
}
|
|
23
|
-
if (breakAll) {
|
|
24
|
-
return text.split('').map(c => {
|
|
25
|
-
if(c.match(/^\n$|^\r$/)) { // new line
|
|
26
|
-
return { text: '', lineEnd: true };
|
|
27
|
-
}
|
|
28
|
-
return { text: c };
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
if (text.length === 0) {
|
|
33
|
-
words.push({ text: '' });
|
|
34
|
-
return words;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
let breaker = new LineBreaker(text);
|
|
38
|
-
let last = 0;
|
|
39
|
-
let bk;
|
|
40
|
-
|
|
41
|
-
while ((bk = breaker.nextBreak())) {
|
|
42
|
-
let word = text.slice(last, bk.position);
|
|
43
|
-
|
|
44
|
-
if (bk.required || word.match(/\r?\n$|\r$/)) { // new line
|
|
45
|
-
word = word.replace(/\r?\n$|\r$/, '');
|
|
46
|
-
words.push({ text: word, lineEnd: true });
|
|
47
|
-
} else {
|
|
48
|
-
words.push({ text: word });
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
last = bk.position;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
return words;
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* @param {Array} words
|
|
59
|
-
* @param {boolean} noWrap
|
|
60
|
-
* @returns {?string}
|
|
61
|
-
*/
|
|
62
|
-
const getFirstWord = (words, noWrap) => {
|
|
63
|
-
let word = words[0];
|
|
64
|
-
if (word === undefined) {
|
|
65
|
-
return null;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
if (noWrap) { // text was not wrapped, we need only first word
|
|
69
|
-
let tmpWords = splitWords(word.text, false);
|
|
70
|
-
if (tmpWords[0] === undefined) {
|
|
71
|
-
return null;
|
|
72
|
-
}
|
|
73
|
-
word = tmpWords[0];
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
return word.text;
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* @param {Array} words
|
|
81
|
-
* @param {boolean} noWrap
|
|
82
|
-
* @returns {?string}
|
|
83
|
-
*/
|
|
84
|
-
const getLastWord = (words, noWrap) => {
|
|
85
|
-
let word = words[words.length - 1];
|
|
86
|
-
if (word === undefined) {
|
|
87
|
-
return null;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
if (word.lineEnd) {
|
|
91
|
-
return null;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
if (noWrap) { // text was not wrapped, we need only last word
|
|
95
|
-
let tmpWords = splitWords(word.text, false);
|
|
96
|
-
if (tmpWords[tmpWords.length - 1] === undefined) {
|
|
97
|
-
return null;
|
|
98
|
-
}
|
|
99
|
-
word = tmpWords[tmpWords.length - 1];
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
return word.text;
|
|
103
|
-
};
|
|
104
|
-
|
|
105
|
-
class TextBreaker {
|
|
106
|
-
/**
|
|
107
|
-
* @param {string|Array} texts
|
|
108
|
-
* @param {StyleContextStack} styleContextStack
|
|
109
|
-
* @returns {Array}
|
|
110
|
-
*/
|
|
111
|
-
getBreaks(texts, styleContextStack) {
|
|
112
|
-
let results = [];
|
|
113
|
-
|
|
114
|
-
if (!Array.isArray(texts)) {
|
|
115
|
-
texts = [texts];
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
let lastWord = null;
|
|
119
|
-
for (let i = 0, l = texts.length; i < l; i++) {
|
|
120
|
-
let item = texts[i];
|
|
121
|
-
let style = null;
|
|
122
|
-
let words;
|
|
123
|
-
let breakAll = StyleContextStack.getStyleProperty(item || {}, styleContextStack, 'wordBreak', 'normal') === 'break-all';
|
|
124
|
-
let noWrap = StyleContextStack.getStyleProperty(item || {}, styleContextStack, 'noWrap', false);
|
|
125
|
-
if (isObject(item)) {
|
|
126
|
-
if (item._textRef && item._textRef._textNodeRef.text) {
|
|
127
|
-
item.text = item._textRef._textNodeRef.text;
|
|
128
|
-
}
|
|
129
|
-
words = splitWords(item.text, noWrap, breakAll);
|
|
130
|
-
style = StyleContextStack.copyStyle(item);
|
|
131
|
-
} else {
|
|
132
|
-
words = splitWords(item, noWrap, breakAll);
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
if (lastWord && words.length) {
|
|
136
|
-
let firstWord = getFirstWord(words, noWrap);
|
|
137
|
-
|
|
138
|
-
let wrapWords = splitWords(lastWord + firstWord, false);
|
|
139
|
-
if (wrapWords.length === 1) {
|
|
140
|
-
results[results.length - 1].noNewLine = true;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
for (let i2 = 0, l2 = words.length; i2 < l2; i2++) {
|
|
145
|
-
let result = {
|
|
146
|
-
text: words[i2].text
|
|
147
|
-
};
|
|
148
|
-
|
|
149
|
-
if (words[i2].lineEnd) {
|
|
150
|
-
result.lineEnd = true;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
StyleContextStack.copyStyle(style, result);
|
|
154
|
-
|
|
155
|
-
results.push(result);
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
lastWord = null;
|
|
159
|
-
if (i + 1 < l) {
|
|
160
|
-
lastWord = getLastWord(words, noWrap);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
return results;
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
export default TextBreaker;
|
|
1
|
+
import LineBreaker from 'linebreak';
|
|
2
|
+
import { isObject } from './helpers/variableType';
|
|
3
|
+
import StyleContextStack from './StyleContextStack';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* @param {string} text
|
|
7
|
+
* @param {boolean} noWrap
|
|
8
|
+
* @param {boolean} breakAll
|
|
9
|
+
* @returns {Array}
|
|
10
|
+
*/
|
|
11
|
+
const splitWords = (text, noWrap, breakAll = false) => {
|
|
12
|
+
let words = [];
|
|
13
|
+
if (text === undefined || text === null) {
|
|
14
|
+
text = '';
|
|
15
|
+
} else {
|
|
16
|
+
text = String(text);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
if (noWrap) {
|
|
20
|
+
words.push({ text: text });
|
|
21
|
+
return words;
|
|
22
|
+
}
|
|
23
|
+
if (breakAll) {
|
|
24
|
+
return text.split('').map(c => {
|
|
25
|
+
if(c.match(/^\n$|^\r$/)) { // new line
|
|
26
|
+
return { text: '', lineEnd: true };
|
|
27
|
+
}
|
|
28
|
+
return { text: c };
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (text.length === 0) {
|
|
33
|
+
words.push({ text: '' });
|
|
34
|
+
return words;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
let breaker = new LineBreaker(text);
|
|
38
|
+
let last = 0;
|
|
39
|
+
let bk;
|
|
40
|
+
|
|
41
|
+
while ((bk = breaker.nextBreak())) {
|
|
42
|
+
let word = text.slice(last, bk.position);
|
|
43
|
+
|
|
44
|
+
if (bk.required || word.match(/\r?\n$|\r$/)) { // new line
|
|
45
|
+
word = word.replace(/\r?\n$|\r$/, '');
|
|
46
|
+
words.push({ text: word, lineEnd: true });
|
|
47
|
+
} else {
|
|
48
|
+
words.push({ text: word });
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
last = bk.position;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return words;
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* @param {Array} words
|
|
59
|
+
* @param {boolean} noWrap
|
|
60
|
+
* @returns {?string}
|
|
61
|
+
*/
|
|
62
|
+
const getFirstWord = (words, noWrap) => {
|
|
63
|
+
let word = words[0];
|
|
64
|
+
if (word === undefined) {
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
if (noWrap) { // text was not wrapped, we need only first word
|
|
69
|
+
let tmpWords = splitWords(word.text, false);
|
|
70
|
+
if (tmpWords[0] === undefined) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
word = tmpWords[0];
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
return word.text;
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* @param {Array} words
|
|
81
|
+
* @param {boolean} noWrap
|
|
82
|
+
* @returns {?string}
|
|
83
|
+
*/
|
|
84
|
+
const getLastWord = (words, noWrap) => {
|
|
85
|
+
let word = words[words.length - 1];
|
|
86
|
+
if (word === undefined) {
|
|
87
|
+
return null;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (word.lineEnd) {
|
|
91
|
+
return null;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (noWrap) { // text was not wrapped, we need only last word
|
|
95
|
+
let tmpWords = splitWords(word.text, false);
|
|
96
|
+
if (tmpWords[tmpWords.length - 1] === undefined) {
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
word = tmpWords[tmpWords.length - 1];
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return word.text;
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
class TextBreaker {
|
|
106
|
+
/**
|
|
107
|
+
* @param {string|Array} texts
|
|
108
|
+
* @param {StyleContextStack} styleContextStack
|
|
109
|
+
* @returns {Array}
|
|
110
|
+
*/
|
|
111
|
+
getBreaks(texts, styleContextStack) {
|
|
112
|
+
let results = [];
|
|
113
|
+
|
|
114
|
+
if (!Array.isArray(texts)) {
|
|
115
|
+
texts = [texts];
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
let lastWord = null;
|
|
119
|
+
for (let i = 0, l = texts.length; i < l; i++) {
|
|
120
|
+
let item = texts[i];
|
|
121
|
+
let style = null;
|
|
122
|
+
let words;
|
|
123
|
+
let breakAll = StyleContextStack.getStyleProperty(item || {}, styleContextStack, 'wordBreak', 'normal') === 'break-all';
|
|
124
|
+
let noWrap = StyleContextStack.getStyleProperty(item || {}, styleContextStack, 'noWrap', false);
|
|
125
|
+
if (isObject(item)) {
|
|
126
|
+
if (item._textRef && item._textRef._textNodeRef.text) {
|
|
127
|
+
item.text = item._textRef._textNodeRef.text;
|
|
128
|
+
}
|
|
129
|
+
words = splitWords(item.text, noWrap, breakAll);
|
|
130
|
+
style = StyleContextStack.copyStyle(item);
|
|
131
|
+
} else {
|
|
132
|
+
words = splitWords(item, noWrap, breakAll);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
if (lastWord && words.length) {
|
|
136
|
+
let firstWord = getFirstWord(words, noWrap);
|
|
137
|
+
|
|
138
|
+
let wrapWords = splitWords(lastWord + firstWord, false);
|
|
139
|
+
if (wrapWords.length === 1) {
|
|
140
|
+
results[results.length - 1].noNewLine = true;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
for (let i2 = 0, l2 = words.length; i2 < l2; i2++) {
|
|
145
|
+
let result = {
|
|
146
|
+
text: words[i2].text
|
|
147
|
+
};
|
|
148
|
+
|
|
149
|
+
if (words[i2].lineEnd) {
|
|
150
|
+
result.lineEnd = true;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
StyleContextStack.copyStyle(style, result);
|
|
154
|
+
|
|
155
|
+
results.push(result);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
lastWord = null;
|
|
159
|
+
if (i + 1 < l) {
|
|
160
|
+
lastWord = getLastWord(words, noWrap);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
return results;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
export default TextBreaker;
|