npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-native-zpl-code

v0.2.3

Published

Zpl Code Generator

Downloads

1,771

Readme

react-native-zpl-code

ZPL Builder Library

This TypeScript library provides a builder pattern for generating Zebra Programming Language (ZPL) commands for label printing. It is designed to simplify the creation of ZPL commands for various elements such as text, barcodes, QR codes, rectangles, and images.

Installation

npm install react-native-zpl-code

Usage

import { Zpl } from "react-native-zpl-code";

// Create a ZPL builder instance
const zplBuilder = new Zpl.Builder();

// Setup label configuration
zplBuilder.setup({
  size: {
    heightDots: 609,
    widthDots: 609,
  },
  labelHome: {
    x: 0,
    y: 0,
  },
  labelTop: 0,
  labeShift: 0,
  orientation: 'NORMAL',
  media: {
    type: 'MARK_SENSING',
    dots: 24,
  },
});

// Add text
zplBuilder.text({
  x: 50,
  y: 50,
  font: {
    type: 'A',
    h: 20,
    w: 10,
  },
  text: 'Hello, ZPL!',
  justification: 0,
});

// Add barcode 128
zplBuilder.barcode128({
  x: 50,
  y: 100,
  height: 50,
  barcodeTxt: 'YES',
  rotation: 'NORMAL',
  width: 2,
  text: '123456',
});

// Add QR code
zplBuilder.qrcode({
  x: 50,
  y: 200,
  model: '2',
  size: 5,
  errorLevel: 'M',
  text: 'https://example.com',
});

// Add rectangle
zplBuilder.rectangle({
  x: 50,
  y: 400,
  w: 200,
  h: 100,
  line: 2,
});

//const src = require('./logo.jpg')
//const uri = Image.resolveAssetSource(src).uri

// Add image
zplBuilder.image({
  uri: "https://s-media-cache-ak0.pinimg.com/236x/ac/bb/d4/acbbd49b22b8c556979418f6618a35fd.jpg",
  //uri: "",
  //uri: "file://data/..."
  x: 330,
  y: 350,
  width: 192,
  height: 192,
  dither: true,
});

// Generate ZPL code
const zplCode = await zplBuilder.build();
console.log(zplCode);

Result

^XA
^LL609
^PW609
^LH0,0
^MNM,24
^PON
^FO50,50
^AAN,20,10
^FH\^FDHello\2C ZPL\21^FS
^FO50,100
^BY2
^BCN,50,Y,N,N
^FH\^FD123456^FS
^FO50,200^BQN,50,5
^FH\^FDMA,https\3A\2F\2Fexample\2Ecom^FS
^FO50,400
^GB200,100,2^FS
^FO330,350^GFA,3552,3552,19,:Z64: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
k86Dj3obY0ymFDi0XBsS1X8AR3bn+A==
:3fac
^XZ

Connections

Network (Wi-Fi) Connection

To send the ZPL command over a network, you can connect to the Zebra printer using its IP address. You can use the JavaScript fetch API to send the data.

Example of Wi-Fi transmission:

import TcpSocket from 'react-native-tcp-socket';

const printZplToNetPrinter = (zpl, ip = "192.168.1.100") => {
  // Printer configuration
  const options = {
    port: 9100, // Typical port for Zebra printers
    host: ip, // Change this IP to your printer's IP address
  };

  // Create a connection to the printer
  const client = TcpSocket.createConnection(options, () => {
    console.log('Connected to the printer');
    
    // Send the ZPL to the printer
    client.write(zpl);
    client.end(); // Close the connection after sending
  });

  // Handle errors
  client.on('error', (error) => {
    console.log('Error:', error);
  });

  // Handle connection close
  client.on('close', () => {
    console.log('Connection closed');
  });
};

Bluetooth Connection

To send the ZPL command via Bluetooth, make sure you have access to the Zebra printer through an active Bluetooth connection. You can use libraries like react-native-ble-plx to handle Bluetooth connections in React Native.

Example of Bluetooth transmission:

import BluetoothSerial from 'react-native-bluetooth-serial';

const printZplToBluetoothPrinter = async (zpl, printerAddress) => {
  try {
    // Enable Bluetooth if it's disabled
    const isEnabled = await BluetoothSerial.isEnabled();
    if (!isEnabled) {
      await BluetoothSerial.enable();
    }

    // Connect to the Bluetooth printer using its MAC address
    await BluetoothSerial.connect(printerAddress);
    console.log('Connected to printer');

    // Send the ZPL command to the printer
    await BluetoothSerial.write(zpl);
    console.log('ZPL command sent to the printer');

    // Disconnect from the printer after sending the command
    await BluetoothSerial.disconnect();
    console.log('Disconnected from printer');
  } catch (error) {
    console.log('Error:', error);
  }
};

Zpl.Builder Class

setup(props: {
  size?: {
    heightDots: number,
    widthDots: number,
  },
  labelHome?: {
    x: number, 
    y: number
  },
  labelTop?: number,
  labeShift?: number,
  orientation?: PrintOrientationType,
  media?: {
    type: MediaTrackingType,
    dots?: number
  },
}): this
Configures label settings such as size, label home, orientation, media, etc.
font(props: {
  type: FontType;
  w: number;
  h: number;
}): this
Sets the font type, width, and height.
point(props: {
  x: number;
  y: number;
  justification?: JustificationType;
}): this
Sets the drawing origin for elements.
text(props: {
  x: number;
  y: number;
  font?: {
    type: FontType;
    h: number; 
    w: number;
  },
  text: string;
  justification?: JustificationType;
}): this
Adds text to the label.
textBlock(props: {
  x: number;
  y: number;
  font?: {
    type: FontType;
    h: number; 
    w: number;
  },
  text: string;
  width: number;
  numLines: number;
  textJustification?: AlignmentType; 
}): this
Adds text in block format to the label.
barcode128(props: {
  x: number;
  y: number;
  height: number;
  barcodeTxt: BarcodeTxtType; 
  rotation: RotationType;
  width: number;
  text: string;
}): this
Adds a Code 128 barcode to the label.
qrcode(props: {
  x: number;
  y: number;
  model?: QRCodeModelType; 
  size: number;
  errorLevel?: QRErrorCorrectionLevelType; 
  text: string;
  characterMode?: string;
}): this
Adds a QR code to the label.
rectangle(props: {
  x: number;
  y: number;
  w: number;
  h: number;
  line: number;
}): this
Draws a rectangle on the label.
bar(props: {
  x: number;
  y: number;
  w: number;
  h: number;
  line: number;
}): this
Adds a horizontal line or bar to the label.
image(props: {
  uri?: string 
  base64?: string,
  x?: number
  y?: number
  width: number
  height?: number
  dither?: boolean
}): this
Adds an image to the label.
build(prefixAndSufix = true): Promise<string>
Generates the ZPL code for the label.

FontType type

Enumeration of available font types.

RotationType type

Enumeration of rotation types.

AlignmentType type

Enumeration of text alignment types.

JustificationType type

Enumeration of text justification types.

MediaTrackingType type

Enumeration of media tracking types.

PrintOrientationType type

Enumeration of print orientation types.

BarcodeTxtType type

Enumeration of barcode text types.

QRCodeModelType type

Enumeration of QR code model types.

QRErrorCorrectionLevelType type

Enumeration of QR code error correction level types.

Image Class

constructor({ uri?: string base64?: string, x?: number y?: number width: number height: number center?: boolean dither?: boolean })

image to the label

Contributing

See the contributing guide to learn how to contribute to the repository and the development workflow.

License

MIT


Made with create-react-native-library