@pdftron/pdfnet-node-samples 9.2.0 → 9.4.0

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 (140) hide show
  1. package/package.json +2 -2
  2. package/samples/AddImageTest/AddImageTest.js +115 -115
  3. package/samples/AdvancedImagingTest/AdvancedImagingTest.js +78 -64
  4. package/samples/AnnotationTest/AnnotationTest.js +641 -641
  5. package/samples/BookmarkTest/BookmarkTest.js +219 -219
  6. package/samples/CAD2PDFTest/CAD2PDFTest.js +4 -4
  7. package/samples/ContentReplacerTest/ContentReplacerTest.js +75 -75
  8. package/samples/ConvertTest/ConvertTest.js +5 -5
  9. package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +1 -1
  10. package/samples/ElementBuilderTest/ElementBuilderTest.js +513 -513
  11. package/samples/ElementEditTest/ElementEditTest.js +110 -110
  12. package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +305 -305
  13. package/samples/ElementReaderTest/ElementReaderTest.js +77 -77
  14. package/samples/EncTest/EncTest.js +175 -175
  15. package/samples/FDFTest/FDFTest.js +1 -1
  16. package/samples/HTML2PDFTest/HTML2PDFTest.js +53 -43
  17. package/samples/HighlightsTest/HighlightsTest.js +97 -0
  18. package/samples/ImageExtractTest/ImageExtractTest.js +1 -1
  19. package/samples/ImpositionTest/ImpositionTest.js +1 -1
  20. package/samples/InteractiveFormsTest/InteractiveFormsTest.js +1 -1
  21. package/samples/JBIG2Test/JBIG2Test.js +1 -1
  22. package/samples/LicenseKey/LicenseKey.js +11 -11
  23. package/samples/LogicalStructureTest/LogicalStructureTest.js +250 -250
  24. package/samples/OCRTest/OCRTest.js +19 -34
  25. package/samples/OfficeTemplateTest/OfficeTemplateTest.js +77 -0
  26. package/samples/OfficeToPDFTest/OfficeToPDFTest.js +1 -1
  27. package/samples/OptimizerTest/OptimizerTest.js +1 -1
  28. package/samples/PDF2HtmlTest/PDF2HtmlTest.js +123 -123
  29. package/samples/PDF2OfficeTest/PDF2OfficeTest.js +158 -158
  30. package/samples/PDFATest/PDFATest.js +85 -85
  31. package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +1 -1
  32. package/samples/PDFDrawTest/PDFDrawTest.js +305 -305
  33. package/samples/PDFLayersTest/PDFLayersTest.js +294 -294
  34. package/samples/PDFPackageTest/PDFPackageTest.js +1 -1
  35. package/samples/PDFPageTest/PDFPageTest.js +189 -189
  36. package/samples/PDFRedactTest/PDFRedactTest.js +74 -74
  37. package/samples/PageLabelsTest/PageLabelsTest.js +1 -1
  38. package/samples/PatternTest/PatternTest.js +1 -1
  39. package/samples/RectTest/RectTest.js +40 -40
  40. package/samples/SDFTest/SDFTest.js +88 -88
  41. package/samples/StamperTest/StamperTest.js +255 -255
  42. package/samples/TestFiles/Misc-Fixed.pfa +1166 -1166
  43. package/samples/TestFiles/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +34 -34
  44. package/samples/TestFiles/form1_annots.xfdf +33 -33
  45. package/samples/TestFiles/form1_data.xfdf +139 -139
  46. package/samples/TestFiles/my_stream.txt +2310 -2310
  47. package/samples/TextExtractTest/TextExtractTest.js +286 -286
  48. package/samples/TextSearchTest/TextSearchTest.js +121 -121
  49. package/samples/U3DTest/U3DTest.js +1 -1
  50. package/samples/UndoRedoTest/UndoRedoTest.js +101 -101
  51. package/samples/UnicodeWriteTest/UnicodeWriteTest.js +173 -173
  52. package/samples/WebViewerConvertTest/WebViewerConvertTest.js +1 -1
  53. package/samples/runall.bat +6 -7
  54. package/samples/runall.sh +15 -14
  55. package/samples/AddImageTest/RunTest.bat +0 -2
  56. package/samples/AddImageTest/RunTest.sh +0 -2
  57. package/samples/AdvancedImagingTest/RunTest.bat +0 -2
  58. package/samples/AdvancedImagingTest/RunTest.sh +0 -2
  59. package/samples/AnnotationTest/RunTest.bat +0 -2
  60. package/samples/AnnotationTest/RunTest.sh +0 -2
  61. package/samples/BookmarkTest/RunTest.bat +0 -2
  62. package/samples/BookmarkTest/RunTest.sh +0 -2
  63. package/samples/CAD2PDFTest/RunTest.bat +0 -2
  64. package/samples/CAD2PDFTest/RunTest.sh +0 -2
  65. package/samples/ContentReplacerTest/RunTest.bat +0 -2
  66. package/samples/ContentReplacerTest/RunTest.sh +0 -2
  67. package/samples/ConvertTest/RunTest.bat +0 -2
  68. package/samples/ConvertTest/RunTest.sh +0 -2
  69. package/samples/DigitalSignaturesTest/RunTest.bat +0 -2
  70. package/samples/DigitalSignaturesTest/RunTest.sh +0 -2
  71. package/samples/ElementBuilderTest/RunTest.bat +0 -2
  72. package/samples/ElementBuilderTest/RunTest.sh +0 -2
  73. package/samples/ElementEditTest/RunTest.bat +0 -2
  74. package/samples/ElementEditTest/RunTest.sh +0 -2
  75. package/samples/ElementReaderAdvTest/RunTest.bat +0 -2
  76. package/samples/ElementReaderAdvTest/RunTest.sh +0 -2
  77. package/samples/ElementReaderTest/RunTest.bat +0 -2
  78. package/samples/ElementReaderTest/RunTest.sh +0 -2
  79. package/samples/EncTest/RunTest.bat +0 -2
  80. package/samples/EncTest/RunTest.sh +0 -2
  81. package/samples/FDFTest/RunTest.bat +0 -2
  82. package/samples/FDFTest/RunTest.sh +0 -2
  83. package/samples/HTML2PDFTest/RunTest.bat +0 -2
  84. package/samples/HTML2PDFTest/RunTest.sh +0 -2
  85. package/samples/ImageExtractTest/RunTest.bat +0 -2
  86. package/samples/ImageExtractTest/RunTest.sh +0 -2
  87. package/samples/ImpositionTest/RunTest.bat +0 -2
  88. package/samples/ImpositionTest/RunTest.sh +0 -2
  89. package/samples/InteractiveFormsTest/RunTest.bat +0 -2
  90. package/samples/InteractiveFormsTest/RunTest.sh +0 -2
  91. package/samples/JBIG2Test/RunTest.bat +0 -2
  92. package/samples/JBIG2Test/RunTest.sh +0 -2
  93. package/samples/LogicalStructureTest/RunTest.bat +0 -2
  94. package/samples/LogicalStructureTest/RunTest.sh +0 -2
  95. package/samples/OCRTest/RunTest.bat +0 -2
  96. package/samples/OCRTest/RunTest.sh +0 -2
  97. package/samples/OfficeToPDFTest/RunTest.bat +0 -2
  98. package/samples/OfficeToPDFTest/RunTest.sh +0 -2
  99. package/samples/OptimizerTest/RunTest.bat +0 -2
  100. package/samples/OptimizerTest/RunTest.sh +0 -2
  101. package/samples/PDF2HtmlTest/RunTest.bat +0 -2
  102. package/samples/PDF2HtmlTest/RunTest.sh +0 -2
  103. package/samples/PDF2OfficeTest/RunTest.bat +0 -2
  104. package/samples/PDF2OfficeTest/RunTest.sh +0 -2
  105. package/samples/PDFATest/RunTest.bat +0 -2
  106. package/samples/PDFATest/RunTest.sh +0 -2
  107. package/samples/PDFDocMemoryTest/RunTest.bat +0 -2
  108. package/samples/PDFDocMemoryTest/RunTest.sh +0 -2
  109. package/samples/PDFDrawTest/RunTest.bat +0 -2
  110. package/samples/PDFDrawTest/RunTest.sh +0 -2
  111. package/samples/PDFLayersTest/RunTest.bat +0 -2
  112. package/samples/PDFLayersTest/RunTest.sh +0 -2
  113. package/samples/PDFPackageTest/RunTest.bat +0 -2
  114. package/samples/PDFPackageTest/RunTest.sh +0 -2
  115. package/samples/PDFPageTest/RunTest.bat +0 -2
  116. package/samples/PDFPageTest/RunTest.sh +0 -2
  117. package/samples/PDFRedactTest/RunTest.bat +0 -2
  118. package/samples/PDFRedactTest/RunTest.sh +0 -2
  119. package/samples/PageLabelsTest/RunTest.bat +0 -2
  120. package/samples/PageLabelsTest/RunTest.sh +0 -2
  121. package/samples/PatternTest/RunTest.bat +0 -2
  122. package/samples/PatternTest/RunTest.sh +0 -2
  123. package/samples/RectTest/RunTest.bat +0 -2
  124. package/samples/RectTest/RunTest.sh +0 -2
  125. package/samples/SDFTest/RunTest.bat +0 -2
  126. package/samples/SDFTest/RunTest.sh +0 -2
  127. package/samples/StamperTest/RunTest.bat +0 -2
  128. package/samples/StamperTest/RunTest.sh +0 -2
  129. package/samples/TextExtractTest/RunTest.bat +0 -2
  130. package/samples/TextExtractTest/RunTest.sh +0 -2
  131. package/samples/TextSearchTest/RunTest.bat +0 -2
  132. package/samples/TextSearchTest/RunTest.sh +0 -2
  133. package/samples/U3DTest/RunTest.bat +0 -2
  134. package/samples/U3DTest/RunTest.sh +0 -2
  135. package/samples/UndoRedoTest/RunTest.bat +0 -2
  136. package/samples/UndoRedoTest/RunTest.sh +0 -2
  137. package/samples/UnicodeWriteTest/RunTest.bat +0 -2
  138. package/samples/UnicodeWriteTest/RunTest.sh +0 -2
  139. package/samples/WebViewerConvertTest/RunTest.bat +0 -2
  140. package/samples/WebViewerConvertTest/RunTest.sh +0 -2
