Skip to main content

Print API

The Print API enables document printing functionality in your POS UI extension. Use this API to trigger the native print dialog for your documents.

Supported document types:

  • HTML documents (.html, .htm) - Best printing experience with full CSS styling, embedded images, and complex layouts. Use for receipts, invoices, and formatted reports.
  • Text files (.txt, .csv) - Plain text with basic content and tabular data support. Use for simple receipts and data exports.
  • Image files (.png, .jpg, .jpeg, .gif, .bmp, .webp) - Common web formats with format-specific optimizations. Use for logos, charts, QR codes, and barcodes.
  • PDF files (.pdf) - Behavior varies by platform: prints directly on iOS/desktop, but downloads to external viewer on Android. Use for complex documents and compliance requirements.

Use cases

  • Custom receipts: Print custom receipts or invoices with branded formatting.
  • Labels: Generate and print shipping labels or return labels.
  • Reports: Create printed reports for sales analytics or inventory counts.
  • Custom workflows: Implement custom printing workflows for specialized business processes.

The PrintApi object provides properties for triggering document printing. Access these properties through api.print to initiate print operations with various document types.

Anchor to print
print
(src: string) => Promise<void>
required

Triggers a print dialog for the specified document source. The print() method accepts either:

  • A relative path that will be appended to your app's application_url
  • A full URL to your app's backend that will be used to return the document to print

Returns a promise that resolves when content is ready and the native print dialog appears. Use for printing custom documents, receipts, labels, or reports.

Examples
import React from 'react';
import {
Tile,
reactExtension,
useApi,
} from '@shopify/ui-extensions-react/point-of-sale';

const TileComponent = () => {
const api = useApi();
return (
<Tile
title="My app"
subtitle="Hello world!"
onPress={() => {
api.print.print('documents/test-print');
}}
enabled
/>
);
};

export default reactExtension('pos.home.tile.render', () => {
return <TileComponent />;
});

  • Handle printing errors gracefully: Implement proper error handling for print operations, including network failures, unsupported document types, or printer connectivity issues.
  • Optimize documents for printing: Design your printable documents with appropriate sizing, margins, and formatting that work well with printers and standard paper sizes.
  • Provide user feedback: Give users clear feedback about print operations, including loading states, success confirmations, and error messages when printing fails.

  • PDF printing on Android devices requires downloading the file and using an external application, which may interrupt the user workflow.
  • Print operations depend on device printer connectivity and configuration, which may not be available in all POS setups.
  • Document formatting and appearance may vary depending on the printer type, paper size, and device capabilities.
Was this page helpful?