@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,220 +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 sample code illustrates how to read and edit existing outline items and create
|
|
8
|
-
// new bookmarks using the high-level API.
|
|
9
|
-
//-----------------------------------------------------------------------------------------
|
|
10
|
-
|
|
11
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
12
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
13
|
-
|
|
14
|
-
((exports) => {
|
|
15
|
-
|
|
16
|
-
exports.runBookmarkTest = () => {
|
|
17
|
-
|
|
18
|
-
const getIndent = async (item) => {
|
|
19
|
-
const ident = (await item.getIndent()) - 1;
|
|
20
|
-
let str = '';
|
|
21
|
-
for (let i = 0; i < ident; ++i) {
|
|
22
|
-
str += ' ';
|
|
23
|
-
}
|
|
24
|
-
return str;
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
// Prints out the outline tree to the standard output
|
|
28
|
-
const printOutlineTree = async (item) => {
|
|
29
|
-
for (; item != null; item = await item.getNext()) {
|
|
30
|
-
const indentString = await getIndent(item);
|
|
31
|
-
const titleString = await item.getTitle();
|
|
32
|
-
|
|
33
|
-
const actionString = indentString + (await item.isOpen() ? '- ' : '+ ') + titleString + ' ACTION -> ';
|
|
34
|
-
|
|
35
|
-
// Print Action
|
|
36
|
-
const action = await item.getAction();
|
|
37
|
-
if (await action.isValid()) {
|
|
38
|
-
const actionType = await action.getType();
|
|
39
|
-
if (actionType === PDFNet.Action.Type.e_GoTo) {
|
|
40
|
-
const dest = await action.getDest();
|
|
41
|
-
if (await dest.isValid()) {
|
|
42
|
-
const page = await dest.getPage();
|
|
43
|
-
console.log(actionString + 'GoTo Page #' + (await page.getIndex()));
|
|
44
|
-
}
|
|
45
|
-
} else {
|
|
46
|
-
console.log(actionString + 'Not a "GoTo" action');
|
|
47
|
-
}
|
|
48
|
-
} else {
|
|
49
|
-
console.log(actionString + 'NULL');
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (await item.hasChildren()) {
|
|
53
|
-
await printOutlineTree(await item.getFirstChild());
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
const main = async () => {
|
|
59
|
-
// Relative path to the folder containing test files.
|
|
60
|
-
const inputPath = '../TestFiles/';
|
|
61
|
-
const outputPath = inputPath + 'Output/';
|
|
62
|
-
|
|
63
|
-
// The following example illustrates how to create and edit the outline tree
|
|
64
|
-
// using high-level Bookmark methods.
|
|
65
|
-
try {
|
|
66
|
-
let doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'numbered.pdf');
|
|
67
|
-
doc.initSecurityHandler();
|
|
68
|
-
|
|
69
|
-
// Lets first create the root bookmark items.
|
|
70
|
-
const red = await PDFNet.Bookmark.create(doc, 'Red');
|
|
71
|
-
const green = await PDFNet.Bookmark.create(doc, 'Green');
|
|
72
|
-
const blue = await PDFNet.Bookmark.create(doc, 'Blue');
|
|
73
|
-
|
|
74
|
-
doc.addRootBookmark(red);
|
|
75
|
-
doc.addRootBookmark(green);
|
|
76
|
-
doc.addRootBookmark(blue);
|
|
77
|
-
|
|
78
|
-
// You can also add new root bookmarks using Bookmark.addNext("...")
|
|
79
|
-
blue.addNewNext('foo');
|
|
80
|
-
blue.addNewNext('bar');
|
|
81
|
-
|
|
82
|
-
// We can now associate new bookmarks with page destinations:
|
|
83
|
-
|
|
84
|
-
// The following example creates an 'explicit' destination (see
|
|
85
|
-
// section '8.2.1 Destinations' in PDF Reference for more details)
|
|
86
|
-
const redIter = await doc.getPageIterator(1);
|
|
87
|
-
const redCurrpage = await redIter.current();
|
|
88
|
-
const redDest = await PDFNet.Destination.createFit(redCurrpage);
|
|
89
|
-
red.setAction(await PDFNet.Action.createGoto(redDest));
|
|
90
|
-
|
|
91
|
-
// Create an explicit destination to the first green page in the document
|
|
92
|
-
const tenthPage = await doc.getPage(10);
|
|
93
|
-
const greenDest = await PDFNet.Destination.createFit(tenthPage);
|
|
94
|
-
green.setAction(await PDFNet.Action.createGoto(greenDest));
|
|
95
|
-
|
|
96
|
-
// The following example creates a 'named' destination (see
|
|
97
|
-
// section '8.2.1 Destinations' in PDF Reference for more details)
|
|
98
|
-
// Named destinations have certain advantages over explicit destinations.
|
|
99
|
-
const key = 'blue1';
|
|
100
|
-
const nineteenthPage = await doc.getPage(19);
|
|
101
|
-
const blueDest = await PDFNet.Destination.createFit(nineteenthPage);
|
|
102
|
-
const blueAction = await PDFNet.Action.createGotoWithKey(key, blueDest); // TODO FIND FIX
|
|
103
|
-
|
|
104
|
-
blue.setAction(blueAction);
|
|
105
|
-
|
|
106
|
-
// We can now add children Bookmarks subRed1 instanceof Promise
|
|
107
|
-
const subRed1 = await red.addNewChild('Red - Page 1');
|
|
108
|
-
subRed1.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(1))));
|
|
109
|
-
const subRed2 = await red.addNewChild('Red - Page 2');
|
|
110
|
-
subRed2.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(2))));
|
|
111
|
-
const subRed3 = await red.addNewChild('Red - Page 3');
|
|
112
|
-
subRed3.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(3))));
|
|
113
|
-
const subRed4 = await subRed3.addNewChild('Red - Page 4');
|
|
114
|
-
subRed4.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(4))));
|
|
115
|
-
const subRed5 = await subRed3.addNewChild('Red - Page 5');
|
|
116
|
-
subRed5.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(5))));
|
|
117
|
-
const subRed6 = await subRed3.addNewChild('Red - Page 6');
|
|
118
|
-
subRed6.setAction(await PDFNet.Action.createGoto(await PDFNet.Destination.createFit(await doc.getPage(6))));
|
|
119
|
-
|
|
120
|
-
// Example of how to find and delete a bookmark by title text.
|
|
121
|
-
const firstbookmark = await doc.getFirstBookmark();
|
|
122
|
-
const foo = await firstbookmark.find('foo');
|
|
123
|
-
if (await foo.isValid()) {
|
|
124
|
-
foo.delete();
|
|
125
|
-
} else {
|
|
126
|
-
console.log('Bookmark foo is invalid');
|
|
127
|
-
}
|
|
128
|
-
const bar = await firstbookmark.find('bar');
|
|
129
|
-
if (await bar.isValid()) {
|
|
130
|
-
bar.delete();
|
|
131
|
-
} else {
|
|
132
|
-
console.log('Bookmark bar is invalid');
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
// Adding color to Bookmarks. Color and other formatting can help readers
|
|
136
|
-
// get around more easily in large PDF documents.
|
|
137
|
-
red.setColor(1, 0, 0);
|
|
138
|
-
green.setColor(0, 1, 0);
|
|
139
|
-
green.setFlags(2); // set bold font
|
|
140
|
-
blue.setColor(0, 0, 1);
|
|
141
|
-
blue.setFlags(3); // set bold and italic
|
|
142
|
-
|
|
143
|
-
await doc.save(outputPath + 'bookmark.pdf', 0);
|
|
144
|
-
console.log('Done. Result saved in bookmark.pdf');
|
|
145
|
-
} catch (err) {
|
|
146
|
-
console.log(err);
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
// The following example illustrates how to traverse the outline tree using
|
|
150
|
-
// Bookmark navigation methods: Bookmark.getNext(), Bookmark.getPrev(),
|
|
151
|
-
// Bookmark.getFirstChild () and Bookmark.getLastChild ().
|
|
152
|
-
try {
|
|
153
|
-
// Open the document that was saved in the previous code sample
|
|
154
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputPath + 'bookmark.pdf');
|
|
155
|
-
doc.initSecurityHandler();
|
|
156
|
-
|
|
157
|
-
const root = await doc.getFirstBookmark();
|
|
158
|
-
await printOutlineTree(root);
|
|
159
|
-
|
|
160
|
-
console.log('Done.');
|
|
161
|
-
} catch (err) {
|
|
162
|
-
console.log(err);
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
// The following example illustrates how to create a Bookmark to a page
|
|
166
|
-
// in a remote document. A remote go-to action is similar to an ordinary
|
|
167
|
-
// go-to action, but jumps to a destination in another PDF file instead
|
|
168
|
-
// of the current file. See Section 8.5.3 'Remote Go-To Actions' in PDF
|
|
169
|
-
// Reference Manual for details.
|
|
170
|
-
|
|
171
|
-
try {
|
|
172
|
-
// Open the document that was saved in the previous code sample
|
|
173
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputPath + 'bookmark.pdf');
|
|
174
|
-
doc.initSecurityHandler();
|
|
175
|
-
|
|
176
|
-
// Create file specification (the file referred to by the remote bookmark)
|
|
177
|
-
const fileSpec = await doc.createIndirectDict();
|
|
178
|
-
fileSpec.putName('Type', 'Filespec');
|
|
179
|
-
fileSpec.putString('F', 'bookmark.pdf');
|
|
180
|
-
const spec = await PDFNet.FileSpec.createFromObj(fileSpec);
|
|
181
|
-
const gotoRemote = await PDFNet.Action.createGotoRemoteSetNewWindow(spec, 5, true);
|
|
182
|
-
|
|
183
|
-
const remoteBookmark1 = await PDFNet.Bookmark.create(doc, 'REMOTE BOOKMARK 1');
|
|
184
|
-
remoteBookmark1.setAction(gotoRemote);
|
|
185
|
-
doc.addRootBookmark(remoteBookmark1);
|
|
186
|
-
|
|
187
|
-
// Create another remote bookmark, but this time using the low-level SDF/Cos API.
|
|
188
|
-
// Create a remote action
|
|
189
|
-
const remoteBookmark2 = await PDFNet.Bookmark.create(doc, 'REMOTE BOOKMARK 2');
|
|
190
|
-
doc.addRootBookmark(remoteBookmark2);
|
|
191
|
-
|
|
192
|
-
const gotoR = await (await remoteBookmark2.getSDFObj()).putDict('A');
|
|
193
|
-
{
|
|
194
|
-
gotoR.putName('S', 'GoToR'); // Set action type
|
|
195
|
-
gotoR.putBool('NewWindow', true);
|
|
196
|
-
|
|
197
|
-
// Set the file specification
|
|
198
|
-
gotoR.put('F', fileSpec);
|
|
199
|
-
|
|
200
|
-
// jump to the first page. Note that pages are indexed from 0.
|
|
201
|
-
const dest = await gotoR.putArray('D');
|
|
202
|
-
dest.pushBackNumber(9);
|
|
203
|
-
dest.pushBackName('Fit');
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
await doc.save(inputPath + 'Output/bookmark_remote.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
207
|
-
|
|
208
|
-
console.log('Done. Result saved in bookmark_remote.pdf');
|
|
209
|
-
} catch (err) {
|
|
210
|
-
console.log(err);
|
|
211
|
-
}
|
|
212
|
-
};
|
|
213
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
|
|
214
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
215
|
-
}).then(function () { return PDFNet.shutdown(); });
|
|
216
|
-
};
|
|
217
|
-
exports.runBookmarkTest();
|
|
218
|
-
})(exports);
|
|
219
|
-
// eslint-disable-next-line spaced-comment
|
|
220
|
-
//# sourceURL=BookmarkTest.js
|
|
@@ -1,80 +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
|
-
//---------------------------------------------------------------------------------------
|
|
8
|
-
// The following sample illustrates how to convert CAD documents to PDF format
|
|
9
|
-
//
|
|
10
|
-
// The CAD module is an optional PDFNet Add-on that can be used to convert CAD
|
|
11
|
-
// documents into PDF documents
|
|
12
|
-
//
|
|
13
|
-
// The PDFTron SDK CAD module can be downloaded from http://www.pdftron.com/
|
|
14
|
-
//---------------------------------------------------------------------------------------
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
18
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
19
|
-
|
|
20
|
-
((exports) => {
|
|
21
|
-
'use strict';
|
|
22
|
-
|
|
23
|
-
exports.runCAD2PDFTest = () => {
|
|
24
|
-
const IsRVTFile = function (inputFile) {
|
|
25
|
-
let rvt_input = false;
|
|
26
|
-
if (inputFile.length > 2) {
|
|
27
|
-
if (inputFile.substr(inputFile.length - 3, 3) === 'rvt') {
|
|
28
|
-
rvt_input = true;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
return rvt_input;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
const main = async () => {
|
|
35
|
-
try {
|
|
36
|
-
await PDFNet.addResourceSearchPath('../../lib/');
|
|
37
|
-
if (!(await PDFNet.CADModule.isModuleAvailable())) {
|
|
38
|
-
console.log('\nUnable to run CAD2PDFTest: PDFTron SDK CAD module not available.');
|
|
39
|
-
console.log('---------------------------------------------------------------');
|
|
40
|
-
console.log('The CAD module is an optional add-on, available for download');
|
|
41
|
-
console.log('at http://www.pdftron.com/. If you have already downloaded this');
|
|
42
|
-
console.log('module, ensure that the SDK is able to find the required files');
|
|
43
|
-
console.log('using the PDFNet.addResourceSearchPath() function.\n');
|
|
44
|
-
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
// Relative path to the folder containing test files.
|
|
49
|
-
const inputPath = '../TestFiles/CAD/';
|
|
50
|
-
const outputPath = '../TestFiles/Output/';
|
|
51
|
-
|
|
52
|
-
const input_file_name = 'construction drawings color-28.05.18.dwg';
|
|
53
|
-
const output_file_name = 'construction drawings color-28.05.18.pdf';
|
|
54
|
-
|
|
55
|
-
const doc = await PDFNet.PDFDoc.create();
|
|
56
|
-
doc.initSecurityHandler();
|
|
57
|
-
|
|
58
|
-
if (IsRVTFile(input_file_name)) {
|
|
59
|
-
const opts = new PDFNet.Convert.CADConvertOptions();
|
|
60
|
-
opts.setPageWidth(800);
|
|
61
|
-
opts.setPageHeight(600);
|
|
62
|
-
opts.setRasterDPI(150);
|
|
63
|
-
await PDFNet.Convert.fromCAD(doc, inputPath + input_file_name, opts);
|
|
64
|
-
} else {
|
|
65
|
-
await PDFNet.Convert.fromCAD(doc, inputPath + input_file_name);
|
|
66
|
-
}
|
|
67
|
-
const outputFile = outputPath + output_file_name;
|
|
68
|
-
await doc.save(outputFile, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
69
|
-
} catch (err) {
|
|
70
|
-
console.log(err);
|
|
71
|
-
}
|
|
72
|
-
};
|
|
73
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
74
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
75
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
76
|
-
};
|
|
77
|
-
exports.runCAD2PDFTest();
|
|
78
|
-
})(exports);
|
|
79
|
-
// eslint-disable-next-line spaced-comment
|
|
80
|
-
//# sourceURL=CAD2PDFTest.js
|
|
@@ -1,75 +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
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
8
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
9
|
-
|
|
10
|
-
((exports) => {
|
|
11
|
-
|
|
12
|
-
exports.runContentReplacer = () => {
|
|
13
|
-
|
|
14
|
-
const main = async() => {
|
|
15
|
-
const inputPath = '../TestFiles/';
|
|
16
|
-
const outputPath = inputPath + 'Output/';
|
|
17
|
-
|
|
18
|
-
try {
|
|
19
|
-
const inputFilename = 'BusinessCardTemplate.pdf';
|
|
20
|
-
const outputFilename = 'BusinessCard.pdf';
|
|
21
|
-
|
|
22
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename);
|
|
23
|
-
doc.initSecurityHandler();
|
|
24
|
-
|
|
25
|
-
const replacer = await PDFNet.ContentReplacer.create();
|
|
26
|
-
const page = await doc.getPage(1);
|
|
27
|
-
const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
|
|
28
|
-
|
|
29
|
-
const region = await page.getMediaBox();
|
|
30
|
-
const replace = await img.getSDFObj();
|
|
31
|
-
await replacer.addImage(region, replace);
|
|
32
|
-
await replacer.addString('NAME', 'John Smith');
|
|
33
|
-
await replacer.addString('QUALIFICATIONS', 'Philosophy Doctor');
|
|
34
|
-
await replacer.addString('JOB_TITLE', 'Software Developer');
|
|
35
|
-
await replacer.addString('ADDRESS_LINE1', '#100 123 Software Rd');
|
|
36
|
-
await replacer.addString('ADDRESS_LINE2', 'Vancouver, BC');
|
|
37
|
-
await replacer.addString('PHONE_OFFICE', '604-730-8989');
|
|
38
|
-
await replacer.addString('PHONE_MOBILE', '604-765-4321');
|
|
39
|
-
await replacer.addString('EMAIL', 'info@pdftron.com');
|
|
40
|
-
await replacer.addString('WEBSITE_URL', 'http://www.pdftron.com');
|
|
41
|
-
await replacer.process(page);
|
|
42
|
-
|
|
43
|
-
await doc.save(outputPath + outputFilename, PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
44
|
-
|
|
45
|
-
console.log('Done. Result saved in ' + outputFilename);
|
|
46
|
-
} catch (err) {
|
|
47
|
-
console.log(err);
|
|
48
|
-
}
|
|
49
|
-
try {
|
|
50
|
-
const inputFilename = 'newsletter.pdf';
|
|
51
|
-
const outputFilename = 'ContentReplaced.pdf';
|
|
52
|
-
|
|
53
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + inputFilename);
|
|
54
|
-
doc.initSecurityHandler();
|
|
55
|
-
|
|
56
|
-
const replacer = await PDFNet.ContentReplacer.create();
|
|
57
|
-
const page = await doc.getPage(1);
|
|
58
|
-
const region = await page.getMediaBox();
|
|
59
|
-
await replacer.addText(region, 'hello hello hello hello hello hello hello hello hello hello');
|
|
60
|
-
await replacer.process(page);
|
|
61
|
-
|
|
62
|
-
await doc.save(outputPath + outputFilename, PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
63
|
-
|
|
64
|
-
console.log('Done. Result saved in ' + outputFilename);
|
|
65
|
-
} catch (err) {
|
|
66
|
-
console.log(err);
|
|
67
|
-
}
|
|
68
|
-
console.log('Done.');
|
|
69
|
-
};
|
|
70
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
|
|
71
|
-
};
|
|
72
|
-
exports.runContentReplacer();
|
|
73
|
-
})(exports);
|
|
74
|
-
// eslint-disable-next-line spaced-comment
|
|
75
|
-
//# sourceURL=ContentReplacerTest.js
|
|
@@ -1,256 +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 PDF, XPS, SVG, or EMF.
|
|
9
|
-
//
|
|
10
|
-
// Certain file formats such as XPS, EMF, PDF, and raster image formats can be directly
|
|
11
|
-
// converted to PDF or XPS. Other formats are converted using a virtual driver. To check
|
|
12
|
-
// if ToPDF (or ToXPS) require that PDFNet printer is installed use Convert::RequiresPrinter(filename).
|
|
13
|
-
// The installing application must be run as administrator. The manifest for this sample
|
|
14
|
-
// specifies appropriate the UAC elevation.
|
|
15
|
-
//
|
|
16
|
-
// Note: the PDFNet printer is a virtual XPS printer supported on Vista SP1 and Windows 7.
|
|
17
|
-
// For Windows XP SP2 or higher, or Vista SP0 you need to install the XPS Essentials Pack (or
|
|
18
|
-
// equivalent redistributables). You can download the XPS Essentials Pack from:
|
|
19
|
-
// http://www.microsoft.com/downloads/details.aspx?FamilyId=B8DCFFDD-E3A5-44CC-8021-7649FD37FFEE&displaylang=en
|
|
20
|
-
// Windows XP Sp2 will also need the Microsoft Core XML Services (MSXML) 6.0:
|
|
21
|
-
// http://www.microsoft.com/downloads/details.aspx?familyid=993C0BCF-3BCF-4009-BE21-27E85E1857B1&displaylang=en
|
|
22
|
-
//
|
|
23
|
-
// Note: Convert.FromEmf and Convert.ToEmf will only work on Windows and require GDI+.
|
|
24
|
-
//
|
|
25
|
-
// Please contact us if you have any questions.
|
|
26
|
-
//---------------------------------------------------------------------------------------
|
|
27
|
-
|
|
28
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
29
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
30
|
-
|
|
31
|
-
((exports) => {
|
|
32
|
-
'use strict';
|
|
33
|
-
|
|
34
|
-
let Testfile = function (inputFile, outputFile, requiresWindowsPlatform) {
|
|
35
|
-
this.inputFile = inputFile;
|
|
36
|
-
this.outputFile = outputFile;
|
|
37
|
-
this.requiresWindowsPlatform = requiresWindowsPlatform;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const testfiles = [
|
|
41
|
-
new Testfile('simple-word_2007.docx', 'docx2pdf.pdf', false),
|
|
42
|
-
new Testfile('simple-powerpoint_2007.pptx', 'pptx2pdf.pdf', false),
|
|
43
|
-
new Testfile('simple-excel_2007.xlsx', 'xlsx2pdf.pdf', false),
|
|
44
|
-
new Testfile('simple-publisher.pub', 'pub2pdf.pdf', true),
|
|
45
|
-
new Testfile('simple-text.txt', 'txt2pdf.pdf', false),
|
|
46
|
-
new Testfile('simple-rtf.rtf', 'rtf2pdf.pdf', true),
|
|
47
|
-
new Testfile('butterfly.png', 'png2pdf.pdf', false),
|
|
48
|
-
new Testfile('simple-emf.emf', 'emf2pdf.pdf', true),
|
|
49
|
-
new Testfile('simple-xps.xps', 'xps2pdf.pdf', false),
|
|
50
|
-
new Testfile('simple-webpage.html', 'html2pdf.pdf', true),
|
|
51
|
-
]
|
|
52
|
-
|
|
53
|
-
const inputPath = '../TestFiles/';
|
|
54
|
-
const outputPath = '../TestFiles/Output/';
|
|
55
|
-
|
|
56
|
-
exports.runConvertTest = () => {
|
|
57
|
-
|
|
58
|
-
const main = async () => {
|
|
59
|
-
try {
|
|
60
|
-
await convertToPdfFromFile();
|
|
61
|
-
console.log('ConvertFile succeeded');
|
|
62
|
-
} catch (err) {
|
|
63
|
-
console.log('ConvertFile failed');
|
|
64
|
-
console.log(err);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
try {
|
|
68
|
-
await convertSpecificFormats();
|
|
69
|
-
console.log('ConvertSpecificFormats succeeded');
|
|
70
|
-
} catch (err) {
|
|
71
|
-
console.log('ConvertSpecificFormats failed');
|
|
72
|
-
console.log(err);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
if (process.platform === 'win32' && await PDFNet.Convert.printerIsInstalled()) {
|
|
76
|
-
try {
|
|
77
|
-
console.log('Uninstalling printer (requires Windows platform and administrator)');
|
|
78
|
-
await PDFNet.Convert.printerUninstall();
|
|
79
|
-
console.log('Uninstalled printer ' + await PDFNet.Convert.printerGetPrinterName());
|
|
80
|
-
} catch (err) {
|
|
81
|
-
console.log('Unable to uninstall printer');
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
console.log('Done.');
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
const convertToPdfFromFile = async () => {
|
|
89
|
-
if (process.platform === 'win32') {
|
|
90
|
-
if (await PDFNet.Convert.printerIsInstalled('PDFTron PDFNet')) {
|
|
91
|
-
await PDFNet.Convert.printerSetPrinterName('PDFTron PDFNet');
|
|
92
|
-
} else if (!(await PDFNet.Convert.printerIsInstalled())) {
|
|
93
|
-
try {
|
|
94
|
-
// This will fail if not run as administrator. Harmless if PDFNet
|
|
95
|
-
// printer already installed
|
|
96
|
-
console.log('Installing printer (requires Windows platform and administrator)');
|
|
97
|
-
await PDFNet.Convert.printerInstall();
|
|
98
|
-
console.log('Installed printer ' + await PDFNet.Convert.printerGetPrinterName());
|
|
99
|
-
} catch (err) {
|
|
100
|
-
console.log('Unable to install printer');
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
for (const testfile of testfiles) {
|
|
106
|
-
if (process.platform !== 'win32' && testfile.requiresWindowsPlatform) continue;
|
|
107
|
-
|
|
108
|
-
try {
|
|
109
|
-
const pdfdoc = await PDFNet.PDFDoc.create();
|
|
110
|
-
await pdfdoc.initSecurityHandler();
|
|
111
|
-
const inputFile = inputPath + testfile.inputFile;
|
|
112
|
-
const outputFile = outputPath + testfile.outputFile;
|
|
113
|
-
if (await PDFNet.Convert.requiresPrinter(inputFile)) {
|
|
114
|
-
console.log('Using PDFNet printer to convert file ' + testfile.inputFile);
|
|
115
|
-
}
|
|
116
|
-
await PDFNet.Convert.toPdf(pdfdoc, inputFile);
|
|
117
|
-
await pdfdoc.save(outputFile, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
118
|
-
console.log('Converted file: ' + testfile.inputFile + '\nto: ' + testfile.outputFile);
|
|
119
|
-
} catch (err) {
|
|
120
|
-
console.log('Unable to convert file ' + testfile.inputFile);
|
|
121
|
-
console.log(err);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
const convertSpecificFormats = async () => {
|
|
127
|
-
try {
|
|
128
|
-
const pdfdoc = await PDFNet.PDFDoc.create();
|
|
129
|
-
await pdfdoc.initSecurityHandler();
|
|
130
|
-
|
|
131
|
-
console.log('Converting from XPS');
|
|
132
|
-
await PDFNet.Convert.fromXps(pdfdoc, inputPath + 'simple-xps.xps');
|
|
133
|
-
await pdfdoc.save(outputPath + 'xps2pdf v2.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
134
|
-
console.log('Saved xps2pdf v2.pdf');
|
|
135
|
-
} catch (err) {
|
|
136
|
-
console.log(err);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
if (process.platform === 'win32') {
|
|
140
|
-
try {
|
|
141
|
-
const pdfdoc = await PDFNet.PDFDoc.create();
|
|
142
|
-
await pdfdoc.initSecurityHandler();
|
|
143
|
-
|
|
144
|
-
console.log('Converting from EMF');
|
|
145
|
-
await PDFNet.Convert.fromEmf(pdfdoc, inputPath + 'simple-emf.emf');
|
|
146
|
-
await pdfdoc.save(outputPath + 'emf2pdf v2.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
147
|
-
console.log('Saved emf2pdf v2.pdf');
|
|
148
|
-
} catch (err) {
|
|
149
|
-
console.log(err);
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
try {
|
|
154
|
-
const pdfdoc = await PDFNet.PDFDoc.create();
|
|
155
|
-
await pdfdoc.initSecurityHandler();
|
|
156
|
-
|
|
157
|
-
// Add a dictionary
|
|
158
|
-
const set = await PDFNet.ObjSet.create();
|
|
159
|
-
const options = await set.createDict();
|
|
160
|
-
|
|
161
|
-
// Put options
|
|
162
|
-
options.putNumber('FontSize', 15);
|
|
163
|
-
options.putBool('UseSourceCodeFormatting', true);
|
|
164
|
-
options.putNumber('PageWidth', 12);
|
|
165
|
-
await options.putNumber('PageHeight', 6);
|
|
166
|
-
|
|
167
|
-
// Convert from .txt file
|
|
168
|
-
console.log('Converting from txt');
|
|
169
|
-
await PDFNet.Convert.fromText(pdfdoc, inputPath + 'simple-text.txt', options);
|
|
170
|
-
await pdfdoc.save(outputPath + 'simple-text.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused);
|
|
171
|
-
console.log('Saved simple-text.pdf');
|
|
172
|
-
} catch (err) {
|
|
173
|
-
console.log(err);
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
try {
|
|
177
|
-
const pdfdoc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
|
|
178
|
-
await pdfdoc.initSecurityHandler();
|
|
179
|
-
|
|
180
|
-
// Convert PDF document to SVG
|
|
181
|
-
console.log('Converting pdfdoc to SVG');
|
|
182
|
-
await PDFNet.Convert.docToSvg(pdfdoc, outputPath + 'pdf2svg v2.svg');
|
|
183
|
-
console.log('Saved pdf2svg v2.svg');
|
|
184
|
-
} catch (err) {
|
|
185
|
-
console.log(err);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
try {
|
|
189
|
-
// Convert PNG image to XPS
|
|
190
|
-
console.log('Converting PNG to XPS');
|
|
191
|
-
await PDFNet.Convert.fileToXps(inputPath + 'butterfly.png', outputPath + 'butterfly.xps');
|
|
192
|
-
console.log('Saved butterfly.xps');
|
|
193
|
-
} catch (err) {
|
|
194
|
-
console.log(err);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
if (process.platform === 'win32') {
|
|
198
|
-
try {
|
|
199
|
-
// Convert MSWord document to XPS
|
|
200
|
-
console.log('Converting DOCX to XPS');
|
|
201
|
-
await PDFNet.Convert.fileToXps(inputPath + 'simple-word_2007.docx', outputPath + 'simple-word_2007.xps');
|
|
202
|
-
console.log('Saved simple-word_2007.xps');
|
|
203
|
-
} catch (err) {
|
|
204
|
-
console.log(err);
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
try {
|
|
209
|
-
// Convert PDF document to XPS
|
|
210
|
-
console.log('Converting PDF to XPS');
|
|
211
|
-
await PDFNet.Convert.fileToXps(inputPath + 'newsletter.pdf', outputPath + 'newsletter.xps');
|
|
212
|
-
console.log('Saved newsletter.xps');
|
|
213
|
-
} catch (err) {
|
|
214
|
-
console.log(err);
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
try {
|
|
218
|
-
// Convert PDF document to HTML
|
|
219
|
-
console.log('Converting PDF to HTML');
|
|
220
|
-
await PDFNet.Convert.fileToHtml(inputPath + 'newsletter.pdf', outputPath + 'newsletter');
|
|
221
|
-
console.log('Saved newsletter as HTML');
|
|
222
|
-
} catch (err) {
|
|
223
|
-
console.log(err);
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
try {
|
|
227
|
-
// Convert PDF document to EPUB
|
|
228
|
-
console.log('Converting PDF to EPUB');
|
|
229
|
-
await PDFNet.Convert.fileToEpub(inputPath + 'newsletter.pdf', outputPath + 'newsletter.epub');
|
|
230
|
-
console.log('Saved newsletter.epub');
|
|
231
|
-
} catch (err) {
|
|
232
|
-
console.log(err);
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
try {
|
|
236
|
-
// Convert PDF document to multipage TIFF
|
|
237
|
-
console.log('Converting PDF to multipage TIFF');
|
|
238
|
-
const tiff_options = new PDFNet.Convert.TiffOutputOptions();
|
|
239
|
-
tiff_options.setDPI(200);
|
|
240
|
-
tiff_options.setDither(true);
|
|
241
|
-
tiff_options.setMono(true);
|
|
242
|
-
|
|
243
|
-
await PDFNet.Convert.fileToTiff(inputPath + 'newsletter.pdf', outputPath + 'newsletter.tiff', tiff_options);
|
|
244
|
-
console.log('Saved newsletter.tiff');
|
|
245
|
-
} catch (err) {
|
|
246
|
-
console.log(err);
|
|
247
|
-
}
|
|
248
|
-
};
|
|
249
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
250
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
251
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
252
|
-
};
|
|
253
|
-
exports.runConvertTest();
|
|
254
|
-
})(exports);
|
|
255
|
-
// eslint-disable-next-line spaced-comment
|
|
256
|
-
//# sourceURL=ConvertTest.js
|