Stamp annotation in TypeScript PDF Viewer
9 Jan 202617 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

Add Stamp Annotation
Add Stamp Annotation in UI
Use the annotation toolbar:
- Click the Edit Annotation button.
- Open the Stamp Annotation dropdown.
- Choose a stamp type and place it on the page.
NOTE
When in pan mode and a stamp tool is selected, the viewer switches to text select mode automatically.
Switch to specific stamp modes
<button id="dynamicStamp">Dynamic Stamp</button>
<button id="signStamp">Sign Stamp</button>
<button id="standardBusinessStamp">Standard Business Stamp</button>
<button id="customStamp">Custom Stamp</button>import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, SignStampItem, StandardBusinessStampItem, DynamicStampItem, StampSettings } 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');
document.getElementById('dynamicStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', DynamicStampItem.NotApproved);
});
document.getElementById('signStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, SignStampItem.Witness);
});
document.getElementById('standardBusinessStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, undefined, StandardBusinessStampItem.Approved);
});
document.getElementById('customStamp')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 100, y: 440 },
width: 46,
height: 100,
pageNumber: 1,
isLock: true,
author: 'Guest',
customStamps: [{
customStampName: 'Image',
customStampImageSource: '...'
}]
} as unknown as StampSettings);
});import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, SignStampItem, StandardBusinessStampItem, DynamicStampItem, StampSettings } 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');
document.getElementById('dynamicStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', DynamicStampItem.NotApproved);
});
document.getElementById('signStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, SignStampItem.Witness);
});
document.getElementById('standardBusinessStamp')?.addEventListener('click', () => {
pdfviewer.annotationModule.setAnnotationMode('Stamp', undefined, undefined, StandardBusinessStampItem.Approved);
});Add Stamp Annotation programmatically
Create stamps via addAnnotation.
<button id="addDynamic">Add Dynamic Stamp</button>
<button id="addSign">Add Sign Stamp</button>
<button id="addStandard">Add Standard Business Stamp</button>
<button id="addCustom">Add Custom Stamp</button>import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, StampSettings, DynamicStampItem, SignStampItem, StandardBusinessStampItem } 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');
document.getElementById('addDynamic')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 140 }, pageNumber: 1
} as StampSettings, DynamicStampItem.Approved);
});
document.getElementById('addSign')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 240 }, pageNumber: 1
} as StampSettings, undefined, SignStampItem.Witness);
});
document.getElementById('addStandard')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 340 }, pageNumber: 1
} as StampSettings, undefined, undefined, StandardBusinessStampItem.Approved);
});
document.getElementById('addCustom')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 100, y: 440 }, width: 46, height: 100, pageNumber: 1, isLock: true,
author: 'Guest',
customStamps: [{ customStampName: 'Image', customStampImageSource: '...' }]
} as unknown as StampSettings);
});import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, PageOrganizer, StampSettings, DynamicStampItem, SignStampItem, StandardBusinessStampItem } 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');
document.getElementById('addDynamic')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 140 }, pageNumber: 1
} as StampSettings, DynamicStampItem.Approved);
});
document.getElementById('addSign')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 240 }, pageNumber: 1
} as StampSettings, undefined, SignStampItem.Witness);
});
document.getElementById('addStandard')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 340 }, pageNumber: 1
} as StampSettings, undefined, undefined, StandardBusinessStampItem.Approved);
});
document.getElementById('addCustom')?.addEventListener('click', () => {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 100, y: 440 }, width: 46, height: 100, pageNumber: 1, isLock: true,
author: 'Guest',
customStamps: [{ customStampName: 'Image', customStampImageSource: '...' }]
} as StampSettings);
});Edit Stamp Annotation
Edit Stamp Annotation in UI
You can select, move, resize, rotate, and delete Stamp annotations directly in the viewer:
- Select a Stamp to show its resize and rotation handles.
- Move: drag inside the stamp to reposition it on the page.
- Resize: drag any corner or side handle to adjust the size.
- Rotate: drag the rotation handle to rotate the stamp.
- Delete or access more options from the context menu.
Use the toolbar to change appearance:
- Adjust Opacity using the Edit Opacity tool.
Edit Stamp Annotation programmatically
Use editAnnotation to change bounds or lock state.
<button id="editStamp">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');
document.getElementById('editStamp')?.addEventListener('click', () => {
for (let i = 0; i < pdfviewer.annotationCollection.length; i++) {
if (pdfviewer.annotationCollection[i].shapeAnnotationType === 'stamp') {
const width = pdfviewer.annotationCollection[i].bounds.width;
const height = pdfviewer.annotationCollection[i].bounds.height;
pdfviewer.annotationCollection[i].bounds = { x: 100, y: 100, width, 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');
document.getElementById('editStamp')?.addEventListener('click', () => {
for (let i = 0; i < pdfviewer.annotationCollection.length; i++) {
if (pdfviewer.annotationCollection[i].shapeAnnotationType === 'stamp') {
const width = pdfviewer.annotationCollection[i].bounds.width;
const height = pdfviewer.annotationCollection[i].bounds.height;
pdfviewer.annotationCollection[i].bounds = { x: 100, y: 100, width, height };
pdfviewer.annotationCollection[i].annotationSettings.isLock = true;
pdfviewer.annotation.editAnnotation(pdfviewer.annotationCollection[i]);
}
}
});Default stamp settings during initialization
Set defaults using stampSettings.
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');Set properties while adding Individual Annotation
Set properties for individual annotation before creating the control using StampSettings.
After editing default color and opacity using the Edit Color and Edit Opacity tools, the values update to the selected settings.
Refer to the following code snippet to set the default Stamp settings.
<button id="Stamp">Add Stamp</button>import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, DynamicStampItem, StampSettings} from '@syncfusion/ej2-pdfviewer';
PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner);
const pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = 'https://cdn.syncfusion.com/content/pdf/form-designer.pdf';
pdfviewer.resourceUrl = 'https://cdn.syncfusion.com/ej2/31.1.23/dist/ej2-pdfviewer-lib';
pdfviewer.appendTo('#PdfViewer');
//Apply Stamp Settings while adding individual Annotation
document.getElementById('Stamp')?.addEventListener('click', function () {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 140 }, pageNumber: 1,
opacity: 0.3, author: 'Guest User'
} as StampSettings, DynamicStampItem.Approved);
});import { PdfViewer, Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner, DynamicStampItem, StampSettings} from '@syncfusion/ej2-pdfviewer';
PdfViewer.Inject(Toolbar, Magnification, Navigation, Annotation, LinkAnnotation, ThumbnailView, BookmarkView, TextSelection, TextSearch, FormFields, FormDesigner);
const pdfviewer: PdfViewer = new PdfViewer();
pdfviewer.documentPath = 'https://cdn.syncfusion.com/content/pdf/form-designer.pdf';
pdfviewer.serviceUrl = 'https://document.syncfusion.com/web-services/pdf-viewer/api/pdfviewer/';
pdfviewer.appendTo('#PdfViewer');
//Apply Stamp Settings while adding individual Annotation
document.getElementById('Stamp')?.addEventListener('click', function () {
pdfviewer.annotation.addAnnotation('Stamp', {
offset: { x: 200, y: 140 }, pageNumber: 1,
opacity: 0.3, author: 'Guest User'
} as StampSettings, DynamicStampItem.Approved);
});