@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.
Files changed (124) hide show
  1. package/package.json +18 -18
  2. package/readme.md +12 -12
  3. package/samples/AddImageTest/AddImageTest.js +2 -2
  4. package/samples/AdvancedImagingTest/AdvancedImagingTest.js +3 -3
  5. package/samples/AnnotationTest/AnnotationTest.js +2 -2
  6. package/samples/BookmarkTest/BookmarkTest.js +2 -2
  7. package/samples/CAD2PDFTest/CAD2PDFTest.js +79 -79
  8. package/samples/ContentReplacerTest/ContentReplacerTest.js +2 -2
  9. package/samples/ConvertTest/ConvertTest.js +270 -256
  10. package/samples/DataExtractionTest/DataExtractionTest.js +180 -0
  11. package/samples/DigitalSignaturesTest/DigitalSignaturesTest.js +526 -526
  12. package/samples/ElementBuilderTest/ElementBuilderTest.js +2 -2
  13. package/samples/ElementEditTest/ElementEditTest.js +2 -2
  14. package/samples/ElementReaderAdvTest/ElementReaderAdvTest.js +2 -2
  15. package/samples/ElementReaderTest/ElementReaderTest.js +2 -2
  16. package/samples/EncTest/EncTest.js +2 -2
  17. package/samples/FDFTest/FDFTest.js +218 -218
  18. package/samples/HTML2PDFTest/HTML2PDFTest.js +165 -165
  19. package/samples/HighlightsTest/HighlightsTest.js +2 -2
  20. package/samples/ImageExtractTest/ImageExtractTest.js +129 -129
  21. package/samples/ImpositionTest/ImpositionTest.js +86 -86
  22. package/samples/InteractiveFormsTest/InteractiveFormsTest.js +381 -381
  23. package/samples/JBIG2Test/JBIG2Test.js +88 -88
  24. package/samples/LogicalStructureTest/LogicalStructureTest.js +2 -2
  25. package/samples/OCRTest/OCRTest.js +234 -234
  26. package/samples/OfficeTemplateTest/OfficeTemplateTest.js +79 -77
  27. package/samples/OfficeToPDFTest/OfficeToPDFTest.js +125 -125
  28. package/samples/OptimizerTest/OptimizerTest.js +191 -191
  29. package/samples/PDF2HtmlTest/PDF2HtmlTest.js +3 -3
  30. package/samples/PDF2OfficeTest/PDF2OfficeTest.js +3 -3
  31. package/samples/PDFATest/PDFATest.js +2 -2
  32. package/samples/PDFDocMemoryTest/PDFDocMemoryTest.js +84 -84
  33. package/samples/PDFDrawTest/PDFDrawTest.js +2 -2
  34. package/samples/PDFLayersTest/PDFLayersTest.js +2 -2
  35. package/samples/PDFPackageTest/PDFPackageTest.js +111 -111
  36. package/samples/PDFPageTest/PDFPageTest.js +2 -2
  37. package/samples/PDFRedactTest/PDFRedactTest.js +2 -2
  38. package/samples/PageLabelsTest/PageLabelsTest.js +138 -138
  39. package/samples/PatternTest/PatternTest.js +226 -226
  40. package/samples/RectTest/RectTest.js +2 -2
  41. package/samples/SDFTest/SDFTest.js +3 -4
  42. package/samples/StamperTest/StamperTest.js +2 -2
  43. package/samples/TextExtractTest/TextExtractTest.js +2 -2
  44. package/samples/TextSearchTest/TextSearchTest.js +2 -2
  45. package/samples/U3DTest/U3DTest.js +104 -104
  46. package/samples/UndoRedoTest/UndoRedoTest.js +2 -2
  47. package/samples/UnicodeWriteTest/UnicodeWriteTest.js +2 -2
  48. package/samples/WebViewerConvertTest/WebViewerConvertTest.js +135 -135
  49. package/samples/runall.bat +6 -5
  50. package/samples/runall.sh +4 -5
  51. package/samples/TestFiles/BusinessCardTemplate.pdf +0 -0
  52. package/samples/TestFiles/Fishermen.docx +0 -0
  53. package/samples/TestFiles/Font_licenses.txt +0 -140
  54. package/samples/TestFiles/GlobalSignRootForTST.cer +0 -0
  55. package/samples/TestFiles/License.txt +0 -1
  56. package/samples/TestFiles/Misc-Fixed.pfa +0 -1166
  57. package/samples/TestFiles/NotoSans_with_hindi.ttf +0 -0
  58. package/samples/TestFiles/Output/empty +0 -1
  59. package/samples/TestFiles/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +0 -34
  60. package/samples/TestFiles/SYH_Letter.docx +0 -0
  61. package/samples/TestFiles/TigerText.pdf +0 -0
  62. package/samples/TestFiles/US061222892-a.pdf +0 -0
  63. package/samples/TestFiles/butterfly.png +0 -0
  64. package/samples/TestFiles/credit card numbers.pdf +0 -0
  65. package/samples/TestFiles/dice.jpg +0 -0
  66. package/samples/TestFiles/dice.u3d +0 -0
  67. package/samples/TestFiles/doc_to_sign.pdf +0 -0
  68. package/samples/TestFiles/factsheet_Arabic.docx +0 -0
  69. package/samples/TestFiles/fish.pdf +0 -0
  70. package/samples/TestFiles/font.ttf +0 -0
  71. package/samples/TestFiles/form1.pdf +1 -245
  72. package/samples/TestFiles/form1_annots.xfdf +0 -34
  73. package/samples/TestFiles/form1_data.fdf +0 -4
  74. package/samples/TestFiles/form1_data.xfdf +0 -140
  75. package/samples/TestFiles/grayscale.tif +0 -0
  76. package/samples/TestFiles/hindi_sample_utf16le.txt +0 -0
  77. package/samples/TestFiles/imagemask.dat +0 -32
  78. package/samples/TestFiles/logo_red.png +0 -0
  79. package/samples/TestFiles/lorem_ipsum.pdf +0 -0
  80. package/samples/TestFiles/multipage.tif +0 -0
  81. package/samples/TestFiles/my_stream.txt +0 -2310
  82. package/samples/TestFiles/newsletter.pdf +0 -0
  83. package/samples/TestFiles/newsletter.xod +0 -0
  84. package/samples/TestFiles/numbered.pdf +0 -0
  85. package/samples/TestFiles/op_blend_test.pdf +0 -1498
  86. package/samples/TestFiles/palm.jp2 +0 -0
  87. package/samples/TestFiles/paragraphs_and_tables.pdf +0 -0
  88. package/samples/TestFiles/pdfnet.gif +0 -0
  89. package/samples/TestFiles/pdftron.bmp +0 -0
  90. package/samples/TestFiles/pdftron.cer +0 -0
  91. package/samples/TestFiles/pdftron.pfx +0 -0
  92. package/samples/TestFiles/pdftron_smart_substitution.plugin +0 -0
  93. package/samples/TestFiles/peppers.jpg +0 -0
  94. package/samples/TestFiles/signature.jpg +0 -0
  95. package/samples/TestFiles/simple-emf.emf +0 -0
  96. package/samples/TestFiles/simple-excel_2007.xlsx +0 -0
  97. package/samples/TestFiles/simple-outlook.msg +0 -0
  98. package/samples/TestFiles/simple-powerpoint_2007.pptx +0 -0
  99. package/samples/TestFiles/simple-publisher.pub +0 -0
  100. package/samples/TestFiles/simple-rtf.rtf +0 -224
  101. package/samples/TestFiles/simple-text.txt +0 -61
  102. package/samples/TestFiles/simple-visio.vsd +0 -0
  103. package/samples/TestFiles/simple-webpage.html +0 -731
  104. package/samples/TestFiles/simple-webpage.mht +0 -6972
  105. package/samples/TestFiles/simple-webpage_files/colorschememapping.xml +0 -2
  106. package/samples/TestFiles/simple-webpage_files/filelist.xml +0 -14
  107. package/samples/TestFiles/simple-webpage_files/image001.gif +0 -0
  108. package/samples/TestFiles/simple-webpage_files/image002.png +0 -0
  109. package/samples/TestFiles/simple-webpage_files/image003.jpg +0 -0
  110. package/samples/TestFiles/simple-webpage_files/image004.emz +0 -0
  111. package/samples/TestFiles/simple-webpage_files/image005.gif +0 -0
  112. package/samples/TestFiles/simple-webpage_files/image006.png +0 -0
  113. package/samples/TestFiles/simple-webpage_files/image007.gif +0 -0
  114. package/samples/TestFiles/simple-webpage_files/oledata.mso +0 -0
  115. package/samples/TestFiles/simple-webpage_files/themedata.thmx +0 -0
  116. package/samples/TestFiles/simple-word_2007.docx +0 -0
  117. package/samples/TestFiles/simple-xps.xps +0 -0
  118. package/samples/TestFiles/tagged.pdf +0 -0
  119. package/samples/TestFiles/the_rime_of_the_ancient_mariner.docx +0 -0
  120. package/samples/TestFiles/tiger.pdf +0 -0
  121. package/samples/TestFiles/waiver.pdf +0 -0
  122. package/samples/TestFiles/waiver_withApprovalField.pdf +0 -0
  123. package/samples/TestFiles/waiver_withApprovalField_certified.pdf +1 -424
  124. package/samples/TestFiles/waiver_withApprovalField_certified_approved.pdf +1 -466
