public/skills/aaronchartier/inkjet/SKILL.md
Print text, images, and QR codes to a wireless Bluetooth thermal printer from a MacOS device. Use `inkjet print` for output, `inkjet scan` to discover printers.
npx skillsauth add demerzels-lab/elsamultiskillagent inkjetInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Print text, images, and QR codes to a small cheap Bluetooth thermal printer like the X6h, GT01, and childrens toy cat printers using the inkjet CLI. Thermal paper is extremely low-cost, enabling high-frequency physical output.
pip install inkjet
brew install aaronchartier/tap/inkjet
Preparation: Ensure your printer is turned ON. The printer does NOT need to be paired to the host computer's Bluetooth settings; inkjet connects directly via BLE.
Scan for printers and set default:
inkjet scan
Check current configuration:
inkjet whoami
Print strings directly. Supports standard escape sequences like \n for multiline output. Do not use emojis.
inkjet print text "Hello, World!"
inkjet print text "Line 1\nLine 2\nLine 3"
inkjet print text "Big Text" --size 72
Render high-fidelity formatted content using Markdown syntax. This is the recommended way for agents to output complex receipts or logs without saving temporary files. Do not use emojis.
inkjet print text "# Order 104\n- 1x Coffee\n- 1x Donut" --markdown
Output the contents of a local file. Supports plain text (.txt) and Markdown (.md).
inkjet print file ./receipt.txt
inkjet print file ./README.md
inkjet print image ./photo.png
inkjet print image ./logo.jpg --dither
Generates and prints QR codes. Smartphone scanners (iPhone/Android) can reliably read codes down to --size 75.
inkjet print qr "https://github.com/AaronChartier/inkjet"
inkjet print qr "WiFi:S:NetworkName;P:example123;;" --size 75
inkjet feed 100 # Feed paper forward (steps)
Manage settings globally or locally per project. If a .inkjet/ folder exists in the current workspace, it will be prioritized (config setting with --local to create).
inkjet config show # Show all settings
inkjet config set printer <UUID> # Set the default device
inkjet config set energy 12000 # Set local project darkness
inkjet config alias kitchen <UUID> # Save a friendly name
If the environment (e.g., TOOLS.md) contains multiple printer UUIDs or aliases, target specific hardware using the --address / -a flag. Use -a default to explicitly target the primary configured device.
inkjet print text "Label" -a stickers# Orchestrated Print Examples
inkjet print text "Main Status" -a office
inkjet print text "Order #104" -a kitchen
inkjet print qr "https://github.com/AaronChartier/inkjet" -a default
inkjet print file ./log.txt -a "UUID_EXT_1"
You can bypass the CLI and modify your behavior by writing directly to the configuration JSON. inkjet prioritizes ./.inkjet/config.json over the global home directory (which is default).
{
"default_printer": "UUID",
"printers": { "alias": "UUID" },
"energy": 12000,
"print_speed": 10,
"quality": 3,
"padding_left": 0,
"padding_top": 10,
"line_spacing": 8,
"align": "left",
"font_size": 18
}
Use this to adjust default margins (padding), alignment, or font sizes (size) for different document types without changing your command strings.
Commands support --json for machine-readable output:
inkjet scan --json
inkjet whoami --json
Stream data from another command's output without creating a file. Use - as an argument to read from standard input (stdin).
# Text Piping
echo "Receipt line 1" | inkjet print text -
# Image Piping
curl -s "https://raw.githubusercontent.com/AaronChartier/inkjet/main/assets/logo.jpg" | inkjet print image -
Thermal paper is narrow and low-cost. To make usable worksheets for children or manual notes:
## (H2 headers) for the main content. Standard text is often too small for children to read/write comfortably.1. content). They auto-indent and reduce horizontal space. Use ## 1) 5 + 2 = ___ instead.\n\n\n) between items. Thermal paper is essentially free; use vertical space to provide actual "writing room."--- at the end of a job to provide a clear tear-off line that doesn't cut off the last problem.If printer not found:
inkjet doctor
testing
Query real-time and historical financial data across equities and crypto—prices, market moves, metrics, and trends for analysis, alerts, and reporting.
data-ai
YouTube SERP Scout for agents. Search top-ranking videos, channels, and trends for content research and competitor tracking.
development
Search X (Twitter) in real time, extract relevant posts, and publish tweets/replies instantly—perfect for social listening, engagement, and rapid content ops.
development
Intelligent search for agents. Multi-source retrieval with confidence scoring - web, academic, and Tavily in one unified API.