Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/enoy19/zpl-tool
Web app for managing ZPL templates and printers with live preview and variable support.
https://github.com/enoy19/zpl-tool
label-printing printer-management svelte sveltekit template-manager zpl
Last synced: 9 days ago
JSON representation
Web app for managing ZPL templates and printers with live preview and variable support.
- Host: GitHub
- URL: https://github.com/enoy19/zpl-tool
- Owner: enoy19
- License: mit
- Created: 2023-07-30T14:23:49.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-08-28T23:07:14.000Z (over 1 year ago)
- Last Synced: 2024-11-16T21:14:26.879Z (2 months ago)
- Topics: label-printing, printer-management, svelte, sveltekit, template-manager, zpl
- Language: TypeScript
- Homepage:
- Size: 2.72 MB
- Stars: 5
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# zpl-tool
zpl-tool is a webapp designed for managing multiple ZPL templates.
It provides an easy-to-use interface for managing ZPL templates with the ability to insert variables such as `${MY_VARIABLE}` directly into your templates.
zpl-tool features a live preview of the templates (powered by [labelary.com](https://labelary.com) and/or [BinaryKits.Zpl](https://github.com/BinaryKits/BinaryKits.Zpl) ), which automatically updates as you develop your template.Besides template management, zpl-tool also provides support for managing multiple printers, including serial and tcp network printers.
## Features
- **✏️ Manage Multiple ZPL Templates**: Easily handle multiple ZPL templates with variable support.
- **🔍 Live Template Preview**: Generates a live preview of the templates with automatic updates when testing variables.
- **🖨️ Support for Multiple Printers**: Manage multiple printers, including Serial and TCP printers.
- **🔢 Bulk Printing**: Efficiently print in bulk by providing a CSV file.
- **📄 PDF Printing**: Print any PDF file.## Quick Start
### **Run zpl-tool using Docker / Docker Compose**
Using docker-compose:
Create a file named `docker-compose.yml` in your directory and paste the following content:
```yaml
version: '3'services:
zpl-tool:
image: ghcr.io/enoy19/zpl-tool:main
ports:
- '3000:3000'
volumes:
- './data:/app/data'
```After saving the file, run the following command to start zpl-tool:
```sh
docker compose up
```zpl-tool will be available at [http://localhost:3000](http://localhost:3000).
Using docker run:
You can use the following `docker run` command:
```sh
docker run -p 3000:3000 -v $(pwd)/data:/app/data ghcr.io/enoy19/zpl-tool:main
```After running this command, zpl-tool will be available at [http://localhost:3000](http://localhost:3000).
## Usage
### Managing ZPL Templates
- **Create a New Template**: Start typing into the textarea below `Editor`
- **Insert Variables**: Insert variables into your template. Format: `${VARIABLE_NAME}`. The variables will automatically be available in the `Variables` section.
- **Live Preview**: When you edit your template or the values of your variables, the preview updates automatically.![Printers](./assets/zpl-tool-templates.gif)
### Managing Printers & Printing
- **Navigate to Printers**: Click `Printers` in the navigation bar.
- **Add a Printer**: Add a serial or tcp printer by entering the configuration and saving.![Printers](./assets/printers.jpg)
- **Print**:
- Navigate back the the home page.
- click on `Print` on one of your templates.
- Select your printer in the dropdown next to the `Print` button
- click `Print`![Print](./assets/print.jpg)
### Printing PDF
- **Navigate to Print PDF**: Click `Print PDF` in the navigation bar.
- **Drop your PDF**: Drag&Drop you PDF file into the upload zone or click the zone and select your file.
- **Print**: Click print!
- **⚠️ IMPORTANT ⚠️**: You need to configure the Printer dimensions and dpmm in the `Printers` page.## Developing
### Prerequisites
- GraphicsMagick + ghostscript
- RPM: `sudo dnf install GraphicsMagick ghostscript`
- Debian / Mac / Windows: https://github.com/yakovmeister/pdf2image/blob/HEAD/docs/gm-installation.mdOnce you've cloned the repository and installed dependencies with `npm install` (or `pnpm install` or `yarn`), start a development server:
```bash
npm run dev# or start the server and open the app in a new browser tab
npm run dev -- --open
```## Building
To create a production version of your app:
```bash
npm run build
```You can preview the production build with `npm run preview`.
> To deploy your app, you may need to install an [adapter](https://kit.svelte.dev/docs/adapters) for your target environment.