@pdftron/pdfnet-node-samples 9.4.2 → 9.5.0-2-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 (124) hide show
  1. package/package.json +18 -18
  2. package/readme.md +12 -12
  3. package/samples/AddImageTest/AddImageTest.js +2 -2
  4. package/samples/AdvancedImagingTest/AdvancedImagingTest.js +3 -3
  5. package/samples/AnnotationTest/AnnotationTest.js +2 -2
  6. package/samples/BookmarkTest/BookmarkTest.js +2 -2
  7. package/samples/CAD2PDFTest/CAD2PDFTest.js +79 -79
  8. package/samples/ContentReplacerTest/ContentReplacerTest.js +2 -2
  9. package/samples/ConvertTest/ConvertTest.js +270 -256
  10. package/samples/DataExtractionTest/DataExtractionTest.js +180 -0
  11. package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +526 -526
  12. package/samples/ElementBuilderTest/ElementBuilderTest.js +2 -2
  13. package/samples/ElementEditTest/ElementEditTest.js +2 -2
  14. package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +2 -2
  15. package/samples/ElementReaderTest/ElementReaderTest.js +2 -2
  16. package/samples/EncTest/EncTest.js +2 -2
  17. package/samples/FDFTest/FDFTest.js +218 -218
  18. package/samples/HTML2PDFTest/HTML2PDFTest.js +165 -165
  19. package/samples/HighlightsTest/HighlightsTest.js +2 -2
  20. package/samples/ImageExtractTest/ImageExtractTest.js +129 -129
  21. package/samples/ImpositionTest/ImpositionTest.js +86 -86
  22. package/samples/InteractiveFormsTest/InteractiveFormsTest.js +381 -381
  23. package/samples/JBIG2Test/JBIG2Test.js +88 -88
  24. package/samples/LogicalStructureTest/LogicalStructureTest.js +2 -2
  25. package/samples/OCRTest/OCRTest.js +234 -234
  26. package/samples/OfficeTemplateTest/OfficeTemplateTest.js +79 -77
  27. package/samples/OfficeToPDFTest/OfficeToPDFTest.js +125 -125
  28. package/samples/OptimizerTest/OptimizerTest.js +191 -191
  29. package/samples/PDF2HtmlTest/PDF2HtmlTest.js +3 -3
  30. package/samples/PDF2OfficeTest/PDF2OfficeTest.js +3 -3
  31. package/samples/PDFATest/PDFATest.js +2 -2
  32. package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +84 -84
  33. package/samples/PDFDrawTest/PDFDrawTest.js +2 -2
  34. package/samples/PDFLayersTest/PDFLayersTest.js +2 -2
  35. package/samples/PDFPackageTest/PDFPackageTest.js +111 -111
  36. package/samples/PDFPageTest/PDFPageTest.js +2 -2
  37. package/samples/PDFRedactTest/PDFRedactTest.js +2 -2
  38. package/samples/PageLabelsTest/PageLabelsTest.js +138 -138
  39. package/samples/PatternTest/PatternTest.js +226 -226
  40. package/samples/RectTest/RectTest.js +2 -2
  41. package/samples/SDFTest/SDFTest.js +3 -4
  42. package/samples/StamperTest/StamperTest.js +2 -2
  43. package/samples/TextExtractTest/TextExtractTest.js +2 -2
  44. package/samples/TextSearchTest/TextSearchTest.js +2 -2
  45. package/samples/U3DTest/U3DTest.js +104 -104
  46. package/samples/UndoRedoTest/UndoRedoTest.js +2 -2
  47. package/samples/UnicodeWriteTest/UnicodeWriteTest.js +2 -2
  48. package/samples/WebViewerConvertTest/WebViewerConvertTest.js +135 -135
  49. package/samples/runall.bat +6 -5
  50. package/samples/runall.sh +4 -5
  51. package/samples/TestFiles/BusinessCardTemplate.pdf +0 -0
  52. package/samples/TestFiles/Fishermen.docx +0 -0
  53. package/samples/TestFiles/Font_licenses.txt +0 -140
  54. package/samples/TestFiles/GlobalSignRootForTST.cer +0 -0
  55. package/samples/TestFiles/License.txt +0 -1
  56. package/samples/TestFiles/Misc-Fixed.pfa +0 -1166
  57. package/samples/TestFiles/NotoSans_with_hindi.ttf +0 -0
  58. package/samples/TestFiles/Output/empty +0 -1
  59. package/samples/TestFiles/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +0 -34
  60. package/samples/TestFiles/SYH_Letter.docx +0 -0
  61. package/samples/TestFiles/TigerText.pdf +0 -0
  62. package/samples/TestFiles/US061222892-a.pdf +0 -0
  63. package/samples/TestFiles/butterfly.png +0 -0
  64. package/samples/TestFiles/credit card numbers.pdf +0 -0
  65. package/samples/TestFiles/dice.jpg +0 -0
  66. package/samples/TestFiles/dice.u3d +0 -0
  67. package/samples/TestFiles/doc_to_sign.pdf +0 -0
  68. package/samples/TestFiles/factsheet_Arabic.docx +0 -0
  69. package/samples/TestFiles/fish.pdf +0 -0
  70. package/samples/TestFiles/font.ttf +0 -0
  71. package/samples/TestFiles/form1.pdf +1 -245
  72. package/samples/TestFiles/form1_annots.xfdf +0 -34
  73. package/samples/TestFiles/form1_data.fdf +0 -4
  74. package/samples/TestFiles/form1_data.xfdf +0 -140
  75. package/samples/TestFiles/grayscale.tif +0 -0
  76. package/samples/TestFiles/hindi_sample_utf16le.txt +0 -0
  77. package/samples/TestFiles/imagemask.dat +0 -32
  78. package/samples/TestFiles/logo_red.png +0 -0
  79. package/samples/TestFiles/lorem_ipsum.pdf +0 -0
  80. package/samples/TestFiles/multipage.tif +0 -0
  81. package/samples/TestFiles/my_stream.txt +0 -2310
  82. package/samples/TestFiles/newsletter.pdf +0 -0
  83. package/samples/TestFiles/newsletter.xod +0 -0
  84. package/samples/TestFiles/numbered.pdf +0 -0
  85. package/samples/TestFiles/op_blend_test.pdf +0 -1498
  86. package/samples/TestFiles/palm.jp2 +0 -0
  87. package/samples/TestFiles/paragraphs_and_tables.pdf +0 -0
  88. package/samples/TestFiles/pdfnet.gif +0 -0
  89. package/samples/TestFiles/pdftron.bmp +0 -0
  90. package/samples/TestFiles/pdftron.cer +0 -0
  91. package/samples/TestFiles/pdftron.pfx +0 -0
  92. package/samples/TestFiles/pdftron_smart_substitution.plugin +0 -0
  93. package/samples/TestFiles/peppers.jpg +0 -0
  94. package/samples/TestFiles/signature.jpg +0 -0
  95. package/samples/TestFiles/simple-emf.emf +0 -0
  96. package/samples/TestFiles/simple-excel_2007.xlsx +0 -0
  97. package/samples/TestFiles/simple-outlook.msg +0 -0
  98. package/samples/TestFiles/simple-powerpoint_2007.pptx +0 -0
  99. package/samples/TestFiles/simple-publisher.pub +0 -0
  100. package/samples/TestFiles/simple-rtf.rtf +0 -224
  101. package/samples/TestFiles/simple-text.txt +0 -61
  102. package/samples/TestFiles/simple-visio.vsd +0 -0
  103. package/samples/TestFiles/simple-webpage.html +0 -731
  104. package/samples/TestFiles/simple-webpage.mht +0 -6972
  105. package/samples/TestFiles/simple-webpage_files/colorschememapping.xml +0 -2
  106. package/samples/TestFiles/simple-webpage_files/filelist.xml +0 -14
  107. package/samples/TestFiles/simple-webpage_files/image001.gif +0 -0
  108. package/samples/TestFiles/simple-webpage_files/image002.png +0 -0
  109. package/samples/TestFiles/simple-webpage_files/image003.jpg +0 -0
  110. package/samples/TestFiles/simple-webpage_files/image004.emz +0 -0
  111. package/samples/TestFiles/simple-webpage_files/image005.gif +0 -0
  112. package/samples/TestFiles/simple-webpage_files/image006.png +0 -0
  113. package/samples/TestFiles/simple-webpage_files/image007.gif +0 -0
  114. package/samples/TestFiles/simple-webpage_files/oledata.mso +0 -0
  115. package/samples/TestFiles/simple-webpage_files/themedata.thmx +0 -0
  116. package/samples/TestFiles/simple-word_2007.docx +0 -0
  117. package/samples/TestFiles/simple-xps.xps +0 -0
  118. package/samples/TestFiles/tagged.pdf +0 -0
  119. package/samples/TestFiles/the_rime_of_the_ancient_mariner.docx +0 -0
  120. package/samples/TestFiles/tiger.pdf +0 -0
  121. package/samples/TestFiles/waiver.pdf +0 -0
  122. package/samples/TestFiles/waiver_withApprovalField.pdf +0 -0
  123. package/samples/TestFiles/waiver_withApprovalField_certified.pdf +1 -424
  124. package/samples/TestFiles/waiver_withApprovalField_certified_approved.pdf +1 -466
