New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details
Socket
Book a DemoSign in
Socket

capacitor-thermal-printer-bluetooth

Package Overview
Dependencies
Maintainers
1
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

capacitor-thermal-printer-bluetooth

High-speed, reliable bluetooth ESC thermal printer and encoder Capacitor plugin.

latest
Source
npmnpm
Version
0.2.18
Version published
Maintainers
1
Created
Source

capacitor-thermal-printer-bluetooth

High-speed, reliable bluetooth ESC thermal printer and encoder Capacitor plugin. Both on Android and iOS!

  • Using the official RTPrinter SDK by Rongta Technology <3
  • Cross-platform compatibility (Android & iOS)
  • Multiple simultaneous Bluetooth connections — connect and manage multiple printers at once
  • Swift speeds on iOS of BLE (known for it's pain-in-the-ass speed)

Install

npm install capacitor-thermal-printer-bluetooth --save
npx cap sync

Additional iOS Setup

Open your iOS project in Xcode, then:

  • In the left sidebar, select your project (usually named "App").
  • Select your main target (usually also named "App").
  • Navigate to "Build Phases" tab.
  • Under "Copy Bundle Resources", click the "+" button and choose "Add Other..."
  • Navigate to the node_modules/capacitor-thermal-printer-bluetooth/ios/Plugin/Resources/ble_serial.plist file and select it

And voilà! You're all set!

Example

Make sure to check the Ionic Angular example in the example folder.

1. Import the plugin

import { CapacitorThermalPrinter } from 'capacitor-thermal-printer-bluetooth';

2. Connect to printer

const device = await CapacitorThermalPrinter.connect({
  address: 'XX:XX:XX:XX:XX:XX',
});
if (device === null) {
  console.log('Woops, failed to connect!');
} else {
    console.log('Connected!', device.name, device.address);
}

You can also use the startScan method to discover nearby devices.

  • On Android, only printers will be discovered.
  • On iOS, all bluetooth devices will be discovered.
CapacitorThermalPrinter.addListener('discoverDevices', (devices) => {
  console.log('Discovered devices list:', devices);
});

await CapacitorThermalPrinter.startScan();

Manage Multiple Printers (New!)

Version 0.2.8+ introduces support for managing multiple simultaneous Bluetooth connections. You can now connect to several printers at once and route print jobs independently to each device.

The plugin maintains separate connection contexts per printer. Each successful connect call returns a unique connectionId that you can use to direct print jobs.

Quick example:

// Connect to multiple printers
const kitchen = await CapacitorThermalPrinter.connect({ address: 'AA:BB:CC:DD:EE:01' });
const bar = await CapacitorThermalPrinter.connect({ address: 'AA:BB:CC:DD:EE:02' });

// Create scoped sessions for each printer
const kitchenPrinter = CapacitorThermalPrinter.useConnection(kitchen!.connectionId);
const barPrinter = CapacitorThermalPrinter.useConnection(bar!.connectionId);

// Send different content to each printer independently
await kitchenPrinter.begin().text('Kitchen Order #42\n').write();
await barPrinter.begin().text('Bar Order #15\n').write();

// List all active connections
const { connections } = await CapacitorThermalPrinter.listConnections();
console.log(`Connected to ${connections.length} printers`);

// Optionally set a default printer for direct method calls
CapacitorThermalPrinter.setActiveConnection(bar!.connectionId);
await CapacitorThermalPrinter.begin().text('Uses bar printer').write();

Key APIs:

  • listConnections() — Returns all active printer connections with their IDs, addresses, and names.
  • useConnection(connectionId) — Creates a scoped session bound to a specific printer.
  • setActiveConnection(connectionId) — Sets the default printer for direct plugin method calls.
  • getActiveConnection() — Returns the currently active connection ID (or null).
  • disconnect({ connectionId }) — Disconnects a specific printer (or the active one if omitted).

Events:

The plugin emits connected and disconnected events with the connectionId so you can track connection state changes per device:

CapacitorThermalPrinter.addListener('connected', (device) => {
  console.log(`Printer connected: ${device.name} (${device.connectionId})`);
});

CapacitorThermalPrinter.addListener('disconnected', (data) => {
  console.log(`Printer disconnected: ${data.connectionId}`);
});

3. Print sample receipt

await CapacitorThermalPrinter.begin()
  .align('center')

  .image('./assets/Logo-Black.png')

  .bold()
  .underline()
  .text('The amazing store\n')

  .doubleWidth()
  .text('RECEIPT\n')
  .clearFormatting()

  .text('Item 1: $10.00\n')
  .text('Item 2: $15.00\n')

  .align('right')
  .text('Total: $25.00\n')

  .align('center')
  .qr('https://example.com')
  .barcode('UPC_A', '123456789012')

  .cutPaper()

  .write()
  .then(() => console.log('Printed!'))
  .catch((e) => console.error('Failed to print!', e));

Documentation

Check out the Docs!

Issues

If you encounter any issues with this plugin, please report them at Issues

Contributing

We're open to, and grateful for, any contributions made! Make sure to check Contribution Guidelines

Keywords

capacitor

FAQs

Package last updated on 04 Feb 2026

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts