@pdftron/pdfnet-node-samples 9.5.0 → 10.0.0-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 (142) hide show
  1. package/package.json +3 -3
  2. package/samples/AddImageTest/AddImageTest.js +1 -1
  3. package/samples/AdvancedImagingTest/AdvancedImagingTest.js +3 -3
  4. package/samples/AnnotationTest/AnnotationTest.js +1 -1
  5. package/samples/BookmarkTest/BookmarkTest.js +1 -1
  6. package/samples/CAD2PDFTest/CAD2PDFTest.js +3 -3
  7. package/samples/ContentReplacerTest/ContentReplacerTest.js +1 -1
  8. package/samples/ConvertTest/ConvertTest.js +1 -1
  9. package/samples/DataExtractionTest/DataExtractionTest.js +7 -7
  10. package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +1 -1
  11. package/samples/DocumentCreationTest/DocumentCreationTest.js +78 -0
  12. package/samples/ElementBuilderTest/ElementBuilderTest.js +1 -1
  13. package/samples/ElementEditTest/ElementEditTest.js +1 -1
  14. package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +1 -1
  15. package/samples/ElementReaderTest/ElementReaderTest.js +1 -1
  16. package/samples/EncTest/EncTest.js +1 -1
  17. package/samples/FDFTest/FDFTest.js +1 -1
  18. package/samples/HTML2PDFTest/HTML2PDFTest.js +2 -2
  19. package/samples/HighlightsTest/HighlightsTest.js +1 -1
  20. package/samples/ImageExtractTest/ImageExtractTest.js +1 -1
  21. package/samples/ImpositionTest/ImpositionTest.js +1 -1
  22. package/samples/InteractiveFormsTest/InteractiveFormsTest.js +1 -1
  23. package/samples/JBIG2Test/JBIG2Test.js +1 -1
  24. package/samples/LicenseKey/LicenseKey.js +1 -1
  25. package/samples/LogicalStructureTest/LogicalStructureTest.js +1 -1
  26. package/samples/OCRTest/OCRTest.js +2 -2
  27. package/samples/OfficeTemplateTest/OfficeTemplateTest.js +1 -1
  28. package/samples/OfficeToPDFTest/OfficeToPDFTest.js +1 -1
  29. package/samples/OptimizerTest/OptimizerTest.js +1 -1
  30. package/samples/PDF2HtmlTest/PDF2HtmlTest.js +3 -3
  31. package/samples/PDF2OfficeTest/PDF2OfficeTest.js +3 -3
  32. package/samples/PDFATest/PDFATest.js +1 -1
  33. package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +1 -1
  34. package/samples/PDFDrawTest/PDFDrawTest.js +1 -1
  35. package/samples/PDFLayersTest/PDFLayersTest.js +1 -1
  36. package/samples/PDFPackageTest/PDFPackageTest.js +1 -1
  37. package/samples/PDFPageTest/PDFPageTest.js +1 -1
  38. package/samples/PDFRedactTest/PDFRedactTest.js +1 -1
  39. package/samples/PageLabelsTest/PageLabelsTest.js +1 -1
  40. package/samples/PatternTest/PatternTest.js +1 -1
  41. package/samples/RectTest/RectTest.js +1 -1
  42. package/samples/SDFTest/SDFTest.js +1 -1
  43. package/samples/StamperTest/StamperTest.js +1 -1
  44. package/samples/TextExtractTest/TextExtractTest.js +1 -1
  45. package/samples/TextSearchTest/TextSearchTest.js +1 -1
  46. package/samples/U3DTest/U3DTest.js +1 -1
  47. package/samples/UndoRedoTest/UndoRedoTest.js +1 -1
  48. package/samples/UnicodeWriteTest/UnicodeWriteTest.js +1 -1
  49. package/samples/WebViewerConvertTest/WebViewerConvertTest.js +1 -1
  50. package/samples/AddImageTest/NODEJS/AddImageTest.js +0 -116
  51. package/samples/AddImageTest/NODEJS/RunTest.sh +0 -2
  52. package/samples/AdvancedImagingTest/NODEJS/AdvancedImagingTest.js +0 -78
  53. package/samples/AdvancedImagingTest/NODEJS/RunTest.sh +0 -2
  54. package/samples/AnnotationTest/NODEJS/AnnotationTest.js +0 -642
  55. package/samples/AnnotationTest/NODEJS/RunTest.sh +0 -2
  56. package/samples/BookmarkTest/NODEJS/BookmarkTest.js +0 -220
  57. package/samples/BookmarkTest/NODEJS/RunTest.sh +0 -2
  58. package/samples/CAD2PDFTest/NODEJS/CAD2PDFTest.js +0 -80
  59. package/samples/CAD2PDFTest/NODEJS/RunTest.sh +0 -2
  60. package/samples/ContentReplacerTest/NODEJS/ContentReplacerTest.js +0 -75
  61. package/samples/ContentReplacerTest/NODEJS/RunTest.sh +0 -2
  62. package/samples/ConvertTest/NODEJS/ConvertTest.js +0 -270
  63. package/samples/ConvertTest/NODEJS/RunTest.sh +0 -2
  64. package/samples/DataExtractionTest/NODEJS/DataExtractionTest.js +0 -180
  65. package/samples/DataExtractionTest/NODEJS/RunTest.sh +0 -2
  66. package/samples/DigitalSignaturesTest/NODEJS/DigitalSignaturesTest.js +0 -527
  67. package/samples/DigitalSignaturesTest/NODEJS/RunTest.sh +0 -2
  68. package/samples/ElementBuilderTest/NODEJS/ElementBuilderTest.js +0 -514
  69. package/samples/ElementBuilderTest/NODEJS/RunTest.sh +0 -2
  70. package/samples/ElementEditTest/NODEJS/ElementEditTest.js +0 -111
  71. package/samples/ElementEditTest/NODEJS/RunTest.sh +0 -2
  72. package/samples/ElementReaderAdvTest/NODEJS/ElementReaderAdvTest.js +0 -305
  73. package/samples/ElementReaderAdvTest/NODEJS/RunTest.sh +0 -2
  74. package/samples/ElementReaderTest/NODEJS/ElementReaderTest.js +0 -77
  75. package/samples/ElementReaderTest/NODEJS/RunTest.sh +0 -2
  76. package/samples/EncTest/NODEJS/EncTest.js +0 -176
  77. package/samples/EncTest/NODEJS/RunTest.sh +0 -2
  78. package/samples/FDFTest/NODEJS/FDFTest.js +0 -219
  79. package/samples/FDFTest/NODEJS/RunTest.sh +0 -2
  80. package/samples/HTML2PDFTest/NODEJS/HTML2PDFTest.js +0 -166
  81. package/samples/HTML2PDFTest/NODEJS/RunTest.sh +0 -2
  82. package/samples/HighlightsTest/NODEJS/HighlightsTest.js +0 -97
  83. package/samples/HighlightsTest/NODEJS/RunTest.sh +0 -2
  84. package/samples/ImageExtractTest/NODEJS/ImageExtractTest.js +0 -130
  85. package/samples/ImageExtractTest/NODEJS/RunTest.sh +0 -2
  86. package/samples/ImpositionTest/NODEJS/ImpositionTest.js +0 -87
  87. package/samples/ImpositionTest/NODEJS/RunTest.sh +0 -2
  88. package/samples/InteractiveFormsTest/NODEJS/InteractiveFormsTest.js +0 -382
  89. package/samples/InteractiveFormsTest/NODEJS/RunTest.sh +0 -2
  90. package/samples/JBIG2Test/NODEJS/JBIG2Test.js +0 -89
  91. package/samples/JBIG2Test/NODEJS/RunTest.sh +0 -2
  92. package/samples/LicenseKey/NODEJS/LicenseKey.js +0 -11
  93. package/samples/LogicalStructureTest/NODEJS/LogicalStructureTest.js +0 -251
  94. package/samples/LogicalStructureTest/NODEJS/RunTest.sh +0 -2
  95. package/samples/OCRTest/NODEJS/OCRTest.js +0 -235
  96. package/samples/OCRTest/NODEJS/RunTest.sh +0 -2
  97. package/samples/OfficeTemplateTest/NODEJS/OfficeTemplateTest.js +0 -79
  98. package/samples/OfficeTemplateTest/NODEJS/RunTest.sh +0 -2
  99. package/samples/OfficeToPDFTest/NODEJS/OfficeToPDFTest.js +0 -125
  100. package/samples/OfficeToPDFTest/NODEJS/RunTest.sh +0 -2
  101. package/samples/OptimizerTest/NODEJS/OptimizerTest.js +0 -192
  102. package/samples/OptimizerTest/NODEJS/RunTest.sh +0 -2
  103. package/samples/PDF2HtmlTest/NODEJS/PDF2HtmlTest.js +0 -123
  104. package/samples/PDF2HtmlTest/NODEJS/RunTest.sh +0 -2
  105. package/samples/PDF2OfficeTest/NODEJS/PDF2OfficeTest.js +0 -158
  106. package/samples/PDF2OfficeTest/NODEJS/RunTest.sh +0 -2
  107. package/samples/PDFATest/NODEJS/PDFATest.js +0 -85
  108. package/samples/PDFATest/NODEJS/RunTest.sh +0 -2
  109. package/samples/PDFDocMemoryTest/NODEJS/PDFDocMemoryTest.js +0 -85
  110. package/samples/PDFDocMemoryTest/NODEJS/RunTest.sh +0 -2
  111. package/samples/PDFDrawTest/NODEJS/PDFDrawTest.js +0 -306
  112. package/samples/PDFDrawTest/NODEJS/RunTest.sh +0 -2
  113. package/samples/PDFLayersTest/NODEJS/PDFLayersTest.js +0 -295
  114. package/samples/PDFLayersTest/NODEJS/RunTest.sh +0 -2
  115. package/samples/PDFPackageTest/NODEJS/PDFPackageTest.js +0 -112
  116. package/samples/PDFPackageTest/NODEJS/RunTest.sh +0 -2
  117. package/samples/PDFPageTest/NODEJS/PDFPageTest.js +0 -190
  118. package/samples/PDFPageTest/NODEJS/RunTest.sh +0 -2
  119. package/samples/PDFRedactTest/NODEJS/PDFRedactTest.js +0 -75
  120. package/samples/PDFRedactTest/NODEJS/RunTest.sh +0 -2
  121. package/samples/PageLabelsTest/NODEJS/PageLabelsTest.js +0 -139
  122. package/samples/PageLabelsTest/NODEJS/RunTest.sh +0 -2
  123. package/samples/PatternTest/NODEJS/PatternTest.js +0 -227
  124. package/samples/PatternTest/NODEJS/RunTest.sh +0 -2
  125. package/samples/RectTest/NODEJS/RectTest.js +0 -41
  126. package/samples/RectTest/NODEJS/RunTest.sh +0 -2
  127. package/samples/SDFTest/NODEJS/RunTest.sh +0 -2
  128. package/samples/SDFTest/NODEJS/SDFTest.js +0 -88
  129. package/samples/StamperTest/NODEJS/RunTest.sh +0 -2
  130. package/samples/StamperTest/NODEJS/StamperTest.js +0 -256
  131. package/samples/TextExtractTest/NODEJS/RunTest.sh +0 -2
  132. package/samples/TextExtractTest/NODEJS/TextExtractTest.js +0 -287
  133. package/samples/TextSearchTest/NODEJS/RunTest.sh +0 -2
  134. package/samples/TextSearchTest/NODEJS/TextSearchTest.js +0 -122
  135. package/samples/U3DTest/NODEJS/RunTest.sh +0 -2
  136. package/samples/U3DTest/NODEJS/U3DTest.js +0 -105
  137. package/samples/UndoRedoTest/NODEJS/RunTest.sh +0 -2
  138. package/samples/UndoRedoTest/NODEJS/UndoRedoTest.js +0 -101
  139. package/samples/UnicodeWriteTest/NODEJS/RunTest.sh +0 -2
  140. package/samples/UnicodeWriteTest/NODEJS/UnicodeWriteTest.js +0 -174
  141. package/samples/WebViewerConvertTest/NODEJS/RunTest.sh +0 -2
  142. package/samples/WebViewerConvertTest/NODEJS/WebViewerConvertTest.js +0 -136
