|
|
|
|
|
|
|
|
|
|
|
const fs = require('fs'); |
|
|
const { createCanvas } = require('canvas'); |
|
|
|
|
|
function createTrayIcon() { |
|
|
|
|
|
|
|
|
const canvas = createCanvas(22, 22); |
|
|
const ctx = canvas.getContext('2d'); |
|
|
|
|
|
|
|
|
ctx.clearRect(0, 0, 22, 22); |
|
|
|
|
|
|
|
|
ctx.fillStyle = '#000000'; |
|
|
ctx.font = 'bold 10px system-ui'; |
|
|
ctx.textAlign = 'center'; |
|
|
ctx.textBaseline = 'middle'; |
|
|
ctx.fillText('API', 11, 11); |
|
|
|
|
|
|
|
|
const buffer = canvas.toBuffer('image/png'); |
|
|
fs.writeFileSync('tray-icon.png', buffer); |
|
|
|
|
|
|
|
|
fs.writeFileSync('tray-iconTemplate.png', buffer); |
|
|
fs.writeFileSync('tray-iconTemplate@2x.png', buffer); |
|
|
|
|
|
console.log('Tray icon created successfully!'); |
|
|
} |
|
|
|
|
|
|
|
|
try { |
|
|
createTrayIcon(); |
|
|
} catch (err) { |
|
|
console.log('Canvas module not installed.'); |
|
|
console.log('For now, creating a placeholder. Install canvas with: npm install canvas'); |
|
|
|
|
|
|
|
|
const minimalPNG = Buffer.from([ |
|
|
0x89, 0x50, 0x4E, 0x47, 0x0D, 0x0A, 0x1A, 0x0A, |
|
|
0x00, 0x00, 0x00, 0x0D, 0x49, 0x48, 0x44, 0x52, |
|
|
0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, |
|
|
0x01, 0x03, 0x00, 0x00, 0x00, 0x25, 0xDB, 0x56, |
|
|
0xCA, 0x00, 0x00, 0x00, 0x03, 0x50, 0x4C, 0x54, |
|
|
0x45, 0x00, 0x00, 0x00, 0xA7, 0x7A, 0x3D, 0xDA, |
|
|
0x00, 0x00, 0x00, 0x01, 0x74, 0x52, 0x4E, 0x53, |
|
|
0x00, 0x40, 0xE6, 0xD8, 0x66, 0x00, 0x00, 0x00, |
|
|
0x0A, 0x49, 0x44, 0x41, 0x54, 0x08, 0x1D, 0x62, |
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, |
|
|
0x00, 0x01, 0x0A, 0x2D, 0xCB, 0x59, 0x00, 0x00, |
|
|
0x00, 0x00, 0x49, 0x45, 0x4E, 0x44, 0xAE, 0x42, |
|
|
0x60, 0x82 |
|
|
]); |
|
|
|
|
|
fs.writeFileSync('tray-icon.png', minimalPNG); |
|
|
console.log('Created placeholder tray icon.'); |
|
|
} |