@@ -1,105 +1,105 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
3
- // Consult legal.txt regarding legal and license information.
4
- //---------------------------------------------------------------------------------------
5
-
6
- const { PDFNet } = require('@pdftron/pdfnet-node');
7
- const PDFTronLicense = require('../LicenseKey/LicenseKey');
8
-
9
- ((exports) => {
10
- '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('../lib/pdfnet.js');
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
@@ -1,12 +1,12 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
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
6
  //---------------------------------------------------------------------------------------
7
7
  // The following sample illustrates how to use the UndoRedo API.
8
8
  //---------------------------------------------------------------------------------------
9
- const { PDFNet } = require('@pdftron/pdfnet-node');
9
+ const { PDFNet } = require('../lib/pdfnet.js');
10
10
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
11
11
 
12
12
  ((exports) => {
@@ -1,11 +1,11 @@
1
1
  //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2022 by PDFTron Systems Inc. All Rights Reserved.
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
6
  const fs = require('fs')
7
7
  const process = require('process');
8
- const { PDFNet } = require('@pdftron/pdfnet-node');
8
+ const { PDFNet } = require('../lib/pdfnet.js');
9
9
  const PDFTronLicense = require('../LicenseKey/LicenseKey');
10
10
 
11
11
  ((exports) => {
@@ -1,136 +1,136 @@
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 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('@pdftron/pdfnet-node');
30
- const PDFTronLicense = require('../LicenseKey/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
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
+ // 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/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
136
  //# sourceURL=WebViewerConvertTest.js
@@ -1,12 +1,13 @@
1
1
  @echo off
2
2
  for /D %%s in (*Test) do (
3
- if exist %%s\%%~nxs.js (
4
- cd %%s
5
- echo %%s running...
3
+ if exist %%s\NODEJS\%%~nxs.js (
4
+ cd %%s\NODEJS
5
+ echo %%s starting...
6
6
  call node %%~nxs.js
7
- cd ..
7
+ cd ..\..
8
8
  echo %%s finished.
9
9
  pause
10
10
  )
11
11
  )
12
- echo All tests finished.
12
+
13
+ echo Run all tests finished.
package/samples/runall.sh CHANGED
@@ -2,14 +2,13 @@
2
2
 
3
3
  for SAMPLE in *Test
4
4
  do
5
- if [ -d $SAMPLE ] && [ -e $SAMPLE/$SAMPLE.js ]
5
+ if [ -d $SAMPLE/NODEJS ] && [ -e $SAMPLE/NODEJS/RunTest.sh ]
6
6
  then
7
- cd $SAMPLE
7
+ cd $SAMPLE/NODEJS
8
8
  echo "$SAMPLE running"
9
- node $SAMPLE.js
10
- cd ..
9
+ sh RunTest.sh
10
+ cd ../..
11
11
  echo "$SAMPLE finished. Press enter to continue..."
12
12
  read -p "$*" a
13
13
  fi
14
14
  done
15
- echo "All tests finished."
Binary file