Stamp annotation in TypeScript PDF Viewer control

17 Oct 202524 minutes to read

The PDF Viewer control provides options to add, edit, delete, and rotate the following stamp annotations in PDF documents:

  • Dynamic
  • Sign Here
  • Standard Business
  • Custom Stamp

StampAnnotation

Add stamp annotations to the PDF document

The stamp annotations can be added to the PDF document using the annotation toolbar.

  • Click the Edit Annotation button in the PDF Viewer toolbar. A toolbar appears below it.
  • Click the Stamp Annotation drop-down button. The pop-up lists available stamp annotation types.

StampTool

  • Select a stamp type to enable its annotation mode.

StampPopup

  • Place the stamp on the pages of the PDF document.

NOTE

When in pan mode and a stamp annotation tool is selected, the PDF Viewer switches to text select mode automatically for a smooth interaction experience.

The following examples switch to stamp annotation modes.

<button id="dynamicStamp">Sign Stamp</button>
<button id="signStamp">Sign Stamp</button>
<button id="standardBusinessStamp">StandardBusiness Stamp</button>
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, SignStampItem, StandardBusinessStampItem, DynamicStampItem,} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.resourceUrl = "https://cdn.syncfusion.com/ej2/31.1.23/dist/ej2-pdfviewer-lib";
pdfviewer.appendTo('#PdfViewer');

let dynamicStamp = document.getElementById('dynamicStamp');
if (dynamicStamp) {
    dynamicStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', DynamicStampItem.NotApproved);
        }
    });
}
let signStamp = document.getElementById('signStamp');
if (signStamp) {
    signStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, SignStampItem.Witness);
        }
    });
}
let standardBusinessStamp = document.getElementById('standardBusinessStamp');
if (standardBusinessStamp) {
    standardBusinessStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, undefined, StandardBusinessStampItem.Approved);
        }
    });
}
let customStamp = document.getElementById('customStamp');
if (customStamp) {
    customStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation('Stamp',
            {
              offset: { x: 100, y: 440 },
              width: 46,
              author: 'Guest',
              height: 100,
              isLock: true,
              pageNumber: 1,
              customStamps: [
                {
                  customStampName: "Image",
                  customStampImageSource:
                    ""
                }
              ]
            } as CustomStampSettings);
        }
    });
}
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, SignStampItem, StandardBusinessStampItem, DynamicStampItem,} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.serviceUrl = 'https://document.syncfusion.com/web-services/pdf-viewer/api/pdfviewer/';
pdfviewer.appendTo('#PdfViewer');

let dynamicStamp = document.getElementById('dynamicStamp');
if (dynamicStamp) {
    dynamicStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', DynamicStampItem.NotApproved);
        }
    });
}
let signStamp = document.getElementById('signStamp');
if (signStamp) {
    signStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, SignStampItem.Witness);
        }
    });
}
let standardBusinessStamp = document.getElementById('standardBusinessStamp');
if (standardBusinessStamp) {
    standardBusinessStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, undefined, StandardBusinessStampItem.Approved);
        }
    });
}

Add a custom stamp to the PDF document

  • Click the Edit Annotation button in the PDF Viewer toolbar. A toolbar appears below it.
  • Click the Stamp Annotation drop-down button. The pop-up lists available stamp annotation types.
  • Click the Custom Stamp button.

CustomStamp

  • In the file explorer dialog, choose an image and add it to the PDF page.

Only JPG and JPEG image formats are supported for custom stamp annotations.

Add a stamp annotation to the PDF document programmatically

The PDF Viewer library allows adding a stamp annotation programmatically using the addAnnotation() method.

Here are examples showing how to add stamp annotations programmatically using addAnnotation():

    <button id="dynamicStamp">Add Sign Stamp Programmatically</button>
    <button id="signStamp">Add Sign Stamp Programmatically</button>
    <button id="standardBusinessStamp">Add StandardBusiness Stamp Programmatically</button>
    <button id="customStamp">Add Custom Stamp Programmatically</button>
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, StampSettings, DynamicStampItem} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.resourceUrl = "https://cdn.syncfusion.com/ej2/31.1.23/dist/ej2-pdfviewer-lib";
pdfviewer.appendTo('#PdfViewer');

let dynamicStamp = document.getElementById('dynamicStamp');
if (dynamicStamp) {
    dynamicStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 140 },
                pageNumber: 1
            } as StampSettings, DynamicStampItem.Approved);
        }
    });
}
let signStamp = document.getElementById('signStamp');
if (signStamp) {
    signStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 240 },
                pageNumber: 1
            } as StampSettings, undefined, SignStampItem.Witness);
        }
    });
}
let standardBusinessStamp = document.getElementById('standardBusinessStamp');
if (standardBusinessStamp) {
    standardBusinessStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 340 },
                pageNumber: 1
            } as StampSettings, undefined, undefined, StandardBusinessStampItem.Approved);
        }
    });
}

