@pdftron/pdfnet-node-samples 9.4.2 → 9.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +18 -18
- package/readme.md +12 -12
- package/samples/AddImageTest/AddImageTest.js +1 -1
- package/samples/AddImageTest/NODEJS/AddImageTest.js +116 -0
- package/samples/AddImageTest/NODEJS/RunTest.sh +2 -0
- package/samples/AdvancedImagingTest/AdvancedImagingTest.js +1 -1
- package/samples/AdvancedImagingTest/NODEJS/AdvancedImagingTest.js +78 -0
- package/samples/AdvancedImagingTest/NODEJS/RunTest.sh +2 -0
- package/samples/AnnotationTest/AnnotationTest.js +1 -1
- package/samples/AnnotationTest/NODEJS/AnnotationTest.js +642 -0
- package/samples/AnnotationTest/NODEJS/RunTest.sh +2 -0
- package/samples/BookmarkTest/BookmarkTest.js +1 -1
- package/samples/BookmarkTest/NODEJS/BookmarkTest.js +220 -0
- package/samples/BookmarkTest/NODEJS/RunTest.sh +2 -0
- package/samples/CAD2PDFTest/CAD2PDFTest.js +79 -79
- package/samples/CAD2PDFTest/NODEJS/CAD2PDFTest.js +80 -0
- package/samples/CAD2PDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/ContentReplacerTest/ContentReplacerTest.js +1 -1
- package/samples/ContentReplacerTest/NODEJS/ContentReplacerTest.js +75 -0
- package/samples/ContentReplacerTest/NODEJS/RunTest.sh +2 -0
- package/samples/ConvertTest/ConvertTest.js +270 -256
- package/samples/ConvertTest/NODEJS/ConvertTest.js +270 -0
- package/samples/ConvertTest/NODEJS/RunTest.sh +2 -0
- package/samples/DataExtractionTest/DataExtractionTest.js +180 -0
- package/samples/DataExtractionTest/NODEJS/DataExtractionTest.js +180 -0
- package/samples/DataExtractionTest/NODEJS/RunTest.sh +2 -0
- package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +526 -526
- package/samples/DigitalSignaturesTest/NODEJS/DigitalSignaturesTest.js +527 -0
- package/samples/DigitalSignaturesTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementBuilderTest/ElementBuilderTest.js +1 -1
- package/samples/ElementBuilderTest/NODEJS/ElementBuilderTest.js +514 -0
- package/samples/ElementBuilderTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementEditTest/ElementEditTest.js +1 -1
- package/samples/ElementEditTest/NODEJS/ElementEditTest.js +111 -0
- package/samples/ElementEditTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +1 -1
- package/samples/ElementReaderAdvTest/NODEJS/ElementReaderAdvTest.js +305 -0
- package/samples/ElementReaderAdvTest/NODEJS/RunTest.sh +2 -0
- package/samples/ElementReaderTest/ElementReaderTest.js +1 -1
- package/samples/ElementReaderTest/NODEJS/ElementReaderTest.js +77 -0
- package/samples/ElementReaderTest/NODEJS/RunTest.sh +2 -0
- package/samples/EncTest/EncTest.js +1 -1
- package/samples/EncTest/NODEJS/EncTest.js +176 -0
- package/samples/EncTest/NODEJS/RunTest.sh +2 -0
- package/samples/FDFTest/FDFTest.js +218 -218
- package/samples/FDFTest/NODEJS/FDFTest.js +219 -0
- package/samples/FDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/HTML2PDFTest/HTML2PDFTest.js +165 -165
- package/samples/HTML2PDFTest/NODEJS/HTML2PDFTest.js +166 -0
- package/samples/HTML2PDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/HighlightsTest/HighlightsTest.js +1 -1
- package/samples/HighlightsTest/NODEJS/HighlightsTest.js +97 -0
- package/samples/HighlightsTest/NODEJS/RunTest.sh +2 -0
- package/samples/ImageExtractTest/ImageExtractTest.js +129 -129
- package/samples/ImageExtractTest/NODEJS/ImageExtractTest.js +130 -0
- package/samples/ImageExtractTest/NODEJS/RunTest.sh +2 -0
- package/samples/ImpositionTest/ImpositionTest.js +86 -86
- package/samples/ImpositionTest/NODEJS/ImpositionTest.js +87 -0
- package/samples/ImpositionTest/NODEJS/RunTest.sh +2 -0
- package/samples/InteractiveFormsTest/InteractiveFormsTest.js +381 -381
- package/samples/InteractiveFormsTest/NODEJS/InteractiveFormsTest.js +382 -0
- package/samples/InteractiveFormsTest/NODEJS/RunTest.sh +2 -0
- package/samples/JBIG2Test/JBIG2Test.js +88 -88
- package/samples/JBIG2Test/NODEJS/JBIG2Test.js +89 -0
- package/samples/JBIG2Test/NODEJS/RunTest.sh +2 -0
- package/samples/LicenseKey/NODEJS/LicenseKey.js +11 -0
- package/samples/LogicalStructureTest/LogicalStructureTest.js +1 -1
- package/samples/LogicalStructureTest/NODEJS/LogicalStructureTest.js +251 -0
- package/samples/LogicalStructureTest/NODEJS/RunTest.sh +2 -0
- package/samples/OCRTest/NODEJS/OCRTest.js +235 -0
- package/samples/OCRTest/NODEJS/RunTest.sh +2 -0
- package/samples/OCRTest/OCRTest.js +234 -234
- package/samples/OfficeTemplateTest/NODEJS/OfficeTemplateTest.js +79 -0
- package/samples/OfficeTemplateTest/NODEJS/RunTest.sh +2 -0
- package/samples/OfficeTemplateTest/OfficeTemplateTest.js +79 -77
- package/samples/OfficeToPDFTest/NODEJS/OfficeToPDFTest.js +125 -0
- package/samples/OfficeToPDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/OfficeToPDFTest/OfficeToPDFTest.js +125 -125
- package/samples/OptimizerTest/NODEJS/OptimizerTest.js +192 -0
- package/samples/OptimizerTest/NODEJS/RunTest.sh +2 -0
- package/samples/OptimizerTest/OptimizerTest.js +191 -191
- package/samples/PDF2HtmlTest/NODEJS/PDF2HtmlTest.js +123 -0
- package/samples/PDF2HtmlTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDF2HtmlTest/PDF2HtmlTest.js +1 -1
- package/samples/PDF2OfficeTest/NODEJS/PDF2OfficeTest.js +158 -0
- package/samples/PDF2OfficeTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDF2OfficeTest/PDF2OfficeTest.js +1 -1
- package/samples/PDFATest/NODEJS/PDFATest.js +85 -0
- package/samples/PDFATest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFATest/PDFATest.js +1 -1
- package/samples/PDFDocMemoryTest/NODEJS/PDFDocMemoryTest.js +85 -0
- package/samples/PDFDocMemoryTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +84 -84
- package/samples/PDFDrawTest/NODEJS/PDFDrawTest.js +306 -0
- package/samples/PDFDrawTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFDrawTest/PDFDrawTest.js +1 -1
- package/samples/PDFLayersTest/NODEJS/PDFLayersTest.js +295 -0
- package/samples/PDFLayersTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFLayersTest/PDFLayersTest.js +1 -1
- package/samples/PDFPackageTest/NODEJS/PDFPackageTest.js +112 -0
- package/samples/PDFPackageTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFPackageTest/PDFPackageTest.js +111 -111
- package/samples/PDFPageTest/NODEJS/PDFPageTest.js +190 -0
- package/samples/PDFPageTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFPageTest/PDFPageTest.js +1 -1
- package/samples/PDFRedactTest/NODEJS/PDFRedactTest.js +75 -0
- package/samples/PDFRedactTest/NODEJS/RunTest.sh +2 -0
- package/samples/PDFRedactTest/PDFRedactTest.js +1 -1
- package/samples/PageLabelsTest/NODEJS/PageLabelsTest.js +139 -0
- package/samples/PageLabelsTest/NODEJS/RunTest.sh +2 -0
- package/samples/PageLabelsTest/PageLabelsTest.js +138 -138
- package/samples/PatternTest/NODEJS/PatternTest.js +227 -0
- package/samples/PatternTest/NODEJS/RunTest.sh +2 -0
- package/samples/PatternTest/PatternTest.js +226 -226
- package/samples/RectTest/NODEJS/RectTest.js +41 -0
- package/samples/RectTest/NODEJS/RunTest.sh +2 -0
- package/samples/RectTest/RectTest.js +1 -1
- package/samples/SDFTest/NODEJS/RunTest.sh +2 -0
- package/samples/SDFTest/NODEJS/SDFTest.js +88 -0
- package/samples/SDFTest/SDFTest.js +2 -3
- package/samples/StamperTest/NODEJS/RunTest.sh +2 -0
- package/samples/StamperTest/NODEJS/StamperTest.js +256 -0
- package/samples/StamperTest/StamperTest.js +1 -1
- package/samples/TestFiles/financial.pdf +0 -0
- package/samples/TestFiles/formfields-scanned.pdf +0 -0
- package/samples/TestFiles/formfields.pdf +0 -0
- package/samples/TestFiles/table.pdf +0 -0
- package/samples/TestFiles/tiger.svg +378 -0
- package/samples/TextExtractTest/NODEJS/RunTest.sh +2 -0
- package/samples/TextExtractTest/NODEJS/TextExtractTest.js +287 -0
- package/samples/TextExtractTest/TextExtractTest.js +1 -1
- package/samples/TextSearchTest/NODEJS/RunTest.sh +2 -0
- package/samples/TextSearchTest/NODEJS/TextSearchTest.js +122 -0
- package/samples/TextSearchTest/TextSearchTest.js +1 -1
- package/samples/U3DTest/NODEJS/RunTest.sh +2 -0
- package/samples/U3DTest/NODEJS/U3DTest.js +105 -0
- package/samples/U3DTest/U3DTest.js +104 -104
- package/samples/UndoRedoTest/NODEJS/RunTest.sh +2 -0
- package/samples/UndoRedoTest/NODEJS/UndoRedoTest.js +101 -0
- package/samples/UndoRedoTest/UndoRedoTest.js +1 -1
- package/samples/UnicodeWriteTest/NODEJS/RunTest.sh +2 -0
- package/samples/UnicodeWriteTest/NODEJS/UnicodeWriteTest.js +174 -0
- package/samples/UnicodeWriteTest/UnicodeWriteTest.js +1 -1
- package/samples/WebViewerConvertTest/NODEJS/RunTest.sh +2 -0
- package/samples/WebViewerConvertTest/NODEJS/WebViewerConvertTest.js +136 -0
- package/samples/WebViewerConvertTest/WebViewerConvertTest.js +135 -135
- package/samples/runall.bat +12 -12
|
@@ -1,105 +1,105 @@
|
|
|
1
|
-
//---------------------------------------------------------------------------------------
|
|
2
|
-
// Copyright (c) 2001-
|
|
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
|
-
'use strict';
|
|
11
|
-
|
|
12
|
-
exports.runU3DTest = () => {
|
|
13
|
-
const input_path = '../TestFiles/';
|
|
14
|
-
|
|
15
|
-
const create3DAnnotation = async (doc, annots) => {
|
|
16
|
-
// ---------------------------------------------------------------------------------
|
|
17
|
-
// Create a 3D annotation based on U3D content. PDF 1.6 introduces the capability
|
|
18
|
-
// for collections of three-dimensional objects, such as those used by CAD software,
|
|
19
|
-
// to be embedded in PDF files.
|
|
20
|
-
const link_3D = await doc.createIndirectDict();
|
|
21
|
-
link_3D.putName('Subtype', '3D');
|
|
22
|
-
|
|
23
|
-
// Annotation location on the page
|
|
24
|
-
const link_3D_rect = await PDFNet.Rect.init(25, 180, 585, 643);
|
|
25
|
-
link_3D.putRect('Rect', link_3D_rect.x1, link_3D_rect.y1,
|
|
26
|
-
link_3D_rect.x2, link_3D_rect.y2);
|
|
27
|
-
annots.pushBack(link_3D);
|
|
28
|
-
|
|
29
|
-
// The 3DA entry is an activation dictionary (see Table 9.34 in the PDF Reference Manual)
|
|
30
|
-
// that determines how the state of the annotation and its associated artwork can change.
|
|
31
|
-
const activation_dict_3D = await link_3D.putDict('3DA');
|
|
32
|
-
|
|
33
|
-
// Set the annotation so that it is activated as soon as the page containing the
|
|
34
|
-
// annotation is opened. Other options are: PV (page view) and XA (explicit) activation.
|
|
35
|
-
activation_dict_3D.putName('A', 'PO');
|
|
36
|
-
|
|
37
|
-
// Embed U3D Streams (3D Model/Artwork).
|
|
38
|
-
const u3d_file = await PDFNet.Filter.createMappedFileFromUString(input_path + 'dice.u3d');
|
|
39
|
-
const u3d_reader = await PDFNet.FilterReader.create(u3d_file);
|
|
40
|
-
|
|
41
|
-
// To embed 3D stream without compression, you can omit the second parameter in CreateIndirectStream.
|
|
42
|
-
const flateEncode = await PDFNet.Filter.createFlateEncode();
|
|
43
|
-
const u3d_data_dict = await doc.createIndirectStreamFromFilter(u3d_reader, flateEncode);
|
|
44
|
-
u3d_data_dict.putName('Subtype', 'U3D');
|
|
45
|
-
link_3D.put('3DD', u3d_data_dict);
|
|
46
|
-
|
|
47
|
-
// Set the initial view of the 3D artwork that should be used when the annotation is activated.
|
|
48
|
-
const view3D_dict = await link_3D.putDict('3DV');
|
|
49
|
-
view3D_dict.putString('IN', 'Unnamed');
|
|
50
|
-
view3D_dict.putString('XN', 'Default');
|
|
51
|
-
view3D_dict.putName('MS', 'M');
|
|
52
|
-
view3D_dict.putNumber('CO', 27.5);
|
|
53
|
-
|
|
54
|
-
// A 12-element 3D transformation matrix that specifies a position and orientation
|
|
55
|
-
// of the camera in world coordinates.
|
|
56
|
-
const tr3d = await view3D_dict.putArray('C2W');
|
|
57
|
-
tr3d.pushBackNumber(1); tr3d.pushBackNumber(0); tr3d.pushBackNumber(0);
|
|
58
|
-
tr3d.pushBackNumber(0); tr3d.pushBackNumber(0); tr3d.pushBackNumber(-1);
|
|
59
|
-
tr3d.pushBackNumber(0); tr3d.pushBackNumber(1); tr3d.pushBackNumber(0);
|
|
60
|
-
tr3d.pushBackNumber(0); tr3d.pushBackNumber(-27.5); tr3d.pushBackNumber(0);
|
|
61
|
-
|
|
62
|
-
// Create annotation appearance stream, a thumbnail which is used during printing or
|
|
63
|
-
// in PDF processors that do not understand 3D data.
|
|
64
|
-
const ap_dict = await link_3D.putDict('AP');
|
|
65
|
-
|
|
66
|
-
const builder = await PDFNet.ElementBuilder.create();
|
|
67
|
-
const writer = await PDFNet.ElementWriter.create();
|
|
68
|
-
|
|
69
|
-
writer.begin(doc);
|
|
70
|
-
|
|
71
|
-
const thumb_pathname = input_path + 'dice.jpg';
|
|
72
|
-
const image = await PDFNet.Image.createFromFile(doc, thumb_pathname);
|
|
73
|
-
writer.writePlacedElement(await builder.createImageScaled(image, 0.0, 0.0, await link_3D_rect.width(), await link_3D_rect.height()));
|
|
74
|
-
|
|
75
|
-
const normal_ap_stream = await writer.end();
|
|
76
|
-
normal_ap_stream.putName('Subtype', 'Form');
|
|
77
|
-
normal_ap_stream.putRect('BBox', 0, 0, await link_3D_rect.width(), await link_3D_rect.height());
|
|
78
|
-
ap_dict.put('N', normal_ap_stream);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
const main = async () => {
|
|
82
|
-
const output_path = '../TestFiles/Output/';
|
|
83
|
-
|
|
84
|
-
try {
|
|
85
|
-
const doc = await PDFNet.PDFDoc.create();
|
|
86
|
-
const page = await doc.pageCreate();
|
|
87
|
-
doc.pagePushBack(page);
|
|
88
|
-
const annots = await doc.createIndirectArray();
|
|
89
|
-
page.getSDFObj().then(sdf => sdf.put('Annots', annots));
|
|
90
|
-
|
|
91
|
-
await create3DAnnotation(doc, annots);
|
|
92
|
-
doc.save(output_path + 'dice_u3d.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
93
|
-
console.log('Done');
|
|
94
|
-
} catch (err) {
|
|
95
|
-
console.log(err);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
99
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
100
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
101
|
-
};
|
|
102
|
-
exports.runU3DTest();
|
|
103
|
-
})(exports);
|
|
104
|
-
// 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 { PDFNet } = require('@pdftron/pdfnet-node');
|
|
7
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
8
|
+
|
|
9
|
+
((exports) => {
|
|
10
|
+
'use strict';
|
|
11
|
+
|
|
12
|
+
exports.runU3DTest = () => {
|
|
13
|
+
const input_path = '../TestFiles/';
|
|
14
|
+
|
|
15
|
+
const create3DAnnotation = async (doc, annots) => {
|
|
16
|
+
// ---------------------------------------------------------------------------------
|
|
17
|
+
// Create a 3D annotation based on U3D content. PDF 1.6 introduces the capability
|
|
18
|
+
// for collections of three-dimensional objects, such as those used by CAD software,
|
|
19
|
+
// to be embedded in PDF files.
|
|
20
|
+
const link_3D = await doc.createIndirectDict();
|
|
21
|
+
link_3D.putName('Subtype', '3D');
|
|
22
|
+
|
|
23
|
+
// Annotation location on the page
|
|
24
|
+
const link_3D_rect = await PDFNet.Rect.init(25, 180, 585, 643);
|
|
25
|
+
link_3D.putRect('Rect', link_3D_rect.x1, link_3D_rect.y1,
|
|
26
|
+
link_3D_rect.x2, link_3D_rect.y2);
|
|
27
|
+
annots.pushBack(link_3D);
|
|
28
|
+
|
|
29
|
+
// The 3DA entry is an activation dictionary (see Table 9.34 in the PDF Reference Manual)
|
|
30
|
+
// that determines how the state of the annotation and its associated artwork can change.
|
|
31
|
+
const activation_dict_3D = await link_3D.putDict('3DA');
|
|
32
|
+
|
|
33
|
+
// Set the annotation so that it is activated as soon as the page containing the
|
|
34
|
+
// annotation is opened. Other options are: PV (page view) and XA (explicit) activation.
|
|
35
|
+
activation_dict_3D.putName('A', 'PO');
|
|
36
|
+
|
|
37
|
+
// Embed U3D Streams (3D Model/Artwork).
|
|
38
|
+
const u3d_file = await PDFNet.Filter.createMappedFileFromUString(input_path + 'dice.u3d');
|
|
39
|
+
const u3d_reader = await PDFNet.FilterReader.create(u3d_file);
|
|
40
|
+
|
|
41
|
+
// To embed 3D stream without compression, you can omit the second parameter in CreateIndirectStream.
|
|
42
|
+
const flateEncode = await PDFNet.Filter.createFlateEncode();
|
|
43
|
+
const u3d_data_dict = await doc.createIndirectStreamFromFilter(u3d_reader, flateEncode);
|
|
44
|
+
u3d_data_dict.putName('Subtype', 'U3D');
|
|
45
|
+
link_3D.put('3DD', u3d_data_dict);
|
|
46
|
+
|
|
47
|
+
// Set the initial view of the 3D artwork that should be used when the annotation is activated.
|
|
48
|
+
const view3D_dict = await link_3D.putDict('3DV');
|
|
49
|
+
view3D_dict.putString('IN', 'Unnamed');
|
|
50
|
+
view3D_dict.putString('XN', 'Default');
|
|
51
|
+
view3D_dict.putName('MS', 'M');
|
|
52
|
+
view3D_dict.putNumber('CO', 27.5);
|
|
53
|
+
|
|
54
|
+
// A 12-element 3D transformation matrix that specifies a position and orientation
|
|
55
|
+
// of the camera in world coordinates.
|
|
56
|
+
const tr3d = await view3D_dict.putArray('C2W');
|
|
57
|
+
tr3d.pushBackNumber(1); tr3d.pushBackNumber(0); tr3d.pushBackNumber(0);
|
|
58
|
+
tr3d.pushBackNumber(0); tr3d.pushBackNumber(0); tr3d.pushBackNumber(-1);
|
|
59
|
+
tr3d.pushBackNumber(0); tr3d.pushBackNumber(1); tr3d.pushBackNumber(0);
|
|
60
|
+
tr3d.pushBackNumber(0); tr3d.pushBackNumber(-27.5); tr3d.pushBackNumber(0);
|
|
61
|
+
|
|
62
|
+
// Create annotation appearance stream, a thumbnail which is used during printing or
|
|
63
|
+
// in PDF processors that do not understand 3D data.
|
|
64
|
+
const ap_dict = await link_3D.putDict('AP');
|
|
65
|
+
|
|
66
|
+
const builder = await PDFNet.ElementBuilder.create();
|
|
67
|
+
const writer = await PDFNet.ElementWriter.create();
|
|
68
|
+
|
|
69
|
+
writer.begin(doc);
|
|
70
|
+
|
|
71
|
+
const thumb_pathname = input_path + 'dice.jpg';
|
|
72
|
+
const image = await PDFNet.Image.createFromFile(doc, thumb_pathname);
|
|
73
|
+
writer.writePlacedElement(await builder.createImageScaled(image, 0.0, 0.0, await link_3D_rect.width(), await link_3D_rect.height()));
|
|
74
|
+
|
|
75
|
+
const normal_ap_stream = await writer.end();
|
|
76
|
+
normal_ap_stream.putName('Subtype', 'Form');
|
|
77
|
+
normal_ap_stream.putRect('BBox', 0, 0, await link_3D_rect.width(), await link_3D_rect.height());
|
|
78
|
+
ap_dict.put('N', normal_ap_stream);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const main = async () => {
|
|
82
|
+
const output_path = '../TestFiles/Output/';
|
|
83
|
+
|
|
84
|
+
try {
|
|
85
|
+
const doc = await PDFNet.PDFDoc.create();
|
|
86
|
+
const page = await doc.pageCreate();
|
|
87
|
+
doc.pagePushBack(page);
|
|
88
|
+
const annots = await doc.createIndirectArray();
|
|
89
|
+
page.getSDFObj().then(sdf => sdf.put('Annots', annots));
|
|
90
|
+
|
|
91
|
+
await create3DAnnotation(doc, annots);
|
|
92
|
+
doc.save(output_path + 'dice_u3d.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
93
|
+
console.log('Done');
|
|
94
|
+
} catch (err) {
|
|
95
|
+
console.log(err);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
99
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
100
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
101
|
+
};
|
|
102
|
+
exports.runU3DTest();
|
|
103
|
+
})(exports);
|
|
104
|
+
// eslint-disable-next-line spaced-comment
|
|
105
105
|
//# sourceURL=U3DTest.js
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//---------------------------------------------------------------------------------------
|
|
7
|
+
// The following sample illustrates how to use the UndoRedo API.
|
|
8
|
+
//---------------------------------------------------------------------------------------
|
|
9
|
+
const { PDFNet } = require('../../../lib/pdfnet.js');
|
|
10
|
+
const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
|
|
11
|
+
|
|
12
|
+
((exports) => {
|
|
13
|
+
|
|
14
|
+
exports.runUndoRedoTest = () => {
|
|
15
|
+
|
|
16
|
+
const main = async () => {
|
|
17
|
+
try {
|
|
18
|
+
// Relative path to the folder containing test files.
|
|
19
|
+
const inputPath = '../../TestFiles/';
|
|
20
|
+
const outputPath = inputPath + 'Output/';
|
|
21
|
+
|
|
22
|
+
// Open the PDF document.
|
|
23
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
|
|
24
|
+
|
|
25
|
+
const undo_manager = await doc.getUndoManager();
|
|
26
|
+
|
|
27
|
+
// Take a snapshot to which we can undo after making changes.
|
|
28
|
+
const snap0 = await undo_manager.takeSnapshot();
|
|
29
|
+
|
|
30
|
+
const snap0_state = await snap0.currentState();
|
|
31
|
+
|
|
32
|
+
const page = await doc.pageCreate(); // Start a new page
|
|
33
|
+
|
|
34
|
+
const bld = await PDFNet.ElementBuilder.create(); // Used to build new Element objects
|
|
35
|
+
const writer = await PDFNet.ElementWriter.create(); // Used to write Elements to the page
|
|
36
|
+
writer.beginOnPage(page); // Begin writing to this page
|
|
37
|
+
|
|
38
|
+
// ----------------------------------------------------------
|
|
39
|
+
// Add JPEG image to the file
|
|
40
|
+
const img = await PDFNet.Image.createFromFile(doc, inputPath + 'peppers.jpg');
|
|
41
|
+
const element = await bld.createImageFromMatrix(img, await PDFNet.Matrix2D.create(200, 0, 0, 250, 50, 500));
|
|
42
|
+
writer.writePlacedElement(element);
|
|
43
|
+
|
|
44
|
+
await writer.end(); // Finish writing to the page
|
|
45
|
+
await doc.pagePushFront(page);
|
|
46
|
+
|
|
47
|
+
// Take a snapshot after making changes, so that we can redo later (after undoing first).
|
|
48
|
+
const snap1 = await undo_manager.takeSnapshot();
|
|
49
|
+
|
|
50
|
+
if (await (await snap1.previousState()).equals(snap0_state)) {
|
|
51
|
+
console.log('snap1 previous state equals snap0_state; previous state is correct');
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const snap1_state = await snap1.currentState();
|
|
55
|
+
|
|
56
|
+
await doc.save(outputPath + 'addimage.pdf', PDFNet.SDFDoc.SaveOptions.e_incremental);
|
|
57
|
+
|
|
58
|
+
if (await undo_manager.canUndo()) {
|
|
59
|
+
const undo_snap = await undo_manager.undo();
|
|
60
|
+
|
|
61
|
+
await doc.save(outputPath + 'addimage_undone.pdf', PDFNet.SDFDoc.SaveOptions.e_incremental);
|
|
62
|
+
|
|
63
|
+
const undo_snap_state = await undo_snap.currentState();
|
|
64
|
+
|
|
65
|
+
if (await undo_snap_state.equals(snap0_state)) {
|
|
66
|
+
console.log('undo_snap_state equals snap0_state; undo was successful');
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
if (await undo_manager.canRedo()) {
|
|
70
|
+
const redo_snap = await undo_manager.redo();
|
|
71
|
+
|
|
72
|
+
await doc.save(outputPath + 'addimage_redone.pdf', PDFNet.SDFDoc.SaveOptions.e_incremental);
|
|
73
|
+
|
|
74
|
+
if (await (await redo_snap.previousState()).equals(undo_snap_state)) {
|
|
75
|
+
console.log('redo_snap previous state equals undo_snap_state; previous state is correct');
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const redo_snap_state = await redo_snap.currentState();
|
|
79
|
+
|
|
80
|
+
if (await redo_snap_state.equals(snap1_state)) {
|
|
81
|
+
console.log('Snap1 and redo_snap are equal; redo was successful');
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
console.log('Problem encountered - cannot redo.');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
console.log('Problem encountered - cannot undo.');
|
|
90
|
+
}
|
|
91
|
+
} catch (err) {
|
|
92
|
+
console.log(err.stack);
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
|
|
97
|
+
};
|
|
98
|
+
exports.runUndoRedoTest();
|
|
99
|
+
})(exports);
|
|
100
|
+
// eslint-disable-next-line spaced-comment
|
|
101
|
+
//# sourceURL=UndoRedoTest.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
|
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
const fs = require('fs')
|
|
7
|
+
const process = require('process');
|
|
8
|
+
const { PDFNet } = require('../../../lib/pdfnet.js');
|
|
9
|
+
const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
|
|
10
|
+
|
|
11
|
+
((exports) => {
|
|
12
|
+
|
|
13
|
+
exports.runUnicodeWriteTest = () => {
|
|
14
|
+
|
|
15
|
+
const main = async () => {
|
|
16
|
+
try {
|
|
17
|
+
// Relative path to the folder containing test files.
|
|
18
|
+
const inputPath = '../../TestFiles/';
|
|
19
|
+
const outputPath = '../../TestFiles/Output/';
|
|
20
|
+
|
|
21
|
+
const doc = await PDFNet.PDFDoc.create();
|
|
22
|
+
doc.initSecurityHandler();
|
|
23
|
+
|
|
24
|
+
const eb = await PDFNet.ElementBuilder.create(); // ElementBuilder, used to build new element Objects
|
|
25
|
+
const writer = await PDFNet.ElementWriter.create(); // ElementWriter, used to write elements to the page
|
|
26
|
+
|
|
27
|
+
// Start a new page ------------------------------------
|
|
28
|
+
let page = await doc.pageCreate(new PDFNet.Rect(0, 0, 612, 794));
|
|
29
|
+
|
|
30
|
+
await writer.beginOnPage(page);
|
|
31
|
+
|
|
32
|
+
let font_program = inputPath + 'ARIALUNI.TTF';
|
|
33
|
+
|
|
34
|
+
if (!fs.existsSync(font_program)) {
|
|
35
|
+
font_program = 'C:/Windows/Fonts/ARIALUNI.TTF';
|
|
36
|
+
if (process.platform !== 'win32' || !fs.existsSync(font_program)) {
|
|
37
|
+
font_program = '';
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
let fnt;
|
|
42
|
+
if (font_program.length) {
|
|
43
|
+
console.log('Note: using ' + font_program + ' for unshaped unicode text');
|
|
44
|
+
// if we can find a specific wide-coverage font file, then use that directly
|
|
45
|
+
fnt = await PDFNet.Font.createCIDTrueTypeFont(doc, font_program, true, true);
|
|
46
|
+
} else {
|
|
47
|
+
console.log('Note: using system font substitution for unshaped unicode text');
|
|
48
|
+
// if we can't find a specific file, then use system font subsitution
|
|
49
|
+
// as a fallback, using 'Helvetica' as a hint
|
|
50
|
+
fnt = await PDFNet.Font.createFromName(doc, 'Helvetica', '');
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
let element = await eb.createTextBeginWithFont(fnt, 1);
|
|
54
|
+
await element.setTextMatrixEntries(10, 0, 0, 10, 50, 600);
|
|
55
|
+
await (await element.getGState()).setLeading(2); // Set the spacing between lines
|
|
56
|
+
await writer.writeElement(element);
|
|
57
|
+
|
|
58
|
+
// Hello World!
|
|
59
|
+
const hello = 'Hello World!';
|
|
60
|
+
await writer.writeElement(await eb.createUnicodeTextRun(hello));
|
|
61
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
62
|
+
|
|
63
|
+
// Latin
|
|
64
|
+
const latin = 'aAbBcCdD' + String.fromCharCode(0x45, 0x0046, 0x00C0, 0x00C1, 0x00C2, 0x0143, 0x0144, 0x0145, 0x0152) + '12';
|
|
65
|
+
await writer.writeElement(await eb.createUnicodeTextRun(latin));
|
|
66
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
67
|
+
|
|
68
|
+
// Greek
|
|
69
|
+
const greek = String.fromCharCode(0x039E, 0x039F, 0x03A0, 0x03A1, 0x03A3, 0x03A6, 0x03A8, 0x03A9);
|
|
70
|
+
await writer.writeElement(await eb.createUnicodeTextRun(greek));
|
|
71
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
72
|
+
|
|
73
|
+
// Cyrillic
|
|
74
|
+
const cyrillic = String.fromCharCode(
|
|
75
|
+
0x0409, 0x040A, 0x040B, 0x040C, 0x040E, 0x040F, 0x0410, 0x0411,
|
|
76
|
+
0x0412, 0x0413, 0x0414, 0x0415, 0x0416, 0x0417, 0x0418, 0x0419);
|
|
77
|
+
await writer.writeElement(await eb.createUnicodeTextRun(cyrillic));
|
|
78
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
79
|
+
|
|
80
|
+
// Hebrew
|
|
81
|
+
const hebrew = String.fromCharCode(
|
|
82
|
+
0x05D0, 0x05D1, 0x05D3, 0x05D3, 0x05D4, 0x05D5, 0x05D6, 0x05D7, 0x05D8,
|
|
83
|
+
0x05D9, 0x05DA, 0x05DB, 0x05DC, 0x05DD, 0x05DE, 0x05DF, 0x05E0, 0x05E1);
|
|
84
|
+
await writer.writeElement(await eb.createUnicodeTextRun(hebrew));
|
|
85
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
86
|
+
|
|
87
|
+
// Arabic
|
|
88
|
+
const arabic = String.fromCharCode(
|
|
89
|
+
0x0624, 0x0625, 0x0626, 0x0627, 0x0628, 0x0629, 0x062A, 0x062B, 0x062C,
|
|
90
|
+
0x062D, 0x062E, 0x062F, 0x0630, 0x0631, 0x0632, 0x0633, 0x0634, 0x0635);
|
|
91
|
+
await writer.writeElement(await eb.createUnicodeTextRun(arabic));
|
|
92
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
93
|
+
|
|
94
|
+
// Thai
|
|
95
|
+
const thai = String.fromCharCode(
|
|
96
|
+
0x0E01, 0x0E02, 0x0E03, 0x0E04, 0x0E05, 0x0E06, 0x0E07, 0x0E08, 0x0E09,
|
|
97
|
+
0x0E0A, 0x0E0B, 0x0E0C, 0x0E0D, 0x0E0E, 0x0E0F, 0x0E10, 0x0E11, 0x0E12);
|
|
98
|
+
await writer.writeElement(await eb.createUnicodeTextRun(thai));
|
|
99
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
100
|
+
|
|
101
|
+
// Hiragana - Japanese
|
|
102
|
+
const hiragana = String.fromCharCode(
|
|
103
|
+
0x3041, 0x3042, 0x3043, 0x3044, 0x3045, 0x3046, 0x3047, 0x3048, 0x3049,
|
|
104
|
+
0x304A, 0x304B, 0x304C, 0x304D, 0x304E, 0x304F, 0x3051, 0x3051, 0x3052);
|
|
105
|
+
await writer.writeElement(await eb.createUnicodeTextRun(hiragana));
|
|
106
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
107
|
+
|
|
108
|
+
// CJK Unified Ideographs
|
|
109
|
+
const cjk_uni = String.fromCharCode(
|
|
110
|
+
0x5841, 0x5842, 0x5843, 0x5844, 0x5845, 0x5846, 0x5847, 0x5848, 0x5849,
|
|
111
|
+
0x584A, 0x584B, 0x584C, 0x584D, 0x584E, 0x584F, 0x5850, 0x5851, 0x5852);
|
|
112
|
+
await writer.writeElement(await eb.createUnicodeTextRun(cjk_uni));
|
|
113
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
114
|
+
|
|
115
|
+
// Simplified Chinese
|
|
116
|
+
const chinese_simplified = String.fromCharCode(0x4e16, 0x754c, 0x60a8, 0x597d);
|
|
117
|
+
await writer.writeElement(await eb.createUnicodeTextRun(chinese_simplified));
|
|
118
|
+
await writer.writeElement(await eb.createTextNewLine());
|
|
119
|
+
|
|
120
|
+
// Finish the block of text
|
|
121
|
+
await writer.writeElement(await eb.createTextEnd());
|
|
122
|
+
|
|
123
|
+
console.log('Now using text shaping logic to place text');
|
|
124
|
+
|
|
125
|
+
// Create a font in indexed encoding mode
|
|
126
|
+
// normally this would mean that we are required to provide glyph indices
|
|
127
|
+
// directly to CreateUnicodeTextRun, but instead, we will use the GetShapedText
|
|
128
|
+
// method to take care of this detail for us.
|
|
129
|
+
const indexed_font = await PDFNet.Font.createCIDTrueTypeFont(doc, inputPath + 'NotoSans_with_hindi.ttf', true, true, PDFNet.Font.Encoding.e_Indices);
|
|
130
|
+
element = await eb.createTextBeginWithFont(indexed_font, 10);
|
|
131
|
+
await writer.writeElement(element);
|
|
132
|
+
|
|
133
|
+
const line_pos = 350.0;
|
|
134
|
+
const line_space = 20.0;
|
|
135
|
+
|
|
136
|
+
// Transform unicode text into an abstract collection of glyph indices and positioning info
|
|
137
|
+
let shaped_text = await indexed_font.getShapedText('Shaped Hindi Text:');
|
|
138
|
+
|
|
139
|
+
// transform the shaped text info into a PDF element and write it to the page
|
|
140
|
+
element = await eb.createShapedTextRun(shaped_text);
|
|
141
|
+
await element.setTextMatrixEntries(1.5, 0, 0, 1.5, 50, line_pos);
|
|
142
|
+
await writer.writeElement(element);
|
|
143
|
+
|
|
144
|
+
// read in unicode text lines from a file
|
|
145
|
+
const hindi_text = fs.readFileSync(inputPath + 'hindi_sample_utf16le.txt', 'utf16le').toString().split(/\n/);
|
|
146
|
+
|
|
147
|
+
console.log('Read in ' + hindi_text.length + ' lines of Unicode text from file');
|
|
148
|
+
for (let i = 0; i < hindi_text.length; ++i) {
|
|
149
|
+
shaped_text = await indexed_font.getShapedText(hindi_text[i]);
|
|
150
|
+
element = await eb.createShapedTextRun(shaped_text);
|
|
151
|
+
await element.setTextMatrixEntries(1.5, 0, 0, 1.5, 50, line_pos - line_space * (i + 1));
|
|
152
|
+
await writer.writeElement(element);
|
|
153
|
+
console.log('Wrote shaped line to page');
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// Finish the shaped block of text
|
|
157
|
+
await writer.writeElement(await eb.createTextEnd());
|
|
158
|
+
|
|
159
|
+
await writer.end(); // save changes to the current page
|
|
160
|
+
await doc.pagePushBack(page);
|
|
161
|
+
|
|
162
|
+
await doc.save(outputPath + 'unicodewrite.pdf', PDFNet.SDFDoc.SaveOptions.e_remove_unused | PDFNet.SDFDoc.SaveOptions.e_hex_strings);
|
|
163
|
+
|
|
164
|
+
console.log('Done. Result saved in unicodewrite.pdf...');
|
|
165
|
+
} catch (err) {
|
|
166
|
+
console.log(err);
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) { console.log('Error: ' + JSON.stringify(error)); }).then(function () { return PDFNet.shutdown(); });
|
|
170
|
+
};
|
|
171
|
+
exports.runUnicodeWriteTest();
|
|
172
|
+
})(exports);
|
|
173
|
+
// eslint-disable-next-line spaced-comment
|
|
174
|
+
//# sourceURL=UnicodeWriteTest.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
|
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
//---------------------------------------------------------------------------------------
|
|
2
|
+
// Copyright (c) 2001-2021 by PDFTron Systems Inc. All Rights Reserved.
|
|
3
|
+
// Consult legal.txt regarding legal and license information.
|
|
4
|
+
//---------------------------------------------------------------------------------------
|
|
5
|
+
|
|
6
|
+
//---------------------------------------------------------------------------------------
|
|
7
|
+
// The following sample illustrates how to convert PDF, XPS, image, MS Office, and
|
|
8
|
+
// other image document formats to XOD.
|
|
9
|
+
//
|
|
10
|
+
// Certain file formats such as PDF, generic XPS, EMF, and raster image formats can
|
|
11
|
+
// be directly converted to XOD. Other formats such as MS Office
|
|
12
|
+
// (Word, Excel, Publisher, Powerpoint, etc) can be directly converted via interop.
|
|
13
|
+
// These types of conversions guarantee optimal output, while preserving important
|
|
14
|
+
// information such as document metadata, intra document links and hyper-links,
|
|
15
|
+
// bookmarks etc.
|
|
16
|
+
//
|
|
17
|
+
// In case there is no direct conversion available, PDFNet can still convert from
|
|
18
|
+
// any printable document to XOD using a virtual printer driver. To check
|
|
19
|
+
// if a virtual printer is required use Convert::RequiresPrinter(filename). In this
|
|
20
|
+
// case the installing application must be run as administrator. The manifest for this
|
|
21
|
+
// sample specifies appropriate the UAC elevation. The administrator privileges are
|
|
22
|
+
// not required for direct or interop conversions.
|
|
23
|
+
//
|
|
24
|
+
// Please note that PDFNet Publisher (i.e. 'pdftron.PDF.Convert.ToXod') is an
|
|
25
|
+
// optionally licensable add-on to PDFNet Core SDK. For details, please see
|
|
26
|
+
// http://www.pdftron.com/webviewer/licensing.html.
|
|
27
|
+
//---------------------------------------------------------------------------------------
|
|
28
|
+
|
|
29
|
+
const { PDFNet } = require('../../../lib/pdfnet.js');
|
|
30
|
+
const PDFTronLicense = require('../../LicenseKey/NODEJS/LicenseKey');
|
|
31
|
+
|
|
32
|
+
((exports) => {
|
|
33
|
+
'use strict';
|
|
34
|
+
|
|
35
|
+
exports.runWebViewerConvertTest = () => {
|
|
36
|
+
const inputPath = '../../TestFiles/';
|
|
37
|
+
const outputPath = inputPath + 'Output/';
|
|
38
|
+
const main = async () => {
|
|
39
|
+
try {
|
|
40
|
+
// Sample 1:
|
|
41
|
+
// Directly convert from PDF to XOD.
|
|
42
|
+
await PDFNet.Convert.fileToXod(inputPath + 'newsletter.pdf', outputPath + 'from_pdf.xod');
|
|
43
|
+
|
|
44
|
+
// Sample 2:
|
|
45
|
+
// Directly convert from generic XPS to XOD.
|
|
46
|
+
await PDFNet.Convert.fileToXod(inputPath + 'simple-xps.xps', outputPath + 'from_xps.xod');
|
|
47
|
+
|
|
48
|
+
// Sample 3:
|
|
49
|
+
// Convert from MS Office (does not require printer driver for Office 2007+)
|
|
50
|
+
// and other document formats to XOD.
|
|
51
|
+
await bulkConvertRandomFilesToXod();
|
|
52
|
+
} catch (err) {
|
|
53
|
+
console.log(err.stack);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
let Testfile = function (inputFile, outputFile, requiresWindowsPlatform) {
|
|
58
|
+
this.inputFile = inputFile;
|
|
59
|
+
this.outputFile = outputFile;
|
|
60
|
+
this.requiresWindowsPlatform = requiresWindowsPlatform;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const testfiles = [
|
|
64
|
+
new Testfile('simple-powerpoint_2007.pptx', 'simple-powerpoint_2007.xod', true),
|
|
65
|
+
new Testfile('simple-word_2007.docx', 'simple-word_2007.xod', true),
|
|
66
|
+
new Testfile('butterfly.png', 'butterfly.xod', false),
|
|
67
|
+
new Testfile('numbered.pdf', 'numbered.xod', false),
|
|
68
|
+
new Testfile('dice.jpg', 'dice.xod', false),
|
|
69
|
+
new Testfile('simple-xps.xps', 'simple-xps.xod', false),
|
|
70
|
+
]
|
|
71
|
+
|
|
72
|
+
const bulkConvertRandomFilesToXod = async () => {
|
|
73
|
+
let err = 0;
|
|
74
|
+
if (process.platform === 'win32') {
|
|
75
|
+
if (await PDFNet.Convert.printerIsInstalled('PDFTron PDFNet')) {
|
|
76
|
+
await PDFNet.Convert.printerSetPrinterName('PDFTron PDFNet');
|
|
77
|
+
} else if (!(await PDFNet.Convert.printerIsInstalled())) {
|
|
78
|
+
try {
|
|
79
|
+
// This will fail if not run as administrator. Harmless if PDFNet
|
|
80
|
+
// printer already installed
|
|
81
|
+
console.log('Installing printer (requires Windows platform and administrator)');
|
|
82
|
+
await PDFNet.Convert.printerUninstall();
|
|
83
|
+
console.log('Installed printer ' + await PDFNet.Convert.printerGetPrinterName());
|
|
84
|
+
} catch (exp) {
|
|
85
|
+
console.log('Unable to install printer');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
for (const testfile of testfiles)
|
|
91
|
+
{
|
|
92
|
+
if (process.platform !== 'win32' && testfile.requiresWindowsPlatform) {
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
try {
|
|
96
|
+
const inputFile = inputPath + testfile.inputFile;
|
|
97
|
+
const outputFile = outputPath + testfile.outputFile;
|
|
98
|
+
if (await PDFNet.Convert.requiresPrinter(inputFile)) {
|
|
99
|
+
console.log('Using PDFNet printer to convert file ' + testfile.inputFile);
|
|
100
|
+
}
|
|
101
|
+
await PDFNet.Convert.fileToXod(inputFile, outputFile);
|
|
102
|
+
console.log('Converted file: ' + testfile.inputFile + ' to: ' + testfile.outputFile);
|
|
103
|
+
} catch (exp) {
|
|
104
|
+
console.log('Unable to convert file ' + testfile.inputFile);
|
|
105
|
+
console.log(exp);
|
|
106
|
+
err = 1;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
if (err) {
|
|
111
|
+
console.log('ConvertFile failed');
|
|
112
|
+
} else {
|
|
113
|
+
console.log('ConvertFile succeeded');
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
if (process.platform === 'win32' && await PDFNet.Convert.printerIsInstalled()) {
|
|
117
|
+
try {
|
|
118
|
+
console.log('Uninstalling printer (requires Windows platform and administrator)');
|
|
119
|
+
await PDFNet.Convert.printerUninstall();
|
|
120
|
+
console.log('Uninstalled Printer ' + await PDFNet.Convert.printerGetPrinterName());
|
|
121
|
+
}
|
|
122
|
+
catch (exp)
|
|
123
|
+
{
|
|
124
|
+
console.log('Unable to uninstall printer');
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function (error) {
|
|
130
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
131
|
+
}).then(function () { return PDFNet.shutdown(); });
|
|
132
|
+
};
|
|
133
|
+
exports.runWebViewerConvertTest();
|
|
134
|
+
})(exports);
|
|
135
|
+
// eslint-disable-next-line spaced-comment
|
|
136
|
+
//# sourceURL=WebViewerConvertTest.js
|