@@ -1,158 +1,158 @@
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 illustrates how to use the PDF::Convert utility class to convert
8
- // documents and files to Word, Excel and PowerPoint.
9
- //
10
- // The Structured Output module is an optional PDFNet Add-on that can be used to convert PDF
11
- // and other documents into Word, Excel, PowerPoint and HTML format.
12
- //
13
- // The PDFTron SDK Structured Output module can be downloaded from
14
- // https://www.pdftron.com/documentation/core/info/modules/
15
- //
16
- // Please contact us if you have any questions.
17
- //---------------------------------------------------------------------------------------
18
-
19
- const { PDFNet } = require('@pdftron/pdfnet-node');
20
- const PDFTronLicense = require('../LicenseKey/LicenseKey');
21
-
22
- ((exports) => {
23
- 'use strict';
24
-
25
- exports.runPDF2OfficeTest = () => {
26
-
27
- const main = async () => {
28
-
29
- const inputPath = '../TestFiles/';
30
- const outputPath = '../TestFiles/Output/';
31
-
32
- //////////////////////////////////////////////////////////////////////////
33
-
34
- await PDFNet.addResourceSearchPath('../../lib/');
35
-
36
- if (!await PDFNet.StructuredOutputModule.isModuleAvailable()) {
37
- console.log('\nUnable to run the sample: PDFTron SDK Structured Output module not available.');
38
- console.log('---------------------------------------------------------------');
39
- console.log('The Structured Output module is an optional add-on, available for download');
40
- console.log('at https://www.pdftron.com/documentation/core/info/modules/. If you have already');
41
- console.log('downloaded this module, ensure that the SDK is able to find the required files');
42
- console.log('using the PDFNet::AddResourceSearchPath() function.\n');
43
-
44
- return;
45
- }
46
-
47
- //////////////////////////////////////////////////////////////////////////
48
-
49
- try {
50
- // Convert PDF document to Word
51
- console.log('Converting PDF to Word');
52
-
53
- const outputFile = outputPath + 'paragraphs_and_tables.docx';
54
-
55
- await PDFNet.Convert.fileToWord(inputPath + 'paragraphs_and_tables.pdf', outputFile);
56
-
57
- console.log('Result saved in ' + outputFile);
58
- } catch (err) {
59
- console.log(err);
60
- }
61
-
62
- try {
63
- // Convert PDF document to Word with options
64
- console.log('Converting PDF to Word with options');
65
-
66
- const outputFile = outputPath + 'paragraphs_and_tables_first_page.docx';
67
-
68
- const wordOutputOptions = new PDFNet.Convert.WordOutputOptions();
69
-
70
- // Convert only the first page
71
- wordOutputOptions.setPages(1, 1);
72
-
73
- await PDFNet.Convert.fileToWord(inputPath + 'paragraphs_and_tables.pdf', outputFile, wordOutputOptions);
74
-
75
- console.log('Result saved in ' + outputFile);
76
- } catch (err) {
77
- console.log(err);
78
- }
79
-
80
- //////////////////////////////////////////////////////////////////////////
81
-
82
- try {
83
- // Convert PDF document to Excel
84
- console.log('Converting PDF to Excel');
85
-
86
- const outputFile = outputPath + 'paragraphs_and_tables.xlsx';
87
-
88
- await PDFNet.Convert.fileToExcel(inputPath + 'paragraphs_and_tables.pdf', outputFile);
89
-
90
- console.log('Result saved in ' + outputFile);
91
- } catch (err) {
92
- console.log(err);
93
- }
94
-
95
- try {
96
- // Convert PDF document to Excel with options
97
- console.log('Converting PDF to Excel with options');
98
-
99
- const outputFile = outputPath + 'paragraphs_and_tables_second_page.xlsx';
100
-
101
- const excelOutputOptions = new PDFNet.Convert.ExcelOutputOptions();
102
-
103
- // Convert only the second page
104
- excelOutputOptions.setPages(2, 2);
105
-
106
- await PDFNet.Convert.fileToExcel(inputPath + 'paragraphs_and_tables.pdf', outputFile, excelOutputOptions);
107
-
108
- console.log('Result saved in ' + outputFile);
109
- } catch (err) {
110
- console.log(err);
111
- }
112
-
113
- //////////////////////////////////////////////////////////////////////////
114
-
115
- try {
116
- // Convert PDF document to PowerPoint
117
- console.log('Converting PDF to PowerPoint');
118
-
119
- const outputFile = outputPath + 'paragraphs_and_tables.pptx';
120
-
121
- await PDFNet.Convert.fileToPowerPoint(inputPath + 'paragraphs_and_tables.pdf', outputFile);
122
-
123
- console.log('Result saved in ' + outputFile);
124
- } catch (err) {
125
- console.log(err);
126
- }
127
-
128
- try {
129
- // Convert PDF document to PowerPoint with options
130
- console.log('Converting PDF to PowerPoint with options');
131
-
132
- const outputFile = outputPath + 'paragraphs_and_tables_first_page.pptx';
133
-
134
- const powerPointOutputOptions = new PDFNet.Convert.PowerPointOutputOptions();
135
-
136
- // Convert only the first page
137
- powerPointOutputOptions.setPages(1, 1);
138
-
139
- await PDFNet.Convert.fileToPowerPoint(inputPath + 'paragraphs_and_tables.pdf', outputFile, powerPointOutputOptions);
140
-
141
- console.log('Result saved in ' + outputFile);
142
- } catch (err) {
143
- console.log(err);
144
- }
145
-
146
- //////////////////////////////////////////////////////////////////////////
147
-
148
- console.log('Done.');
149
- };
150
-
151
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
152
- console.log('Error: ' + JSON.stringify(error));
153
- }).then(function () { return PDFNet.shutdown(); });
154
- };
155
- exports.runPDF2OfficeTest();
156
- })(exports);
157
- // eslint-disable-next-line spaced-comment
158
- //# sourceURL=PDF2OfficeTest.js
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
+ //---------------------------------------------------------------------------------------
7
+ // The following sample illustrates how to use the PDF::Convert utility class to convert
8
+ // documents and files to Word, Excel and PowerPoint.
9
+ //
10
+ // The Structured Output module is an optional PDFNet Add-on that can be used to convert PDF
11
+ // and other documents into Word, Excel, PowerPoint and HTML format.
12
+ //
13
+ // The PDFTron SDK Structured Output module can be downloaded from
14
+ // https://www.pdftron.com/documentation/core/info/modules/
15
+ //
16
+ // Please contact us if you have any questions.
17
+ //---------------------------------------------------------------------------------------
18
+
19
+ const { PDFNet } = require('@pdftron/pdfnet-node');
20
+ const PDFTronLicense = require('../LicenseKey/LicenseKey');
21
+
22
+ ((exports) => {
23
+ 'use strict';
24
+
25
+ exports.runPDF2OfficeTest = () => {
26
+
27
+ const main = async () => {
28
+
29
+ const inputPath = '../TestFiles/';
30
+ const outputPath = '../TestFiles/Output/';
31
+
32
+ //////////////////////////////////////////////////////////////////////////
33
+
34
+ await PDFNet.addResourceSearchPath('../../lib/');
35
+
36
+ if (!await PDFNet.StructuredOutputModule.isModuleAvailable()) {
37
+ console.log('\nUnable to run the sample: PDFTron SDK Structured Output module not available.');
38
+ console.log('---------------------------------------------------------------');
39
+ console.log('The Structured Output module is an optional add-on, available for download');
40
+ console.log('at https://www.pdftron.com/documentation/core/info/modules/. If you have already');
41
+ console.log('downloaded this module, ensure that the SDK is able to find the required files');
42
+ console.log('using the PDFNet::AddResourceSearchPath() function.\n');
43
+
44
+ return;
45
+ }
46
+
47
+ //////////////////////////////////////////////////////////////////////////
48
+
49
+ try {
50
+ // Convert PDF document to Word
51
+ console.log('Converting PDF to Word');
52
+
53
+ const outputFile = outputPath + 'paragraphs_and_tables.docx';
54
+
55
+ await PDFNet.Convert.fileToWord(inputPath + 'paragraphs_and_tables.pdf', outputFile);
56
+
57
+ console.log('Result saved in ' + outputFile);
58
+ } catch (err) {
59
+ console.log(err);
60
+ }
61
+
62
+ try {
63
+ // Convert PDF document to Word with options
64
+ console.log('Converting PDF to Word with options');
65
+
66
+ const outputFile = outputPath + 'paragraphs_and_tables_first_page.docx';
67
+
68
+ const wordOutputOptions = new PDFNet.Convert.WordOutputOptions();
69
+
70
+ // Convert only the first page
71
+ wordOutputOptions.setPages(1, 1);
72
+
73
+ await PDFNet.Convert.fileToWord(inputPath + 'paragraphs_and_tables.pdf', outputFile, wordOutputOptions);
74
+
75
+ console.log('Result saved in ' + outputFile);
76
+ } catch (err) {
77
+ console.log(err);
78
+ }
79
+
80
+ //////////////////////////////////////////////////////////////////////////
81
+
82
+ try {
83
+ // Convert PDF document to Excel
84
+ console.log('Converting PDF to Excel');
85
+
86
+ const outputFile = outputPath + 'paragraphs_and_tables.xlsx';
87
+
88
+ await PDFNet.Convert.fileToExcel(inputPath + 'paragraphs_and_tables.pdf', outputFile);
89
+
90
+ console.log('Result saved in ' + outputFile);
91
+ } catch (err) {
92
+ console.log(err);
93
+ }
94
+
95
+ try {
96
+ // Convert PDF document to Excel with options
97
+ console.log('Converting PDF to Excel with options');
98
+
99
+ const outputFile = outputPath + 'paragraphs_and_tables_second_page.xlsx';
100
+
101
+ const excelOutputOptions = new PDFNet.Convert.ExcelOutputOptions();
102
+
103
+ // Convert only the second page
104
+ excelOutputOptions.setPages(2, 2);
105
+
106
+ await PDFNet.Convert.fileToExcel(inputPath + 'paragraphs_and_tables.pdf', outputFile, excelOutputOptions);
107
+
108
+ console.log('Result saved in ' + outputFile);
109
+ } catch (err) {
110
+ console.log(err);
111
+ }
112
+
113
+ //////////////////////////////////////////////////////////////////////////
114
+
115
+ try {
116
+ // Convert PDF document to PowerPoint
117
+ console.log('Converting PDF to PowerPoint');
118
+
119
+ const outputFile = outputPath + 'paragraphs_and_tables.pptx';
120
+
121
+ await PDFNet.Convert.fileToPowerPoint(inputPath + 'paragraphs_and_tables.pdf', outputFile);
122
+
123
+ console.log('Result saved in ' + outputFile);
124
+ } catch (err) {
125
+ console.log(err);
126
+ }
127
+
128
+ try {
129
+ // Convert PDF document to PowerPoint with options
130
+ console.log('Converting PDF to PowerPoint with options');
131
+
132
+ const outputFile = outputPath + 'paragraphs_and_tables_first_page.pptx';
133
+
134
+ const powerPointOutputOptions = new PDFNet.Convert.PowerPointOutputOptions();
135
+
136
+ // Convert only the first page
137
+ powerPointOutputOptions.setPages(1, 1);
138
+
139
+ await PDFNet.Convert.fileToPowerPoint(inputPath + 'paragraphs_and_tables.pdf', outputFile, powerPointOutputOptions);
140
+
141
+ console.log('Result saved in ' + outputFile);
142
+ } catch (err) {
143
+ console.log(err);
144
+ }
145
+
146
+ //////////////////////////////////////////////////////////////////////////
147
+
148
+ console.log('Done.');
149
+ };
150
+
151
+ PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
152
+ console.log('Error: ' + JSON.stringify(error));
153
+ }).then(function () { return PDFNet.shutdown(); });
154
+ };
155
+ exports.runPDF2OfficeTest();
156
+ })(exports);
157
+ // eslint-disable-next-line spaced-comment
158
+ //# sourceURL=PDF2OfficeTest.js
@@ -1,85 +1,85 @@
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
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
- const PDFTronLicense = require('../LicenseKey/LicenseKey');
8
-
9
- ((exports) => {
10
-
11
- exports.runPDFA = () => {
12
-
13
- const printResults = async (pdfa, filename) => {
14
-
15
- const errorCount = await pdfa.getErrorCount();
16
- if (errorCount === 0) {
17
- console.log(filename + ': OK.');
18
- } else {
19
- console.log(filename + ' is NOT a valid PDFA.');
20
- for (let i = 0; i < errorCount; i++) {
21
- const errorCode = await pdfa.getError(i);
22
- const errorMsg = await PDFNet.PDFACompliance.getPDFAErrorMessage(errorCode);
23
- console.log(' - e_PDFA ' + errorCode + ': ' + errorMsg + '.');
24
- const numRefs = await pdfa.getRefObjCount(errorCode);
25
- if (numRefs > 0) {
26
- const objs = [];
27
- for (let j = 0; j < numRefs; j++) {
28
- const objRef = await pdfa.getRefObj(errorCode, j);
29
- objs.push(objRef);
30
- }
31
- console.log(' Objects: ' + objs.join(', '));
32
- }
33
- }
34
- console.log('');
35
- }
36
- }
37
-
38
- //---------------------------------------------------------------------------------------
39
- // The following sample illustrates how to parse and check if a PDF document meets the
40
- // PDFA standard, using the PDFACompliance class object.
41
- //---------------------------------------------------------------------------------------
42
- const main = async () => {
43
- const inputPath = '../TestFiles/';
44
- const outputPath = inputPath + 'Output/';
45
- await PDFNet.setColorManagement(); // Enable color management (required for PDFA validation).
46
-
47
- //-----------------------------------------------------------
48
- // Example 1: PDF/A Validation
49
- //-----------------------------------------------------------
50
- try {
51
- const filename = 'newsletter.pdf';
52
- /* The max_ref_objs parameter to the PDFACompliance constructor controls the maximum number
53
- of object numbers that are collected for particular error codes. The default value is 10
54
- in order to prevent spam. If you need all the object numbers, pass 0 for max_ref_objs. */
55
- const pdfa = await PDFNet.PDFACompliance.createFromFile(false, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
56
- await printResults(pdfa, filename);
57
- } catch (err) {
58
- console.log(err);
59
- }
60
-
61
- //-----------------------------------------------------------
62
- // Example 2: PDF/A Conversion
63
- //-----------------------------------------------------------
64
- try {
65
- let filename = 'fish.pdf';
66
- const pdfa = await PDFNet.PDFACompliance.createFromFile(true, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
67
- filename = 'pdfa.pdf';
68
- await pdfa.saveAsFromFileName(outputPath + filename);
69
-
70
- // Re-validate the document after the conversion...
71
- const comp = await PDFNet.PDFACompliance.createFromFile(false, outputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
72
- await printResults(comp, filename);
73
- } catch (err) {
74
- console.log(err);
75
- }
76
-
77
- console.log('PDFACompliance test completed.')
78
- };
79
-
80
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
81
- };
82
- exports.runPDFA();
83
- })(exports);
84
- // eslint-disable-next-line spaced-comment
85
- //# sourceURL=PDFATest.js
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
+
11
+ exports.runPDFA = () => {
12
+
13
+ const printResults = async (pdfa, filename) => {
14
+
15
+ const errorCount = await pdfa.getErrorCount();
16
+ if (errorCount === 0) {
17
+ console.log(filename + ': OK.');
18
+ } else {
19
+ console.log(filename + ' is NOT a valid PDFA.');
20
+ for (let i = 0; i < errorCount; i++) {
21
+ const errorCode = await pdfa.getError(i);
22
+ const errorMsg = await PDFNet.PDFACompliance.getPDFAErrorMessage(errorCode);
23
+ console.log(' - e_PDFA ' + errorCode + ': ' + errorMsg + '.');
24
+ const numRefs = await pdfa.getRefObjCount(errorCode);
25
+ if (numRefs > 0) {
26
+ const objs = [];
27
+ for (let j = 0; j < numRefs; j++) {
28
+ const objRef = await pdfa.getRefObj(errorCode, j);
29
+ objs.push(objRef);
30
+ }
31
+ console.log(' Objects: ' + objs.join(', '));
32
+ }
33
+ }
34
+ console.log('');
35
+ }
36
+ }
37
+
38
+ //---------------------------------------------------------------------------------------
39
+ // The following sample illustrates how to parse and check if a PDF document meets the
40
+ // PDFA standard, using the PDFACompliance class object.
41
+ //---------------------------------------------------------------------------------------
42
+ const main = async () => {
43
+ const inputPath = '../TestFiles/';
44
+ const outputPath = inputPath + 'Output/';
45
+ await PDFNet.setColorManagement(); // Enable color management (required for PDFA validation).
46
+
47
+ //-----------------------------------------------------------
48
+ // Example 1: PDF/A Validation
49
+ //-----------------------------------------------------------
50
+ try {
51
+ const filename = 'newsletter.pdf';
52
+ /* The max_ref_objs parameter to the PDFACompliance constructor controls the maximum number
53
+ of object numbers that are collected for particular error codes. The default value is 10
54
+ in order to prevent spam. If you need all the object numbers, pass 0 for max_ref_objs. */
55
+ const pdfa = await PDFNet.PDFACompliance.createFromFile(false, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
56
+ await printResults(pdfa, filename);
57
+ } catch (err) {
58
+ console.log(err);
59
+ }
60
+
61
+ //-----------------------------------------------------------
62
+ // Example 2: PDF/A Conversion
63
+ //-----------------------------------------------------------
64
+ try {
65
+ let filename = 'fish.pdf';
66
+ const pdfa = await PDFNet.PDFACompliance.createFromFile(true, inputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
67
+ filename = 'pdfa.pdf';
68
+ await pdfa.saveAsFromFileName(outputPath + filename);
69
+
70
+ // Re-validate the document after the conversion...
71
+ const comp = await PDFNet.PDFACompliance.createFromFile(false, outputPath + filename, '', PDFNet.PDFACompliance.Conformance.e_Level2B);
72
+ await printResults(comp, filename);
73
+ } catch (err) {
74
+ console.log(err);
75
+ }
76
+
77
+ console.log('PDFACompliance test completed.')
78
+ };
79
+
80
+ PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
81
+ };
82
+ exports.runPDFA();
83
+ })(exports);
84
+ // eslint-disable-next-line spaced-comment
85
+ //# sourceURL=PDFATest.js
@@ -1,5 +1,5 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
2
+ // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
3
3
  // Consult legal.txt regarding legal and license information.
4
4
  //---------------------------------------------------------------------------------------
5
5