@pdftron/pdfnet-node-samples 10.8.0-beta → 10.9.0-1-beta

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 (135) hide show
  1. package/{samples/AddImageTest → AddImageTest}/AddImageTest.js +115 -115
  2. package/{samples/AdvancedImagingTest → AdvancedImagingTest}/AdvancedImagingTest.js +78 -78
  3. package/{samples/AnnotationTest → AnnotationTest}/AnnotationTest.js +641 -641
  4. package/{samples/BookmarkTest → BookmarkTest}/BookmarkTest.js +219 -219
  5. package/{samples/CAD2PDFTest → CAD2PDFTest}/CAD2PDFTest.js +79 -79
  6. package/{samples/ContentReplacerTest → ContentReplacerTest}/ContentReplacerTest.js +75 -75
  7. package/{samples/ConvertPrintTest → ConvertPrintTest}/ConvertPrintTest.js +153 -153
  8. package/{samples/ConvertTest → ConvertTest}/ConvertTest.js +203 -203
  9. package/{samples/DataExtractionTest → DataExtractionTest}/DataExtractionTest.js +214 -214
  10. package/{samples/DigitalSignaturesTest → DigitalSignaturesTest}/DigitalSignaturesTest.js +621 -526
  11. package/{samples/DocumentCreationTest → DocumentCreationTest}/DocumentCreationTest.js +409 -409
  12. package/{samples/ElementBuilderTest → ElementBuilderTest}/ElementBuilderTest.js +513 -513
  13. package/{samples/ElementEditTest → ElementEditTest}/ElementEditTest.js +110 -110
  14. package/{samples/ElementReaderAdvTest → ElementReaderAdvTest}/ElementReaderAdvTest.js +305 -305
  15. package/{samples/ElementReaderTest → ElementReaderTest}/ElementReaderTest.js +77 -77
  16. package/{samples/EncTest → EncTest}/EncTest.js +175 -175
  17. package/{samples/FDFTest → FDFTest}/FDFTest.js +218 -218
  18. package/{samples/HTML2PDFTest → HTML2PDFTest}/HTML2PDFTest.js +164 -164
  19. package/{samples/HighlightsTest → HighlightsTest}/HighlightsTest.js +97 -97
  20. package/{samples/ImageExtractTest → ImageExtractTest}/ImageExtractTest.js +129 -129
  21. package/{samples/ImpositionTest → ImpositionTest}/ImpositionTest.js +86 -86
  22. package/{samples/InteractiveFormsTest → InteractiveFormsTest}/InteractiveFormsTest.js +381 -381
  23. package/{samples/JBIG2Test → JBIG2Test}/JBIG2Test.js +88 -88
  24. package/{samples/LicenseKey → LicenseKey}/LicenseKey.js +11 -11
  25. package/{samples/LogicalStructureTest → LogicalStructureTest}/LogicalStructureTest.js +250 -250
  26. package/{samples/OCRTest → OCRTest}/OCRTest.js +235 -235
  27. package/{samples/OfficeTemplateTest → OfficeTemplateTest}/OfficeTemplateTest.js +79 -79
  28. package/{samples/OfficeToPDFTest → OfficeToPDFTest}/OfficeToPDFTest.js +125 -125
  29. package/{samples/OptimizerTest → OptimizerTest}/OptimizerTest.js +191 -191
  30. package/{samples/PDF2HtmlTest → PDF2HtmlTest}/PDF2HtmlTest.js +123 -123
  31. package/{samples/PDF2OfficeTest → PDF2OfficeTest}/PDF2OfficeTest.js +158 -158
  32. package/{samples/PDFATest → PDFATest}/PDFATest.js +85 -85
  33. package/{samples/PDFDocMemoryTest → PDFDocMemoryTest}/PDFDocMemoryTest.js +84 -84
  34. package/{samples/PDFDrawTest → PDFDrawTest}/PDFDrawTest.js +305 -305
  35. package/{samples/PDFLayersTest → PDFLayersTest}/PDFLayersTest.js +294 -294
  36. package/{samples/PDFPackageTest → PDFPackageTest}/PDFPackageTest.js +111 -111
  37. package/{samples/PDFPageTest → PDFPageTest}/PDFPageTest.js +189 -189
  38. package/{samples/PDFRedactTest → PDFRedactTest}/PDFRedactTest.js +74 -74
  39. package/{samples/PageLabelsTest → PageLabelsTest}/PageLabelsTest.js +138 -138
  40. package/{samples/PatternTest → PatternTest}/PatternTest.js +226 -226
  41. package/{samples/RectTest → RectTest}/RectTest.js +40 -40
  42. package/{samples/SDFTest → SDFTest}/SDFTest.js +87 -87
  43. package/{samples/StamperTest → StamperTest}/StamperTest.js +255 -255
  44. package/{samples/TestFiles → TestFiles}/Misc-Fixed.pfa +1166 -1166
  45. package/{samples/TestFiles → TestFiles}/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +34 -34
  46. package/{samples/TestFiles → TestFiles}/form1_annots.xfdf +33 -33
  47. package/{samples/TestFiles → TestFiles}/form1_data.xfdf +139 -139
  48. package/{samples/TestFiles → TestFiles}/my_stream.txt +2310 -2310
  49. package/{samples/TestFiles → TestFiles}/tiger.svg +378 -378
  50. package/{samples/TextExtractTest → TextExtractTest}/TextExtractTest.js +286 -286
  51. package/{samples/TextSearchTest → TextSearchTest}/TextSearchTest.js +121 -121
  52. package/{samples/U3DTest → U3DTest}/U3DTest.js +104 -104
  53. package/{samples/UndoRedoTest → UndoRedoTest}/UndoRedoTest.js +101 -101
  54. package/{samples/UnicodeWriteTest → UnicodeWriteTest}/UnicodeWriteTest.js +173 -173
  55. package/{samples/WebViewerConvertTest → WebViewerConvertTest}/WebViewerConvertTest.js +135 -135
  56. package/legal.txt +632 -0
  57. package/license.pdf +0 -0
  58. package/package.json +20 -20
  59. package/readme.md +38 -13
  60. package/{samples/runall.bat → runall.bat} +12 -12
  61. package/{samples/runall.sh → runall.sh} +15 -15
  62. /package/{samples/TestFiles → TestFiles}/BusinessCardTemplate.pdf +0 -0
  63. /package/{samples/TestFiles → TestFiles}/Fishermen.docx +0 -0
  64. /package/{samples/TestFiles → TestFiles}/Font_licenses.txt +0 -0
  65. /package/{samples/TestFiles → TestFiles}/GlobalSignRootForTST.cer +0 -0
  66. /package/{samples/TestFiles → TestFiles}/License.txt +0 -0
  67. /package/{samples/TestFiles → TestFiles}/NotoSans_with_hindi.ttf +0 -0
  68. /package/{samples/TestFiles → TestFiles}/Output/empty +0 -0
  69. /package/{samples/TestFiles → TestFiles}/SYH_Letter.docx +0 -0
  70. /package/{samples/TestFiles → TestFiles}/TigerText.pdf +0 -0
  71. /package/{samples/TestFiles → TestFiles}/US061222892-a.pdf +0 -0
  72. /package/{samples/TestFiles → TestFiles}/butterfly.png +0 -0
  73. /package/{samples/TestFiles → TestFiles}/credit card numbers.pdf +0 -0
  74. /package/{samples/TestFiles → TestFiles}/dice.jpg +0 -0
  75. /package/{samples/TestFiles → TestFiles}/dice.u3d +0 -0
  76. /package/{samples/TestFiles → TestFiles}/doc_to_sign.pdf +0 -0
  77. /package/{samples/TestFiles → TestFiles}/factsheet_Arabic.docx +0 -0
  78. /package/{samples/TestFiles → TestFiles}/financial.pdf +0 -0
  79. /package/{samples/TestFiles → TestFiles}/fish.pdf +0 -0
  80. /package/{samples/TestFiles → TestFiles}/font.ttf +0 -0
  81. /package/{samples/TestFiles → TestFiles}/form1.pdf +0 -0
  82. /package/{samples/TestFiles → TestFiles}/form1_data.fdf +0 -0
  83. /package/{samples/TestFiles → TestFiles}/formfields-scanned-withfields.pdf +0 -0
  84. /package/{samples/TestFiles → TestFiles}/formfields-scanned.pdf +0 -0
  85. /package/{samples/TestFiles → TestFiles}/formfields.pdf +0 -0
  86. /package/{samples/TestFiles → TestFiles}/grayscale.tif +0 -0
  87. /package/{samples/TestFiles → TestFiles}/hindi_sample_utf16le.txt +0 -0
  88. /package/{samples/TestFiles → TestFiles}/imagemask.dat +0 -0
  89. /package/{samples/TestFiles → TestFiles}/logo_red.png +0 -0
  90. /package/{samples/TestFiles → TestFiles}/lorem_ipsum.pdf +0 -0
  91. /package/{samples/TestFiles → TestFiles}/multipage.tif +0 -0
  92. /package/{samples/TestFiles → TestFiles}/newsletter.pdf +0 -0
  93. /package/{samples/TestFiles → TestFiles}/newsletter.xod +0 -0
  94. /package/{samples/TestFiles → TestFiles}/numbered.pdf +0 -0
  95. /package/{samples/TestFiles → TestFiles}/op_blend_test.pdf +0 -0
  96. /package/{samples/TestFiles → TestFiles}/palm.jp2 +0 -0
  97. /package/{samples/TestFiles → TestFiles}/paragraphs_and_tables.pdf +0 -0
  98. /package/{samples/TestFiles → TestFiles}/pdfnet.gif +0 -0
  99. /package/{samples/TestFiles → TestFiles}/pdftron.bmp +0 -0
  100. /package/{samples/TestFiles → TestFiles}/pdftron.cer +0 -0
  101. /package/{samples/TestFiles → TestFiles}/pdftron.pfx +0 -0
  102. /package/{samples/TestFiles → TestFiles}/pdftron_smart_substitution.plugin +0 -0
  103. /package/{samples/TestFiles → TestFiles}/peppers.jpg +0 -0
  104. /package/{samples/TestFiles → TestFiles}/signature.jpg +0 -0
  105. /package/{samples/TestFiles → TestFiles}/simple-emf.emf +0 -0
  106. /package/{samples/TestFiles → TestFiles}/simple-excel_2007.xlsx +0 -0
  107. /package/{samples/TestFiles → TestFiles}/simple-outlook.msg +0 -0
  108. /package/{samples/TestFiles → TestFiles}/simple-powerpoint_2007.pptx +0 -0
  109. /package/{samples/TestFiles → TestFiles}/simple-publisher.pub +0 -0
  110. /package/{samples/TestFiles → TestFiles}/simple-rtf.rtf +0 -0
  111. /package/{samples/TestFiles → TestFiles}/simple-text.txt +0 -0
  112. /package/{samples/TestFiles → TestFiles}/simple-visio.vsd +0 -0
  113. /package/{samples/TestFiles → TestFiles}/simple-webpage.html +0 -0
  114. /package/{samples/TestFiles → TestFiles}/simple-webpage.mht +0 -0
  115. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/colorschememapping.xml +0 -0
  116. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/filelist.xml +0 -0
  117. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image001.gif +0 -0
  118. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image002.png +0 -0
  119. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image003.jpg +0 -0
  120. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image004.emz +0 -0
  121. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image005.gif +0 -0
  122. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image006.png +0 -0
  123. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image007.gif +0 -0
  124. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/oledata.mso +0 -0
  125. /package/{samples/TestFiles → TestFiles}/simple-webpage_files/themedata.thmx +0 -0
  126. /package/{samples/TestFiles → TestFiles}/simple-word_2007.docx +0 -0
  127. /package/{samples/TestFiles → TestFiles}/simple-xps.xps +0 -0
  128. /package/{samples/TestFiles → TestFiles}/table.pdf +0 -0
  129. /package/{samples/TestFiles → TestFiles}/tagged.pdf +0 -0
  130. /package/{samples/TestFiles → TestFiles}/the_rime_of_the_ancient_mariner.docx +0 -0
  131. /package/{samples/TestFiles → TestFiles}/tiger.pdf +0 -0
  132. /package/{samples/TestFiles → TestFiles}/waiver.pdf +0 -0
  133. /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField.pdf +0 -0
  134. /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified.pdf +0 -0
  135. /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified_approved.pdf +0 -0
@@ -1,220 +1,220 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2024 by Apryse Software 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
1
+ //---------------------------------------------------------------------------------------
2
+ // Copyright (c) 2001-2024 by Apryse Software 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
220
  //# sourceURL=BookmarkTest.js
@@ -1,80 +1,80 @@
1
- //---------------------------------------------------------------------------------------
2
- // Copyright (c) 2001-2024 by Apryse Software 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 Apryse 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: Apryse 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
1
+ //---------------------------------------------------------------------------------------
2
+ // Copyright (c) 2001-2024 by Apryse Software 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 Apryse 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: Apryse 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
80
  //# sourceURL=CAD2PDFTest.js