Descripción
Usa la API de chrome.printing
para enviar trabajos de impresión a las impresoras instaladas en la Chromebook.
Permisos
printing
Disponibilidad
Todos los métodos y eventos de chrome.printing
requieren que declares el permiso "printing"
en el manifiesto de la extensión. Por ejemplo:
{
"name": "My extension",
...
"permissions": [
"printing"
],
...
}
Ejemplos
En los siguientes ejemplos, se muestra cómo usar cada uno de los métodos en el espacio de nombres de impresión. Este código se copió de api-samples/printing en el repo de GitHub de extensiones-samples o se basa en él.
cancelJob()
En este ejemplo, se usa el controlador onJobStatusChanged
para ocultar un botón de "cancelar" cuando jobStatus
no es PENDING
ni IN_PROGRESS
. Ten en cuenta que, en algunas redes o cuando una Chromebook está conectada directamente a la impresora, es posible que estos estados pasen demasiado rápido para que el botón de cancelar esté visible el tiempo suficiente para que se lo llame. Este es un ejemplo de impresión muy simplificado.
chrome.printing.onJobStatusChanged.addListener((jobId, status) => {
const cancelButton = document.getElementById("cancelButton");
cancelButton.addEventListener('click', () => {
chrome.printing.cancelJob(jobId).then((response) => {
if (response !== undefined) {
console.log(response.status);
}
if (chrome.runtime.lastError !== undefined) {
console.log(chrome.runtime.lastError.message);
}
});
});
if (status !== "PENDING" && status !== "IN_PROGRESS") {
cancelButton.style.visibility = 'hidden';
} else {
cancelButton.style.visibility = 'visible';
}
}
getPrinters() and getPrinterInfo()
Se usa un solo ejemplo para estas funciones porque obtener información de la impresora requiere un ID de impresora, que se recupera llamando a getPrinters()
. En este ejemplo, se registra el nombre y la descripción de la impresora predeterminada en la consola. Esta es una versión simplificada del ejemplo de impresión.
const printers = await chrome.printing.getPrinters();
const defaultPrinter = printers.find((printer) => {
const printerInfo = await chrome.printing.getPrinterInfo(printer.id);
return printerInfo.isDefault;
}
console.log(`Default printer: ${defaultPrinter.name}.\n\t${defaultPrinter.description}`);
submitJob()
El método submitJob()
requiere tres elementos.
- Es una estructura
ticket
que especifica qué capacidades de la impresora se deben usar. Si el usuario necesita seleccionar entre las capacidades disponibles, puedes recuperarlas para una impresora específica congetPrinterInfo()
. - Una estructura
SubmitJobRequest
, que especifica la impresora que se usará y el archivo o la fecha que se imprimirá. Esta estructura contiene una referencia a la estructuraticket
. - Es un BLOB del archivo o los datos que se imprimirán.
Llamar a submitJob()
activa un cuadro de diálogo en el que se le pide al usuario que confirme la impresión. Usa PrintingAPIExtensionsAllowlist
para omitir la confirmación.
Esta es una versión simplificada del ejemplo de impresión. Observa que ticket
está adjunto a la estructura SubmitJobRequest
(línea 8) y que los datos que se imprimirán se convierten en un blob (línea 10). Obtener el ID de la impresora (línea 1) es más complicado en la muestra de lo que se muestra aquí.
const defaultPrinter = getDefaultPrinter();
const ticket = getPrinterTicket(defaultPrinter);
const arrayBuffer = getPrintData();
const submitJobRequest = {
job: {
printerId: defaultPrinter,
title: 'test job',
ticket: ticket,
contentType: 'application/pdf',
document: new Blob([new Uint8Array(arrayBuffer)], {
type: 'application/pdf'
});
}
};
chrome.printing.submitJob(submitJobRequest, (response) => {
if (response !== undefined) {
console.log(response.status);
}
if (chrome.runtime.lastError !== undefined) {
console.log(chrome.runtime.lastError.message);
}
});
Impresión en rollo
En este ejemplo, se muestra cómo compilar un ticket de impresora para la impresión continua (o en rollo), que se suele usar para la impresión de recibos. El objeto submitJobRequest
para la impresión en rollo es el mismo que se muestra en el ejemplo de submitJob()
.
Si necesitas cambiar el valor predeterminado para el corte de papel, usa la tecla vendor_ticket_item
. (El valor predeterminado varía según la impresora). Para cambiar el valor, proporciona un array con un miembro: un objeto cuyo id
es 'finishings'
. El valor puede ser 'trim'
para las impresoras que cortan el rollo al final de la impresión o 'none'
para las impresoras que requieren que se arranque el trabajo de impresión.
const ticket = {
version: '1.0',
print: {
vendor_ticket_item: [{id: 'finishings', value: 'trim'}],
color: {type: 'STANDARD_MONOCHROME'},
duplex: {type: 'NO_DUPLEX'},
page_orientation: {type: 'PORTRAIT'},
copies: {copies: 1},
dpi: {horizontal_dpi: 300, vertical_dpi: 300},
media_size: {
width_microns: 72320,
height_microns: 100000
},
collate: {collate: false}
}
};
Algunas impresoras no admiten la opción "finishings"
. Para determinar si tu impresora lo hace, llama a getPrinterInfo()
y busca un "display_name"
de "finishings/11"
.
"vendor_capability": [
{
"display_name": "finishings/11",
"id": "finishings/11",
"type": "TYPED_VALUE",
"typed_value_cap": {
"value_type": "BOOLEAN"
}
},
...
]
Los valores de la clave media_size
de un ticket son específicos de cada impresora. Para seleccionar un tamaño adecuado, llama a getPrinterInfo()
. El objeto GetPrinterResponse
que se devuelve contiene un array de tamaños de medios admitidos en "media_size"."option"
. Elige una opción cuyo valor de "is_continuous_feed"
sea verdadero. Usa los valores de altura y ancho para el boleto.
"media_size": {
"option": [
{
"custom_display_name": "",
"is_continuous_feed": true,
"max_height_microns": 2000000,
"min_height_microns": 25400,
"width_microns": 50800
},
...
]
}
Tipos
GetPrinterInfoResponse
Propiedades
-
capabilities
objeto opcional
Capacidades de la impresora en formato CDD. Es posible que falte la propiedad.
-
estado
Es el estado de la impresora.
JobStatus
Es el estado del trabajo de impresión.
Enum
"PENDING"
Se recibió el trabajo de impresión en Chrome, pero aún no se procesó.
"IN_PROGRESS"
Se envió el trabajo de impresión para que se imprima.
"FAILED"
Se interrumpió el trabajo de impresión debido a un error.
"CANCELED"
El usuario o la API cancelaron el trabajo de impresión.
"PRINTED"
El trabajo de impresión se imprimió sin errores.
Printer
Propiedades
-
descripción
string
Es la descripción de la impresora legible por humanos.
-
id
string
Es el identificador de la impresora, que garantiza ser único entre las impresoras del dispositivo.
-
isDefault
booleano
Es la marca que muestra si la impresora cumple con las reglas de DefaultPrinterSelection. Ten en cuenta que se pueden marcar varias impresoras.
-
nombre
string
Es el nombre de la impresora.
-
recentlyUsedRank
número opcional
Es el valor que muestra qué tan reciente fue el uso de la impresora para imprimir desde Chrome. Cuanto más bajo sea el valor, más reciente fue el uso de la impresora. El valor mínimo es 0. El valor faltante indica que la impresora no se usó recientemente. Se garantiza que este valor es único entre las impresoras.
-
source
Es la fuente de la impresora (usuario o política configurados).
-
uri
string
Es el URI de la impresora. Las extensiones pueden usar este parámetro para elegir la impresora del usuario.
PrinterSource
Es la fuente de la impresora.
Enum
"USER"
El usuario agregó la impresora.
"POLICY"
La impresora se agregó a través de una política.
PrinterStatus
Es el estado de la impresora.
Enum
"DOOR_OPEN"
La puerta de la impresora está abierta. La impresora sigue aceptando trabajos de impresión.
"TRAY_MISSING"
Falta la bandeja de la impresora. La impresora sigue aceptando trabajos de impresión.
"OUT_OF_INK"
La impresora se quedó sin tinta. La impresora sigue aceptando trabajos de impresión.
"OUT_OF_PAPER"
La impresora no tiene papel. La impresora sigue aceptando trabajos de impresión.
"OUTPUT_FULL"
El área de salida de la impresora (p.ej., la bandeja) está llena. La impresora sigue aceptando trabajos de impresión.
"PAPER_JAM"
La impresora tiene un atasco de papel. La impresora sigue aceptando trabajos de impresión.
"GENERIC_ISSUE"
Algún problema genérico. La impresora sigue aceptando trabajos de impresión.
"STOPPED"
La impresora está detenida y no imprime, pero sigue aceptando trabajos de impresión.
"UNREACHABLE"
No se puede acceder a la impresora y no acepta trabajos de impresión.
"EXPIRED_CERTIFICATE"
El certificado SSL venció. La impresora acepta trabajos, pero estos fallan.
"DISPONIBLE"
La impresora está disponible.
SubmitJobRequest
Propiedades
-
trabajo
Es el trabajo de impresión que se enviará. Los tipos de contenido admitidos son "application/pdf" e "image/png". El Cloud Job Ticket no debe incluir los campos
FitToPageTicketItem
,PageRangeTicketItem
yReverseOrderTicketItem
, ya que no son relevantes para la impresión nativa.VendorTicketItem
es opcional. Todos los demás campos deben estar presentes.
SubmitJobResponse
Propiedades
-
ID de tarea
cadena opcional
Es el ID del trabajo de impresión creado. Es un identificador único entre todos los trabajos de impresión del dispositivo. Si el estado no es OK, jobId será nulo.
-
estado
Es el estado de la solicitud.
SubmitJobStatus
Es el estado de la solicitud de submitJob
.
Enum
"OK"
Se aceptó la solicitud de trabajo de impresión.
"USER_REJECTED"
El usuario rechazó la solicitud de trabajo de impresión enviada.
Propiedades
MAX_GET_PRINTER_INFO_CALLS_PER_MINUTE
Es la cantidad máxima de veces que se puede llamar a getPrinterInfo
por minuto.
Valor
20
MAX_SUBMIT_JOB_CALLS_PER_MINUTE
Es la cantidad máxima de veces que se puede llamar a submitJob
por minuto.
Valor
40
Métodos
cancelJob()
chrome.printing.cancelJob(
jobId: string,
): Promise<void>
Cancela el trabajo enviado anteriormente.
Parámetros
-
ID de tarea
string
Es el ID del trabajo de impresión que se cancelará. Debe ser el mismo ID que se recibió en un
SubmitJobResponse
.
Muestra
-
Promise<void>
Chrome 100 y versiones posteriores
getJobStatus()
chrome.printing.getJobStatus(
jobId: string,
): Promise<JobStatus>
Devuelve el estado del trabajo de impresión. Esta llamada fallará con un error de tiempo de ejecución si no existe el trabajo de impresión con el jobId
determinado. jobId
: Es el ID del trabajo de impresión del que se devolverá el estado. Debe ser el mismo ID que se recibió en un SubmitJobResponse
.
Parámetros
-
ID de tarea
string
Muestra
-
Promise<JobStatus>
getPrinterInfo()
chrome.printing.getPrinterInfo(
printerId: string,
): Promise<GetPrinterInfoResponse>
Devuelve el estado y las capacidades de la impresora en formato CDD. Esta llamada fallará con un error de tiempo de ejecución si no se instaló ninguna impresora con el ID determinado.
Parámetros
-
printerId
string
Muestra
-
Promise<GetPrinterInfoResponse>
Chrome 100 y versiones posteriores
getPrinters()
chrome.printing.getPrinters(): Promise<Printer[]>
Devuelve la lista de impresoras disponibles en el dispositivo. Esto incluye las impresoras agregadas manualmente, las empresariales y las detectadas.
Muestra
-
Promise<Printer[]>
Chrome 100 y versiones posteriores
submitJob()
chrome.printing.submitJob(
request: SubmitJobRequest,
): Promise<SubmitJobResponse>
Envía el trabajo para imprimirlo. Si la extensión no aparece en la política PrintingAPIExtensionsAllowlist
, se le solicitará al usuario que acepte el trabajo de impresión.
Antes de Chrome 120, esta función no devolvía una promesa.
Parámetros
-
solicitud
Muestra
-
Promise<SubmitJobResponse>
Chrome 100 y versiones posteriores
Eventos
onJobStatusChanged
chrome.printing.onJobStatusChanged.addListener(
callback: function,
)
Evento que se activa cuando cambia el estado del trabajo. Este evento solo se activa para los trabajos creados por esta extensión.