@pdftron/pdfnet-node-samples 10.9.0 → 10.10.0-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.
- package/{samples/AddImageTest → AddImageTest}/AddImageTest.js +115 -115
- package/{samples/AdvancedImagingTest → AdvancedImagingTest}/AdvancedImagingTest.js +78 -78
- package/{samples/AnnotationTest → AnnotationTest}/AnnotationTest.js +641 -641
- package/{samples/BookmarkTest → BookmarkTest}/BookmarkTest.js +219 -219
- package/{samples/CAD2PDFTest → CAD2PDFTest}/CAD2PDFTest.js +79 -79
- package/{samples/ContentReplacerTest → ContentReplacerTest}/ContentReplacerTest.js +75 -75
- package/{samples/ConvertPrintTest → ConvertPrintTest}/ConvertPrintTest.js +153 -153
- package/{samples/ConvertTest → ConvertTest}/ConvertTest.js +203 -203
- package/{samples/DataExtractionTest → DataExtractionTest}/DataExtractionTest.js +214 -214
- package/{samples/DigitalSignaturesTest → DigitalSignaturesTest}/DigitalSignaturesTest.js +622 -527
- package/{samples/DocumentCreationTest → DocumentCreationTest}/DocumentCreationTest.js +409 -409
- package/{samples/ElementBuilderTest → ElementBuilderTest}/ElementBuilderTest.js +513 -513
- package/{samples/ElementEditTest → ElementEditTest}/ElementEditTest.js +110 -110
- package/{samples/ElementReaderAdvTest → ElementReaderAdvTest}/ElementReaderAdvTest.js +305 -305
- package/{samples/ElementReaderTest → ElementReaderTest}/ElementReaderTest.js +77 -77
- package/{samples/EncTest → EncTest}/EncTest.js +175 -175
- package/{samples/FDFTest → FDFTest}/FDFTest.js +218 -218
- package/{samples/HTML2PDFTest → HTML2PDFTest}/HTML2PDFTest.js +164 -164
- package/{samples/HighlightsTest → HighlightsTest}/HighlightsTest.js +97 -97
- package/{samples/ImageExtractTest → ImageExtractTest}/ImageExtractTest.js +129 -129
- package/{samples/ImpositionTest → ImpositionTest}/ImpositionTest.js +86 -86
- package/{samples/InteractiveFormsTest → InteractiveFormsTest}/InteractiveFormsTest.js +381 -381
- package/{samples/JBIG2Test → JBIG2Test}/JBIG2Test.js +88 -88
- package/{samples/LicenseKey → LicenseKey}/LicenseKey.js +11 -11
- package/{samples/LogicalStructureTest → LogicalStructureTest}/LogicalStructureTest.js +250 -250
- package/{samples/OCRTest → OCRTest}/OCRTest.js +235 -235
- package/{samples/OfficeTemplateTest → OfficeTemplateTest}/OfficeTemplateTest.js +79 -79
- package/{samples/OfficeToPDFTest → OfficeToPDFTest}/OfficeToPDFTest.js +125 -125
- package/{samples/OptimizerTest → OptimizerTest}/OptimizerTest.js +191 -191
- package/{samples/PDF2HtmlTest → PDF2HtmlTest}/PDF2HtmlTest.js +123 -123
- package/{samples/PDF2OfficeTest → PDF2OfficeTest}/PDF2OfficeTest.js +158 -158
- package/{samples/PDFATest → PDFATest}/PDFATest.js +85 -85
- package/{samples/PDFDocMemoryTest → PDFDocMemoryTest}/PDFDocMemoryTest.js +84 -84
- package/{samples/PDFDrawTest → PDFDrawTest}/PDFDrawTest.js +305 -305
- package/{samples/PDFLayersTest → PDFLayersTest}/PDFLayersTest.js +294 -294
- package/{samples/PDFPackageTest → PDFPackageTest}/PDFPackageTest.js +111 -111
- package/{samples/PDFPageTest → PDFPageTest}/PDFPageTest.js +189 -189
- package/{samples/PDFRedactTest → PDFRedactTest}/PDFRedactTest.js +74 -74
- package/{samples/PageLabelsTest → PageLabelsTest}/PageLabelsTest.js +138 -138
- package/{samples/PatternTest → PatternTest}/PatternTest.js +226 -226
- package/{samples/RectTest → RectTest}/RectTest.js +40 -40
- package/{samples/SDFTest → SDFTest}/SDFTest.js +87 -87
- package/{samples/StamperTest → StamperTest}/StamperTest.js +255 -255
- package/{samples/TestFiles → TestFiles}/Misc-Fixed.pfa +1166 -1166
- package/{samples/TestFiles → TestFiles}/SHA-2 Root USERTrust RSA CA Sectigo timestamping.crt +34 -34
- package/{samples/TestFiles → TestFiles}/form1_annots.xfdf +33 -33
- package/{samples/TestFiles → TestFiles}/form1_data.xfdf +139 -139
- package/{samples/TestFiles → TestFiles}/my_stream.txt +2310 -2310
- package/{samples/TestFiles → TestFiles}/tiger.svg +378 -378
- package/{samples/TextExtractTest → TextExtractTest}/TextExtractTest.js +286 -286
- package/{samples/TextSearchTest → TextSearchTest}/TextSearchTest.js +121 -121
- package/{samples/U3DTest → U3DTest}/U3DTest.js +104 -104
- package/{samples/UndoRedoTest → UndoRedoTest}/UndoRedoTest.js +101 -101
- package/{samples/UnicodeWriteTest → UnicodeWriteTest}/UnicodeWriteTest.js +173 -173
- package/{samples/WebViewerConvertTest → WebViewerConvertTest}/WebViewerConvertTest.js +135 -135
- package/legal.txt +632 -0
- package/license.pdf +0 -0
- package/package.json +20 -21
- package/readme.md +38 -13
- package/{samples/runall.bat → runall.bat} +12 -12
- package/{samples/runall.sh → runall.sh} +15 -15
- /package/{samples/TestFiles → TestFiles}/BusinessCardTemplate.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/Fishermen.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/Font_licenses.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/GlobalSignRootForTST.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/License.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/NotoSans_with_hindi.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/Output/empty +0 -0
- /package/{samples/TestFiles → TestFiles}/SYH_Letter.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/TigerText.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/US061222892-a.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/butterfly.png +0 -0
- /package/{samples/TestFiles → TestFiles}/credit card numbers.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/dice.u3d +0 -0
- /package/{samples/TestFiles → TestFiles}/doc_to_sign.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/factsheet_Arabic.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/financial.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/fish.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/font.ttf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/form1_data.fdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned-withfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields-scanned.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/formfields.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/grayscale.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/hindi_sample_utf16le.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/imagemask.dat +0 -0
- /package/{samples/TestFiles → TestFiles}/logo_red.png +0 -0
- /package/{samples/TestFiles → TestFiles}/lorem_ipsum.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/multipage.tif +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/newsletter.xod +0 -0
- /package/{samples/TestFiles → TestFiles}/numbered.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/op_blend_test.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/palm.jp2 +0 -0
- /package/{samples/TestFiles → TestFiles}/paragraphs_and_tables.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/pdfnet.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.bmp +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.cer +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron.pfx +0 -0
- /package/{samples/TestFiles → TestFiles}/pdftron_smart_substitution.plugin +0 -0
- /package/{samples/TestFiles → TestFiles}/peppers.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/signature.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-emf.emf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-excel_2007.xlsx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-outlook.msg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-powerpoint_2007.pptx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-publisher.pub +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-rtf.rtf +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-text.txt +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-visio.vsd +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.html +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage.mht +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/colorschememapping.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/filelist.xml +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image001.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image002.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image003.jpg +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image004.emz +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image005.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image006.png +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/image007.gif +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/oledata.mso +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-webpage_files/themedata.thmx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-word_2007.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/simple-xps.xps +0 -0
- /package/{samples/TestFiles → TestFiles}/table.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/tagged.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/the_rime_of_the_ancient_mariner.docx +0 -0
- /package/{samples/TestFiles → TestFiles}/tiger.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified.pdf +0 -0
- /package/{samples/TestFiles → TestFiles}/waiver_withApprovalField_certified_approved.pdf +0 -0
|
@@ -1,75 +1,75 @@
|
|
|
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
|
-
// PDF Redactor is a separately licensable Add-on that offers options to remove
|
|
7
|
-
// (not just covering or obscuring) content within a region of PDF.
|
|
8
|
-
// With printed pages, redaction involves blacking-out or cutting-out areas of
|
|
9
|
-
// the printed page. With electronic documents that use formats such as PDF,
|
|
10
|
-
// redaction typically involves removing sensitive content within documents for
|
|
11
|
-
// safe distribution to courts, patent and government institutions, the media,
|
|
12
|
-
// customers, vendors or any other audience with restricted access to the content.
|
|
13
|
-
//
|
|
14
|
-
// The redaction process in PDFNet consists of two steps:
|
|
15
|
-
//
|
|
16
|
-
// a) Content identification: A user applies redact annotations that specify the
|
|
17
|
-
// pieces or regions of content that should be removed. The content for redaction
|
|
18
|
-
// can be identified either interactively (e.g. using 'pdftron.PDF.PDFViewCtrl'
|
|
19
|
-
// as shown in PDFView sample) or programmatically (e.g. using 'pdftron.PDF.TextSearch'
|
|
20
|
-
// or 'pdftron.PDF.TextExtractor'). Up until the next step is performed, the user
|
|
21
|
-
// can see, move and redefine these annotations.
|
|
22
|
-
// b) Content removal: Using 'pdftron.PDF.Redactor.Redact()' the user instructs
|
|
23
|
-
// PDFNet to apply the redact regions, after which the content in the area specified
|
|
24
|
-
// by the redact annotations is removed. The redaction function includes number of
|
|
25
|
-
// options to control the style of the redaction overlay (including color, text,
|
|
26
|
-
// font, border, transparency, etc.).
|
|
27
|
-
//
|
|
28
|
-
// PDFTron Redactor makes sure that if a portion of an image, text, or vector graphics
|
|
29
|
-
// is contained in a redaction region, that portion of the image or path data is
|
|
30
|
-
// destroyed and is not simply hidden with clipping or image masks. PDFNet API can also
|
|
31
|
-
// be used to review and remove metadata and other content that can exist in a PDF
|
|
32
|
-
// document, including XML Forms Architecture (XFA) content and Extensible Metadata
|
|
33
|
-
// Platform (XMP) content.
|
|
34
|
-
|
|
35
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
36
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
37
|
-
|
|
38
|
-
((exports) => {
|
|
39
|
-
|
|
40
|
-
exports.runPDFRedactTest = () => {
|
|
41
|
-
const redact = async(input, output, vec, app) => {
|
|
42
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(input);
|
|
43
|
-
if (await doc.initSecurityHandler()) {
|
|
44
|
-
PDFNet.Redactor.redact(doc, vec, app, false, true);
|
|
45
|
-
await doc.save(output, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
|
|
49
|
-
const main = async() => {
|
|
50
|
-
// Relative path to the folder containing test files.
|
|
51
|
-
const inputPath = '../TestFiles/';
|
|
52
|
-
try {
|
|
53
|
-
const redactionArray = []; // we will contain a list of redaction objects in this array
|
|
54
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(1, (await PDFNet.Rect.init(100, 100, 550, 600)), false, 'Top Secret'));
|
|
55
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(30, 30, 450, 450)), true, 'Negative Redaction'));
|
|
56
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(0, 0, 100, 100)), false, 'Positive'));
|
|
57
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(100, 100, 200, 200)), false, 'Positive'));
|
|
58
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(300, 300, 400, 400)), false, ''));
|
|
59
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(500, 500, 600, 600)), false, ''));
|
|
60
|
-
redactionArray.push(await PDFNet.Redactor.redactionCreate(3, (await PDFNet.Rect.init(0, 0, 700, 20)), false, ''));
|
|
61
|
-
|
|
62
|
-
const appear = { redaction_overlay: true, border: false, show_redacted_content_regions: true };
|
|
63
|
-
await redact(inputPath + 'newsletter.pdf', inputPath + 'Output/redacted.pdf', redactionArray, appear);
|
|
64
|
-
|
|
65
|
-
console.log('Done...');
|
|
66
|
-
} catch (err) {
|
|
67
|
-
console.log(err.stack);
|
|
68
|
-
}
|
|
69
|
-
};
|
|
70
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
|
|
71
|
-
};
|
|
72
|
-
exports.runPDFRedactTest();
|
|
73
|
-
})(exports);
|
|
74
|
-
// 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
|
+
// PDF Redactor is a separately licensable Add-on that offers options to remove
|
|
7
|
+
// (not just covering or obscuring) content within a region of PDF.
|
|
8
|
+
// With printed pages, redaction involves blacking-out or cutting-out areas of
|
|
9
|
+
// the printed page. With electronic documents that use formats such as PDF,
|
|
10
|
+
// redaction typically involves removing sensitive content within documents for
|
|
11
|
+
// safe distribution to courts, patent and government institutions, the media,
|
|
12
|
+
// customers, vendors or any other audience with restricted access to the content.
|
|
13
|
+
//
|
|
14
|
+
// The redaction process in PDFNet consists of two steps:
|
|
15
|
+
//
|
|
16
|
+
// a) Content identification: A user applies redact annotations that specify the
|
|
17
|
+
// pieces or regions of content that should be removed. The content for redaction
|
|
18
|
+
// can be identified either interactively (e.g. using 'pdftron.PDF.PDFViewCtrl'
|
|
19
|
+
// as shown in PDFView sample) or programmatically (e.g. using 'pdftron.PDF.TextSearch'
|
|
20
|
+
// or 'pdftron.PDF.TextExtractor'). Up until the next step is performed, the user
|
|
21
|
+
// can see, move and redefine these annotations.
|
|
22
|
+
// b) Content removal: Using 'pdftron.PDF.Redactor.Redact()' the user instructs
|
|
23
|
+
// PDFNet to apply the redact regions, after which the content in the area specified
|
|
24
|
+
// by the redact annotations is removed. The redaction function includes number of
|
|
25
|
+
// options to control the style of the redaction overlay (including color, text,
|
|
26
|
+
// font, border, transparency, etc.).
|
|
27
|
+
//
|
|
28
|
+
// PDFTron Redactor makes sure that if a portion of an image, text, or vector graphics
|
|
29
|
+
// is contained in a redaction region, that portion of the image or path data is
|
|
30
|
+
// destroyed and is not simply hidden with clipping or image masks. PDFNet API can also
|
|
31
|
+
// be used to review and remove metadata and other content that can exist in a PDF
|
|
32
|
+
// document, including XML Forms Architecture (XFA) content and Extensible Metadata
|
|
33
|
+
// Platform (XMP) content.
|
|
34
|
+
|
|
35
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
36
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
37
|
+
|
|
38
|
+
((exports) => {
|
|
39
|
+
|
|
40
|
+
exports.runPDFRedactTest = () => {
|
|
41
|
+
const redact = async(input, output, vec, app) => {
|
|
42
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(input);
|
|
43
|
+
if (await doc.initSecurityHandler()) {
|
|
44
|
+
PDFNet.Redactor.redact(doc, vec, app, false, true);
|
|
45
|
+
await doc.save(output, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
const main = async() => {
|
|
50
|
+
// Relative path to the folder containing test files.
|
|
51
|
+
const inputPath = '../TestFiles/';
|
|
52
|
+
try {
|
|
53
|
+
const redactionArray = []; // we will contain a list of redaction objects in this array
|
|
54
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(1, (await PDFNet.Rect.init(100, 100, 550, 600)), false, 'Top Secret'));
|
|
55
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(30, 30, 450, 450)), true, 'Negative Redaction'));
|
|
56
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(0, 0, 100, 100)), false, 'Positive'));
|
|
57
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(100, 100, 200, 200)), false, 'Positive'));
|
|
58
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(300, 300, 400, 400)), false, ''));
|
|
59
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(2, (await PDFNet.Rect.init(500, 500, 600, 600)), false, ''));
|
|
60
|
+
redactionArray.push(await PDFNet.Redactor.redactionCreate(3, (await PDFNet.Rect.init(0, 0, 700, 20)), false, ''));
|
|
61
|
+
|
|
62
|
+
const appear = { redaction_overlay: true, border: false, show_redacted_content_regions: true };
|
|
63
|
+
await redact(inputPath + 'newsletter.pdf', inputPath + 'Output/redacted.pdf', redactionArray, appear);
|
|
64
|
+
|
|
65
|
+
console.log('Done...');
|
|
66
|
+
} catch (err) {
|
|
67
|
+
console.log(err.stack);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error){console.log('Error: ' + JSON.stringify(error));}).then(function(){return PDFNet.shutdown();});
|
|
71
|
+
};
|
|
72
|
+
exports.runPDFRedactTest();
|
|
73
|
+
})(exports);
|
|
74
|
+
// eslint-disable-next-line spaced-comment
|
|
75
75
|
//# sourceURL=PDFRedactTest.js
|
|
@@ -1,139 +1,139 @@
|
|
|
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 illustrates how to work with PDF page labels.
|
|
8
|
-
//
|
|
9
|
-
// PDF page labels can be used to describe a page. This is used to
|
|
10
|
-
// allow for non-sequential page numbering or the addition of arbitrary
|
|
11
|
-
// labels for a page (such as the inclusion of Roman numerals at the
|
|
12
|
-
// beginning of a book). PDFNet PageLabel object can be used to specify
|
|
13
|
-
// the numbering style to use (for example, upper- or lower-case Roman,
|
|
14
|
-
// decimal, and so forth), the starting number for the first page,
|
|
15
|
-
// and an arbitrary prefix to be pre-appended to each number (for
|
|
16
|
-
// example, 'A-' to generate 'A-1', 'A-2', 'A-3', and so forth.)
|
|
17
|
-
//-----------------------------------------------------------------------------------
|
|
18
|
-
|
|
19
|
-
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
20
|
-
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
21
|
-
|
|
22
|
-
((exports) => {
|
|
23
|
-
'use strict';
|
|
24
|
-
|
|
25
|
-
exports.runPageLabelsTest = () => {
|
|
26
|
-
const main = async () => {
|
|
27
|
-
const inputPath = '../TestFiles/';
|
|
28
|
-
const outputPath = inputPath + 'Output/';
|
|
29
|
-
const outputFile = outputPath + 'newsletter_with_pagelabels.pdf';
|
|
30
|
-
|
|
31
|
-
try {
|
|
32
|
-
//-----------------------------------------------------------
|
|
33
|
-
// Example 1: Add page labels to an existing or newly created PDF
|
|
34
|
-
// document.
|
|
35
|
-
//-----------------------------------------------------------
|
|
36
|
-
{
|
|
37
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
|
|
38
|
-
doc.initSecurityHandler();
|
|
39
|
-
|
|
40
|
-
// Create a page labeling scheme that starts with the first page in
|
|
41
|
-
// the document (page 1) and is using uppercase roman numbering
|
|
42
|
-
// style.
|
|
43
|
-
const L1 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_roman_uppercase, 'My Prefix ', 1);
|
|
44
|
-
doc.setPageLabel(1, L1);
|
|
45
|
-
|
|
46
|
-
// Create a page labeling scheme that starts with the fourth page in
|
|
47
|
-
// the document and is using decimal Arabic numbering style.
|
|
48
|
-
// Also the numeric portion of the first label should start with number
|
|
49
|
-
// 4 (otherwise the first label would be 'My Prefix 1').
|
|
50
|
-
const L2 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_decimal, 'My Prefix ', 4);
|
|
51
|
-
doc.setPageLabel(4, L2);
|
|
52
|
-
|
|
53
|
-
// Create a page labeling scheme that starts with the seventh page in
|
|
54
|
-
// the document and is using alphabetic numbering style. The numeric
|
|
55
|
-
// portion of the first label should start with number 1.
|
|
56
|
-
const L3 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_alphabetic_uppercase, 'My Prefix ', 1);
|
|
57
|
-
doc.setPageLabel(7, L3);
|
|
58
|
-
|
|
59
|
-
doc.save(outputFile, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
60
|
-
console.log('Done. Result saved in newsletter_with_pagelabels.pdf...');
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
//-----------------------------------------------------------
|
|
64
|
-
// Example 2: Read page labels from an existing PDF document.
|
|
65
|
-
//-----------------------------------------------------------
|
|
66
|
-
{
|
|
67
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
68
|
-
doc.initSecurityHandler();
|
|
69
|
-
|
|
70
|
-
const page_num = await doc.getPageCount();
|
|
71
|
-
for (let i = 1; i <= page_num; ++i) {
|
|
72
|
-
console.log('Page number: ' + i);
|
|
73
|
-
const label = await doc.getPageLabel(i);
|
|
74
|
-
if (await label.isValid()) {
|
|
75
|
-
console.log(' Label: ' + await label.getLabelTitle(i));
|
|
76
|
-
}
|
|
77
|
-
else {
|
|
78
|
-
console.log(' No Label.');
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
//-----------------------------------------------------------
|
|
84
|
-
// Example 3: Modify page labels from an existing PDF document.
|
|
85
|
-
//-----------------------------------------------------------
|
|
86
|
-
{
|
|
87
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
88
|
-
doc.initSecurityHandler();
|
|
89
|
-
|
|
90
|
-
// Remove the alphabetic labels from example 1.
|
|
91
|
-
doc.removePageLabel(7);
|
|
92
|
-
|
|
93
|
-
// Replace the Prefix in the decimal labels (from example 1).
|
|
94
|
-
const label = await doc.getPageLabel(4);
|
|
95
|
-
if (await label.isValid()) {
|
|
96
|
-
await label.setPrefix('A');
|
|
97
|
-
label.setStart(1);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
// Add a new label
|
|
101
|
-
const new_label = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_decimal, 'B', 1);
|
|
102
|
-
doc.setPageLabel(10, new_label); // starting from page 10.
|
|
103
|
-
|
|
104
|
-
doc.save(outputPath + 'newsletter_with_pagelabels_modified.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
105
|
-
console.log('Done. Result saved in newsletter_with_pagelabels_modified.pdf...');
|
|
106
|
-
|
|
107
|
-
const page_num = await doc.getPageCount();
|
|
108
|
-
for (let i = 1; i <= page_num; ++i) {
|
|
109
|
-
console.log('Page number: ' + i);
|
|
110
|
-
const label = await doc.getPageLabel(i);
|
|
111
|
-
if (await label.isValid()) {
|
|
112
|
-
console.log(' Label: ' + await label.getLabelTitle(i));
|
|
113
|
-
}
|
|
114
|
-
else {
|
|
115
|
-
console.log(' No Label.');
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
//-----------------------------------------------------------
|
|
121
|
-
// Example 4: Delete all page labels in an existing PDF document.
|
|
122
|
-
//-----------------------------------------------------------
|
|
123
|
-
{
|
|
124
|
-
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
125
|
-
(await doc.getRoot()).eraseFromKey('PageLabels');
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
} catch (err) {
|
|
129
|
-
console.log(err);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
133
|
-
console.log('Error: ' + JSON.stringify(error));
|
|
134
|
-
}).then(function(){ return PDFNet.shutdown(); });
|
|
135
|
-
};
|
|
136
|
-
exports.runPageLabelsTest();
|
|
137
|
-
})(exports);
|
|
138
|
-
// 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 illustrates how to work with PDF page labels.
|
|
8
|
+
//
|
|
9
|
+
// PDF page labels can be used to describe a page. This is used to
|
|
10
|
+
// allow for non-sequential page numbering or the addition of arbitrary
|
|
11
|
+
// labels for a page (such as the inclusion of Roman numerals at the
|
|
12
|
+
// beginning of a book). PDFNet PageLabel object can be used to specify
|
|
13
|
+
// the numbering style to use (for example, upper- or lower-case Roman,
|
|
14
|
+
// decimal, and so forth), the starting number for the first page,
|
|
15
|
+
// and an arbitrary prefix to be pre-appended to each number (for
|
|
16
|
+
// example, 'A-' to generate 'A-1', 'A-2', 'A-3', and so forth.)
|
|
17
|
+
//-----------------------------------------------------------------------------------
|
|
18
|
+
|
|
19
|
+
const { PDFNet } = require('@pdftron/pdfnet-node');
|
|
20
|
+
const PDFTronLicense = require('../LicenseKey/LicenseKey');
|
|
21
|
+
|
|
22
|
+
((exports) => {
|
|
23
|
+
'use strict';
|
|
24
|
+
|
|
25
|
+
exports.runPageLabelsTest = () => {
|
|
26
|
+
const main = async () => {
|
|
27
|
+
const inputPath = '../TestFiles/';
|
|
28
|
+
const outputPath = inputPath + 'Output/';
|
|
29
|
+
const outputFile = outputPath + 'newsletter_with_pagelabels.pdf';
|
|
30
|
+
|
|
31
|
+
try {
|
|
32
|
+
//-----------------------------------------------------------
|
|
33
|
+
// Example 1: Add page labels to an existing or newly created PDF
|
|
34
|
+
// document.
|
|
35
|
+
//-----------------------------------------------------------
|
|
36
|
+
{
|
|
37
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(inputPath + 'newsletter.pdf');
|
|
38
|
+
doc.initSecurityHandler();
|
|
39
|
+
|
|
40
|
+
// Create a page labeling scheme that starts with the first page in
|
|
41
|
+
// the document (page 1) and is using uppercase roman numbering
|
|
42
|
+
// style.
|
|
43
|
+
const L1 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_roman_uppercase, 'My Prefix ', 1);
|
|
44
|
+
doc.setPageLabel(1, L1);
|
|
45
|
+
|
|
46
|
+
// Create a page labeling scheme that starts with the fourth page in
|
|
47
|
+
// the document and is using decimal Arabic numbering style.
|
|
48
|
+
// Also the numeric portion of the first label should start with number
|
|
49
|
+
// 4 (otherwise the first label would be 'My Prefix 1').
|
|
50
|
+
const L2 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_decimal, 'My Prefix ', 4);
|
|
51
|
+
doc.setPageLabel(4, L2);
|
|
52
|
+
|
|
53
|
+
// Create a page labeling scheme that starts with the seventh page in
|
|
54
|
+
// the document and is using alphabetic numbering style. The numeric
|
|
55
|
+
// portion of the first label should start with number 1.
|
|
56
|
+
const L3 = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_alphabetic_uppercase, 'My Prefix ', 1);
|
|
57
|
+
doc.setPageLabel(7, L3);
|
|
58
|
+
|
|
59
|
+
doc.save(outputFile, PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
60
|
+
console.log('Done. Result saved in newsletter_with_pagelabels.pdf...');
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
//-----------------------------------------------------------
|
|
64
|
+
// Example 2: Read page labels from an existing PDF document.
|
|
65
|
+
//-----------------------------------------------------------
|
|
66
|
+
{
|
|
67
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
68
|
+
doc.initSecurityHandler();
|
|
69
|
+
|
|
70
|
+
const page_num = await doc.getPageCount();
|
|
71
|
+
for (let i = 1; i <= page_num; ++i) {
|
|
72
|
+
console.log('Page number: ' + i);
|
|
73
|
+
const label = await doc.getPageLabel(i);
|
|
74
|
+
if (await label.isValid()) {
|
|
75
|
+
console.log(' Label: ' + await label.getLabelTitle(i));
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
console.log(' No Label.');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
//-----------------------------------------------------------
|
|
84
|
+
// Example 3: Modify page labels from an existing PDF document.
|
|
85
|
+
//-----------------------------------------------------------
|
|
86
|
+
{
|
|
87
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
88
|
+
doc.initSecurityHandler();
|
|
89
|
+
|
|
90
|
+
// Remove the alphabetic labels from example 1.
|
|
91
|
+
doc.removePageLabel(7);
|
|
92
|
+
|
|
93
|
+
// Replace the Prefix in the decimal labels (from example 1).
|
|
94
|
+
const label = await doc.getPageLabel(4);
|
|
95
|
+
if (await label.isValid()) {
|
|
96
|
+
await label.setPrefix('A');
|
|
97
|
+
label.setStart(1);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// Add a new label
|
|
101
|
+
const new_label = await PDFNet.PageLabel.create(doc, PDFNet.PageLabel.Style.e_decimal, 'B', 1);
|
|
102
|
+
doc.setPageLabel(10, new_label); // starting from page 10.
|
|
103
|
+
|
|
104
|
+
doc.save(outputPath + 'newsletter_with_pagelabels_modified.pdf', PDFNet.SDFDoc.SaveOptions.e_linearized);
|
|
105
|
+
console.log('Done. Result saved in newsletter_with_pagelabels_modified.pdf...');
|
|
106
|
+
|
|
107
|
+
const page_num = await doc.getPageCount();
|
|
108
|
+
for (let i = 1; i <= page_num; ++i) {
|
|
109
|
+
console.log('Page number: ' + i);
|
|
110
|
+
const label = await doc.getPageLabel(i);
|
|
111
|
+
if (await label.isValid()) {
|
|
112
|
+
console.log(' Label: ' + await label.getLabelTitle(i));
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
console.log(' No Label.');
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
//-----------------------------------------------------------
|
|
121
|
+
// Example 4: Delete all page labels in an existing PDF document.
|
|
122
|
+
//-----------------------------------------------------------
|
|
123
|
+
{
|
|
124
|
+
const doc = await PDFNet.PDFDoc.createFromFilePath(outputFile);
|
|
125
|
+
(await doc.getRoot()).eraseFromKey('PageLabels');
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
} catch (err) {
|
|
129
|
+
console.log(err);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
PDFNet.runWithCleanup(main, PDFTronLicense.Key).catch(function(error) {
|
|
133
|
+
console.log('Error: ' + JSON.stringify(error));
|
|
134
|
+
}).then(function(){ return PDFNet.shutdown(); });
|
|
135
|
+
};
|
|
136
|
+
exports.runPageLabelsTest();
|
|
137
|
+
})(exports);
|
|
138
|
+
// eslint-disable-next-line spaced-comment
|
|
139
139
|
//# sourceURL=PageLabelsTest.js
|