let customStamp = document.getElementById('customStamp');
if (customStamp) {
    customStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation('Stamp',
            {
                offset: { x: 100, y: 440 },
                 width: 46,
                author: 'Guest',
                height: 100,
                isLock: true,
                pageNumber: 1,
                customStamps: [
                    {
                        customStampName: "Image",
                        customStampImageSource:
                            ""
                    }
                ]
            } as CustomStampSettings);
        }
    });
}
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, StampSettings, DynamicStampItem} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.serviceUrl = 'https://document.syncfusion.com/web-services/pdf-viewer/api/pdfviewer/';
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.appendTo('#PdfViewer');

let dynamicStamp = document.getElementById('dynamicStamp');
if (dynamicStamp) {
    dynamicStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 140 },
                pageNumber: 1
            } as StampSettings, DynamicStampItem.Approved);
        }
    });
}
let signStamp = document.getElementById('signStamp');
if (signStamp) {
    signStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 240 },
                pageNumber: 1
            } as StampSettings, undefined, SignStampItem.Witness);
        }
    });
}
let standardBusinessStamp = document.getElementById('standardBusinessStamp');
if (standardBusinessStamp) {
    standardBusinessStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation("Stamp", {
                offset: { x: 200, y: 340 },
                pageNumber: 1
            } as StampSettings, undefined, undefined, StandardBusinessStampItem.Approved);
        }
    });
}

let customStamp = document.getElementById('customStamp');
if (customStamp) {
    customStamp.addEventListener('click', function () {
        if (pdfviewer) {
            pdfviewer.annotation.addAnnotation('Stamp',
            {
                offset: { x: 100, y: 440 },
                 width: 46,
                author: 'Guest',
                height: 100,
                isLock: true,
                pageNumber: 1,
                customStamps: [
                    {
                        customStampName: "Image",
                        customStampImageSource:
                            ""
                    }
                ]
            } as CustomStampSettings);
        }
    });
}

Edit an existing stamp annotation programmatically

To modify an existing stamp annotation programmatically, use the editAnnotation() method.

Here is an example of using editAnnotation():

<button id="editAnnotation">Edit Stamp annotation</button>
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.resourceUrl = "https://cdn.syncfusion.com/ej2/31.1.23/dist/ej2-pdfviewer-lib";

pdfviewer.appendTo('#PdfViewer');
let editAnnotation = document.getElementById('editAnnotation');
if (editAnnotation) {
    editAnnotation.addEventListener('click', function () {
        if (pdfviewer) {
            for (let i = 0; i < pdfviewer.annotationCollection.length; i++) {
                if (pdfviewer.annotationCollection[i].shapeAnnotationType === "stamp") {
                    var width = pdfviewer.annotationCollection[i].bounds.width;
                    var height = pdfviewer.annotationCollection[i].bounds.height;
                    pdfviewer.annotationCollection[i].bounds = { x: 100, y: 100, width: width, height: height };
                    pdfviewer.annotationCollection[i].annotationSettings.isLock = true;
                    pdfviewer.annotation.editAnnotation(pdfviewer.annotationCollection[i]);
                }
            }
        }
    });
}
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.serviceUrl = 'https://document.syncfusion.com/web-services/pdf-viewer/api/pdfviewer/';
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";

pdfviewer.appendTo('#PdfViewer');

let editAnnotation = document.getElementById('editAnnotation');
if (editAnnotation) {
    editAnnotation.addEventListener('click', function () {
        if (pdfviewer) {
            for (let i = 0; i < pdfviewer.annotationCollection.length; i++) {
                if (pdfviewer.annotationCollection[i].shapeAnnotationType === "stamp") {
                    var width = pdfviewer.annotationCollection[i].bounds.width;
                    var height = pdfviewer.annotationCollection[i].bounds.height;
                    pdfviewer.annotationCollection[i].bounds = { x: 100, y: 100, width: width, height: height };
                    pdfviewer.annotationCollection[i].annotationSettings.isLock = true;
                    pdfviewer.annotation.editAnnotation(pdfviewer.annotationCollection[i]);
                }
            }
        }
    });
}

Set default properties during control initialization

Default properties for stamp annotations can be set before creating the control using StampSettings.

After changing default opacity using the Edit Opacity tool, the selected value is applied. The following example sets default stamp annotation settings.

import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.resourceUrl = "https://cdn.syncfusion.com/ej2/31.1.23/dist/ej2-pdfviewer-lib";
pdfviewer.stampSettings = {opacity: 0.3, author: 'Guest User'}

pdfviewer.appendTo('#PdfViewer');
import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer} from '@syncfusion/ej2-pdfviewer';

PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer);

let pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.serviceUrl = 'https://document.syncfusion.com/web-services/pdf-viewer/api/pdfviewer/';
pdfviewer.documentPath = "https://cdn.syncfusion.com/content/pdf/pdf-succinctly.pdf";
pdfviewer.stampSettings = {opacity: 0.3, author: 'Guest User'}

pdfviewer.appendTo('#PdfViewer');