@pdftron/pdfnet-node-samples 9.4.2 → 9.5.0-2-beta-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +18 -18
- package/readme.md +12 -12
- package/samples/AddImageTest/AddImageTest.js +2 -2
- package/samples/AdvancedImagingTest/AdvancedImagingTest.js +3 -3
- package/samples/AnnotationTest/AnnotationTest.js +2 -2
- package/samples/BookmarkTest/BookmarkTest.js +2 -2
- package/samples/CAD2PDFTest/CAD2PDFTest.js +79 -79
- package/samples/ContentReplacerTest/ContentReplacerTest.js +2 -2
- package/samples/ConvertTest/ConvertTest.js +270 -256
- package/samples/DataExtractionTest/DataExtractionTest.js +180 -0
- package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +526 -526
- package/samples/ElementBuilderTest/ElementBuilderTest.js +2 -2
- package/samples/ElementEditTest/ElementEditTest.js +2 -2
- package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +2 -2
- package/samples/ElementReaderTest/ElementReaderTest.js +2 -2
- package/samples/EncTest/EncTest.js +2 -2
- package/samples/FDFTest/FDFTest.js +218 -218
- package/samples/HTML2PDFTest/HTML2PDFTest.js +165 -165
- package/samples/HighlightsTest/HighlightsTest.js +2 -2
- package/samples/ImageExtractTest/ImageExtractTest.js +129 -129
- package/samples/ImpositionTest/ImpositionTest.js +86 -86
- package/samples/InteractiveFormsTest/InteractiveFormsTest.js +381 -381
- package/samples/JBIG2Test/JBIG2Test.js +88 -88
- package/samples/LogicalStructureTest/LogicalStructureTest.js +2 -2
- package/samples/OCRTest/OCRTest.js +234 -234
- package/samples/OfficeTemplateTest/OfficeTemplateTest.js +79 -77
- package/samples/OfficeToPDFTest/OfficeToPDFTest.js +125 -125
- package/samples/OptimizerTest/OptimizerTest.js +191 -191
- package/samples/PDF2HtmlTest/PDF2HtmlTest.js +3 -3
- package/samples/PDF2OfficeTest/PDF2OfficeTest.js +3 -3
- package/samples/PDFATest/PDFATest.js +2 -2
- package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +84 -84
- package/samples/PDFDrawTest/PDFDrawTest.js +2 -2
- package/samples/PDFLayersTest/PDFLayersTest.js +2 -2
- package/samples/PDFPackageTest/PDFPackageTest.js +111 -111
- package/samples/PDFPageTest/PDFPageTest.js +2 -2
- package/samples/PDFRedactTest/PDFRedactTest.js +2 -2
- package/samples/PageLabelsTest/PageLabelsTest.js +138 -138
- package/samples/PatternTest/PatternTest.js +226 -226
- package/samples/RectTest/RectTest.js +2 -2
- package/samples/SDFTest/SDFTest.js +3 -4
- package/samples/StamperTest/StamperTest.js +2 -2
- package/samples/TextExtractTest/TextExtractTest.js +2 -2
- package/samples/TextSearchTest/TextSearchTest.js +2 -2
- package/samples/U3DTest/U3DTest.js +104 -104
- package/samples/UndoRedoTest/UndoRedoTest.js +2 -2
- package/samples/UnicodeWriteTest/UnicodeWriteTest.js +2 -2
- package/samples/WebViewerConvertTest/WebViewerConvertTest.js +135 -135
- package/samples/runall.bat +6 -5
- package/samples/runall.sh +4 -5
- 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
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
// Please contact us if you have any questions.
|
|
20
20
|
//---------------------------------------------------------------------------------------
|
|
21
21
|
|
|
22
|
-
const { PDFNet } = require('
|
|
22
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
23
23
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
24
24
|
|
|
25
25
|
((exports) => {
|
|
@@ -50,7 +50,7 @@ const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
|
50
50
|
|
|
51
51
|
//////////////////////////////////////////////////////////////////////////
|
|
52
52
|
|
|
53
|
-
await PDFNet.addResourceSearchPath('
|
|
53
|
+
await PDFNet.addResourceSearchPath('../lib/');
|
|
54
54
|
|
|
55
55
|
if (!await PDFNet.StructuredOutputModule.isModuleAvailable()) {
|
|
56
56
|
console.log('\nUnable to run part of the sample: PDFTron SDK Structured Output module not available.');
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
// Please contact us if you have any questions.
|
|
17
17
|
//---------------------------------------------------------------------------------------
|
|
18
18
|
|
|
19
|
-
const { PDFNet } = require('
|
|
19
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
20
20
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
21
21
|
|
|
22
22
|
((exports) => {
|
|
@@ -31,7 +31,7 @@ const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
|
31
31
|
|
|
32
32
|
//////////////////////////////////////////////////////////////////////////
|
|
33
33
|
|
|
34
|
-
await PDFNet.addResourceSearchPath('
|
|
34
|
+
await PDFNet.addResourceSearchPath('../lib/');
|
|
35
35
|
|
|
36
36
|
if (!await PDFNet.StructuredOutputModule.isModuleAvailable()) {
|
|
37
37
|
console.log('\nUnable to run the sample: PDFTron SDK Structured Output module not available.');
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
6
|
-
const { PDFNet } = require('
|
|
6
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
7
7
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
8
8
|
|
|
9
9
|
((exports) => {
|
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
const fs = require('fs');
|
|
7
|
-
const { PDFNet } = require('
|
|
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
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
const fs = require('fs');
|
|
7
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
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
85
|
//# sourceURL=PDFDocMemoryTest.js
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
//---------------------------------------------------------------------------------------
|
|
11
11
|
|
|
12
12
|
const fs = require('fs');
|
|
13
|
-
const { PDFNet } = require('
|
|
13
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
14
14
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
15
15
|
|
|
16
16
|
((exports) => {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
// to process.
|
|
29
29
|
//-----------------------------------------------------------------------------------
|
|
30
30
|
|
|
31
|
-
const { PDFNet } = require('
|
|
31
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
32
32
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
33
33
|
|
|
34
34
|
((exports) => {
|
|
@@ -1,112 +1,112 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
3
|
-
// Consult legal.txt regarding legal and license information.
|
|
4
|
-
//---------------------------------------------------------------------------------------
|
|
5
|
-
|
|
6
|
-
//-----------------------------------------------------------------------------------
|
|
7
|
-
/// This sample illustrates how to create, extract, and manipulate PDF Portfolios
|
|
8
|
-
/// (a.k.a. PDF Packages) using PDFNet SDK.
|
|
9
|
-
//-----------------------------------------------------------------------------------
|
|
10
|
-
|
|
11
|
-
const { PDFNet } = require('
|
|
12
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
13
|
-
|
|
14
|
-
((exports) => {
|
|
15
|
-
'use strict';
|
|
16
|
-
|
|
17
|
-
exports.runPDFPackageTest = () => {
|
|
18
|
-
// Relative path to the folder containing test files.
|
|
19
|
-
const inputPath = '../TestFiles/';
|
|
20
|
-
const outputPath = inputPath + 'Output/';
|
|
21
|
-
|
|
22
|
-
const addPackage = async (doc, file, desc) => {
|
|
23
|
-
const files = await PDFNet.NameTree.create(doc, 'EmbeddedFiles');
|
|
24
|
-
const fs = await PDFNet.FileSpec.create(doc, file, true);
|
|
25
|
-
files.put(file, await fs.getSDFObj());
|
|
26
|
-
fs.setDesc(desc);
|
|
27
|
-
|
|
28
|
-
const root = await doc.getRoot();
|
|
29
|
-
let collection = await root.findObj('Collection');
|
|
30
|
-
if (!collection) collection = await root.putDict('Collection');
|
|
31
|
-
|
|
32
|
-
// You could here manipulate any entry in the Collection dictionary.
|
|
33
|
-
// For example, the following line sets the tile mode for initial view mode
|
|
34
|
-
// Please refer to section '2.3.5 Collections' in PDF Reference for details.
|
|
35
|
-
collection.putName('View', 'T');
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const addCoverPage = async (doc) => {
|
|
39
|
-
// Here we dynamically generate cover page (please see ElementBuilder
|
|
40
|
-
// sample for more extensive coverage of PDF creation API).
|
|
41
|
-
const page = await doc.pageCreate(await PDFNet.Rect.init(0, 0, 200, 200));
|
|
42
|
-
|
|
43
|
-
const b = await PDFNet.ElementBuilder.create();
|
|
44
|
-
const w = await PDFNet.ElementWriter.create();
|
|
45
|
-
w.beginOnPage(page);
|
|
46
|
-
const font = await PDFNet.Font.create(doc, PDFNet.Font.StandardType1Font.e_helvetica);
|
|
47
|
-
w.writeElement(await b.createTextBeginWithFont(font, 12));
|
|
48
|
-
const e = await b.createNewTextRun('My PDF Collection');
|
|
49
|
-
e.setTextMatrixEntries(1, 0, 0, 1, 50, 96);
|
|
50
|
-
const gstate = await e.getGState();
|
|
51
|
-
gstate.setFillColorSpace(await PDFNet.ColorSpace.createDeviceRGB());
|
|
52
|
-
gstate.setFillColorWithColorPt(await PDFNet.ColorPt.init(1, 0, 0));
|
|
53
|
-
w.writeElement(e);
|
|
54
|
-
w.writeElement(await b.createTextEnd());
|
|
55
|
-
w.end();
|
|
56
|
-
doc.pagePushBack(page);
|
|
57
|
-
|
|
58
|
-
// Alternatively we could import a PDF page from a template PDF document
|
|
59
|
-
// (for an example please see PDFPage sample project).
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
const main = async () => {
|
|
63
|
-
|
|
64
|
-
// Create a PDF Package.
|
|
65
|
-
try {
|
|
66
|
-
const doc = await PDFNet.PDFDoc.create();
|
|
67
|
-
await addPackage(doc, inputPath + 'numbered.pdf', 'My File 1');
|
|
68
|
-
await addPackage(doc, inputPath + 'newsletter.pdf', 'My Newsletter...');
|
|
69
|
-
await addPackage(doc, inputPath + 'peppers.jpg', 'An image');
|
|
70
|
-
await addCoverPage(doc);
|
|
71
|
-
await doc.save(outputPath + 'package.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
72
|
-
console.log('Done.');
|
|
73
|
-
} catch (err) {
|
|
74
|
-
console.log(err);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
try {
|
|
78
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputPath + 'package.pdf');
|
|
79
|
-
await doc.initSecurityHandler();
|
|
80
|
-
|
|
81
|
-
const files = await PDFNet.NameTree.find(doc, 'EmbeddedFiles');
|
|
82
|
-
if (await files.isValid()) {
|
|
83
|
-
// Traverse the list of embedded files.
|
|
84
|
-
const i = await files.getIteratorBegin();
|
|
85
|
-
for (var counter = 0; await i.hasNext(); await i.next(), ++counter) {
|
|
86
|
-
const entry_name = await i.key().then(key => key.getAsPDFText());
|
|
87
|
-
console.log('Part: ' + entry_name);
|
|
88
|
-
const file_spec = await PDFNet.FileSpec.createFromObj(await i.value());
|
|
89
|
-
const stm = await file_spec.getFileData();
|
|
90
|
-
if (stm) {
|
|
91
|
-
let ext = '.pdf';
|
|
92
|
-
if (entry_name.includes('.')) {
|
|
93
|
-
ext = entry_name.substr(entry_name.lastIndexOf('.'));
|
|
94
|
-
}
|
|
95
|
-
stm.writeToFile(outputPath + 'extract_' + counter + ext, false);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
console.log('Done.');
|
|
101
|
-
} catch (err) {
|
|
102
|
-
console.log(err);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
106
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
107
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
108
|
-
};
|
|
109
|
-
exports.runPDFPackageTest();
|
|
110
|
-
})(exports);
|
|
111
|
-
// eslint-disable-next-line spaced-comment
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//-----------------------------------------------------------------------------------
|
|
7
|
+
/// This sample illustrates how to create, extract, and manipulate PDF Portfolios
|
|
8
|
+
/// (a.k.a. PDF Packages) using PDFNet SDK.
|
|
9
|
+
//-----------------------------------------------------------------------------------
|
|
10
|
+
|
|
11
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
12
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
13
|
+
|
|
14
|
+
((exports) => {
|
|
15
|
+
'use strict';
|
|
16
|
+
|
|
17
|
+
exports.runPDFPackageTest = () => {
|
|
18
|
+
// Relative path to the folder containing test files.
|
|
19
|
+
const inputPath = '../TestFiles/';
|
|
20
|
+
const outputPath = inputPath + 'Output/';
|
|
21
|
+
|
|
22
|
+
const addPackage = async (doc, file, desc) => {
|
|
23
|
+
const files = await PDFNet.NameTree.create(doc, 'EmbeddedFiles');
|
|
24
|
+
const fs = await PDFNet.FileSpec.create(doc, file, true);
|
|
25
|
+
files.put(file, await fs.getSDFObj());
|
|
26
|
+
fs.setDesc(desc);
|
|
27
|
+
|
|
28
|
+
const root = await doc.getRoot();
|
|
29
|
+
let collection = await root.findObj('Collection');
|
|
30
|
+
if (!collection) collection = await root.putDict('Collection');
|
|
31
|
+
|
|
32
|
+
// You could here manipulate any entry in the Collection dictionary.
|
|
33
|
+
// For example, the following line sets the tile mode for initial view mode
|
|
34
|
+
// Please refer to section '2.3.5 Collections' in PDF Reference for details.
|
|
35
|
+
collection.putName('View', 'T');
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const addCoverPage = async (doc) => {
|
|
39
|
+
// Here we dynamically generate cover page (please see ElementBuilder
|
|
40
|
+
// sample for more extensive coverage of PDF creation API).
|
|
41
|
+
const page = await doc.pageCreate(await PDFNet.Rect.init(0, 0, 200, 200));
|
|
42
|
+
|
|
43
|
+
const b = await PDFNet.ElementBuilder.create();
|
|
44
|
+
const w = await PDFNet.ElementWriter.create();
|
|
45
|
+
w.beginOnPage(page);
|
|
46
|
+
const font = await PDFNet.Font.create(doc, PDFNet.Font.StandardType1Font.e_helvetica);
|
|
47
|
+
w.writeElement(await b.createTextBeginWithFont(font, 12));
|
|
48
|
+
const e = await b.createNewTextRun('My PDF Collection');
|
|
49
|
+
e.setTextMatrixEntries(1, 0, 0, 1, 50, 96);
|
|
50
|
+
const gstate = await e.getGState();
|
|
51
|
+
gstate.setFillColorSpace(await PDFNet.ColorSpace.createDeviceRGB());
|
|
52
|
+
gstate.setFillColorWithColorPt(await PDFNet.ColorPt.init(1, 0, 0));
|
|
53
|
+
w.writeElement(e);
|
|
54
|
+
w.writeElement(await b.createTextEnd());
|
|
55
|
+
w.end();
|
|
56
|
+
doc.pagePushBack(page);
|
|
57
|
+
|
|
58
|
+
// Alternatively we could import a PDF page from a template PDF document
|
|
59
|
+
// (for an example please see PDFPage sample project).
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const main = async () => {
|
|
63
|
+
|
|
64
|
+
// Create a PDF Package.
|
|
65
|
+
try {
|
|
66
|
+
const doc = await PDFNet.PDFDoc.create();
|
|
67
|
+
await addPackage(doc, inputPath + 'numbered.pdf', 'My File 1');
|
|
68
|
+
await addPackage(doc, inputPath + 'newsletter.pdf', 'My Newsletter...');
|
|
69
|
+
await addPackage(doc, inputPath + 'peppers.jpg', 'An image');
|
|
70
|
+
await addCoverPage(doc);
|
|
71
|
+
await doc.save(outputPath + 'package.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
72
|
+
console.log('Done.');
|
|
73
|
+
} catch (err) {
|
|
74
|
+
console.log(err);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
try {
|
|
78
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(outputPath + 'package.pdf');
|
|
79
|
+
await doc.initSecurityHandler();
|
|
80
|
+
|
|
81
|
+
const files = await PDFNet.NameTree.find(doc, 'EmbeddedFiles');
|
|
82
|
+
if (await files.isValid()) {
|
|
83
|
+
// Traverse the list of embedded files.
|
|
84
|
+
const i = await files.getIteratorBegin();
|
|
85
|
+
for (var counter = 0; await i.hasNext(); await i.next(), ++counter) {
|
|
86
|
+
const entry_name = await i.key().then(key => key.getAsPDFText());
|
|
87
|
+
console.log('Part: ' + entry_name);
|
|
88
|
+
const file_spec = await PDFNet.FileSpec.createFromObj(await i.value());
|
|
89
|
+
const stm = await file_spec.getFileData();
|
|
90
|
+
if (stm) {
|
|
91
|
+
let ext = '.pdf';
|
|
92
|
+
if (entry_name.includes('.')) {
|
|
93
|
+
ext = entry_name.substr(entry_name.lastIndexOf('.'));
|
|
94
|
+
}
|
|
95
|
+
stm.writeToFile(outputPath + 'extract_' + counter + ext, false);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
console.log('Done.');
|
|
101
|
+
} catch (err) {
|
|
102
|
+
console.log(err);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
106
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
107
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
108
|
+
};
|
|
109
|
+
exports.runPDFPackageTest();
|
|
110
|
+
})(exports);
|
|
111
|
+
// eslint-disable-next-line spaced-comment
|
|
112
112
|
//# sourceURL=PDFPackageTest.js
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
6
|
-
const { PDFNet } = require('
|
|
6
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
7
7
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
8
8
|
|
|
9
9
|
((exports) => {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
2
|
+
// Copyright (c) 2001-2023 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
3
|
// Consult legal.txt regarding legal and license information.
|
|
4
4
|
//---------------------------------------------------------------------------------------
|
|
5
5
|
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
// document, including XML Forms Architecture (XFA) content and Extensible Metadata
|
|
33
33
|
// Platform (XMP) content.
|
|
34
34
|
|
|
35
|
-
const { PDFNet } = require('
|
|
35
|
+
const { PDFNet } = require('../lib/pdfnet.js');
|
|
36
36
|
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
37
37
|
|
|
38
38
|
((exports) => {
|