@nmmty/lazycanvas
Version:
A simple way to interact with @napi-rs/canvas in an advanced way!
186 lines (185 loc) • 7.54 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.Exporter = void 0;
const types_1 = require("../../types");
const LazyUtil_1 = require("../../utils/LazyUtil");
const fs = __importStar(require("fs"));
const utils_1 = require("../../utils/utils");
const _yaml = __importStar(require("js-yaml"));
/**
* Class responsible for exporting a LazyCanvas instance to various formats.
*/
class Exporter {
/**
* The LazyCanvas instance to be exported.
*/
canvas;
/**
* Constructs a new Exporter instance.
* @param canvas {LazyCanvas} - The LazyCanvas instance to be exported.
*/
constructor(canvas) {
this.canvas = canvas;
}
/**
* Saves a file to the filesystem.
* @param {any} [buffer] - The data to be saved.
* @param {Extensions} [extension] - The file extension.
* @param {string} [name] - The name of the file (optional).
* @throws {LazyError} If the buffer or extension is not provided.
*/
async saveFile(buffer, extension, name) {
if (!buffer)
throw new LazyUtil_1.LazyError('Buffer must be provided');
if (!extension)
throw new LazyUtil_1.LazyError('Extension must be provided');
fs.writeFileSync(`${name === undefined ? (0, utils_1.generateRandomName)() : name}.${extension}`, buffer);
}
/**
* Exports all layers from the LayersManager as an array of JSON objects.
* @param {LayersManager} [manager] - The LayersManager instance.
* @returns {any[]} An array of JSON representations of the layers.
*/
exportLayers(manager) {
let arr = [];
for (const layer of Array.from(manager.map.values())) {
arr.push(layer.toJSON());
}
return arr;
}
/**
* Exports the canvas to the specified format.
* @param {AnyExport} [exportType] - The type of export (e.g., "png", "json").
* @param {Object} [opts] - Optional settings.
* @param {string} [opts.name] - The name of the file (optional).
* @param {boolean} [opts.saveAsFile] - Whether to save the export as a file (optional).
* @returns {Promise<Buffer | SKRSContext2D | Canvas | SvgCanvas | string>} The exported data.
* @throws {LazyError} If the export type is not supported.
*/
async export(exportType, opts) {
// beforeExport hook
this.canvas.manager.plugins.executeHook('beforeExport', this.canvas);
let result;
switch (exportType) {
case types_1.Export.CTX:
case "ctx":
result = await this.canvas.manager.render.render(exportType);
break;
case types_1.Export.SVG:
case "svg":
result = await this.canvas.manager.render.render('svg');
if (opts?.saveAsFile) {
await this.saveFile(result, 'svg', opts.name);
}
break;
case types_1.Export.BUFFER:
case "buffer":
result = await this.canvas.manager.render.render('buffer');
if (opts?.saveAsFile) {
await this.saveFile(result, 'png', opts.name);
}
break;
case types_1.Export.GIF:
case "gif":
result = await this.canvas.manager.render.render('buffer');
if (opts?.saveAsFile) {
await this.saveFile(result, 'gif', opts.name);
}
break;
case types_1.Export.WEBP:
case "webp":
result = await this.canvas.manager.render.render('buffer');
if (opts?.saveAsFile) {
await this.saveFile(result, 'webp', opts.name);
}
break;
case types_1.Export.JPEG:
case "jpeg":
result = await this.canvas.manager.render.render('buffer');
await this.saveFile(result, 'jpeg', opts?.name);
break;
case types_1.Export.JPG:
case "jpg":
const jpg = await this.canvas.manager.render.render('buffer');
await this.saveFile(jpg, 'jpg', opts?.name);
return jpg;
case types_1.Export.PNG:
case "png":
const png = await this.canvas.manager.render.render('buffer');
await this.saveFile(png, 'png', opts?.name);
return png;
case types_1.Export.JSON:
case "json":
const json = this.syncExport(exportType);
if (opts?.saveAsFile) {
await this.saveFile(JSON.stringify(json), 'json', opts.name);
}
return JSON.stringify(json);
case types_1.Export.CANVAS:
case "canvas":
return await this.canvas.manager.render.render(exportType);
case types_1.Export.YAML:
case "yaml":
const yaml = _yaml.dump(this.syncExport(types_1.Export.JSON));
if (opts?.saveAsFile) {
await this.saveFile(yaml, 'yaml', opts.name);
}
return yaml;
default:
throw new LazyUtil_1.LazyError(`Export type ${exportType} is not supported`);
}
// afterExport hook
this.canvas.manager.plugins.executeHook('afterExport', this.canvas, result);
return result;
}
/**
* Synchronously exports the canvas to the specified format.
* @param {AnyExport} [exportType] - The type of export (e.g., "json").
* @returns {IOLazyCanvas | void} The exported data or void if the export type is unsupported.
*/
syncExport(exportType) {
switch (exportType) {
case types_1.Export.JSON:
case "json":
return {
options: this.canvas.options,
animation: this.canvas.manager.animation.options,
layers: this.exportLayers(this.canvas.manager.layers)
};
}
}
}
exports.Exporter = Exporter;