@mcpcn/markdown-converter 1.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/README.md +210 -0
  2. package/dist/config/word.d.ts +67 -0
  3. package/dist/config/word.d.ts.map +1 -0
  4. package/dist/config/word.js +86 -0
  5. package/dist/config/word.js.map +1 -0
  6. package/dist/core/BaseConverter.d.ts +104 -0
  7. package/dist/core/BaseConverter.d.ts.map +1 -0
  8. package/dist/core/BaseConverter.js +203 -0
  9. package/dist/core/BaseConverter.js.map +1 -0
  10. package/dist/core/BrowserPool.d.ts +25 -0
  11. package/dist/core/BrowserPool.d.ts.map +1 -0
  12. package/dist/core/BrowserPool.js +152 -0
  13. package/dist/core/BrowserPool.js.map +1 -0
  14. package/dist/core/CacheManager.d.ts +26 -0
  15. package/dist/core/CacheManager.d.ts.map +1 -0
  16. package/dist/core/CacheManager.js +74 -0
  17. package/dist/core/CacheManager.js.map +1 -0
  18. package/dist/core/MarkdownRenderer.d.ts +19 -0
  19. package/dist/core/MarkdownRenderer.d.ts.map +1 -0
  20. package/dist/core/MarkdownRenderer.js +160 -0
  21. package/dist/core/MarkdownRenderer.js.map +1 -0
  22. package/dist/core/PDFConverter.d.ts +81 -0
  23. package/dist/core/PDFConverter.d.ts.map +1 -0
  24. package/dist/core/PDFConverter.js +284 -0
  25. package/dist/core/PDFConverter.js.map +1 -0
  26. package/dist/core/PDFGenerator.d.ts +32 -0
  27. package/dist/core/PDFGenerator.d.ts.map +1 -0
  28. package/dist/core/PDFGenerator.js +352 -0
  29. package/dist/core/PDFGenerator.js.map +1 -0
  30. package/dist/core/TemplateManager.d.ts +16 -0
  31. package/dist/core/TemplateManager.d.ts.map +1 -0
  32. package/dist/core/TemplateManager.js +321 -0
  33. package/dist/core/TemplateManager.js.map +1 -0
  34. package/dist/core/WordConverter.d.ts +44 -0
  35. package/dist/core/WordConverter.d.ts.map +1 -0
  36. package/dist/core/WordConverter.js +409 -0
  37. package/dist/core/WordConverter.js.map +1 -0
  38. package/dist/index.d.ts +36 -0
  39. package/dist/index.d.ts.map +1 -0
  40. package/dist/index.js +507 -0
  41. package/dist/index.js.map +1 -0
  42. package/dist/types/index.d.ts +69 -0
  43. package/dist/types/index.d.ts.map +1 -0
  44. package/dist/types/index.js +2 -0
  45. package/dist/types/index.js.map +1 -0
  46. package/package.json +72 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BaseConverter.js","sourceRoot":"","sources":["../../src/core/BaseConverter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import { Browser } from 'puppeteer';
