OnAfterSetupPrinters Event
This article describes the OnAfterSetupPrinters event and the structure of the printer payload.
Usage
Use the OnAfterSetupPrinters event to set up different printers that users can use to print reports. Users can set which printer to use on the Printer Selections page. By subscribing to this event, you create payloads for different printers. A payload specifies settings such as paper sizes, paper trays, and more. For more information about subscribing to this event, see Developing Printer Extensions Overview.
Publisher
Codeunit 44 ReportManagement.
Raised
The OnAfterSetupPrinters event is raised when you:
- Open a page that uses the virtual table Printer as its source is opened in the client.
- Select the lookup on the Printer Name field in page 64 Printer Selections. This field is used for selecting a printer to use on a report.
- Select the Print or Preview action on the request page of a report that is set up to use a specific printer from the Printer Selections page.
Syntax
[IntegrationEvent(false, false)]
local procedure OnAfterSetupPrinters(var Printers: Dictionary of [Text[250], JsonObject])
Parameters
Printers
The Printers parameter is a Dictionary of [Text, Text] type. It includes a collection of key-value pairs that define different printer setups. The key specifies a name for the printer. The value is a JSON object that specifies various settings supported by the printer. The settings include information like the paper size, paper trays, default number of copies, and more. The JSON object is referred to as the payload.
Printer payload
The payload consists of several attributes that are arranged in the following structure.
{
"version":,
"description":,
"duplex":,
"color":,
"defaultcopies":,
"papertrays":
[
{
"papersourcekind":,
"paperkind":,
"units":,
"height":,
"width":,
"landscape":
}
]
}
- The
version
andpapertrays
attributes are mandatory. - The
papertrays
attribute must contain at least one paper tray setup. - Each individual paper tray setup is defined within brackets
{ }
and must include the attributespapersourcekind
andpaperkind
.
Given this information, the minimum payload looks like this:
{
"version":1,
"papertrays":
[
{
"papersourcekind":"Upper",
"paperkind":"A4"
}
]
}
If the required attributes aren't provided, a general error similar to the following error occurs at runtime:
"The provided payload for printer 'My Printer' is not formatted correctly. Please update the payload and try again."
Attributes
version
Currently, the only supported version for the payload is 1
. If the value is less than or greater than 1, an invalid payload version error like the following error is shown:
"The payload version '2' is not valid for the printer 'My Printer'. The version must be a positive number not greater than 1. Please change the version and try again."
description
Specifies an alternative or friendly name for the printer. The value can include 250 characters. If the value is greater than 250, an invalid payload version error like the following error is shown:
"The description of the printer 'My Printer' exceeds the limit of 250 characters (current length: 300 characters). Please change the description and try again."
duplex
Specifies whether the printer supports duplex (double-sided) printing. true
specifies that the printer supports duplex printing; false
specifies that it doesn't.
Note
duplex
is currently not used and ignored at runtime.
color attribute
Specifies whether the printer supports color printing. true
specifies that the printer supports color printing; false
specifies that it doesn't.
Note
color
is currently not used and ignored at runtime.
defaultcopies
Specifies the number of copies to print by default. The value must be a non-negative integer that isn't greater than 32767.
Note
defaultcopies
is currently not used and ignored at runtime.
If the value exceeds 32767, an error like the following error is shown:
"The provided payload for printer 'My Printer' is not formatted correctly. Please update the payload and try again."
If the value is less than 0, an error like the following error is shown:
"The value for the default copies parameter for the printer 'My Printer' must be a positive number. Please update the parameter and try again."
papertrays
Specifies a setup for one or more paper trays that the printer has. Each paper tray setup is defined within a set of brackets { }
and separated by a comma. A paper tray setup must contain a papersourcekind
and paperkind
attribute. Other attributes are optional.
There can be a maximum of 14 paper trays. The first defined paper tray in the list will be considered as the default paper tray.
If the papertray
attribute is empty, an error like the following error occurs:
"The provided payload for printer 'My Printer' is not formatted correctly. Please update the payload and try again."
papersourcekind
Specifies a standard paper source for the paper tray. You can set the value to any of the 14 paper sources that are supported by .NET Framework. You can see the supported paper sources at PaperSourceKind Enum. You can either use the text representation (such as AutomaticFeed
or the corresponding number (such as 7
).
The papersourcekind
must be unique within the paper trays, meaning it cannot be used more than once in the list. If values for papersourcekind
are not unique, an error like the following error occurs:
"The printer 'My Printer' already has the paper source kind 'Upper'. Please change the paper source kind and try again."
paperkind
Specifies the paper sizes supported by the printer. You set the value to any standard paper kind that .NET Framework supports. You can see the supported paper kinds at PaperKind Enum. You can either use the text representation (such as A4
) or the corresponding number (such as 9
).
If you use any value other than Custom
or 0
, the system will automatically take care of the height
, width
, and units
attributes. For example, if you specified that paperkind
is A4
, then the paper dimensions are 210 mm by 297 mm. In this case, if you provide values for the height
, width
, and units
attributes, the values will be ignored.
If paperkind
is set to Custom
or 0
, then paper size is defined by the user in the client. However, you must provide proper values for height
and width
attributes; otherwise an error will occur. The values are used as the default values for the custom size. So if you don't set an attribute, then 0 is used, which isn't valid. Additionally, if the paperkind
is Custom
or 0
, you can also specify units
attribute.
units
Specifies the units of measurement for values in height
and width
attributes. Valid values include:
HI
for hundredths of an inch. This value is the default value.TI
for thousandths of an inch.IN
for inches.CM
for centimeters.MM
for millimeters.PC
for picas.PT
for points.
If you provide a unit that isn't valid, the following error is shown:
"The provided payload for printer 'My Printer' is not formatted correctly. Please update the payload and try again."
height and width
Specifies the dimensions of the paper. Set these attributes only when the paperkind
is set to Custom
.
Valid values include positive integers up to 2147483647. If the provided value exceeds the limit, an error like the following error occurs:
"The provided payload for printer 'My Printer' is not formatted correctly. Please update the payload and try again."
If the value is less than 1, an error like the following error occurs:
"The paper 'height' must be a positive number (paper kind = 'Custom', paper source kind = 'Custom', printer = 'My Printer'). Please update the 'height' parameter and try again."
landscape
Specifies whether landscape orientation is supported. true
specifies landscape orientation is supported; otherwise false
.
See Also
Working With and Troubleshooting Payloads
Developing Printer Extensions Overview
Creating a Printer Extension
Events in AL
Publishing Events
Raising Events
Subscribing to Events