@@ -1,227 +1,227 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
3
- // Consult legal.txt regarding legal and license information.
4
- //---------------------------------------------------------------------------------------
5
-
6
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
- const PDFTronLicense = require('../LicenseKey/LicenseKey');
8
-
9
- ((exports) => {
10
- 'use strict';
11
-
12
- exports.runPatternTest = () => {
13
- const createTilingPattern = async (doc) => {
14
- const writer = await PDFNet.ElementWriter.create();
15
- const eb = await PDFNet.ElementBuilder.create();
16
-
17
- // Create a new pattern content stream - a heart. ------------
18
- writer.begin(doc);
19
- eb.pathBegin();
20
- eb.moveTo(0, 0);
21
- eb.curveTo(500, 500, 125, 625, 0, 500);
22
- eb.curveTo(-125, 625, -500, 500, 0, 0);
23
- const heart = await eb.pathEnd();
24
- heart.setPathFill(true);
25
-
26
- // Set heart color to red.
27
- const gstate = await heart.getGState();
28
- gstate.setFillColorSpace(await PDFNet.ColorSpace.createDeviceRGB());
29
- gstate.setStrokeColorWithColorPt(await PDFNet.ColorPt.init(1, 0, 0));
30
- writer.writeElement(heart);
31
-
32
- const patternDict = await writer.end();
33
-
34
- // Initialize pattern dictionary. For details on what each parameter represents please
35
- // refer to Table 4.22 (Section '4.6.2 Tiling Patterns') in PDF Reference Manual.
36
- patternDict.putName('Type', 'Pattern');
37
- patternDict.putNumber('PatternType', 1);
38
-
39
- // TilingType - Constant spacing.
40
- patternDict.putNumber('TilingType', 1);
41
-
42
- // This is a Type1 pattern - A colored tiling pattern.
43
- patternDict.putNumber('PaintType', 1);
44
-
45
- // Set bounding box
46
- patternDict.putRect('BBox', -253, 0, 253, 545);
47
-
48
- // Create and set the matrix
49
- const pattern_mtx = await PDFNet.Matrix2D.create(0.04, 0, 0, 0.04, 0, 0);
50
- patternDict.putMatrix('Matrix', pattern_mtx);
51
-
52
- // Set the desired horizontal and vertical spacing between pattern cells,
53
- // measured in the pattern coordinate system.
54
- patternDict.putNumber('XStep', 1000);
55
- await patternDict.putNumber('YStep', 1000);
56
-
57
- return patternDict; // finished creating the Pattern resource
58
- }
59
-
60
- const createImageTilingPattern = async (doc) => {
61
- const writer = await PDFNet.ElementWriter.create();
62
- const eb = await PDFNet.ElementBuilder.create();
63
-
64
- // Create a new pattern content stream - a single bitmap object ----------
65
- writer.begin(doc);
66
- const image = await PDFNet.Image.createFromFile(doc, '../TestFiles/dice.jpg');
67
- const imgElement = await eb.createImageScaled(image, 0, 0, await image.getImageWidth(), await image.getImageHeight());
68
- writer.writePlacedElement(imgElement);
69
-
70
- const patternDict = await writer.end();
71
-
72
- // Initialize pattern dictionary. For details on what each parameter represents please
73
- // refer to Table 4.22 (Section '4.6.2 Tiling Patterns') in PDF Reference Manual.
74
- patternDict.putName('Type', 'Pattern');
75
- patternDict.putNumber('PatternType', 1);
76
-
77
- // TilingType - Constant spacing.
78
- patternDict.putNumber('TilingType', 1);
79
-
80
- // This is a Type1 pattern - A colored tiling pattern.
81
- patternDict.putNumber('PaintType', 1);
82
-
83
- // Set bounding box
84
- patternDict.putRect('BBox', -253, 0, 253, 545);
85
-
86
- // Create and set the matrix
87
- const pattern_mtx = await PDFNet.Matrix2D.create(0.3, 0, 0, 0.3, 0, 0);
88
- patternDict.putMatrix('Matrix', pattern_mtx);
89
-
90
- // Set the desired horizontal and vertical spacing between pattern cells,
91
- // measured in the pattern coordinate system.
92
- patternDict.putNumber('XStep', 300);
93
- await patternDict.putNumber('YStep', 300);
94
-
95
- return patternDict; // finished creating the Pattern resource
96
- }
97
-
98
- const createAxialShading = async (doc) => {
99
- // Create a new Shading object ------------
100
- const patternDict = await doc.createIndirectDict();
101
-
102
- // Initialize pattern dictionary. For details on what each parameter represents
103
- // please refer to Tables 4.30 and 4.26 in PDF Reference Manual
104
- patternDict.putName('Type', 'Pattern');
105
- patternDict.putNumber('PatternType', 2); // 2 stands for shading
106
-
107
- const shadingDict = await patternDict.putDict('Shading');
108
- shadingDict.putNumber('ShadingType', 2);
109
- shadingDict.putName('ColorSpace', 'DeviceCMYK');
110
-
111
- // pass the coordinates of the axial shading to the output
112
- const shadingCoords = await shadingDict.putArray('Coords');
113
- shadingCoords.pushBackNumber(0);
114
- shadingCoords.pushBackNumber(0);
115
- shadingCoords.pushBackNumber(612);
116
- shadingCoords.pushBackNumber(794);
117
-
118
- // pass the function to the axial shading
119
- const func = await shadingDict.putDict('Function');
120
- const C0 = await func.putArray('C0');
121
- C0.pushBackNumber(1);
122
- C0.pushBackNumber(0);
123
- C0.pushBackNumber(0);
124
- await C0.pushBackNumber(0);
125
-
126
- const C1 = await func.putArray('C1');
127
- C1.pushBackNumber(0);
128
- C1.pushBackNumber(1);
129
- C1.pushBackNumber(0);
130
- await C1.pushBackNumber(0);
131
-
132
- const domain = await func.putArray('Domain');
133
- domain.pushBackNumber(0);
134
- await domain.pushBackNumber(1);
135
-
136
- func.putNumber('FunctionType', 2);
137
- await func.putNumber('N', 1);
138
-
139
- return patternDict;
140
- }
141
-
142
- const main = async () => {
143
- try {
144
- const doc = await PDFNet.PDFDoc.create();
145
- const writer = await PDFNet.ElementWriter.create();
146
- var eb = await PDFNet.ElementBuilder.create();
147
-
148
- // The following sample illustrates how to create and use tiling patterns
149
- var page = await doc.pageCreate();
150
- writer.beginOnPage(page);
151
-
152
- var element = await eb.createTextBeginWithFont(await PDFNet.Font.createAndEmbed(doc, PDFNet.Font.StandardType1Font.e_times_bold), 1);
153
- writer.writeElement(element); // Begin the text block
154
-
155
- const data = 'G';
156
- element = await eb.createNewTextRun(data);
157
- element.setTextMatrixEntries(720, 0, 0, 720, 20, 240);
158
- var gs = await element.getGState();
159
- gs.setTextRenderMode(PDFNet.GState.TextRenderingMode.e_fill_stroke_text);
160
- gs.setLineWidth(4);
161
-
162
- // Set the fill color space to the Pattern color space.
163
- gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
164
- var patterColor = await PDFNet.PatternColor.create(await createTilingPattern(doc));
165
- gs.setFillColorWithPattern(patterColor);
166
-
167
- writer.writeElement(element);
168
- writer.writeElement(await eb.createTextEnd()); // Finish the text block
169
-
170
- writer.end(); // Save the page
171
- doc.pagePushBack(page);
172
- //-----------------------------------------------
173
-
174
- /// The following sample illustrates how to create and use image tiling pattern
175
- page = await doc.pageCreate();
176
- writer.beginOnPage(page);
177
-
178
- eb.reset();
179
- element = await eb.createRect(0, 0, 612, 794);
180
-
181
- // Set the fill color space to the Pattern color space.
182
- gs = await element.getGState();
183
- gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
184
- patterColor = await PDFNet.PatternColor.create(await createImageTilingPattern(doc));
185
- gs.setFillColorWithPattern(patterColor);
186
- element.setPathFill(true);
187
-
188
- writer.writeElement(element);
189
-
190
- await writer.end(); // Save the page
191
- doc.pagePushBack(page);
192
- //-----------------------------------------------
193
-
194
- /// The following sample illustrates how to create and use PDF shadings
195
- page = await doc.pageCreate();
196
- writer.beginOnPage(page);
197
-
198
- eb.reset();
199
- element = await eb.createRect(0, 0, 612, 794);
200
-
201
- // Set the fill color space to the Pattern color space.
202
- gs = await element.getGState();
203
- gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
204
- patterColor = await PDFNet.PatternColor.create(await createAxialShading(doc));
205
- gs.setFillColorWithPattern(patterColor);
206
- element.setPathFill(true);
207
-
208
- writer.writeElement(element);
209
-
210
- await writer.end(); // Save the page
211
- doc.pagePushBack(page);
212
- //-----------------------------------------------
213
-
214
- await doc.save('../TestFiles/Output/patterns.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
215
- console.log('Done. Result saved in patterns.pdf...');
216
- } catch (err) {
217
- console.log(err);
218
- }
219
- }
220
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
221
- console.log('Error: ' + JSON.stringify(error));
222
- }).then(function(){ return PDFNet.shutdown(); });
223
- };
224
- exports.runPatternTest();
225
- })(exports);
226
- // eslint-disable-next-line spaced-comment
1
+ //---------------------------------------------------------------------------------------
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
+ // Consult legal.txt regarding legal and license information.
4
+ //---------------------------------------------------------------------------------------
5
+
6
+ const { PDFNet } = require('../lib/pdfnet.js');
7
+ const PDFTronLicense = require('../LicenseKey/LicenseKey');
8
+
9
+ ((exports) => {
10
+ 'use strict';
11
+
12
+ exports.runPatternTest = () => {
13
+ const createTilingPattern = async (doc) => {
14
+ const writer = await PDFNet.ElementWriter.create();
15
+ const eb = await PDFNet.ElementBuilder.create();
16
+
17
+ // Create a new pattern content stream - a heart. ------------
18
+ writer.begin(doc);
19
+ eb.pathBegin();
20
+ eb.moveTo(0, 0);
21
+ eb.curveTo(500, 500, 125, 625, 0, 500);
22
+ eb.curveTo(-125, 625, -500, 500, 0, 0);
23
+ const heart = await eb.pathEnd();
24
+ heart.setPathFill(true);
25
+
26
+ // Set heart color to red.
27
+ const gstate = await heart.getGState();
28
+ gstate.setFillColorSpace(await PDFNet.ColorSpace.createDeviceRGB());
29
+ gstate.setStrokeColorWithColorPt(await PDFNet.ColorPt.init(1, 0, 0));
30
+ writer.writeElement(heart);
31
+
32
+ const patternDict = await writer.end();
33
+
34
+ // Initialize pattern dictionary. For details on what each parameter represents please
35
+ // refer to Table 4.22 (Section '4.6.2 Tiling Patterns') in PDF Reference Manual.
36
+ patternDict.putName('Type', 'Pattern');
37
+ patternDict.putNumber('PatternType', 1);
38
+
39
+ // TilingType - Constant spacing.
40
+ patternDict.putNumber('TilingType', 1);
41
+
42
+ // This is a Type1 pattern - A colored tiling pattern.
43
+ patternDict.putNumber('PaintType', 1);
44
+
45
+ // Set bounding box
46
+ patternDict.putRect('BBox', -253, 0, 253, 545);
47
+
48
+ // Create and set the matrix
49
+ const pattern_mtx = await PDFNet.Matrix2D.create(0.04, 0, 0, 0.04, 0, 0);
50
+ patternDict.putMatrix('Matrix', pattern_mtx);
51
+
52
+ // Set the desired horizontal and vertical spacing between pattern cells,
53
+ // measured in the pattern coordinate system.
54
+ patternDict.putNumber('XStep', 1000);
55
+ await patternDict.putNumber('YStep', 1000);
56
+
57
+ return patternDict; // finished creating the Pattern resource
58
+ }
59
+
60
+ const createImageTilingPattern = async (doc) => {
61
+ const writer = await PDFNet.ElementWriter.create();
62
+ const eb = await PDFNet.ElementBuilder.create();
63
+
64
+ // Create a new pattern content stream - a single bitmap object ----------
65
+ writer.begin(doc);
66
+ const image = await PDFNet.Image.createFromFile(doc, '../TestFiles/dice.jpg');
67
+ const imgElement = await eb.createImageScaled(image, 0, 0, await image.getImageWidth(), await image.getImageHeight());
68
+ writer.writePlacedElement(imgElement);
69
+
70
+ const patternDict = await writer.end();
71
+
72
+ // Initialize pattern dictionary. For details on what each parameter represents please
73
+ // refer to Table 4.22 (Section '4.6.2 Tiling Patterns') in PDF Reference Manual.
74
+ patternDict.putName('Type', 'Pattern');
75
+ patternDict.putNumber('PatternType', 1);
76
+
77
+ // TilingType - Constant spacing.
78
+ patternDict.putNumber('TilingType', 1);
79
+
80
+ // This is a Type1 pattern - A colored tiling pattern.
81
+ patternDict.putNumber('PaintType', 1);
82
+
83
+ // Set bounding box
84
+ patternDict.putRect('BBox', -253, 0, 253, 545);
85
+
86
+ // Create and set the matrix
87
+ const pattern_mtx = await PDFNet.Matrix2D.create(0.3, 0, 0, 0.3, 0, 0);
88
+ patternDict.putMatrix('Matrix', pattern_mtx);
89
+
90
+ // Set the desired horizontal and vertical spacing between pattern cells,
91
+ // measured in the pattern coordinate system.
92
+ patternDict.putNumber('XStep', 300);
93
+ await patternDict.putNumber('YStep', 300);
94
+
95
+ return patternDict; // finished creating the Pattern resource
96
+ }
97
+
98
+ const createAxialShading = async (doc) => {
99
+ // Create a new Shading object ------------
100
+ const patternDict = await doc.createIndirectDict();
101
+
102
+ // Initialize pattern dictionary. For details on what each parameter represents
103
+ // please refer to Tables 4.30 and 4.26 in PDF Reference Manual
104
+ patternDict.putName('Type', 'Pattern');
105
+ patternDict.putNumber('PatternType', 2); // 2 stands for shading
106
+
107
+ const shadingDict = await patternDict.putDict('Shading');
108
+ shadingDict.putNumber('ShadingType', 2);
109
+ shadingDict.putName('ColorSpace', 'DeviceCMYK');
110
+
111
+ // pass the coordinates of the axial shading to the output
112
+ const shadingCoords = await shadingDict.putArray('Coords');
113
+ shadingCoords.pushBackNumber(0);
114
+ shadingCoords.pushBackNumber(0);
115
+ shadingCoords.pushBackNumber(612);
116
+ shadingCoords.pushBackNumber(794);
117
+
118
+ // pass the function to the axial shading
119
+ const func = await shadingDict.putDict('Function');
120
+ const C0 = await func.putArray('C0');
121
+ C0.pushBackNumber(1);
122
+ C0.pushBackNumber(0);
123
+ C0.pushBackNumber(0);
124
+ await C0.pushBackNumber(0);
125
+
126
+ const C1 = await func.putArray('C1');
127
+ C1.pushBackNumber(0);
128
+ C1.pushBackNumber(1);
129
+ C1.pushBackNumber(0);
130
+ await C1.pushBackNumber(0);
131
+
132
+ const domain = await func.putArray('Domain');
133
+ domain.pushBackNumber(0);
134
+ await domain.pushBackNumber(1);
135
+
136
+ func.putNumber('FunctionType', 2);
137
+ await func.putNumber('N', 1);
138
+
139
+ return patternDict;
140
+ }
141
+
142
+ const main = async () => {
143
+ try {
144
+ const doc = await PDFNet.PDFDoc.create();
145
+ const writer = await PDFNet.ElementWriter.create();
146
+ var eb = await PDFNet.ElementBuilder.create();
147
+
148
+ // The following sample illustrates how to create and use tiling patterns
149
+ var page = await doc.pageCreate();
150
+ writer.beginOnPage(page);
151
+
152
+ var element = await eb.createTextBeginWithFont(await PDFNet.Font.createAndEmbed(doc, PDFNet.Font.StandardType1Font.e_times_bold), 1);
153
+ writer.writeElement(element); // Begin the text block
154
+
155
+ const data = 'G';
156
+ element = await eb.createNewTextRun(data);
157
+ element.setTextMatrixEntries(720, 0, 0, 720, 20, 240);
158
+ var gs = await element.getGState();
159
+ gs.setTextRenderMode(PDFNet.GState.TextRenderingMode.e_fill_stroke_text);
160
+ gs.setLineWidth(4);
161
+
162
+ // Set the fill color space to the Pattern color space.
163
+ gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
164
+ var patterColor = await PDFNet.PatternColor.create(await createTilingPattern(doc));
165
+ gs.setFillColorWithPattern(patterColor);
166
+
167
+ writer.writeElement(element);
168
+ writer.writeElement(await eb.createTextEnd()); // Finish the text block
169
+
170
+ writer.end(); // Save the page
171
+ doc.pagePushBack(page);
172
+ //-----------------------------------------------
173
+
174
+ /// The following sample illustrates how to create and use image tiling pattern
175
+ page = await doc.pageCreate();
176
+ writer.beginOnPage(page);
177
+
178
+ eb.reset();
179
+ element = await eb.createRect(0, 0, 612, 794);
180
+
181
+ // Set the fill color space to the Pattern color space.
182
+ gs = await element.getGState();
183
+ gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
184
+ patterColor = await PDFNet.PatternColor.create(await createImageTilingPattern(doc));
185
+ gs.setFillColorWithPattern(patterColor);
186
+ element.setPathFill(true);
187
+
188
+ writer.writeElement(element);
189
+
190
+ await writer.end(); // Save the page
191
+ doc.pagePushBack(page);
192
+ //-----------------------------------------------
193
+
194
+ /// The following sample illustrates how to create and use PDF shadings
195
+ page = await doc.pageCreate();
196
+ writer.beginOnPage(page);
197
+
198
+ eb.reset();
199
+ element = await eb.createRect(0, 0, 612, 794);
200
+
201
+ // Set the fill color space to the Pattern color space.
202
+ gs = await element.getGState();
203
+ gs.setFillColorSpace(await PDFNet.ColorSpace.createPattern());
204
+ patterColor = await PDFNet.PatternColor.create(await createAxialShading(doc));
205
+ gs.setFillColorWithPattern(patterColor);
206
+ element.setPathFill(true);
207
+
208
+ writer.writeElement(element);
209
+
210
+ await writer.end(); // Save the page
211
+ doc.pagePushBack(page);
212
+ //-----------------------------------------------
213
+
214
+ await doc.save('../TestFiles/Output/patterns.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
215
+ console.log('Done. Result saved in patterns.pdf...');
216
+ } catch (err) {
217
+ console.log(err);
218
+ }
219
+ }
220
+ PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
221
+ console.log('Error: ' + JSON.stringify(error));
222
+ }).then(function(){ return PDFNet.shutdown(); });
223
+ };
224
+ exports.runPatternTest();
225
+ })(exports);
226
+ // eslint-disable-next-line spaced-comment
227
227
  //# sourceURL=PatternTest.js