2
+ import { BrowserPool } from '../types/index.js';
3
+ /**
4
+ * 高性能浏览器连接池
5
+ * 支持浏览器复用,减少启动开销
6
+ */
7
+ export declare class PuppeteerBrowserPool implements BrowserPool {
8
+ private browsers;
9
+ private busyBrowsers;
10
+ private readonly maxBrowsers;
11
+ private readonly chromeVersion;
12
+ private isShuttingDown;
13
+ constructor(maxBrowsers?: number);
14
+ private getChromeExecutablePath;
15
+ private createBrowser;
16
+ getBrowser(): Promise<Browser>;
17
+ releaseBrowser(browser: Browser): void;
18
+ cleanup(): Promise<void>;
19
+ getStats(): {
20
+ total: number;
21
+ busy: number;
22
+ available: number;
23
+ };
24
+ }
25
+ //# sourceMappingURL=BrowserPool.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BrowserPool.d.ts","sourceRoot":"","sources":["../../src/core/BrowserPool.ts"],"names":[],"mappings":"AAAA,OAAkB,EAAE,OAAO,EAAQ,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAKhD;;;GAGG;AACH,qBAAa,oBAAqB,YAAW,WAAW;IACtD,OAAO,CAAC,QAAQ,CAAiB;IACjC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAoB;IAClD,OAAO,CAAC,cAAc,CAAS;gBAEnB,WAAW,GAAE,MAAU;IAQnC,OAAO,CAAC,uBAAuB;YA2BjB,aAAa;IAyCrB,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC;IAoDpC,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAIhC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAkB9B,QAAQ,IAAI;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE;CAQ/D"}
@@ -0,0 +1,152 @@
1
+ import puppeteer from 'puppeteer';
2
+ import os from 'os';
3
+ import fs from 'fs';
4
+ import path from 'path';
5
+ /**
6
+ * 高性能浏览器连接池
7
+ * 支持浏览器复用,减少启动开销
8
+ */
9
+ export class PuppeteerBrowserPool {
10
+ browsers = [];
11
+ busyBrowsers = new Set();
12
+ maxBrowsers;
13
+ chromeVersion = '131.0.6778.204';
14
+ isShuttingDown = false;
15
+ constructor(maxBrowsers = 3) {
16
+ this.maxBrowsers = maxBrowsers;
17
+ // 优雅关闭处理
18
+ process.on('SIGINT', () => this.cleanup());
19
+ process.on('SIGTERM', () => this.cleanup());
20
+ }
21
+ getChromeExecutablePath() {
22
+ const platform = process.platform;
23
+ const arch = os.arch();
24
+ let chromePath;
25
+ if (platform === 'darwin') {
26
+ chromePath = arch === 'arm64'
27
+ ? `mac_arm-${this.chromeVersion}/chrome-mac-arm64/Google Chrome for Testing.app/Contents/MacOS/Google Chrome for Testing`
28
+ : `mac-${this.chromeVersion}/chrome-mac/Google Chrome for Testing.app/Contents/MacOS/Google Chrome for Testing`;
29
+ }
30
+ else if (platform === 'linux') {
31
+ chromePath = `linux-${this.chromeVersion}/chrome-linux/chrome`;
32
+ }
33
+ else if (platform === 'win32') {
34
+ chromePath = `win64-${this.chromeVersion}/chrome-win/chrome.exe`;
35
+ }
36
+ else {
37
+ throw new Error(`Unsupported platform: ${platform}`);
38
+ }
39
+ const fullPath = path.join(os.homedir(), '.cache', 'puppeteer', 'chrome', chromePath);
40
+ if (!fs.existsSync(fullPath)) {
41
+ throw new Error(`Chrome executable not found at: ${fullPath}`);
42
+ }
43
+ return fullPath;
44
+ }
45
+ async createBrowser() {
46
+ try {
47
+ const executablePath = this.getChromeExecutablePath();
48
+ return await puppeteer.launch({
49
+ headless: true,
50
+ executablePath,
51
+ args: [
52
+ '--no-sandbox',
53
+ '--disable-setuid-sandbox',
54
+ '--disable-dev-shm-usage',
55
+ '--disable-extensions',
56
+ '--disable-gpu',
57
+ '--disable-background-timer-throttling',
58
+ '--disable-backgrounding-occluded-windows',
59
+ '--disable-renderer-backgrounding',
60
+ '--disable-features=TranslateUI,VizDisplayCompositor',
61
+ '--run-all-compositor-stages-before-draw',
62
+ '--disable-ipc-flooding-protection',
63
+ '--memory-pressure-off'
64
+ ],
65
+ defaultViewport: {
66
+ width: 1200,
67
+ height: 1600,
68
+ deviceScaleFactor: 1
69
+ }
70
+ });
71
+ }
72
+ catch (error) {
73
+ // 回退到默认Chrome
74
+ console.warn('使用默认Chrome安装,性能可能受影响');
75
+ return await puppeteer.launch({
76
+ headless: true,
77
+ args: [
78
+ '--no-sandbox',
79
+ '--disable-setuid-sandbox',
80
+ '--disable-dev-shm-usage'
81
+ ]
82
+ });
83
+ }
84
+ }
85
+ async getBrowser() {
86
+ if (this.isShuttingDown) {
87
+ throw new Error('BrowserPool is shutting down');
88
+ }
89
+ // 查找空闲浏览器
90
+ const availableBrowser = this.browsers.find(browser => !this.busyBrowsers.has(browser) && browser.isConnected());
91
+ if (availableBrowser) {
92
+ this.busyBrowsers.add(availableBrowser);
93
+ return availableBrowser;
94
+ }
95
+ // 创建新浏览器(如果未达到最大数量)
96
+ if (this.browsers.length < this.maxBrowsers) {
97
+ const newBrowser = await this.createBrowser();
98
+ this.browsers.push(newBrowser);
99
+ this.busyBrowsers.add(newBrowser);
100
+ // 监听浏览器断开事件
101
+ newBrowser.on('disconnected', () => {
102
+ this.browsers = this.browsers.filter(b => b !== newBrowser);
103
+ this.busyBrowsers.delete(newBrowser);
104
+ });
105
+ return newBrowser;
106
+ }
107
+ // 等待浏览器可用
108
+ return new Promise((resolve, reject) => {
109
+ const checkInterval = setInterval(() => {
110
+ const available = this.browsers.find(browser => !this.busyBrowsers.has(browser) && browser.isConnected());
111
+ if (available) {
112
+ clearInterval(checkInterval);
113
+ this.busyBrowsers.add(available);
114
+ resolve(available);
115
+ }
116
+ }, 100);
117
+ // 超时处理
118
+ setTimeout(() => {
119
+ clearInterval(checkInterval);
120
+ reject(new Error('获取浏览器超时'));
121
+ }, 30000);
122
+ });
123
+ }
124
+ releaseBrowser(browser) {
125
+ this.busyBrowsers.delete(browser);
126
+ }
127
+ async cleanup() {
128
+ this.isShuttingDown = true;
129
+ const closePromises = this.browsers.map(async (browser) => {
130
+ try {
131
+ if (browser.isConnected()) {
132
+ await browser.close();
133
+ }
134
+ }
135
+ catch (error) {
136
+ console.error('关闭浏览器时出错:', error);
137
+ }
138
+ });
139
+ await Promise.all(closePromises);
140
+ this.browsers = [];
141
+ this.busyBrowsers.clear();
142
+ }
143
+ getStats() {
144
+ const connected = this.browsers.filter(b => b.isConnected());
145
+ return {
146
+ total: connected.length,
147
+ busy: this.busyBrowsers.size,
148
+ available: connected.length - this.busyBrowsers.size
149
+ };
150
+ }
151
+ }
152
+ //# sourceMappingURL=BrowserPool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BrowserPool.js","sourceRoot":"","sources":["../../src/core/BrowserPool.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { CacheManager } from '../types/index.js';
2
+ /**
3
+ * 内存缓存管理器
4
+ * 用于缓存渲染结果,提升性能
5
+ */
6
+ export declare class MemoryCacheManager implements CacheManager {
7
+ private defaultTTL;
8
+ private cache;
9
+ private cleanupInterval;
10
+ constructor(defaultTTL?: number);
11
+ get<T>(key: string): Promise<T | null>;
12
+ set<T>(key: string, value: T, ttl?: number): Promise<void>;
13
+ delete(key: string): Promise<void>;
14
+ clear(): Promise<void>;
15
+ private cleanExpired;
16
+ private cleanup;
17
+ getStats(): {
18
+ size: number;
19
+ expired: number;
20
+ };
21
+ /**
22
+ * 生成缓存键
23
+ */
24
+ static generateKey(prefix: string, data: any): string;
25
+ }
26
+ //# sourceMappingURL=CacheManager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CacheManager.d.ts","sourceRoot":"","sources":["../../src/core/CacheManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD;;;GAGG;AACH,qBAAa,kBAAmB,YAAW,YAAY;IAIzC,OAAO,CAAC,UAAU;IAH9B,OAAO,CAAC,KAAK,CAAqD;IAClE,OAAO,CAAC,eAAe,CAAiB;gBAEpB,UAAU,GAAE,MAAe;IAQzC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAetC,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1D,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIlC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5B,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,OAAO;IAOf,QAAQ,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE;IAgB7C;;OAEG;IACH,MAAM,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,MAAM;CAKtD"}
@@ -0,0 +1,74 @@
1
+ import crypto from 'crypto';
2
+ /**
3
+ * 内存缓存管理器
4
+ * 用于缓存渲染结果,提升性能
5
+ */
6
+ export class MemoryCacheManager {
7
+ defaultTTL;
8
+ cache = new Map();
9
+ cleanupInterval;
10
+ constructor(defaultTTL = 300000) {
11
+ this.defaultTTL = defaultTTL;
12
+ // 每分钟清理过期缓存
13
+ this.cleanupInterval = setInterval(() => this.cleanExpired(), 60000);
14
+ // 进程退出时清理
15
+ process.on('exit', () => this.cleanup());
16
+ }
17
+ async get(key) {
18
+ const item = this.cache.get(key);
19
+ if (!item) {
20
+ return null;
21
+ }
22
+ if (Date.now() > item.expiry) {
23
+ this.cache.delete(key);
24
+ return null;
25
+ }
26
+ return item.value;
27
+ }
28
+ async set(key, value, ttl) {
29
+ const expiry = Date.now() + (ttl || this.defaultTTL);
30
+ this.cache.set(key, { value, expiry });
31
+ }
32
+ async delete(key) {
33
+ this.cache.delete(key);
34
+ }
35
+ async clear() {
36
+ this.cache.clear();
37
+ }
38
+ cleanExpired() {
39
+ const now = Date.now();
40
+ for (const [key, item] of this.cache.entries()) {
41
+ if (now > item.expiry) {
42
+ this.cache.delete(key);
43
+ }
44
+ }
45
+ }
46
+ cleanup() {
47
+ if (this.cleanupInterval) {
48
+ clearInterval(this.cleanupInterval);
49
+ }
50
+ this.cache.clear();
51
+ }
52
+ getStats() {
53
+ const now = Date.now();
54
+ let expired = 0;
55
+ for (const item of this.cache.values()) {
56
+ if (now > item.expiry) {
57
+ expired++;
58
+ }
59
+ }
60
+ return {
61
+ size: this.cache.size,
62
+ expired
63
+ };
64
+ }
65
+ /**
66
+ * 生成缓存键
67
+ */
68
+ static generateKey(prefix, data) {
69
+ const hash = crypto.createHash('sha256');
70
+ hash.update(JSON.stringify(data));
71
+ return `${prefix}:${hash.digest('hex')}`;
72
+ }
73
+ }
74
+ //# sourceMappingURL=CacheManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CacheManager.js","sourceRoot":"","sources":["../../src/core/CacheManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { MarkdownConfig, ConversionProgress } from '../types/index.js';
2
+ /**
3
+ * 高性能Markdown渲染器
4
+ * 支持语法高亮、Mermaid图表、数学公式等
5
+ */
6
+ export declare class MarkdownRenderer {
7
+ private renderer;
8
+ private config;
9
+ constructor(config?: Partial<MarkdownConfig>);
10
+ private initializeRenderer;
11
+ private highlightCode;
12
+ private setupCustomRules;
13
+ render(markdown: string, progressCallback?: (progress: ConversionProgress) => void): Promise<string>;
14
+ private preprocessMarkdown;
15
+ private postprocessHtml;
16
+ updateConfig(config: Partial<MarkdownConfig>): void;
17
+ getConfig(): MarkdownConfig;
18
+ }
19
+ //# sourceMappingURL=MarkdownRenderer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownRenderer.d.ts","sourceRoot":"","sources":["../../src/core/MarkdownRenderer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAEvE;;;GAGG;AACH,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,QAAQ,CAAc;IAC9B,OAAO,CAAC,MAAM,CAAiB;gBAEnB,MAAM,GAAE,OAAO,CAAC,cAAc,CAAM;IAchD,OAAO,CAAC,kBAAkB;IAY1B,OAAO,CAAC,aAAa;IAuBrB,OAAO,CAAC,gBAAgB;IA8ClB,MAAM,CACV,QAAQ,EAAE,MAAM,EAChB,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,kBAAkB,KAAK,IAAI,GACxD,OAAO,CAAC,MAAM,CAAC;IA+ClB,OAAO,CAAC,kBAAkB;IA2B1B,OAAO,CAAC,eAAe;IAkBvB,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI;IAKnD,SAAS,IAAI,cAAc;CAG5B"}
@@ -0,0 +1,160 @@
1
+ import { Remarkable } from 'remarkable';
2
+ import hljs from 'highlight.js';
3
+ /**
4
+ * 高性能Markdown渲染器
5
+ * 支持语法高亮、Mermaid图表、数学公式等
6
+ */
7
+ export class MarkdownRenderer {
8
+ renderer;
9
+ config;
10
+ constructor(config = {}) {
11
+ this.config = {
12
+ breaks: true,
13
+ html: true,
14
+ linkify: true,
15
+ typographer: true,
16
+ highlight: true,
17
+ mermaid: true,
18
+ ...config
19
+ };
20
+ this.initializeRenderer();
21
+ }
22
+ initializeRenderer() {
23
+ this.renderer = new Remarkable({
24
+ breaks: this.config.breaks,
25
+ html: this.config.html,
26
+ typographer: this.config.typographer,
27
+ highlight: this.config.highlight ? this.highlightCode.bind(this) : undefined
28
+ });
29
+ // 自定义渲染规则
30
+ this.setupCustomRules();
31
+ }
32
+ highlightCode(code, language) {
33
+ // Mermaid 图表处理
34
+ if (language === 'mermaid' && this.config.mermaid) {
35
+ return `<div class="mermaid" data-processed="false">${code}</div>`;
36
+ }
37
+ // 语法高亮
38
+ if (language && hljs.getLanguage(language)) {
39
+ try {
40
+ return hljs.highlight(code, { language }).value;
41
+ }
42
+ catch (error) {
43
+ console.warn(`语法高亮失败 (${language}):`, error);
44
+ }
45
+ }
46
+ // 自动检测语言
47
+ try {
48
+ return hljs.highlightAuto(code).value;
49
+ }
50
+ catch (error) {
51
+ return code;
52
+ }
53
+ }
54
+ setupCustomRules() {
55
+ // 任务列表支持
56
+ this.renderer.renderer.rules.list_item_open = function (tokens, idx) {
57
+ const token = tokens[idx];
58
+ const content = tokens[idx + 2]?.content || '';
59
+ if (content.startsWith('[ ]') || content.startsWith('[x]') || content.startsWith('[X]')) {
60
+ const checked = content.startsWith('[x]') || content.startsWith('[X]');
61
+ const cleanContent = content.substring(3).trim();
62
+ return `<li class="task-list-item"><input type="checkbox" ${checked ? 'checked' : ''} disabled> `;
63
+ }
64
+ return '<li>';
65
+ };
66
+ // 表格增强
67
+ this.renderer.renderer.rules.table_open = function () {
68
+ return '<div class="table-container"><table class="enhanced-table">';
69
+ };
70
+ this.renderer.renderer.rules.table_close = function () {
71
+ return '</table></div>';
72
+ };
73
+ // 代码块增强
74
+ this.renderer.renderer.rules.fence = (tokens, idx, options, env) => {
75
+ const token = tokens[idx];
76
+ const info = token.info ? token.info.trim() : '';
77
+ const langName = info.split(/\s+/g)[0];
78
+ if (langName === 'mermaid' && this.config.mermaid) {
79
+ return `<div class="mermaid-container">
80
+ <div class="mermaid" data-processed="false">${token.content}</div>
81
+ </div>`;
82
+ }
83
+ const highlighted = this.highlightCode(token.content, langName);
84
+ const langClass = langName ? ` class="language-${langName}"` : '';
85
+ return `<div class="code-block-container">
86
+ <pre><code${langClass}>${highlighted}</code></pre>
87
+ ${langName ? `<div class="code-language">${langName}</div>` : ''}
88
+ </div>`;
89
+ };
90
+ }
91
+ async render(markdown, progressCallback) {
92
+ try {
93
+ progressCallback?.({
94
+ stage: 'parsing',
95
+ progress: 0,
96
+ message: '开始解析Markdown...'
97
+ });
98
+ // 预处理Markdown
99
+ const processedMarkdown = this.preprocessMarkdown(markdown);
100
+ progressCallback?.({
101
+ stage: 'parsing',
102
+ progress: 30,
103
+ message: '预处理完成...'
104
+ });
105
+ // 渲染HTML
106
+ const html = this.renderer.render(processedMarkdown);
107
+ progressCallback?.({
108
+ stage: 'parsing',
109
+ progress: 70,
110
+ message: '渲染HTML...'
111
+ });
112
+ // 后处理HTML
113
+ const processedHtml = this.postprocessHtml(html);
114
+ progressCallback?.({
115
+ stage: 'parsing',
116
+ progress: 100,
117
+ message: 'Markdown解析完成'
118
+ });
119
+ return processedHtml;
120
+ }
121
+ catch (error) {
122
+ progressCallback?.({
123
+ stage: 'error',
124
+ progress: 0,
125
+ message: '解析Markdown时出错',
126
+ error: error
127
+ });
128
+ throw error;
129
+ }
130
+ }
131
+ preprocessMarkdown(markdown) {
132
+ let processed = markdown;
133
+ // 处理GitHub风格的警告框
134
+ processed = processed.replace(/^>\s*\[!(NOTE|TIP|IMPORTANT|WARNING|CAUTION)\]\s*(.+?)$/gm, (match, type, content) => {
135
+ const className = `alert alert-${type.toLowerCase()}`;
136
+ return `<div class="${className}"><strong>${type}:</strong> ${content}</div>`;
137
+ });
138
+ // 处理脚注
139
+ processed = processed.replace(/\[\^([^\]]+)\]:\s*(.+?)$/gm, '<div class="footnote" id="footnote-$1"><strong>[$1]:</strong> $2</div>');
140
+ // 处理脚注引用
141
+ processed = processed.replace(/\[\^([^\]]+)\]/g, '<sup><a href="#footnote-$1" class="footnote-ref">$1</a></sup>');
142
+ return processed;
143
+ }
144
+ postprocessHtml(html) {
145
+ let processed = html;
146
+ // 为图片添加懒加载和错误处理
147
+ processed = processed.replace(/<img([^>]+)src="([^"]+)"([^>]*)>/g, '<img$1src="$2" loading="lazy" onerror="this.style.display=\'none\'"$3>');
148
+ // 为外部链接添加target="_blank"
149
+ processed = processed.replace(/<a([^>]+)href="(https?:\/\/[^"]+)"([^>]*)>/g, '<a$1href="$2" target="_blank" rel="noopener noreferrer"$3>');
150
+ return processed;
151
+ }
152
+ updateConfig(config) {
153
+ this.config = { ...this.config, ...config };
154
+ this.initializeRenderer();
155
+ }
156
+ getConfig() {
157
+ return { ...this.config };
158
+ }
159
+ }
160
+ //# sourceMappingURL=MarkdownRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownRenderer.js","sourceRoot":"","sources":["../../src/core/MarkdownRenderer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * PDF转换器
3
+ * 基于原EnhancedConverter重构,继承BaseConverter
4
+ */
5
+ import { BaseConverter, ConversionResult, BaseConversionOptions } from './BaseConverter.js';
6
+ export interface PDFConversionOptions extends BaseConversionOptions {
7
+ template?: string;
8
+ pdfConfig?: any;
9
+ markdownConfig?: any;
10
+ watermark?: any;
11
+ }
12
+ export declare class PDFConverter extends BaseConverter {
13
+ private browserPool;
14
+ private templateManager;
15
+ private markdownRenderer;
16
+ private pdfGenerator;
17
+ private memoryCacheManager;
18
+ private concurrencyLimit;
19
+ constructor(options?: {
20
+ maxBrowsers?: number;
21
+ maxConcurrent?: number;
22
+ templateDir?: string;
23
+ cacheEnabled?: boolean;
24
+ cacheDir?: string;
25
+ });
26
+ /**
27
+ * 实现基类的抽象方法
28
+ */
29
+ convert(markdownContent: string, outputPath: string, options?: PDFConversionOptions): Promise<ConversionResult>;
30
+ /**
31
+ * 批量转换
32
+ */
33
+ convertBatch(inputs: Array<{
34
+ markdown: string;
35
+ outputPath: string;
36
+ options?: PDFConversionOptions;
37
+ }>, globalProgress?: (overall: {
38
+ completed: number;
39
+ total: number;
40
+ current?: string;
41
+ errors: Error[];
42
+ }) => void): Promise<string[]>;
43
+ /**
44
+ * 从文件转换
45
+ */
46
+ convertFromFile(markdownPath: string, outputPath?: string, options?: PDFConversionOptions): Promise<ConversionResult>;
47
+ /**
48
+ * 获取系统状态
49
+ */
50
+ getStats(): {
51
+ browserPool: {
52
+ total: number;
53
+ busy: number;
54
+ available: number;
55
+ };
56
+ cache?: {
57
+ size: number;
58
+ expired: number;
59
+ };
60
+ system: {
61
+ memory: {
62
+ used: number;
63
+ total: number;
64
+ };
65
+ cpu: number;
66
+ };
67
+ };
68
+ /**
69
+ * 清理资源 - 重写基类方法
70
+ */
71
+ cleanup(): Promise<void>;
72
+ /**
73
+ * 获取可用模板
74
+ */
75
+ getAvailableTemplates(): string[];
76
+ /**
77
+ * 获取模板详情
78
+ */
79
+ getTemplateInfo(name: string): Promise<import("../types/index.js").Template | null>;
80
+ }
81
+ //# sourceMappingURL=PDFConverter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PDFConverter.d.ts","sourceRoot":"","sources":["../../src/core/PDFConverter.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAY5F,MAAM,WAAW,oBAAqB,SAAQ,qBAAqB;IACjE,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,GAAG,CAAC;IAChB,cAAc,CAAC,EAAE,GAAG,CAAC;IACrB,SAAS,CAAC,EAAE,GAAG,CAAC;CACjB;AAED,qBAAa,YAAa,SAAQ,aAAa;IAC7C,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,kBAAkB,CAA4B;IACtD,OAAO,CAAC,gBAAgB,CAA2C;gBAEvD,OAAO,GAAE;QACnB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,YAAY,CAAC,EAAE,OAAO,CAAC;QACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACd;IA0BN;;OAEG;IACG,OAAO,CACX,eAAe,EAAE,MAAM,EACvB,UAAU,EAAE,MAAM,EAClB,OAAO,GAAE,oBAAyB,GACjC,OAAO,CAAC,gBAAgB,CAAC;IAyI5B;;OAEG;IACG,YAAY,CAChB,MAAM,EAAE,KAAK,CAAC;QACZ,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,oBAAoB,CAAC;KAChC,CAAC,EACF,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE;QACzB,SAAS,EAAE,MAAM,CAAC;QAClB,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,MAAM,EAAE,KAAK,EAAE,CAAC;KACjB,KAAK,IAAI,GACT,OAAO,CAAC,MAAM,EAAE,CAAC;IA4EpB;;OAEG;IACG,eAAe,CACnB,YAAY,EAAE,MAAM,EACpB,UAAU,CAAC,EAAE,MAAM,EACnB,OAAO,GAAE,oBAAyB,GACjC,OAAO,CAAC,gBAAgB,CAAC;IAa5B;;OAEG;IACH,QAAQ,IAAI;QACV,WAAW,EAAE;YAAE,KAAK,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAC;YAAC,SAAS,EAAE,MAAM,CAAA;SAAE,CAAC;QAChE,KAAK,CAAC,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,MAAM,CAAA;SAAE,CAAC;QAC1C,MAAM,EAAE;YACN,MAAM,EAAE;gBAAE,IAAI,EAAE,MAAM,CAAC;gBAAC,KAAK,EAAE,MAAM,CAAA;aAAE,CAAC;YACxC,GAAG,EAAE,MAAM,CAAC;SACb,CAAC;KACH;IAgBD;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAW9B;;OAEG;IACH,qBAAqB,IAAI,MAAM,EAAE;IAIjC;;OAEG;IACG,eAAe,CAAC,IAAI,EAAE,MAAM;CAGnC"}