@pdftron/pdfnet-node-samples 9.4.2 → 9.5.0-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.
- package/package.json +18 -18
- package/readme.md +12 -12
- package/samples/runall.bat +12 -12
- package/samples/AddImageTest/AddImageTest.js +0 -116
- package/samples/AdvancedImagingTest/AdvancedImagingTest.js +0 -78
- package/samples/AnnotationTest/AnnotationTest.js +0 -642
- package/samples/BookmarkTest/BookmarkTest.js +0 -220
- package/samples/CAD2PDFTest/CAD2PDFTest.js +0 -80
- package/samples/ContentReplacerTest/ContentReplacerTest.js +0 -75
- package/samples/ConvertTest/ConvertTest.js +0 -256
- package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +0 -527
- package/samples/ElementBuilderTest/ElementBuilderTest.js +0 -514
- package/samples/ElementEditTest/ElementEditTest.js +0 -111
- package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +0 -305
- package/samples/ElementReaderTest/ElementReaderTest.js +0 -77
- package/samples/EncTest/EncTest.js +0 -176
- package/samples/FDFTest/FDFTest.js +0 -219
- package/samples/HTML2PDFTest/HTML2PDFTest.js +0 -166
- package/samples/HighlightsTest/HighlightsTest.js +0 -97
- package/samples/ImageExtractTest/ImageExtractTest.js +0 -130
- package/samples/ImpositionTest/ImpositionTest.js +0 -87
- package/samples/InteractiveFormsTest/InteractiveFormsTest.js +0 -382
- package/samples/JBIG2Test/JBIG2Test.js +0 -89
- package/samples/LicenseKey/LicenseKey.js +0 -11
- package/samples/LogicalStructureTest/LogicalStructureTest.js +0 -251
- package/samples/OCRTest/OCRTest.js +0 -235
- package/samples/OfficeTemplateTest/OfficeTemplateTest.js +0 -77
- package/samples/OfficeToPDFTest/OfficeToPDFTest.js +0 -125
- package/samples/OptimizerTest/OptimizerTest.js +0 -192
- package/samples/PDF2HtmlTest/PDF2HtmlTest.js +0 -123
- package/samples/PDF2OfficeTest/PDF2OfficeTest.js +0 -158
- package/samples/PDFATest/PDFATest.js +0 -85
- package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +0 -85
- package/samples/PDFDrawTest/PDFDrawTest.js +0 -306
- package/samples/PDFLayersTest/PDFLayersTest.js +0 -295
- package/samples/PDFPackageTest/PDFPackageTest.js +0 -112
- package/samples/PDFPageTest/PDFPageTest.js +0 -190
- package/samples/PDFRedactTest/PDFRedactTest.js +0 -75
- package/samples/PageLabelsTest/PageLabelsTest.js +0 -139
- package/samples/PatternTest/PatternTest.js +0 -227
- package/samples/RectTest/RectTest.js +0 -41
- package/samples/SDFTest/SDFTest.js +0 -89
- package/samples/StamperTest/StamperTest.js +0 -256
- package/samples/TestFiles/BusinessCardTemplate.pdf +0 -0
- package/samples/TestFiles/Fishermen.docx +0 -0
- package/samples/TestFiles/Font_licenses.txt +0 -140
- package/samples/TestFiles/GlobalSignRootForTST.cer +0 -0
- package/samples/TestFiles/License.txt +0 -1
- package/samples/TestFiles/Misc-Fixed.pfa +0 -1166
- package/samples/TestFiles/NotoSans_with_hindi.ttf +0 -0
- package/samples/TestFiles/Output/empty +0 -1
- package/samples/TestFiles/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +0 -34
- package/samples/TestFiles/SYH_Letter.docx +0 -0
- package/samples/TestFiles/TigerText.pdf +0 -0
- package/samples/TestFiles/US061222892-a.pdf +0 -0
- package/samples/TestFiles/butterfly.png +0 -0
- package/samples/TestFiles/credit card numbers.pdf +0 -0
- package/samples/TestFiles/dice.jpg +0 -0
- package/samples/TestFiles/dice.u3d +0 -0
- package/samples/TestFiles/doc_to_sign.pdf +0 -0
- package/samples/TestFiles/factsheet_Arabic.docx +0 -0
- package/samples/TestFiles/fish.pdf +0 -0
- package/samples/TestFiles/font.ttf +0 -0
- package/samples/TestFiles/form1.pdf +1 -245
- package/samples/TestFiles/form1_annots.xfdf +0 -34
- package/samples/TestFiles/form1_data.fdf +0 -4
- package/samples/TestFiles/form1_data.xfdf +0 -140
- package/samples/TestFiles/grayscale.tif +0 -0
- package/samples/TestFiles/hindi_sample_utf16le.txt +0 -0
- package/samples/TestFiles/imagemask.dat +0 -32
- package/samples/TestFiles/logo_red.png +0 -0
- package/samples/TestFiles/lorem_ipsum.pdf +0 -0
- package/samples/TestFiles/multipage.tif +0 -0
- package/samples/TestFiles/my_stream.txt +0 -2310
- package/samples/TestFiles/newsletter.pdf +0 -0
- package/samples/TestFiles/newsletter.xod +0 -0
- package/samples/TestFiles/numbered.pdf +0 -0
- package/samples/TestFiles/op_blend_test.pdf +0 -1498
- package/samples/TestFiles/palm.jp2 +0 -0
- package/samples/TestFiles/paragraphs_and_tables.pdf +0 -0
- package/samples/TestFiles/pdfnet.gif +0 -0
- package/samples/TestFiles/pdftron.bmp +0 -0
- package/samples/TestFiles/pdftron.cer +0 -0
- package/samples/TestFiles/pdftron.pfx +0 -0
- package/samples/TestFiles/pdftron_smart_substitution.plugin +0 -0
- package/samples/TestFiles/peppers.jpg +0 -0
- package/samples/TestFiles/signature.jpg +0 -0
- package/samples/TestFiles/simple-emf.emf +0 -0
- package/samples/TestFiles/simple-excel_2007.xlsx +0 -0
- package/samples/TestFiles/simple-outlook.msg +0 -0
- package/samples/TestFiles/simple-powerpoint_2007.pptx +0 -0
- package/samples/TestFiles/simple-publisher.pub +0 -0
- package/samples/TestFiles/simple-rtf.rtf +0 -224
- package/samples/TestFiles/simple-text.txt +0 -61
- package/samples/TestFiles/simple-visio.vsd +0 -0
- package/samples/TestFiles/simple-webpage.html +0 -731
- package/samples/TestFiles/simple-webpage.mht +0 -6972
- package/samples/TestFiles/simple-webpage_files/colorschememapping.xml +0 -2
- package/samples/TestFiles/simple-webpage_files/filelist.xml +0 -14
- package/samples/TestFiles/simple-webpage_files/image001.gif +0 -0
- package/samples/TestFiles/simple-webpage_files/image002.png +0 -0
- package/samples/TestFiles/simple-webpage_files/image003.jpg +0 -0
- package/samples/TestFiles/simple-webpage_files/image004.emz +0 -0
- package/samples/TestFiles/simple-webpage_files/image005.gif +0 -0
- package/samples/TestFiles/simple-webpage_files/image006.png +0 -0
- package/samples/TestFiles/simple-webpage_files/image007.gif +0 -0
- package/samples/TestFiles/simple-webpage_files/oledata.mso +0 -0
- package/samples/TestFiles/simple-webpage_files/themedata.thmx +0 -0
- package/samples/TestFiles/simple-word_2007.docx +0 -0
- package/samples/TestFiles/simple-xps.xps +0 -0
- package/samples/TestFiles/tagged.pdf +0 -0
- package/samples/TestFiles/the_rime_of_the_ancient_mariner.docx +0 -0
- package/samples/TestFiles/tiger.pdf +0 -0
- package/samples/TestFiles/waiver.pdf +0 -0
- package/samples/TestFiles/waiver_withApprovalField.pdf +0 -0
- package/samples/TestFiles/waiver_withApprovalField_certified.pdf +1 -424
- package/samples/TestFiles/waiver_withApprovalField_certified_approved.pdf +1 -466
- package/samples/TextExtractTest/TextExtractTest.js +0 -287
- package/samples/TextSearchTest/TextSearchTest.js +0 -122
- package/samples/U3DTest/U3DTest.js +0 -105
- package/samples/UndoRedoTest/UndoRedoTest.js +0 -101
- package/samples/UnicodeWriteTest/UnicodeWriteTest.js +0 -174
- package/samples/WebViewerConvertTest/WebViewerConvertTest.js +0 -136
|
@@ -1,192 +0,0 @@
|
|
|
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 reduce PDF file size using 'pdftron.PDF.Optimizer'.
|
|
8
|
-
// The sample also shows how to simplify and optimize PDF documents for viewing on mobile devices
|
|
9
|
-
// and on the Web using 'pdftron.PDF.Flattener'.
|
|
10
|
-
//
|
|
11
|
-
// @note Both 'Optimizer' and 'Flattener' are separately licensable add-on options to the core PDFNet license.
|
|
12
|
-
//
|
|
13
|
-
// ----
|
|
14
|
-
//
|
|
15
|
-
// 'pdftron.PDF.Optimizer' can be used to optimize PDF documents by reducing the file size, removing
|
|
16
|
-
// redundant information, and compressing data streams using the latest in image compression technology.
|
|
17
|
-
//
|
|
18
|
-
// PDF Optimizer can compress and shrink PDF file size with the following operations:
|
|
19
|
-
// - Remove duplicated fonts, images, ICC profiles, and any other data stream.
|
|
20
|
-
// - Optionally convert high-quality or print-ready PDF files to small, efficient and web-ready PDF.
|
|
21
|
-
// - Optionally down-sample large images to a given resolution.
|
|
22
|
-
// - Optionally compress or recompress PDF images using JBIG2 and JPEG2000 compression formats.
|
|
23
|
-
// - Compress uncompressed streams and remove unused PDF objects.
|
|
24
|
-
//
|
|
25
|
-
// ----
|
|
26
|
-
//
|
|
27
|
-
// 'pdftron.PDF.Flattener' can be used to speed-up PDF rendering on mobile devices and on the Web by
|
|
28
|
-
// simplifying page content (e.g. flattening complex graphics into images) while maintaining vector text
|
|
29
|
-
// whenever possible.
|
|
30
|
-
//
|
|
31
|
-
// Flattener can also be used to simplify process of writing custom converters from PDF to other formats.
|
|
32
|
-
// In this case, Flattener can be used as first step in the conversion pipeline to reduce any PDF to a
|
|
33
|
-
// very simple representation (e.g. vector text on top of a background image).
|
|
34
|
-
//---------------------------------------------------------------------------------------
|
|
35
|
-
|
|
36
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
37
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
38
|
-
|
|
39
|
-
((exports) => {
|
|
40
|
-
'use strict';
|
|
41
|
-
|
|
42
|
-
exports.runOptimizerTest = () => {
|
|
43
|
-
const main = async () => {
|
|
44
|
-
const inputPath = '../TestFiles/';
|
|
45
|
-
const outputPath = inputPath + 'Output/';
|
|
46
|
-
const inputFilename = 'newsletter';
|
|
47
|
-
|
|
48
|
-
// The first step in every application using PDFNet is to initialize the
|
|
49
|
-
// library and set the path to common PDF resources. The library is usually
|
|
50
|
-
// initialized only once, but calling Initialize() multiple times is also fine.
|
|
51
|
-
|
|
52
|
-
//--------------------------------------------------------------------------------
|
|
53
|
-
// Example 1) Simple optimization of a pdf with default settings.
|
|
54
|
-
//
|
|
55
|
-
try {
|
|
56
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename + '.pdf');
|
|
57
|
-
await doc.initSecurityHandler();
|
|
58
|
-
await PDFNet.Optimizer.optimize(doc);
|
|
59
|
-
doc.save(outputPath + inputFilename + '_opt1.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
60
|
-
}
|
|
61
|
-
catch (err) {
|
|
62
|
-
console.log(err);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
//--------------------------------------------------------------------------------
|
|
66
|
-
// Example 2) Reduce image quality and use jpeg compression for
|
|
67
|
-
// non monochrome images.
|
|
68
|
-
try {
|
|
69
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename + '.pdf');
|
|
70
|
-
await doc.initSecurityHandler();
|
|
71
|
-
const image_settings = new PDFNet.Optimizer.ImageSettings();
|
|
72
|
-
|
|
73
|
-
// low quality jpeg compression
|
|
74
|
-
image_settings.setCompressionMode(PDFNet.Optimizer.ImageSettings.CompressionMode.e_jpeg);
|
|
75
|
-
image_settings.setQuality(1);
|
|
76
|
-
|
|
77
|
-
// Set the output dpi to be standard screen resolution
|
|
78
|
-
image_settings.setImageDPI(144, 96);
|
|
79
|
-
|
|
80
|
-
// this option will recompress images not compressed with
|
|
81
|
-
// jpeg compression and use the result if the new image
|
|
82
|
-
// is smaller.
|
|
83
|
-
image_settings.forceRecompression(true);
|
|
84
|
-
|
|
85
|
-
// this option is not commonly used since it can
|
|
86
|
-
// potentially lead to larger files. It should be enabled
|
|
87
|
-
// only if the output compression specified should be applied
|
|
88
|
-
// to every image of a given type regardless of the output image size
|
|
89
|
-
//image_settings.forceChanges(true);
|
|
90
|
-
|
|
91
|
-
const opt_settings = new PDFNet.Optimizer.OptimizerSettings();
|
|
92
|
-
opt_settings.setColorImageSettings(image_settings);
|
|
93
|
-
opt_settings.setGrayscaleImageSettings(image_settings);
|
|
94
|
-
|
|
95
|
-
// use the same settings for both color and grayscale images
|
|
96
|
-
await PDFNet.Optimizer.optimize(doc, opt_settings);
|
|
97
|
-
|
|
98
|
-
doc.save(outputPath + inputFilename + '_opt2.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
99
|
-
}
|
|
100
|
-
catch (err) {
|
|
101
|
-
console.log(err);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
//--------------------------------------------------------------------------------
|
|
105
|
-
// Example 3) Use monochrome image settings and default settings
|
|
106
|
-
// for color and grayscale images.
|
|
107
|
-
try {
|
|
108
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename + '.pdf');
|
|
109
|
-
await doc.initSecurityHandler();
|
|
110
|
-
|
|
111
|
-
const mono_image_settings = new PDFNet.Optimizer.MonoImageSettings();
|
|
112
|
-
|
|
113
|
-
mono_image_settings.setCompressionMode(PDFNet.Optimizer.MonoImageSettings.CompressionMode.e_jbig2);
|
|
114
|
-
mono_image_settings.forceRecompression(true);
|
|
115
|
-
|
|
116
|
-
const opt_settings = new PDFNet.Optimizer.OptimizerSettings();
|
|
117
|
-
|
|
118
|
-
opt_settings.setMonoImageSettings(mono_image_settings);
|
|
119
|
-
|
|
120
|
-
await PDFNet.Optimizer.optimize(doc, opt_settings);
|
|
121
|
-
doc.save(outputPath + inputFilename + '_opt3.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
122
|
-
}
|
|
123
|
-
catch (err) {
|
|
124
|
-
console.log(err);
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
// ----------------------------------------------------------------------
|
|
128
|
-
// Example 4) Use Flattener to simplify content in this document
|
|
129
|
-
// using default settings
|
|
130
|
-
try {
|
|
131
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'TigerText.pdf');
|
|
132
|
-
await doc.initSecurityHandler();
|
|
133
|
-
|
|
134
|
-
const fl = await PDFNet.Flattener.create();
|
|
135
|
-
|
|
136
|
-
// The following lines can increase the resolution of background
|
|
137
|
-
// images.
|
|
138
|
-
//fl.setDPI(300);
|
|
139
|
-
//fl.setMaximumImagePixels(5000000);
|
|
140
|
-
|
|
141
|
-
// This line can be used to output Flate compressed background
|
|
142
|
-
// images rather than DCTDecode compressed images which is the default
|
|
143
|
-
//fl.setPreferJPG(false);
|
|
144
|
-
|
|
145
|
-
// In order to adjust thresholds for when text is Flattened
|
|
146
|
-
// the following function can be used.
|
|
147
|
-
//fl.setThreshold(PDFNet.Flattener.Threshold.e_keep_most);
|
|
148
|
-
|
|
149
|
-
// We use e_fast option here since it is usually preferable
|
|
150
|
-
// to avoid Flattening simple pages in terms of size and
|
|
151
|
-
// rendering speed. If the desire is to simplify the
|
|
152
|
-
// document for processing such that it contains only text and
|
|
153
|
-
// a background image e_simple should be used instead.
|
|
154
|
-
await fl.process(doc, PDFNet.Flattener.Mode.e_fast);
|
|
155
|
-
|
|
156
|
-
doc.save(outputPath + 'TigerText_flatten.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
157
|
-
}
|
|
158
|
-
catch (err) {
|
|
159
|
-
console.log(err);
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
//--------------------------------------------------------------------------------
|
|
163
|
-
// Example 5) Optimize a PDF for viewing using SaveViewerOptimized.
|
|
164
|
-
try {
|
|
165
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename + '.pdf');
|
|
166
|
-
doc.initSecurityHandler();
|
|
167
|
-
|
|
168
|
-
const opts = new PDFNet.PDFDoc.ViewerOptimizedOptions();
|
|
169
|
-
|
|
170
|
-
// set the maximum dimension (width or height) that thumbnails will have.
|
|
171
|
-
opts.setThumbnailSize(1500);
|
|
172
|
-
|
|
173
|
-
// set thumbnail rendering threshold. A number from 0 (include all thumbnails) to 100 (include only the first thumbnail)
|
|
174
|
-
// representing the complexity at which SaveViewerOptimized would include the thumbnail.
|
|
175
|
-
// By default it only produces thumbnails on the first and complex pages.
|
|
176
|
-
// The following line will produce thumbnails on every page.
|
|
177
|
-
// opts.setThumbnailRenderingThreshold(0);
|
|
178
|
-
|
|
179
|
-
await doc.saveViewerOptimized(outputPath + inputFilename + '_SaveViewerOptimized.pdf', opts);
|
|
180
|
-
}
|
|
181
|
-
catch (err) {
|
|
182
|
-
console.log(err);
|
|
183
|
-
}
|
|
184
|
-
};
|
|
185
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
|
|
186
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
187
|
-
}).then(function () { return PDFNet.shutdown(); });
|
|
188
|
-
};
|
|
189
|
-
exports.runOptimizerTest();
|
|
190
|
-
})(exports);
|
|
191
|
-
// eslint-disable-next-line spaced-comment
|
|
192
|
-
//# sourceURL=OptimizerTest.js
|
|
@@ -1,123 +0,0 @@
|
|
|
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 HTML.
|
|
9
|
-
//
|
|
10
|
-
// There are two HTML modules and one of them is an optional PDFNet Add-on.
|
|
11
|
-
// 1. The built-in HTML module is used to convert PDF documents to fixed-position HTML
|
|
12
|
-
// documents.
|
|
13
|
-
// 2. The optional Structured Output add-on module is used to convert PDF documents to
|
|
14
|
-
// HTML documents with text flowing across the browser window.
|
|
15
|
-
//
|
|
16
|
-
// The PDFTron SDK Structured Output module can be downloaded from
|
|
17
|
-
// https://www.pdftron.com/documentation/core/info/modules/
|
|
18
|
-
//
|
|
19
|
-
// Please contact us if you have any questions.
|
|
20
|
-
//---------------------------------------------------------------------------------------
|
|
21
|
-
|
|
22
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
23
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
24
|
-
|
|
25
|
-
((exports) => {
|
|
26
|
-
'use strict';
|
|
27
|
-
|
|
28
|
-
exports.runPDF2HtmlTest = () => {
|
|
29
|
-
|
|
30
|
-
const main = async () => {
|
|
31
|
-
|
|
32
|
-
const inputPath = '../TestFiles/';
|
|
33
|
-
const outputPath = '../TestFiles/Output/';
|
|
34
|
-
|
|
35
|
-
//////////////////////////////////////////////////////////////////////////
|
|
36
|
-
|
|
37
|
-
try {
|
|
38
|
-
// Convert PDF document to HTML with fixed positioning option turned on (default)
|
|
39
|
-
console.log('Converting PDF to HTML with fixed positioning option turned on (default)');
|
|
40
|
-
|
|
41
|
-
const outputFile = outputPath + 'paragraphs_and_tables_fixed_positioning';
|
|
42
|
-
|
|
43
|
-
// Convert PDF to HTML
|
|
44
|
-
await PDFNet.Convert.fileToHtml(inputPath + 'paragraphs_and_tables.pdf', outputFile);
|
|
45
|
-
|
|
46
|
-
console.log('Result saved in ' + outputFile);
|
|
47
|
-
} catch (err) {
|
|
48
|
-
console.log(err);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
//////////////////////////////////////////////////////////////////////////
|
|
52
|
-
|
|
53
|
-
await PDFNet.addResourceSearchPath('../../lib/');
|
|
54
|
-
|
|
55
|
-
if (!await PDFNet.StructuredOutputModule.isModuleAvailable()) {
|
|
56
|
-
console.log('\nUnable to run part of the sample: PDFTron SDK Structured Output module not available.');
|
|
57
|
-
console.log('---------------------------------------------------------------');
|
|
58
|
-
console.log('The Structured Output module is an optional add-on, available for download');
|
|
59
|
-
console.log('at https://www.pdftron.com/documentation/core/info/modules/. If you have already');
|
|
60
|
-
console.log('downloaded this module, ensure that the SDK is able to find the required files');
|
|
61
|
-
console.log('using the PDFNet::AddResourceSearchPath() function.\n');
|
|
62
|
-
|
|
63
|
-
return;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
//////////////////////////////////////////////////////////////////////////
|
|
67
|
-
|
|
68
|
-
try {
|
|
69
|
-
// Convert PDF document to HTML with reflow full option turned on (1)
|
|
70
|
-
console.log('Converting PDF to HTML with reflow full option turned on (1)');
|
|
71
|
-
|
|
72
|
-
const outputFile = outputPath + 'paragraphs_and_tables_reflow_full.html';
|
|
73
|
-
|
|
74
|
-
const htmlOutputOptions = new PDFNet.Convert.HTMLOutputOptions();
|
|
75
|
-
|
|
76
|
-
// Set e_reflow_full content reflow setting
|
|
77
|
-
htmlOutputOptions.setContentReflowSetting(PDFNet.Convert.HTMLOutputOptions.ContentReflowSetting.e_reflow_full);
|
|
78
|
-
|
|
79
|
-
// Convert PDF to HTML
|
|
80
|
-
await PDFNet.Convert.fileToHtml(inputPath + 'paragraphs_and_tables.pdf', outputFile, htmlOutputOptions);
|
|
81
|
-
|
|
82
|
-
console.log('Result saved in ' + outputFile);
|
|
83
|
-
} catch (err) {
|
|
84
|
-
console.log(err);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
//////////////////////////////////////////////////////////////////////////
|
|
88
|
-
|
|
89
|
-
try {
|
|
90
|
-
// Convert PDF document to HTML with reflow full option turned on (only converting the first page) (2)
|
|
91
|
-
console.log('Converting PDF to HTML with reflow full option turned on (only converting the first page) (2)');
|
|
92
|
-
|
|
93
|
-
const outputFile = outputPath + 'paragraphs_and_tables_reflow_full_first_page.html';
|
|
94
|
-
|
|
95
|
-
const htmlOutputOptions = new PDFNet.Convert.HTMLOutputOptions();
|
|
96
|
-
|
|
97
|
-
// Set e_reflow_full content reflow setting
|
|
98
|
-
htmlOutputOptions.setContentReflowSetting(PDFNet.Convert.HTMLOutputOptions.ContentReflowSetting.e_reflow_full);
|
|
99
|
-
|
|
100
|
-
// Convert only the first page
|
|
101
|
-
htmlOutputOptions.setPages(1, 1);
|
|
102
|
-
|
|
103
|
-
// Convert PDF to HTML
|
|
104
|
-
await PDFNet.Convert.fileToHtml(inputPath + 'paragraphs_and_tables.pdf', outputFile, htmlOutputOptions);
|
|
105
|
-
|
|
106
|
-
console.log('Result saved in ' + outputFile);
|
|
107
|
-
} catch (err) {
|
|
108
|
-
console.log(err);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
//////////////////////////////////////////////////////////////////////////
|
|
112
|
-
|
|
113
|
-
console.log('Done.');
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
|
|
117
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
118
|
-
}).then(function () { return PDFNet.shutdown(); });
|
|
119
|
-
};
|
|
120
|
-
exports.runPDF2HtmlTest();
|
|
121
|
-
})(exports);
|
|
122
|
-
// eslint-disable-next-line spaced-comment
|
|
123
|
-
//# sourceURL=PDF2HtmlTest.js
|
|
@@ -1,158 +0,0 @@
|
|
|
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 +0,0 @@
|
|
|
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,85 +0,0 @@
|
|
|
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 fs = require('fs');
|
|
7
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
8
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
9
|
-
|
|
10
|
-
((exports) => {
|
|
11
|
-
'use strict';
|
|
12
|
-
|
|
13
|
-
exports.runPDFDocMemoryTest = () => {
|
|
14
|
-
const main = async () => {
|
|
15
|
-
const outputPath = '../TestFiles/Output/';
|
|
16
|
-
|
|
17
|
-
// The following sample illustrates how to read/write a PDF document from/to
|
|
18
|
-
// a memory buffer. This is useful for applications that work with dynamic PDF
|
|
19
|
-
// documents that don't need to be saved/read from a disk.
|
|
20
|
-
try {
|
|
21
|
-
// Read a PDF document in a memory buffer.
|
|
22
|
-
const file = await PDFNet.Filter.createMappedFileFromUString('../TestFiles/tiger.pdf');
|
|
23
|
-
const file_sz = await file.mappedFileFileSize();
|
|
24
|
-
|
|
25
|
-
const file_reader = await PDFNet.FilterReader.create(file);
|
|
26
|
-
|
|
27
|
-
const mem = await file_reader.read(file_sz);
|
|
28
|
-
const doc = await PDFNet.PDFDoc.createFromBuffer(mem);
|
|
29
|
-
|
|
30
|
-
doc.initSecurityHandler();
|
|
31
|
-
const num_pages = await doc.getPageCount();
|
|
32
|
-
|
|
33
|
-
const writer = await PDFNet.ElementWriter.create();
|
|
34
|
-
const reader = await PDFNet.ElementReader.create();
|
|
35
|
-
|
|
36
|
-
// Create a duplicate of every page but copy only path objects
|
|
37
|
-
for (let i = 1; i <= num_pages; ++i) {
|
|
38
|
-
const itr = await doc.getPageIterator(2 * i - 1);
|
|
39
|
-
|
|
40
|
-
const cur_page = await itr.current();
|
|
41
|
-
reader.beginOnPage(cur_page);
|
|
42
|
-
const new_page = await doc.pageCreate(await cur_page.getMediaBox());
|
|
43
|
-
itr.next();
|
|
44
|
-
doc.pageInsert(itr, new_page);
|
|
45
|
-
|
|
46
|
-
writer.beginOnPage(new_page);
|
|
47
|
-
var element;
|
|
48
|
-
while (element = await reader.next()) { // Read page contents
|
|
49
|
-
writer.writeElement(element);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
await writer.end();
|
|
53
|
-
await reader.end();
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
doc.save(outputPath + 'doc_memory_edit.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
57
|
-
|
|
58
|
-
// Save the document to a memory buffer.
|
|
59
|
-
const docbuf = await doc.saveMemoryBuffer(PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
60
|
-
|
|
61
|
-
// Write the contents of the buffer to the disk
|
|
62
|
-
fs.appendFileSync(outputPath + 'doc_memory_edit.txt', docbuf);
|
|
63
|
-
|
|
64
|
-
let dataStr = ''
|
|
65
|
-
// Read some data from the file stored in memory
|
|
66
|
-
reader.beginOnPage(await doc.getPage(1));
|
|
67
|
-
while (element = await reader.next()) {
|
|
68
|
-
if (await element.getType() == PDFNet.Element.Type.e_path) dataStr += 'Path, ';
|
|
69
|
-
}
|
|
70
|
-
reader.end();
|
|
71
|
-
console.log(dataStr);
|
|
72
|
-
|
|
73
|
-
console.log('\nDone. Result saved in doc_memory_edit.pdf and doc_memory_edit.txt ...');
|
|
74
|
-
} catch (err) {
|
|
75
|
-
console.log(err);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
79
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
80
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
81
|
-
};
|
|
82
|
-
exports.runPDFDocMemoryTest();
|
|
83
|
-
})(exports);
|
|
84
|
-
// eslint-disable-next-line spaced-comment
|
|
85
|
-
//# sourceURL=PDFDocMemoryTest.js
|