@@ -1,256 +0,0 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
3
- // Consult legal.txt regarding legal and license information.
4
- //---------------------------------------------------------------------------------------
5
-
6
- //---------------------------------------------------------------------------------------
7
- // The following sample shows how to add new content (or watermark) PDF pages
8
- // using 'pdftron.PDF.Stamper' utility class.
9
- //
10
- // Stamper can be used to PDF pages with text, images, or with other PDF content
11
- // in only a few lines of code. Although Stamper is very simple to use compared
12
- // to ElementBuilder/ElementWriter it is not as powerful or flexible. In case you
13
- // need full control over PDF creation use ElementBuilder/ElementWriter to add
14
- // new content to existing PDF pages as shown in the ElementBuilder sample project.
15
- //---------------------------------------------------------------------------------------
16
-
17
- const { PDFNet } = require('../../../lib/pdfnet.js');
18
- const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
19
-
20
- ((exports) => {
21
-
22
- exports.runStamperTest = () => {
23
-
24
- const main = async () => {
25
- // Relative path to the folder containing test files.
26
- const inputPath = '../../TestFiles/';
27
- const outputPath = inputPath + 'Output/';
28
-
29
- //--------------------------------------------------------------------------------
30
- // Example 1) Add text stamp to all pages, then remove text stamp from odd pages.
31
- try {
32
- // start stack-based deallocation with startDeallocateStack. Later on when endDeallocateStack is called,
33
- // all objects in memory that were initialized since the most recent startDeallocateStack call will be
34
- // cleaned up. Doing this makes sure that memory growth does not get too high.
35
- await PDFNet.startDeallocateStack();
36
-
37
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
38
- doc.initSecurityHandler();
39
-
40
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.5, 0.5); // Stamp size is relative to the size of the crop box of the destination page
41
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_center, PDFNet.Stamper.VerticalAlignment.e_vertical_center);
42
-
43
- const redColorPt = await PDFNet.ColorPt.init(1, 0, 0);
44
- stamper.setFontColor(redColorPt);
45
- const pgSet = await PDFNet.PageSet.createRange(1, (await doc.getPageCount()));
46
- stamper.stampText(doc, 'If you are reading this\nthis is an even page', pgSet);
47
- const oddPgSet = await PDFNet.PageSet.createFilteredRange(1, (await doc.getPageCount()), PDFNet.PageSet.Filter.e_odd);
48
- // delete all text stamps in odd pages
49
- PDFNet.Stamper.deleteStamps(doc, oddPgSet);
50
-
51
- await doc.save(outputPath + 'newsletter.ex1.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
52
-
53
- await PDFNet.endDeallocateStack();
54
- } catch (err) {
55
- console.log(err.stack);
56
- }
57
-
58
- //--------------------------------------------------------------------------------
59
- // Example 2) Add Image stamp to first 2 pages.
60
- try {
61
- await PDFNet.startDeallocateStack();
62
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
63
- doc.initSecurityHandler();
64
-
65
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.5, 0.5);
66
- const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
67
- stamper.setSize(PDFNet.Stamper.SizeType.e_relative_scale, 0.5, 0.5);
68
- // set position of the image to the center, left of PDF pages
69
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_left, PDFNet.Stamper.VerticalAlignment.e_vertical_center);
70
-
71
- const blackColorPt = await PDFNet.ColorPt.init(0, 0, 0, 0);
72
- stamper.setFontColor(blackColorPt);
73
- stamper.setRotation(180);
74
- stamper.setAsBackground(false);
75
- // only stamp first 2 pages
76
- const pgSet = await PDFNet.PageSet.createRange(1, 2);
77
- stamper.stampImage(doc, img, pgSet);
78
-
79
- await doc.save(outputPath + 'newsletter.ex2.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
80
- await PDFNet.endDeallocateStack();
81
- } catch (err) {
82
- console.log(err.stack);
83
- }
84
-
85
- //--------------------------------------------------------------------------------
86
- // Example 3) Add Page stamp to all pages.
87
- try {
88
- await PDFNet.startDeallocateStack();
89
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
90
- doc.initSecurityHandler();
91
- const fishDoc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'fish.pdf');
92
- fishDoc.initSecurityHandler();
93
-
94
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.5, 0.5);
95
- const srcPage = await fishDoc.getPage(1);
96
- const pageOneCrop = await srcPage.getCropBox();
97
- // set size of the image to 10% of the original while keep the old aspect ratio
98
- stamper.setSize(PDFNet.Stamper.SizeType.e_absolute_size, (await pageOneCrop.width()) * 0.1, -1);
99
- stamper.setOpacity(0.4);
100
- stamper.setRotation(-67);
101
-
102
- // put the image at the bottom right hand corner
103
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_right, PDFNet.Stamper.VerticalAlignment.e_vertical_bottom);
104
- const pgSet = await PDFNet.PageSet.createRange(1, (await doc.getPageCount()));
105
- stamper.stampPage(doc, srcPage, pgSet);
106
-
107
- await doc.save(outputPath + 'newsletter.ex3.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
108
- await PDFNet.endDeallocateStack();
109
- } catch (err) {
110
- console.log(err.stack);
111
- }
112
-
113
- //--------------------------------------------------------------------------------
114
- // Example 4) Add Image stamp to first 20 odd pages.
115
- try {
116
- await PDFNet.startDeallocateStack();
117
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
118
- doc.initSecurityHandler();
119
-
120
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_absolute_size, 20, 20);
121
- stamper.setOpacity(1);
122
- stamper.setRotation(45);
123
- stamper.setAsBackground(true);
124
- stamper.setPosition(30, 40);
125
- const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
126
-
127
- const pgSet = await PDFNet.PageSet.createFilteredRange(1, 20, PDFNet.PageSet.Filter.e_odd);
128
- stamper.stampImage(doc, img, pgSet);
129
-
130
- await doc.save(outputPath + 'newsletter.ex4.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
131
- await PDFNet.endDeallocateStack();
132
- } catch (err) {
133
- console.log(err.stack);
134
- }
135
-
136
- //--------------------------------------------------------------------------------
137
- // Example 5) Add text stamp to first 20 even pages
138
- try {
139
- await PDFNet.startDeallocateStack();
140
-
141
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
142
- doc.initSecurityHandler();
143
-
144
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.05, 0.05);
145
- stamper.setPosition(0, 0);
146
- stamper.setOpacity(0.7);
147
- stamper.setRotation(90);
148
- stamper.setSize(PDFNet.Stamper.SizeType.e_font_size, 80, -1);
149
- stamper.setTextAlignment(PDFNet.Stamper.TextAlignment.e_align_center);
150
- const pgSet = await PDFNet.PageSet.createFilteredRange(1, 20, PDFNet.PageSet.Filter.e_even);
151
- stamper.stampText(doc, 'Goodbye\nMoon', pgSet);
152
-
153
- await doc.save(outputPath + 'newsletter.ex5.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
154
-
155
- await PDFNet.endDeallocateStack();
156
- } catch (err) {
157
- console.log(err.stack);
158
- }
159
-
160
- //--------------------------------------------------------------------------------
161
- // Example 6) Add first page as stamp to all even pages
162
- try {
163
- await PDFNet.startDeallocateStack();
164
-
165
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
166
- doc.initSecurityHandler();
167
-
168
- const fishDoc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'fish.pdf');
169
- fishDoc.initSecurityHandler();
170
-
171
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.3, 0.3);
172
- stamper.setOpacity(1);
173
- stamper.setRotation(270);
174
- stamper.setAsBackground(true);
175
- stamper.setPosition(0.5, 0.5, true);
176
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_left, PDFNet.Stamper.VerticalAlignment.e_vertical_bottom);
177
- const pgOne = await fishDoc.getPage(1);
178
- const pgSet = await PDFNet.PageSet.createFilteredRange(1, await doc.getPageCount(), PDFNet.PageSet.Filter.e_even);
179
- stamper.stampPage(doc, pgOne, pgSet);
180
-
181
- await doc.save(outputPath + 'newsletter.ex6.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
182
-
183
- await PDFNet.endDeallocateStack();
184
- } catch (err) {
185
- console.log(err.stack);
186
- }
187
-
188
- //--------------------------------------------------------------------------------
189
- // Example 7) Add image stamp at top right corner in every pages
190
- try {
191
- await PDFNet.startDeallocateStack();
192
-
193
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
194
- doc.initSecurityHandler();
195
-
196
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.1, 0.1);
197
- stamper.setOpacity(0.8);
198
- stamper.setRotation(135);
199
- stamper.setAsBackground(false);
200
- stamper.showsOnPrint(false);
201
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_left, PDFNet.Stamper.VerticalAlignment.e_vertical_top);
202
- stamper.setPosition(10, 10);
203
-
204
- const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
205
- const pgSet = await PDFNet.PageSet.createFilteredRange(1, (await doc.getPageCount()), PDFNet.PageSet.Filter.e_all);
206
- stamper.stampImage(doc, img, pgSet);
207
-
208
- await doc.save(outputPath + 'newsletter.ex7.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
209
-
210
- await PDFNet.endDeallocateStack();
211
- } catch (err) {
212
- console.log(err.stack);
213
- }
214
-
215
- //--------------------------------------------------------------------------------
216
- // Example 8) Add Text stamp to first 2 pages, and image stamp to first page.
217
- // Because text stamp is set as background, the image is top of the text
218
- // stamp. Text stamp on the first page is not visible.
219
- try {
220
- await PDFNet.startDeallocateStack();
221
-
222
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
223
- doc.initSecurityHandler();
224
-
225
- const stamper = await PDFNet.Stamper.create(PDFNet.Stamper.SizeType.e_relative_scale, 0.07, -0.1);
226
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_right, PDFNet.Stamper.VerticalAlignment.e_vertical_bottom);
227
- stamper.setAlignment(PDFNet.Stamper.HorizontalAlignment.e_horizontal_center, PDFNet.Stamper.VerticalAlignment.e_vertical_top);
228
- const font = await PDFNet.Font.create(doc, PDFNet.Font.StandardType1Font.e_courier);
229
- stamper.setFont(font);
230
- const redColorPt = await PDFNet.ColorPt.init(1, 0, 0, 0);
231
- stamper.setFontColor(redColorPt);
232
- stamper.setTextAlignment(PDFNet.Stamper.TextAlignment.e_align_right);
233
- stamper.setAsBackground(true);
234
-
235
- const pgSet = await PDFNet.PageSet.createRange(1, 2);
236
- stamper.stampText(doc, 'This is a title!', pgSet);
237
-
238
- const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
239
- stamper.setAsBackground(false);
240
-
241
- const pgSetImage = await PDFNet.PageSet.createRange(1, 1);
242
- stamper.stampImage(doc, img, pgSetImage);
243
-
244
- await doc.save(outputPath + 'newsletter.ex8.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
245
-
246
- await PDFNet.endDeallocateStack();
247
- } catch (err) {
248
- console.log(err.stack);
249
- }
250
- };
251
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
252
- };
253
- exports.runStamperTest();
254
- })(exports);
255
- // eslint-disable-next-line spaced-comment
256
- //# sourceURL=StamperTest.js
@@ -1,2 +0,0 @@
1
- #!/bin/sh
2
- node TextExtractTest.js
@@ -1,287 +0,0 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
3
- // Consult legal.txt regarding legal and license information.
4
- //---------------------------------------------------------------------------------------
5
-
6
-
7
- const { PDFNet } = require('../../../lib/pdfnet.js');
8
- const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
9
-
10
- ((exports) => {
11
-
12
- exports.runTextExtractTest = async () => {
13
- // A utility method used to dump all text content in the console window.
14
- const dumpAllText = async (reader) => {
15
- let element;
16
- let bbox;
17
- let arr;
18
- while ((element = await reader.next()) !== null) {
19
- switch (await element.getType()) {
20
- case PDFNet.Element.Type.e_text_begin:
21
- console.log('\n--> Text Block Begin');
22
- break;
23
- case PDFNet.Element.Type.e_text_end:
24
- console.log('\n--> Text Block End');
25
- break;
26
- case PDFNet.Element.Type.e_text:
27
- bbox = await element.getBBox();
28
- console.log('\n--> BBox: ' + bbox.x1.toFixed(2) + ', ' + bbox.y1.toFixed(2) + ', ' + bbox.x2.toFixed(2) + ', ' + bbox.y2.toFixed(2) + '\n');
29
- arr = await element.getTextString();
30
- console.log(arr);
31
- break;
32
- case PDFNet.Element.Type.e_text_new_line:
33
- console.log('\n--> New Line');
34
- break;
35
- case PDFNet.Element.Type.e_form:
36
- reader.formBegin();
37
- await dumpAllText(reader);
38
- reader.end();
39
- break;
40
- }
41
- }
42
- };
43
-
44
- // helper method for ReadTextFromRect
45
- const rectTextSearch = async (reader, pos, srchStr) => {
46
- let element;
47
- let arr;
48
- while ((element = await reader.next()) !== null) {
49
- let bbox;
50
- switch (await element.getType()) {
51
- case PDFNet.Element.Type.e_text:
52
- bbox = await element.getBBox();
53
- if (await bbox.intersectRect(bbox, pos)) {
54
- arr = await element.getTextString();
55
- srchStr += arr + '\n';
56
- }
57
- break;
58
- case PDFNet.Element.Type.e_text_new_line:
59
- break;
60
- case PDFNet.Element.Type.e_form:
61
- reader.formBegin();
62
- srchStr += await rectTextSearch(reader, pos, srchStr); // possibly need srchStr = ...
63
- reader.end();
64
- break;
65
- }
66
- }
67
- return srchStr;
68
- };
69
-
70
- const readTextFromRect = async (page, pos, reader) => {
71
- let srchStr = '';
72
- reader.beginOnPage(page); // uses default parameters.
73
- srchStr += await rectTextSearch(reader, pos, srchStr);
74
- reader.end();
75
- return srchStr;
76
- };
77
-
78
- const twoDigitHex = function (num) {
79
- const hexStr = num.toString(16).toUpperCase();
80
- return ('0' + hexStr).substr(-2);
81
- }
82
-
83
- const printStyle = async (s) => {
84
- const rgb = await s.getColor();
85
- const rColorVal = await rgb.get(0);
86
- const gColorVal = await rgb.get(1);
87
- const bColorVal = await rgb.get(2);
88
- const rgbHex = twoDigitHex(rColorVal) + twoDigitHex(gColorVal) + twoDigitHex(bColorVal)
89
- const fontName = await s.getFontName();
90
- const fontSize = await s.getFontSize();
91
- const serifOutput = ((await s.isSerif()) ? ' sans-serif; ' : ' ');
92
- const returnString = ' style="font-family:' + fontName + '; font-size:' + fontSize + ';' + serifOutput + 'color:#' + rgbHex + ';"';
93
- return returnString;
94
- };
95
-
96
- const main = async () => {
97
- // eslint-disable-next-line no-unused-vars
98
- let ret = 0;
99
-
100
- // Relative path to the folder containing test files.
101
- const inputPath = '../../TestFiles/';
102
- const inputFilename = 'newsletter.pdf'; // addimage.pdf, newsletter.pdf
103
-
104
- const example1Basic = false;
105
- const example2XML = false;
106
- const example3Wordlist = false;
107
- const example4Advanced = true;
108
- const example5LowLevel = false;
109
-
110
- try {
111
- await PDFNet.startDeallocateStack();
112
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename);
113
- doc.initSecurityHandler();
114
-
115
- const page = await doc.getPage(1);
116
-
117
- if (page.id === '0') {
118
- console.log('Page not found.');
119
- return 1;
120
- }
121
-
122
- const txt = await PDFNet.TextExtractor.create();
123
- txt.begin(page);
124
-
125
- let text;
126
- let line;
127
- let word;
128
-
129
- // Example 1. Get all text on the page in a single string.
130
- // Words will be separated with space or new line characters.
131
- if (example1Basic) {
132
- const wordCount = await txt.getWordCount();
133
- console.log('Word Count: ' + wordCount);
134
- text = await txt.getAsText();
135
- console.log('\n\n- GetAsText --------------------------');
136
- console.log(text);
137
- console.log('-----------------------------------------------------------');
138
- }
139
-
140
- // Example 2. Get XML logical structure for the page.
141
- if (example2XML) {
142
- text = await txt.getAsXML(PDFNet.TextExtractor.XMLOutputFlags.e_words_as_elements | PDFNet.TextExtractor.XMLOutputFlags.e_output_bbox | PDFNet.TextExtractor.XMLOutputFlags.e_output_style_info);
143
- console.log('\n\n- GetAsXML --------------------------\n' + text);
144
- console.log('-----------------------------------------------------------');
145
- }
146
-
147
- // Example 3. Extract words one by one.
148
- if (example3Wordlist) {
149
- line = await txt.getFirstLine();
150
- for (; (await line.isValid()); line = (await line.getNextLine())) {
151
- for (word = await line.getFirstWord(); await word.isValid(); word = await word.getNextWord()) {
152
- text = await word.getString();
153
- console.log(text);
154
- }
155
- }
156
- console.log('-----------------------------------------------------------');
157
- }
158
-
159
- // Example 4. A more advanced text extraction example.
160
- // The output is XML structure containing paragraphs, lines, words,
161
- // as well as style and positioning information.
162
- if (example4Advanced) {
163
- let b;
164
- let q;
165
- let curFlowID = -1;
166
- let curParaID = -1;
167
-
168
- console.log('<PDFText>');
169
-
170
- // For each line on the page...
171
- for (line = await txt.getFirstLine(); await line.isValid(); line = await line.getNextLine()) {
172
- if ((await line.getNumWords()) === 0) {
173
- continue;
174
- }
175
- if (curFlowID !== await line.getFlowID()) {
176
- if (curFlowID !== -1) {
177
- if (curParaID !== -1) {
178
- curParaID = -1;
179
- console.log('</Para>');
180
- }
181
- console.log('</Flow>');
182
- }
183
- curFlowID = await line.getFlowID();
184
- console.log('<Flow id="' + curFlowID + '">');
185
- }
186
- if (curParaID !== await line.getParagraphID()) {
187
- if (curParaID !== -1) {
188
- console.log('</Para>');
189
- }
190
- curParaID = await line.getParagraphID();
191
- console.log('<Para id="' + curParaID + '">');
192
- }
193
- b = await line.getBBox();
194
- const lineStyle = await line.getStyle();
195
- let outputStringLineBox = '<Line box="' + b.x1.toFixed(2) + ', ' + b.y1.toFixed(2) + ', ' + b.x2.toFixed(2) + ', ' + b.y2.toFixed(2) + '"';
196
- outputStringLineBox += (await printStyle(lineStyle));
197
- const currentLineNum = await line.getCurrentNum();
198
- outputStringLineBox += ' cur_num="' + currentLineNum + '">';
199
- console.log(outputStringLineBox);
200
-
201
- // For each word in the line...
202
- for (word = await line.getFirstWord(); await word.isValid(); word = await word.getNextWord()) {
203
- // output bounding box for the word
204
- q = await word.getBBox();
205
- const currentNum = await word.getCurrentNum();
206
- let outputStringWord = '<Word box="' + q.x1.toFixed(2) + ', ' + q.y1.toFixed(2) + ', ' + q.x2.toFixed(2) + ', ' + q.y2.toFixed(2) + '" cur_num="' + currentNum + '"';
207
- const sz = await word.getStringLen();
208
- if (sz === 0) {
209
- continue;
210
- }
211
- // if the word style is different from the parent style, output the new style
212
- const sty = await word.getStyle();
213
- if (!(await sty.compare(lineStyle))) {
214
- outputStringWord += await printStyle(sty);
215
- }
216
- outputStringWord += '>' + (await word.getString()) + '</Word>';
217
- console.log(outputStringWord);
218
- }
219
- console.log('</Line>');
220
- }
221
- if (curFlowID !== -1) {
222
- if (curParaID !== -1) {
223
- curParaID = -1;
224
- console.log('</Para>');
225
- }
226
- console.log('</Flow>');
227
- }
228
- console.log('</PDFText>');
229
- }
230
- await PDFNet.endDeallocateStack();
231
- } catch (err) {
232
- console.log(err);
233
- console.log(err.stack);
234
- ret = 1;
235
- }
236
-
237
-
238
- if (example5LowLevel) {
239
- ret = 0;
240
- try {
241
- await PDFNet.startDeallocateStack();
242
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename);
243
- doc.initSecurityHandler();
244
-
245
- // Example 1. Extract all text content from the document
246
- const reader = await PDFNet.ElementReader.create();
247
- const itr = await doc.getPageIterator(1);
248
-
249
- // Read every page
250
- for (itr; await itr.hasNext(); itr.next()) {
251
- const page = await itr.current();
252
- reader.beginOnPage(page);
253
- await dumpAllText(reader);
254
- reader.end();
255
- }
256
- // Example 2. Extract text content based on the
257
- // selection rectangle.
258
- console.log('\n----------------------------------------------------');
259
- console.log('Extract text based on the selection rectangle.');
260
- console.log('----------------------------------------------------');
261
-
262
-
263
- const firstPage = await (await doc.getPageIterator()).current();
264
- let s1 = await readTextFromRect(firstPage, (await PDFNet.Rect.init(27, 392, 563, 534)), reader);
265
- console.log('\nField 1: ' + s1);
266
-
267
- s1 = await readTextFromRect(firstPage, (await PDFNet.Rect.init(28, 551, 106, 623)), reader);
268
- console.log('Field 2: ' + s1);
269
-
270
- s1 = await readTextFromRect(firstPage, (await PDFNet.Rect.init(208, 550, 387, 621)), reader);
271
- console.log('Field 3: ' + s1);
272
-
273
- // ...
274
- console.log('Done');
275
- await PDFNet.endDeallocateStack();
276
- } catch (err) {
277
- console.log(err.stack);
278
- ret = 1;
279
- }
280
- }
281
- };
282
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
283
- };
284
- exports.runTextExtractTest();
285
- })(exports);
286
- // eslint-disable-next-line spaced-comment
287
- //# sourceURL=TextExtractTest.js
@@ -1,2 +0,0 @@
1
- #!/bin/sh
2
- node TextSearchTest.js
@@ -1,122 +0,0 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
3
- // Consult legal.txt regarding legal and license information.
4
- //---------------------------------------------------------------------------------------
5
-
6
-
7
- const { PDFNet } = require('../../../lib/pdfnet.js');
8
- const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
9
-
10
- ((exports) => {
11
-
12
- exports.runTextSearchTest = () => {
13
-
14
- const main = async() => {
15
- // Relative path to the folder containing test files.
16
- const inputURL = '../../TestFiles/';
17
- const inputFilename = 'credit card numbers.pdf'; // addimage.pdf, newsletter.pdf
18
-
19
- try {
20
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputURL + inputFilename);
21
- doc.initSecurityHandler();
22
-
23
- const txtSearch = await PDFNet.TextSearch.create();
24
- let mode = PDFNet.TextSearch.Mode.e_whole_word + PDFNet.TextSearch.Mode.e_page_stop; // Uses both whole word and page stop
25
- let pattern = 'joHn sMiTh';
26
-
27
- txtSearch.begin(doc, pattern, mode); // searches for the "pattern" in the document while following the inputted modes.
28
-
29
- let step = 0;
30
-
31
- // call Run() iteratively to find all matching instances of the word 'joHn sMiTh'
32
- /* eslint-disable-next-line no-constant-condition */
33
- while (true) {
34
- const result = await txtSearch.run();
35
- let hlts;
36
- if (result.code === PDFNet.TextSearch.ResultCode.e_found) {
37
- if (step === 0) { // Step 0: found "John Smith"
38
- // note that, here, 'ambient_str' and 'highlights' are not written to,
39
- // as 'e_ambient_string' and 'e_highlight' are not set.
40
- console.log(result.out_str + "'s credit card number is: ");
41
-
42
- // now switch to using regular expressions to find John's credit card number
43
- mode = await txtSearch.getMode();
44
- mode += PDFNet.TextSearch.Mode.e_reg_expression + PDFNet.TextSearch.Mode.e_highlight;
45
- txtSearch.setMode(mode);
46
- pattern = '\\d{4}-\\d{4}-\\d{4}-\\d{4}'; // or "(\\d{4}-){3}\\d{4}"
47
- txtSearch.setPattern(pattern);
48
-
49
- ++step;
50
- } else if (step === 1) {
51
- // step 1: found John's credit card number
52
- console.log(' ' + result.out_str);
53
- // note that, here, 'hlts' is written to, as 'e_highlight' has been set.
54
- // output the highlight info of the credit card number.
55
- hlts = result.highlights;
56
- hlts.begin(doc);
57
- while ((await hlts.hasNext())) {
58
- const highlightPageNum = await hlts.getCurrentPageNumber();
59
- console.log('The current highlight is from page: ' + highlightPageNum);
60
- await hlts.next();
61
- }
62
- // see if there is an AMEX card number
63
- pattern = '\\d{4}-\\d{6}-\\d{5}';
64
- txtSearch.setPattern(pattern);
65
-
66
- ++step;
67
- } else if (step === 2) {
68
- // found an AMEX card number
69
- console.log('\nThere is an AMEX card number:\n ' + result.out_str);
70
-
71
- // change mode to find the owner of the credit card; supposedly, the owner's
72
- // name proceeds the number
73
- mode = await txtSearch.getMode();
74
- mode += PDFNet.TextSearch.Mode.e_search_up;
75
- txtSearch.setMode(mode);
76
- pattern = '[A-z]++ [A-z]++';
77
- txtSearch.setPattern(pattern);
78
-
79
- ++step;
80
- } else if (step === 3) {
81
- // found the owner's name of the AMEX card
82
- console.log("Is the owner's name:\n " + result.out_str + '?');
83
-
84
- // add a link annotation based on the location of the found instance
85
- hlts = result.highlights;
86
- await hlts.begin(doc); // is await needed?
87
- while ((await hlts.hasNext())) {
88
- const curPage = await doc.getPage((await hlts.getCurrentPageNumber()));
89
- const quadArr = await hlts.getCurrentQuads();
90
- for (let i = 0; i < quadArr.length; ++i) {
91
- const currQuad = quadArr[i];
92
- const x1 = Math.min(Math.min(Math.min(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
93
- const x2 = Math.max(Math.max(Math.max(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
94
- const y1 = Math.min(Math.min(Math.min(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
95
- const y2 = Math.max(Math.max(Math.max(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
96
-
97
- const hyperLink = await PDFNet.LinkAnnot.create(doc, (await PDFNet.Rect.init(x1, y1, x2, y2)));
98
- await hyperLink.setAction((await PDFNet.Action.createURI(doc, 'http://www.pdftron.com')));
99
- await curPage.annotPushBack(hyperLink);
100
- }
101
- hlts.next();
102
- }
103
- await doc.save('../../TestFiles/Output/credit card numbers_linked.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
104
- break;
105
- }
106
- } else if (result.code === PDFNet.TextSearch.ResultCode.e_page) {
107
- // you can update your UI here, if needed
108
- console.log('page end');
109
- } else if (result.code === PDFNet.TextSearch.ResultCode.e_done) {
110
- break;
111
- }
112
- }
113
- } catch (err) {
114
- console.log(err);
115
- }
116
- };
117
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
118
- };
119
- exports.runTextSearchTest();
120
- })(exports);
121
- // eslint-disable-next-line spaced-comment
122
- //# sourceURL=TextSearchTest.js
@@ -1,2 +0,0 @@
1
- #!/bin/sh
2
- node U3DTest.js