Documentation Docs
Documentation Docs

Add Header and Footer to PDF Form Pages

A page header and footer is the content that appears consistently at the top and bottom of each page in a PDF form. Header and footer typically contain your brand logo, page numbers, or essential information about your document, such as its title, author, date of creation, or version number. This article describes how to customize header and footer in a PDF form created by SurveyJS PDF Generator.

Add a Brand Logo to the Header

Generated PDF forms can include your company logo in the header. This will help increase your brand recognition and make your form look more professional. To add a logo to a PDF form, add it to the original survey. This logo can be exported to PDF without additional configuration.

To add a logo to a survey, assign a Base64 or URL string value to the logo property in the survey JSON schema. You can also specify other logo parameters:

  • logoHeight and logoWidth
    Set the height and width of a logo in CSS-accepted values.

  • logoFit: "contain" (default) | "cover" | "fill" | "none"
    Specifies how a logo should be resized to fit its container.

  • logoPosition: "left" (default) | "right" | "none"
    Specifies the position of a logo relative to the survey title.

The following code shows how to add a Base64-encoded logo to the right of the survey title. The full Base64 string is omitted for brevity.

const surveyJson = {
  "logo": "data:image/png;base64,...",
  "logoPosition": "right"
};
const pdfDocOptions = { ... };

const surveyPdf = new SurveyPDF.SurveyPDF(surveyJson, pdfDocOptions);

// In modular applications:
import { SurveyPDF } from "survey-pdf";
const surveyPdf = new SurveyPDF(surveyJson, pdfDocOptions);

View Demo

With SurveyJS PDF Generator, you can create a fully custom header and footer for your PDF form. To do this, implement the onRenderHeader and onRenderFooter event handlers. They accept a DrawCanvas object as the second parameter. The following subtopics describe how you can use this object to draw images or text within a PDF page header or footer.

Drawing Area

Drawing area is limited by a rectangle in which you can draw text and images. A DrawCanvas object includes the rect property that contains rectangle coordinates: xLeft, xRight, xTop, and yBot. To find the width and height of the rectangle, and therefore the available drawing area, subtract xLeft from xRight and xTop from xBot:

surveyPdf.onRenderHeader.add((_, canvas) => {
  const width = canvas.rect.xRight - canvas.rect.xLeft;
  const height = canvas.rect.yBot - canvas.rect.yTop;
});

The width and height of the header and footer rectangles depend upon PDF page settings as follows:

  • A header rectangle's height is specified by the margins.top property.
  • A footer rectangle's width is specified by the margins.bot property.
  • The width of both rectangles equals page width.

Draw Text

A DrawCanvas object has the drawText() method that draws a piece of text within the drawing area. This method accepts an IDrawTextOptions object in which you can specify the text string to draw, font size, text boldness, and other parameters.

The following code draws a text in bold with reduced font size in the page footer:

surveyPdf.onRenderFooter.add((_, canvas) => {
  canvas.drawText({
    text: "Created by SurveyJS PDF Generator",
    fontSize: 10,
    isBold: true
  });
});

View Demo

Draw an Image

To draw an image within the drawing area, use DrawCanvas's drawImage() method. It accepts an IDrawImageOptions object that allows you to specify the image to draw, its height and width, and other parameters. Note that this method supports only Base64-encoded images.

The code below shows how to draw in image that occupies only half of the drawing area's width and height:

surveyPdf.onRenderFooter.add((_, canvas) => {
  canvas.drawImage({
    base64: "data:image/png;base64,...",
    width: (canvas.rect.yBot - canvas.rect.yTop) * 0.5,
    height: (canvas.rect.yBot - canvas.rect.yTop) * 0.5
  });
});

Add Page Numbers

A DrawCanvas object contains the pageNumber and pageCount properties that you can use to add page numbers to your PDF form. Use the drawText() to draw the numbers on the canvas:

surveyPdf.onRenderFooter.add((_, canvas) => {
  canvas.drawText({
    text: "Page " + canvas.pageNumber + " of " + canvas.pageCount
  });
});

Objects passed to the drawText() and drawImage() methods (IDrawTextOptions and IDrawImageOptions) can contain properties that specify element alignment within the header or footer. These properties are listed below:

  • horizontalAlign: "center" (default) | "left" | "right"
    Aligns an element within a header or footer in the horizontal direction.

  • verticalAlign: "middle" (default) | "top" | "bottom"
    Aligns an element within a header or footer in the vertical direction.

  • margins: { left: number, right: number, top: number, bot: number }
    Specifies an element's margins within the drawing area. Margins apply only if the element is aligned to the left/right or top/bottom.

  • rect: { xLeft: number, xRight: number, yTop: number, yBot: number}
    Specifies the position of the drawing area on the canvas in absolute coordinates and thus aligns an element. Use this property as an alternative to the previously listed properties.

The following code adds page numbers to the page footer and positions them in the bottom right corner with 12-millimeter margins.

surveyPdf.onRenderFooter.add((_, canvas) => {
  canvas.drawText({
    text: "Page " + canvas.pageNumber + " of " + canvas.pageCount,
    horizontalAlign: "right",
    verticalAlign: "bottom",
    margins: {
      right: 12,
      bot: 12
    }
  });
});

View Demo

Send feedback to the SurveyJS team

Need help? Visit our support page

Copyright © 2025 Devsoft Baltic OÜ. All rights reserved.

Your cookie settings

We use cookies on our site to make your browsing experience more convenient and personal. In some cases, they are essential to making the site work properly. By clicking "Accept All", you consent to the use of all cookies in accordance with our Terms of Use & Privacy Statement. However, you may visit "Cookie settings" to provide a controlled consent.

Your renewal subscription expires soon.

Since the license is perpetual, you will still have permanent access to the product versions released within the first 12 month of the original purchase date.

If you wish to continue receiving technical support from our Help Desk specialists and maintain access to the latest product updates, make sure to renew your subscription by clicking the "Renew" button below.

Your renewal subscription has expired.

Since the license is perpetual, you will still have permanent access to the product versions released within the first 12 month of the original purchase date.

If you wish to continue receiving technical support from our Help Desk specialists and maintain access to the latest product updates, make sure to renew your subscription by clicking the "Renew" button below.