@mofanx/md2pdf
Version:
高兼容性 Markdown 转 PDF 工具,支持本地图片、批量转换、字体优化,命令行一键使用。
109 lines (108 loc) • 4.36 kB
JavaScript
;
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;
};
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
/**
* md2pdf 命令行入口
* 支持将 Markdown 文件/目录批量转换为 PDF,兼容本地图片、代码块高亮、多字体。
*
* 用法示例:
* md2pdf <input> [output] [--ext .pdf]
*
* @author mofanx <yanwuning@live.cn>
* @license MIT
*/
const commander_1 = require("commander");
const path_1 = __importDefault(require("path"));
const md2pdf_1 = require("../src/md2pdf");
const program = new commander_1.Command();
program
.name('md2pdf')
.description('将 Markdown 文件或目录批量转换为 PDF')
.version('1.0.4')
.argument('<input>', '输入的 Markdown 文件或目录路径')
.argument('[output]', '输出的 PDF 文件路径或目录,可选')
.option('--ext <ext>', '输出 PDF 文件后缀名', '.pdf')
.action(async (input, output, opts) => {
const fs = await Promise.resolve().then(() => __importStar(require('fs')));
const inputPath = path_1.default.resolve(process.cwd(), input);
const outputPath = output ? path_1.default.resolve(process.cwd(), output) : '';
const ext = opts.ext || '.pdf';
const isDir = fs.existsSync(inputPath) && fs.statSync(inputPath).isDirectory();
if (!isDir) {
// 单文件
if (!outputPath) {
console.error('单文件转换需指定输出 PDF 路径');
process.exit(1);
}
await (0, md2pdf_1.mdToPdf)(inputPath, outputPath);
console.log(`转换成功: ${outputPath}`);
}
else {
// 目录批量
const outDir = outputPath || path_1.default.join(process.cwd(), 'md2pdf_out');
if (!fs.existsSync(outDir))
fs.mkdirSync(outDir, { recursive: true });
const walk = (dir) => {
let files = [];
for (const item of fs.readdirSync(dir)) {
const full = path_1.default.join(dir, item);
if (fs.statSync(full).isDirectory())
files = files.concat(walk(full));
else if (/\.md$/i.test(item))
files.push(full);
}
return files;
};
const mdFiles = walk(inputPath);
if (mdFiles.length === 0) {
console.warn('目录下未找到 Markdown 文件');
process.exit(0);
}
for (const md of mdFiles) {
const rel = path_1.default.relative(inputPath, md).replace(/\.md$/i, ext);
const pdfPath = path_1.default.join(outDir, rel);
const pdfDir = path_1.default.dirname(pdfPath);
if (!fs.existsSync(pdfDir))
fs.mkdirSync(pdfDir, { recursive: true });
await (0, md2pdf_1.mdToPdf)(md, pdfPath);
console.log(`转换成功: ${pdfPath}`);
}
}
});
program.parse(process.argv);