@@ -1,10 +1,10 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5
 
6
6
 
7
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
+ const { PDFNet } = require('../lib/pdfnet.js');
8
8
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
9
9
 
10
10
  ((exports) => {
@@ -1,12 +1,12 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5
 
6
6
  // This sample illustrates how to use basic SDF API (also known as Cos) to edit an
7
7
  // existing document.
8
8
 
9
- const { PDFNet } = require('@pdftron/pdfnet-node');
9
+ const { PDFNet } = require('../lib/pdfnet.js');
10
10
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
11
11
 
12
12
  ((exports) => {
@@ -21,8 +21,7 @@ const PDFTronLicense = require('../LicenseKey/LicenseKey');
21
21
  console.log('Opening the test file...');
22
22
  // Here we create a SDF/Cos document directly from PDF file. In case you have
23
23
  // PDFDoc you can always access SDF/Cos document using PDFDoc.GetSDFDoc() method.
24
- const docorig = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'fish.pdf');
25
- const doc = await docorig.getSDFDoc();
24
+ const doc = await PDFNet.SDFDoc.createFromFileUString(inputPath + 'fish.pdf');
26
25
  doc.initSecurityHandler();
27
26
  console.log('Modifying into dictionary, adding custom properties, embedding a stream...');
28
27
 
@@ -1,5 +1,5 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5
 
@@ -14,7 +14,7 @@
14
14
  // new content to existing PDF pages as shown in the ElementBuilder sample project.
15
15
  //---------------------------------------------------------------------------------------
16
16
 
17
- const { PDFNet } = require('@pdftron/pdfnet-node');
17
+ const { PDFNet } = require('../lib/pdfnet.js');
18
18
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
19
19
 
20
20
  ((exports) => {
@@ -1,10 +1,10 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5
 
6
6
 
7
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
+ const { PDFNet } = require('../lib/pdfnet.js');
8
8
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
9
9
 
10
10
  ((exports) => {
@@ -1,10 +1,10 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5
 
6
6
 
7
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
+ const { PDFNet } = require('../lib/pdfnet.js');
8
8
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
9
9
 
10
10
  ((exports) => {