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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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 -21
  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,122 +1,122 @@
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
- const { PDFNet } = require('@pdftron/pdfnet-node');
8
- const PDFTronLicense = require('../LicenseKey/LicenseKey');
9
-
10
- ((exports) => {
11
-
12
- exports.runTextSearchTest = () => {
13
-
14
- const main = async() => {
15
- // Relative path to the folder containing test files.
16
- const inputURL = '../TestFiles/';
17
- const inputFilename = 'credit card numbers.pdf'; // addimage.pdf, newsletter.pdf
18
-
19
- try {
20
- const doc = await PDFNet.PDFDoc.createFromFilePath(inputURL + inputFilename);
21
- doc.initSecurityHandler();
22
-
23
- const txtSearch = await PDFNet.TextSearch.create();
24
- let mode = PDFNet.TextSearch.Mode.e_whole_word + PDFNet.TextSearch.Mode.e_page_stop; // Uses both whole word and page stop
25
- let pattern = 'joHn sMiTh';
26
-
27
- txtSearch.begin(doc, pattern, mode); // searches for the "pattern" in the document while following the inputted modes.
28
-
29
- let step = 0;
30
-
31
- // call Run() iteratively to find all matching instances of the word 'joHn sMiTh'
32
- /* eslint-disable-next-line no-constant-condition */
33
- while (true) {
34
- const result = await txtSearch.run();
35
- let hlts;
36
- if (result.code === PDFNet.TextSearch.ResultCode.e_found) {
37
- if (step === 0) { // Step 0: found "John Smith"
38
- // note that, here, 'ambient_str' and 'highlights' are not written to,
39
- // as 'e_ambient_string' and 'e_highlight' are not set.
40
- console.log(result.out_str + "'s credit card number is: ");
41
-
42
- // now switch to using regular expressions to find John's credit card number
43
- mode = await txtSearch.getMode();
44
- mode += PDFNet.TextSearch.Mode.e_reg_expression + PDFNet.TextSearch.Mode.e_highlight;
45
- txtSearch.setMode(mode);
46
- pattern = '\\d{4}-\\d{4}-\\d{4}-\\d{4}'; // or "(\\d{4}-){3}\\d{4}"
47
- txtSearch.setPattern(pattern);
48
-
49
- ++step;
50
- } else if (step === 1) {
51
- // step 1: found John's credit card number
52
- console.log(' ' + result.out_str);
53
- // note that, here, 'hlts' is written to, as 'e_highlight' has been set.
54
- // output the highlight info of the credit card number.
55
- hlts = result.highlights;
56
- hlts.begin(doc);
57
- while ((await hlts.hasNext())) {
58
- const highlightPageNum = await hlts.getCurrentPageNumber();
59
- console.log('The current highlight is from page: ' + highlightPageNum);
60
- await hlts.next();
61
- }
62
- // see if there is an AMEX card number
63
- pattern = '\\d{4}-\\d{6}-\\d{5}';
64
- txtSearch.setPattern(pattern);
65
-
66
- ++step;
67
- } else if (step === 2) {
68
- // found an AMEX card number
69
- console.log('\nThere is an AMEX card number:\n ' + result.out_str);
70
-
71
- // change mode to find the owner of the credit card; supposedly, the owner's
72
- // name proceeds the number
73
- mode = await txtSearch.getMode();
74
- mode += PDFNet.TextSearch.Mode.e_search_up;
75
- txtSearch.setMode(mode);
76
- pattern = '[A-z]++ [A-z]++';
77
- txtSearch.setPattern(pattern);
78
-
79
- ++step;
80
- } else if (step === 3) {
81
- // found the owner's name of the AMEX card
82
- console.log("Is the owner's name:\n " + result.out_str + '?');
83
-
84
- // add a link annotation based on the location of the found instance
85
- hlts = result.highlights;
86
- await hlts.begin(doc); // is await needed?
87
- while ((await hlts.hasNext())) {
88
- const curPage = await doc.getPage((await hlts.getCurrentPageNumber()));
89
- const quadArr = await hlts.getCurrentQuads();
90
- for (let i = 0; i < quadArr.length; ++i) {
91
- const currQuad = quadArr[i];
92
- const x1 = Math.min(Math.min(Math.min(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
93
- const x2 = Math.max(Math.max(Math.max(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
94
- const y1 = Math.min(Math.min(Math.min(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
95
- const y2 = Math.max(Math.max(Math.max(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
96
-
97
- const hyperLink = await PDFNet.LinkAnnot.create(doc, (await PDFNet.Rect.init(x1, y1, x2, y2)));
98
- await hyperLink.setAction((await PDFNet.Action.createURI(doc, 'http://www.pdftron.com')));
99
- await curPage.annotPushBack(hyperLink);
100
- }
101
- hlts.next();
102
- }
103
- await doc.save('../TestFiles/Output/credit card numbers_linked.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
104
- break;
105
- }
106
- } else if (result.code === PDFNet.TextSearch.ResultCode.e_page) {
107
- // you can update your UI here, if needed
108
- console.log('page end');
109
- } else if (result.code === PDFNet.TextSearch.ResultCode.e_done) {
110
- break;
111
- }
112
- }
113
- } catch (err) {
114
- console.log(err);
115
- }
116
- };
117
- PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
118
- };
119
- exports.runTextSearchTest();
120
- })(exports);
121
- // 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
+ const { PDFNet } = require('@pdftron/pdfnet-node');
8
+ const PDFTronLicense = require('../LicenseKey/LicenseKey');
9
+
10
+ ((exports) => {
11
+
12
+ exports.runTextSearchTest = () => {
13
+
14
+ const main = async() => {
15
+ // Relative path to the folder containing test files.
16
+ const inputURL = '../TestFiles/';
17
+ const inputFilename = 'credit card numbers.pdf'; // addimage.pdf, newsletter.pdf
18
+
19
+ try {
20
+ const doc = await PDFNet.PDFDoc.createFromFilePath(inputURL + inputFilename);
21
+ doc.initSecurityHandler();
22
+
23
+ const txtSearch = await PDFNet.TextSearch.create();
24
+ let mode = PDFNet.TextSearch.Mode.e_whole_word + PDFNet.TextSearch.Mode.e_page_stop; // Uses both whole word and page stop
25
+ let pattern = 'joHn sMiTh';
26
+
27
+ txtSearch.begin(doc, pattern, mode); // searches for the "pattern" in the document while following the inputted modes.
28
+
29
+ let step = 0;
30
+
31
+ // call Run() iteratively to find all matching instances of the word 'joHn sMiTh'
32
+ /* eslint-disable-next-line no-constant-condition */
33
+ while (true) {
34
+ const result = await txtSearch.run();
35
+ let hlts;
36
+ if (result.code === PDFNet.TextSearch.ResultCode.e_found) {
37
+ if (step === 0) { // Step 0: found "John Smith"
38
+ // note that, here, 'ambient_str' and 'highlights' are not written to,
39
+ // as 'e_ambient_string' and 'e_highlight' are not set.
40
+ console.log(result.out_str + "'s credit card number is: ");
41
+
42
+ // now switch to using regular expressions to find John's credit card number
43
+ mode = await txtSearch.getMode();
44
+ mode += PDFNet.TextSearch.Mode.e_reg_expression + PDFNet.TextSearch.Mode.e_highlight;
45
+ txtSearch.setMode(mode);
46
+ pattern = '\\d{4}-\\d{4}-\\d{4}-\\d{4}'; // or "(\\d{4}-){3}\\d{4}"
47
+ txtSearch.setPattern(pattern);
48
+
49
+ ++step;
50
+ } else if (step === 1) {
51
+ // step 1: found John's credit card number
52
+ console.log(' ' + result.out_str);
53
+ // note that, here, 'hlts' is written to, as 'e_highlight' has been set.
54
+ // output the highlight info of the credit card number.
55
+ hlts = result.highlights;
56
+ hlts.begin(doc);
57
+ while ((await hlts.hasNext())) {
58
+ const highlightPageNum = await hlts.getCurrentPageNumber();
59
+ console.log('The current highlight is from page: ' + highlightPageNum);
60
+ await hlts.next();
61
+ }
62
+ // see if there is an AMEX card number
63
+ pattern = '\\d{4}-\\d{6}-\\d{5}';
64
+ txtSearch.setPattern(pattern);
65
+
66
+ ++step;
67
+ } else if (step === 2) {
68
+ // found an AMEX card number
69
+ console.log('\nThere is an AMEX card number:\n ' + result.out_str);
70
+
71
+ // change mode to find the owner of the credit card; supposedly, the owner's
72
+ // name proceeds the number
73
+ mode = await txtSearch.getMode();
74
+ mode += PDFNet.TextSearch.Mode.e_search_up;
75
+ txtSearch.setMode(mode);
76
+ pattern = '[A-z]++ [A-z]++';
77
+ txtSearch.setPattern(pattern);
78
+
79
+ ++step;
80
+ } else if (step === 3) {
81
+ // found the owner's name of the AMEX card
82
+ console.log("Is the owner's name:\n " + result.out_str + '?');
83
+
84
+ // add a link annotation based on the location of the found instance
85
+ hlts = result.highlights;
86
+ await hlts.begin(doc); // is await needed?
87
+ while ((await hlts.hasNext())) {
88
+ const curPage = await doc.getPage((await hlts.getCurrentPageNumber()));
89
+ const quadArr = await hlts.getCurrentQuads();
90
+ for (let i = 0; i < quadArr.length; ++i) {
91
+ const currQuad = quadArr[i];
92
+ const x1 = Math.min(Math.min(Math.min(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
93
+ const x2 = Math.max(Math.max(Math.max(currQuad.p1x, currQuad.p2x), currQuad.p3x), currQuad.p4x);
94
+ const y1 = Math.min(Math.min(Math.min(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
95
+ const y2 = Math.max(Math.max(Math.max(currQuad.p1y, currQuad.p2y), currQuad.p3y), currQuad.p4y);
96
+
97
+ const hyperLink = await PDFNet.LinkAnnot.create(doc, (await PDFNet.Rect.init(x1, y1, x2, y2)));
98
+ await hyperLink.setAction((await PDFNet.Action.createURI(doc, 'http://www.pdftron.com')));
99
+ await curPage.annotPushBack(hyperLink);
100
+ }
101
+ hlts.next();
102
+ }
103
+ await doc.save('../TestFiles/Output/credit card numbers_linked.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
104
+ break;
105
+ }
106
+ } else if (result.code === PDFNet.TextSearch.ResultCode.e_page) {
107
+ // you can update your UI here, if needed
108
+ console.log('page end');
109
+ } else if (result.code === PDFNet.TextSearch.ResultCode.e_done) {
110
+ break;
111
+ }
112
+ }
113
+ } catch (err) {
114
+ console.log(err);
115
+ }
116
+ };
117
+ PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
118
+ };
119
+ exports.runTextSearchTest();
120
+ })(exports);
121
+ // eslint-disable-next-line spaced-comment
122
122
  //# sourceURL=TextSearchTest.js
@@ -1,105 +1,105 @@
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
- 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-2024 by Apryse Software 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