@matechat/ng 0.0.1-alpha.1 → 20.0.1-alpha.0

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.
@@ -9,9 +9,8 @@ import MdParserUtils from '../components-common/MarkdownCard/common/parser';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@angular/common";
11
11
  export class MarkdownCardComponent extends BaseComponent {
12
- constructor(resolver, renderer, cdr) {
12
+ constructor(renderer, cdr) {
13
13
  super();
14
- this.resolver = resolver;
15
14
  this.renderer = renderer;
16
15
  this.cdr = cdr;
17
16
  this.content = '';
@@ -38,6 +37,7 @@ export class MarkdownCardComponent extends BaseComponent {
38
37
  this.isTyping = false;
39
38
  this.timer = null;
40
39
  this.parser = MdParserUtils;
40
+ this.noDiff = false;
41
41
  this.mdt = markdownit({
42
42
  breaks: true,
43
43
  linkify: true,
@@ -56,11 +56,14 @@ export class MarkdownCardComponent extends BaseComponent {
56
56
  filterOuterDiff: (t1, t2, diffs) => {
57
57
  // 检查是否是class为code-block-wrapper的div元素
58
58
  const isTargetElement = t2.nodeName === 'DIV' &&
59
- t2.attributes && t2.attributes.class && t2.attributes.class.includes('code-block-wrapper');
59
+ t2.attributes &&
60
+ t2.attributes.class &&
61
+ t2.attributes.class.includes('code-block-wrapper');
60
62
  if (isTargetElement) {
61
63
  t1.innerDone = true;
64
+ t2.innerDone = true;
62
65
  }
63
- }
66
+ },
64
67
  });
65
68
  }
66
69
  ngOnInit() {
@@ -110,58 +113,60 @@ export class MarkdownCardComponent extends BaseComponent {
110
113
  }
111
114
  }
112
115
  parseContent() {
113
- this.foundation.parseContent(this.content || '');
116
+ this.foundation.parseContent();
114
117
  }
115
118
  renderContent(vnodes) {
116
- if (!this.markdownContainer ||
117
- !this.markdownContainer.element ||
118
- !this.markdownContainer.element.nativeElement) {
119
+ if (!this.markdownContainer || !this.markdownContainer.element) {
120
+ return;
121
+ }
122
+ if (this.noDiff) {
123
+ this.renderContentNoDiff(vnodes);
119
124
  return;
120
125
  }
121
126
  const container = this.markdownContainer.element.nativeElement;
122
- // 创建新内容容器
123
- const newContent = document.createElement('div');
127
+ const parser = new DOMParser();
128
+ const newContainerDiv = parser.parseFromString(`<div></div>`, 'text/html');
129
+ const codeBlockWrappers = vnodes.filter((node) => {
130
+ return (node.nodeName === 'DIV' &&
131
+ node.className?.includes('code-block-wrapper'));
132
+ });
124
133
  vnodes.forEach((node) => {
125
134
  if (node &&
126
135
  (node.nodeType ||
127
136
  typeof node === 'string' ||
128
137
  node instanceof HTMLElement)) {
129
- newContent.appendChild(node);
138
+ if (codeBlockWrappers.includes(node)) {
139
+ newContainerDiv.body.firstChild?.appendChild(this.getEmptyCodeBlock(node));
140
+ }
141
+ else {
142
+ newContainerDiv.body.firstChild?.appendChild(node);
143
+ }
130
144
  }
131
145
  });
132
- // 不适用diff-dom,直接替换内容
133
- let noDIff = false;
134
- if (noDIff) {
135
- while (container.firstChild) {
136
- container.removeChild(container.firstChild);
137
- }
138
- container.appendChild(newContent);
139
- return;
140
- }
141
- let oldNode = container;
142
- let newNode = newContent;
143
- const patches = this.diffDom.diff(oldNode, newNode);
144
- //code-block-wrapper
146
+ let newContainerDivHTML = newContainerDiv.body?.firstChild?.outerHTML || '';
147
+ const patches = this.diffDom.diff(container, newContainerDivHTML);
145
148
  this.diffDom.apply(container, patches);
146
- // 从vNodes中找到所有class为code-block-wrapper的div元素
147
- const codeBlockWrappers = vnodes.filter((node) => {
148
- return node.nodeName === 'DIV' && node.className?.includes('code-block-wrapper');
149
- });
150
149
  // 将codeBlockWrappers中的每个div元素替换container中的对应key属性的元素
151
150
  codeBlockWrappers.forEach((newCodeBlock) => {
152
- if (newCodeBlock && newCodeBlock.attributes && newCodeBlock.attributes.key) {
153
- const key = newCodeBlock.attributes.key.value;
154
- // 查找container中对应key的元素
151
+ if (newCodeBlock &&
152
+ newCodeBlock.attributes &&
153
+ newCodeBlock.attributes.key) {
154
+ const key = newCodeBlock?.attributes?.key?.value;
155
155
  const existingElement = container.querySelector(`[key="${key}"]`);
156
- if (existingElement && newCodeBlock instanceof HTMLElement) {
157
- // 替换元素
158
- if (newCodeBlock !== existingElement) {
159
- existingElement.parentNode?.replaceChild(newCodeBlock, existingElement);
160
- }
156
+ if (existingElement &&
157
+ newCodeBlock instanceof HTMLElement &&
158
+ existingElement !== newCodeBlock) {
159
+ existingElement.replaceWith(newCodeBlock);
161
160
  }
162
161
  }
163
162
  });
164
163
  }
164
+ getEmptyCodeBlock(node) {
165
+ const codeNode = document.createElement('div');
166
+ codeNode.className = 'code-block-wrapper';
167
+ codeNode.setAttribute('key', node?.attributes?.key?.value);
168
+ return codeNode;
169
+ }
165
170
  astToVnodes(nodes) {
166
171
  return nodes.map((node) => this.processASTNode(node));
167
172
  }
@@ -180,21 +185,38 @@ export class MarkdownCardComponent extends BaseComponent {
180
185
  processHTMLNode(node) {
181
186
  if (!node.openNode?.content)
182
187
  return;
183
- const container = this.renderer.createElement(node.nodeType === 'html_block' ? 'div' : 'span');
184
- this.renderer.setProperty(container, 'innerHTML', node.openNode.content);
188
+ const parser = new DOMParser();
189
+ const tagName = node.nodeType === 'html_block' ? 'div' : 'span';
190
+ const containerDocument = parser.parseFromString(`<${tagName}>${node.openNode.content}</${tagName}>`, 'text/html');
191
+ const containerBody = containerDocument.body.firstChild;
185
192
  // 处理子节点
186
193
  if (node.children && node.children.length > 0) {
187
194
  node.children.forEach((child) => {
188
195
  const childVnode = this.processASTNode(child);
189
- if (childVnode) {
190
- this.renderer.appendChild(container.firstChild || container, childVnode);
196
+ if (childVnode && containerBody) {
197
+ (containerBody?.firstChild || containerBody).appendChild(childVnode);
191
198
  }
192
199
  });
193
200
  }
194
- return container;
201
+ return containerBody;
202
+ }
203
+ renderContentNoDiff(vnodes) {
204
+ const container = this.markdownContainer.element.nativeElement;
205
+ const newContentFragement = this.renderer.createElement('div');
206
+ vnodes.forEach((node) => {
207
+ if (node &&
208
+ (node.nodeType ||
209
+ typeof node === 'string' ||
210
+ node instanceof HTMLElement)) {
211
+ newContentFragement.appendChild(node);
212
+ }
213
+ });
214
+ while (container.firstChild) {
215
+ container.removeChild(container.firstChild);
216
+ }
217
+ container.appendChild(newContentFragement);
195
218
  }
196
219
  processInlineToken(node) {
197
- const div = this.renderer.createElement('div');
198
220
  let html = '';
199
221
  try {
200
222
  if (!node.openNode) {
@@ -207,12 +229,14 @@ export class MarkdownCardComponent extends BaseComponent {
207
229
  return null;
208
230
  }
209
231
  // 将HTML字符串转换为DOM节点
210
- this.renderer.setProperty(div, 'innerHTML', html);
232
+ const parser = new DOMParser();
233
+ const doc = parser.parseFromString(`<div>${html}</div>`, 'text/html');
234
+ const token = doc.body.firstChild;
211
235
  // 如果只有一个子节点,直接返回子节点而不是包含div
212
- if (div.firstChild && div.childNodes.length === 1) {
213
- return div.firstChild;
236
+ if (token && token.childNodes.length === 1) {
237
+ return token.firstChild;
214
238
  }
215
- return div;
239
+ return token;
216
240
  }
217
241
  processFenceNode(token) {
218
242
  const language = token.info?.replace(/<span\b[^>]*>/i, '').replace('</span>', '') || '';
@@ -245,7 +269,7 @@ export class MarkdownCardComponent extends BaseComponent {
245
269
  node.children.forEach((child) => {
246
270
  const childNode = this.processASTNode(child);
247
271
  if (childNode) {
248
- this.renderer.appendChild(element, childNode);
272
+ element.appendChild(childNode);
249
273
  }
250
274
  });
251
275
  return element;
@@ -253,7 +277,7 @@ export class MarkdownCardComponent extends BaseComponent {
253
277
  node.children.forEach((child) => {
254
278
  const childNode = this.processASTNode(child);
255
279
  if (childNode) {
256
- this.renderer.appendChild(element, childNode);
280
+ element.appendChild(childNode);
257
281
  }
258
282
  });
259
283
  return element;
@@ -277,9 +301,15 @@ export class MarkdownCardComponent extends BaseComponent {
277
301
  }
278
302
  }
279
303
  if (token.type === 'html_block' || token.type === 'html_inline') {
280
- const htmlContainer = this.renderer.createElement(token.type === 'html_block' ? 'div' : 'span');
281
- this.renderer.setProperty(htmlContainer, 'innerHTML', token.content || '');
282
- return htmlContainer;
304
+ const parser = new DOMParser();
305
+ const tagName = token.type === 'html_block' ? 'div' : 'span';
306
+ const doc = parser.parseFromString(`<${tagName}>${token.content}</${tagName}>`, 'text/html');
307
+ const tokenDom = doc.body;
308
+ // 如果只有一个子节点,直接返回子节点而不是包含div
309
+ if (tokenDom.firstChild && tokenDom.childNodes.length === 1) {
310
+ return tokenDom.firstChild;
311
+ }
312
+ return tokenDom;
283
313
  }
284
314
  if (token.tag) {
285
315
  const tagName = this.parser.isValidTagName(token.tag) ? token.tag : 'div';
@@ -292,7 +322,7 @@ export class MarkdownCardComponent extends BaseComponent {
292
322
  // 设置内容
293
323
  if (token.content) {
294
324
  const textNode = this.renderer.createText(token.content);
295
- this.renderer.appendChild(element, textNode);
325
+ element.appendChild(textNode);
296
326
  }
297
327
  return element;
298
328
  }
@@ -341,7 +371,7 @@ export class MarkdownCardComponent extends BaseComponent {
341
371
  // 缓存组件实例和容器
342
372
  this.codeBlockComponentsCache.set(key, {
343
373
  componentRef: componentRef,
344
- container: codeBlockContainer
374
+ container: codeBlockContainer,
345
375
  });
346
376
  // 返回创建的DOM容器
347
377
  return codeBlockContainer;
@@ -357,13 +387,13 @@ export class MarkdownCardComponent extends BaseComponent {
357
387
  });
358
388
  this.codeBlockComponentsCache.clear();
359
389
  }
360
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: MarkdownCardComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
361
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: MarkdownCardComponent, selector: "mc-markdown-card", inputs: { content: "content", typing: "typing", enableThink: "enableThink", typingOptions: "typingOptions", thinkOptions: "thinkOptions", mdOptions: "mdOptions", mdPlugins: "mdPlugins", customXssRules: "customXssRules", theme: "theme", enableMermaid: "enableMermaid", mermaidConfig: "mermaidConfig", actionsTemplate: "actionsTemplate", headerTemplate: "headerTemplate", contentTemplate: "contentTemplate" }, outputs: { afterMdtInit: "afterMdtInit", typingStart: "typingStart", typingEvent: "typingEvent", typingEnd: "typingEnd" }, viewQueries: [{ propertyName: "markdownContainer", first: true, predicate: ["markdownContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>", styles: [".mc-markdown-render ::ng-deep ul,.mc-markdown-render ::ng-deep ol{list-style:none;margin:0;padding:0}.mc-markdown-render ::ng-deep ul{list-style-type:disc;padding-left:16px}.mc-markdown-render ::ng-deep ol{list-style-type:decimal;padding-inline-start:1.75em}.mc-markdown-render ::ng-deep p{line-height:28px;margin:0;padding:0;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render ::ng-deep td,.mc-markdown-render ::ng-deep th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render ::ng-deep caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render ::ng-deep th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render ::ng-deep td p{margin:0;padding:0}.mc-markdown-render ::ng-deep .h1,.mc-markdown-render ::ng-deep .h2,.mc-markdown-render ::ng-deep .h3,.mc-markdown-render ::ng-deep .h4,.mc-markdown-render ::ng-deep .h5,.mc-markdown-render ::ng-deep .h6,.mc-markdown-render ::ng-deep h1,.mc-markdown-render ::ng-deep h2,.mc-markdown-render ::ng-deep h3,.mc-markdown-render ::ng-deep h4,.mc-markdown-render ::ng-deep h5,.mc-markdown-render ::ng-deep h6{line-height:1.1}.mc-markdown-render ::ng-deep blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render ::ng-deep a{color:var(--devui-link, #526ecc);text-decoration:underline;cursor:pointer}.mc-markdown-render ::ng-deep a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render ::ng-deep img{max-width:100%}.mc-markdown-render{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark{color:#ced1db}.mc-markdown-render.mc-markdown-render-light{color:#252b3a}::ng-deep .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}::ng-deep .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-cursor{font-weight:900;animation:typewriter .8s linear 0s infinite}@keyframes typewriter{0%{opacity:1}50%{opacity:0}to{opacity:1}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
390
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: MarkdownCardComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
391
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: MarkdownCardComponent, selector: "mc-markdown-card", inputs: { content: "content", typing: "typing", enableThink: "enableThink", typingOptions: "typingOptions", thinkOptions: "thinkOptions", mdOptions: "mdOptions", mdPlugins: "mdPlugins", customXssRules: "customXssRules", theme: "theme", enableMermaid: "enableMermaid", mermaidConfig: "mermaidConfig", actionsTemplate: "actionsTemplate", headerTemplate: "headerTemplate", contentTemplate: "contentTemplate" }, outputs: { afterMdtInit: "afterMdtInit", typingStart: "typingStart", typingEvent: "typingEvent", typingEnd: "typingEnd" }, viewQueries: [{ propertyName: "markdownContainer", first: true, predicate: ["markdownContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>", styles: [".mc-markdown-render ::ng-deep .h1,.mc-markdown-render ::ng-deep .h2,.mc-markdown-render ::ng-deep .h3,.mc-markdown-render ::ng-deep .h4,.mc-markdown-render ::ng-deep .h5,.mc-markdown-render ::ng-deep .h6,.mc-markdown-render ::ng-deep h1,.mc-markdown-render ::ng-deep h2,.mc-markdown-render ::ng-deep h3,.mc-markdown-render ::ng-deep h4,.mc-markdown-render ::ng-deep h5,.mc-markdown-render ::ng-deep h6{line-height:1.1;margin:16px 0 12px}.mc-markdown-render ::ng-deep .h1:first-child,.mc-markdown-render ::ng-deep .h2:first-child,.mc-markdown-render ::ng-deep .h3:first-child,.mc-markdown-render ::ng-deep .h4:first-child,.mc-markdown-render ::ng-deep .h5:first-child,.mc-markdown-render ::ng-deep .h6:first-child,.mc-markdown-render ::ng-deep h1:first-child,.mc-markdown-render ::ng-deep h2:first-child,.mc-markdown-render ::ng-deep h3:first-child,.mc-markdown-render ::ng-deep h4:first-child,.mc-markdown-render ::ng-deep h5:first-child,.mc-markdown-render ::ng-deep h6:first-child{margin-top:0}.mc-markdown-render ::ng-deep h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render ::ng-deep p{overflow-wrap:break-word;margin:0;padding:0;line-height:24px}.mc-markdown-render ::ng-deep p:last-child{margin:0}.mc-markdown-render ::ng-deep ul,.mc-markdown-render ::ng-deep ol{margin:0;padding:0;padding-inline-start:1.75em}.mc-markdown-render ::ng-deep ul>li,.mc-markdown-render ::ng-deep ol>li{line-height:21px}.mc-markdown-render ::ng-deep ul{list-style-type:disc}.mc-markdown-render ::ng-deep ul li::marker{font-size:20px}.mc-markdown-render ::ng-deep ol{list-style-type:decimal}.mc-markdown-render ::ng-deep table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render ::ng-deep td,.mc-markdown-render ::ng-deep th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render ::ng-deep th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render ::ng-deep td p{margin:0;padding:0}.mc-markdown-render ::ng-deep blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render ::ng-deep a{color:var(--devui-link, #526ecc);text-decoration:none;cursor:pointer}.mc-markdown-render ::ng-deep a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render ::ng-deep img{max-width:100%}.mc-markdown-render{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark{color:#ced1db}.mc-markdown-render.mc-markdown-render-light{color:#252b3a}::ng-deep .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}::ng-deep .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-cursor{font-weight:900;animation:typewriter .8s linear 0s infinite}@keyframes typewriter{0%{opacity:1}50%{opacity:0}to{opacity:1}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
362
392
  }
363
393
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: MarkdownCardComponent, decorators: [{
364
394
  type: Component,
365
- args: [{ selector: 'mc-markdown-card', template: "<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>", styles: [".mc-markdown-render ::ng-deep ul,.mc-markdown-render ::ng-deep ol{list-style:none;margin:0;padding:0}.mc-markdown-render ::ng-deep ul{list-style-type:disc;padding-left:16px}.mc-markdown-render ::ng-deep ol{list-style-type:decimal;padding-inline-start:1.75em}.mc-markdown-render ::ng-deep p{line-height:28px;margin:0;padding:0;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render ::ng-deep td,.mc-markdown-render ::ng-deep th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render ::ng-deep caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render ::ng-deep th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render ::ng-deep td p{margin:0;padding:0}.mc-markdown-render ::ng-deep .h1,.mc-markdown-render ::ng-deep .h2,.mc-markdown-render ::ng-deep .h3,.mc-markdown-render ::ng-deep .h4,.mc-markdown-render ::ng-deep .h5,.mc-markdown-render ::ng-deep .h6,.mc-markdown-render ::ng-deep h1,.mc-markdown-render ::ng-deep h2,.mc-markdown-render ::ng-deep h3,.mc-markdown-render ::ng-deep h4,.mc-markdown-render ::ng-deep h5,.mc-markdown-render ::ng-deep h6{line-height:1.1}.mc-markdown-render ::ng-deep blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render ::ng-deep a{color:var(--devui-link, #526ecc);text-decoration:underline;cursor:pointer}.mc-markdown-render ::ng-deep a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render ::ng-deep img{max-width:100%}.mc-markdown-render{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark{color:#ced1db}.mc-markdown-render.mc-markdown-render-light{color:#252b3a}::ng-deep .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}::ng-deep .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-cursor{font-weight:900;animation:typewriter .8s linear 0s infinite}@keyframes typewriter{0%{opacity:1}50%{opacity:0}to{opacity:1}}\n"] }]
366
- }], ctorParameters: () => [{ type: i0.ComponentFactoryResolver }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { content: [{
395
+ args: [{ selector: 'mc-markdown-card', template: "<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>", styles: [".mc-markdown-render ::ng-deep .h1,.mc-markdown-render ::ng-deep .h2,.mc-markdown-render ::ng-deep .h3,.mc-markdown-render ::ng-deep .h4,.mc-markdown-render ::ng-deep .h5,.mc-markdown-render ::ng-deep .h6,.mc-markdown-render ::ng-deep h1,.mc-markdown-render ::ng-deep h2,.mc-markdown-render ::ng-deep h3,.mc-markdown-render ::ng-deep h4,.mc-markdown-render ::ng-deep h5,.mc-markdown-render ::ng-deep h6{line-height:1.1;margin:16px 0 12px}.mc-markdown-render ::ng-deep .h1:first-child,.mc-markdown-render ::ng-deep .h2:first-child,.mc-markdown-render ::ng-deep .h3:first-child,.mc-markdown-render ::ng-deep .h4:first-child,.mc-markdown-render ::ng-deep .h5:first-child,.mc-markdown-render ::ng-deep .h6:first-child,.mc-markdown-render ::ng-deep h1:first-child,.mc-markdown-render ::ng-deep h2:first-child,.mc-markdown-render ::ng-deep h3:first-child,.mc-markdown-render ::ng-deep h4:first-child,.mc-markdown-render ::ng-deep h5:first-child,.mc-markdown-render ::ng-deep h6:first-child{margin-top:0}.mc-markdown-render ::ng-deep h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render ::ng-deep caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render ::ng-deep p{overflow-wrap:break-word;margin:0;padding:0;line-height:24px}.mc-markdown-render ::ng-deep p:last-child{margin:0}.mc-markdown-render ::ng-deep ul,.mc-markdown-render ::ng-deep ol{margin:0;padding:0;padding-inline-start:1.75em}.mc-markdown-render ::ng-deep ul>li,.mc-markdown-render ::ng-deep ol>li{line-height:21px}.mc-markdown-render ::ng-deep ul{list-style-type:disc}.mc-markdown-render ::ng-deep ul li::marker{font-size:20px}.mc-markdown-render ::ng-deep ol{list-style-type:decimal}.mc-markdown-render ::ng-deep table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render ::ng-deep td,.mc-markdown-render ::ng-deep th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render ::ng-deep th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render ::ng-deep td p{margin:0;padding:0}.mc-markdown-render ::ng-deep blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render ::ng-deep a{color:var(--devui-link, #526ecc);text-decoration:none;cursor:pointer}.mc-markdown-render ::ng-deep a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render ::ng-deep img{max-width:100%}.mc-markdown-render{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark{color:#ced1db}.mc-markdown-render.mc-markdown-render-light{color:#252b3a}::ng-deep .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}::ng-deep .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}::ng-deep .mc-typewriter-cursor{font-weight:900;animation:typewriter .8s linear 0s infinite}@keyframes typewriter{0%{opacity:1}50%{opacity:0}to{opacity:1}}\n"] }]
396
+ }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { content: [{
367
397
  type: Input
368
398
  }], typing: [{
369
399
  type: Input
@@ -403,4 +433,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
403
433
  type: ViewChild,
404
434
  args: ['markdownContainer', { read: ViewContainerRef, static: true }]
405
435
  }] } });
406
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-card.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/MarkdownCard/markdown-card.component.ts","../../../../projects/components-ng/src/MarkdownCard/markdown-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DiffDOM } from 'diff-dom';\nimport {\n  Component,\n  Input,\n  OnInit,\n  OnChanges,\n  OnDestroy,\n  ChangeDetectorRef,\n  SimpleChanges,\n  ViewChild,\n  Output,\n  EventEmitter,\n  Renderer2,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  TemplateRef,\n} from '@angular/core';\nimport markdownit from 'markdown-it';\nimport type { Token } from 'markdown-it';\nimport { MDCardService } from '../components-common/MarkdownCard/common/MDCardService';\nimport type { ASTNode } from '../components-common/MarkdownCard/common/mdCard.types';\nimport { CodeBlockComponent } from './code-block.component';\nimport {\n  MarkdownCardProps,\n  defaultTypingConfig,\n} from '../components-common/MarkdownCard/common/mdCard.types';\nimport BaseComponent from '../Base/base.component';\nimport {\n  MarkdownCardAdapter,\n  MarkdownCardFoundation,\n} from '../components-common/MarkdownCard/foundation';\nimport MdParserUtils from '../components-common/MarkdownCard/common/parser';\n\n@Component({\n  selector: 'mc-markdown-card',\n  templateUrl: './markdown-card.component.html',\n  styleUrls: ['./markdown-card.component.scss'],\n})\nexport class MarkdownCardComponent\n  extends BaseComponent\n  implements OnInit, OnChanges, OnDestroy\n{\n  private diffDom: DiffDOM;\n  @Input() content: string = '';\n  @Input() typing: boolean = false;\n  @Input() enableThink: boolean = false;\n  @Input() typingOptions: MarkdownCardProps['typingOptions'] | any = {};\n  @Input() thinkOptions: MarkdownCardProps['thinkOptions'] = {};\n  @Input() mdOptions: MarkdownCardProps['mdOptions'] = {};\n  @Input() mdPlugins: MarkdownCardProps['mdPlugins'] = [];\n  @Input() customXssRules: MarkdownCardProps['customXssRules'] = [];\n  @Input() theme: 'light' | 'dark' | any = 'light';\n  @Input() enableMermaid: boolean = false;\n  @Input() mermaidConfig: MarkdownCardProps['mermaidConfig'] = {};\n  @Input() actionsTemplate: TemplateRef<any> | null = null;\n  @Input() headerTemplate: TemplateRef<any> | null = null;\n  @Input() contentTemplate: TemplateRef<any> | null = null;\n  \n  // 组件缓存映射表，用于存储已创建的CodeBlockComponent实例\n  private codeBlockComponentsCache: Map<string, {componentRef: any, container: HTMLElement}> = new Map();\n\n  @Output() afterMdtInit = new EventEmitter<markdownit>();\n  @Output() typingStart = new EventEmitter<void>();\n  @Output() typingEvent = new EventEmitter<void>();\n  @Output() typingEnd = new EventEmitter<void>();\n\n  @ViewChild('markdownContainer', { read: ViewContainerRef, static: true })\n  markdownContainer!: ViewContainerRef;\n\n  private mdt: markdownit;\n  typingIndex: number = 0;\n  isTyping: boolean = false;\n  timer: number | null = null;\n  parser = MdParserUtils;\n  mdCardService;\n\n  constructor(\n    private resolver: ComponentFactoryResolver,\n    private renderer: Renderer2,\n    public cdr: ChangeDetectorRef\n  ) {\n    super();\n    this.mdt = markdownit({\n      breaks: true,\n      linkify: true,\n      html: true,\n      highlight: (str, lang) => {\n        // 与Vue组件保持一致的高亮处理\n        return '';\n      },\n      ...this.mdOptions,\n    });\n    this.mdCardService = new MDCardService();\n    this.foundation = new MarkdownCardFoundation(this.adapter);\n\n    // 初始化 diffDom 实例\n    this.diffDom = new DiffDOM({\n      // 配置filterOuterDiff钩子，识别code-block-wrapper元素并直接替换\n      filterOuterDiff: (t1, t2, diffs) => {\n        // 检查是否是class为code-block-wrapper的div元素\n        const isTargetElement = \n          t2.nodeName === 'DIV' &&\n          t2.attributes && t2.attributes.class && t2.attributes.class.includes('code-block-wrapper');\n\n        if (isTargetElement) {\n          t1.innerDone = true;\n        }\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.mdCardService.setMdPlugins(this.mdPlugins || [], this.mdt);\n    this.parseContent();\n    this.afterMdtInit.emit(this.mdt);\n  }\n\n  override get adapter(): MarkdownCardAdapter {\n    return {\n      ...super.adapter,\n      locale: (key: string, params?: Record<string, string>) =>\n        this.adapter.locale(key, params),\n      typingStart: () => this.typingStart.emit(),\n      typingEnd: () => this.typingEnd.emit(),\n      typingEvent: () => this.typingEvent.emit(),\n      parseContent: (content: string) => {\n        // 解析 Markdown 内容\n        const tokens: any = this.mdt.parse(content, {});\n        const ast = this.parser.tokensToAst(tokens);\n        const vnodes = this.astToVnodes(ast);\n        this.renderContent(vnodes);\n      },\n    };\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['content']) {\n      if (!this.typing) {\n        this.typingIndex = this.content?.length || 0;\n        this.parseContent();\n        return;\n      }\n      if (this.content.indexOf(changes['content']?.previousValue) === -1) {\n        this.typingIndex = 0;\n      }\n      // 使用setTimeout模拟Vue的nextTick行为\n      setTimeout(() => this.typewriterStart());\n    }\n\n    if (changes['enableThink'] || changes['thinkOptions'] || changes['theme']) {\n      this.parseContent();\n    }\n\n    if (changes['customXssRules']) {\n      this.mdCardService.setCustomXssRules(this.customXssRules || []);\n      this.parseContent();\n    }\n\n    if (changes['mdPlugins']) {\n      this.mdCardService.setMdPlugins(this.mdPlugins || [], this.mdt);\n      this.parseContent();\n    }\n  }\n\n  private parseContent() {\n    this.foundation.parseContent(this.content || '');\n  }\n\n  private renderContent(vnodes) {\n    if (\n      !this.markdownContainer ||\n      !this.markdownContainer.element ||\n      !this.markdownContainer.element.nativeElement\n    ) {\n      return;\n    }\n\n    const container = this.markdownContainer.element.nativeElement;\n\n    // 创建新内容容器\n    const newContent = document.createElement('div');\n    vnodes.forEach((node) => {\n      if (\n        node &&\n        (node.nodeType ||\n          typeof node === 'string' ||\n          node instanceof HTMLElement)\n      ) {\n        newContent.appendChild(node);\n      }\n    });\n\n    // 不适用diff-dom，直接替换内容\n    let noDIff = false;\n    if (noDIff) {\n      while (container.firstChild) {\n        container.removeChild(container.firstChild);\n      }\n      container.appendChild(newContent);\n      return;\n    }\n\n    let oldNode = container;\n    let newNode = newContent;\n    const patches = this.diffDom.diff(oldNode, newNode);\n    //code-block-wrapper\n    this.diffDom.apply(container, patches);\n    // 从vNodes中找到所有class为code-block-wrapper的div元素\n    const codeBlockWrappers = vnodes.filter((node) => {\n      return node.nodeName === 'DIV' && node.className?.includes('code-block-wrapper');\n    });\n    // 将codeBlockWrappers中的每个div元素替换container中的对应key属性的元素\n    codeBlockWrappers.forEach((newCodeBlock) => {\n      if (newCodeBlock && newCodeBlock.attributes && newCodeBlock.attributes.key) {\n        const key = newCodeBlock.attributes.key.value;\n        // 查找container中对应key的元素\n        const existingElement = container.querySelector(`[key=\"${key}\"]`);\n        \n        if (existingElement && newCodeBlock instanceof HTMLElement) {\n          // 替换元素\n          if (newCodeBlock !== existingElement) {\n              existingElement.parentNode?.replaceChild(newCodeBlock, existingElement);\n          }\n        }\n      }\n    });\n  }\n\n  private astToVnodes(nodes: ASTNode[]) {\n    return nodes.map((node) => this.processASTNode(node));\n  }\n\n  private processASTNode(node: ASTNode | Token | any) {\n    if (node.nodeType === 'html_inline' || node.nodeType === 'html_block') {\n      return this.processHTMLNode(node);\n    }\n\n    if (node.nodeType === 'inline') {\n      return this.processInlineToken(node);\n    }\n    if (this.foundation.isToken(node)) {\n      return this.processToken(node);\n    }\n\n    return this.processASTNodeInternal(node);\n  }\n\n  private processHTMLNode(node: ASTNode): void {\n    if (!node.openNode?.content) return;\n\n    const container = this.renderer.createElement(\n      node.nodeType === 'html_block' ? 'div' : 'span'\n    );\n    this.renderer.setProperty(container, 'innerHTML', node.openNode.content);\n\n    // 处理子节点\n    if (node.children && node.children.length > 0) {\n      node.children.forEach((child) => {\n        const childVnode = this.processASTNode(child as any);\n        if (childVnode) {\n          this.renderer.appendChild(container.firstChild || container, childVnode);\n        }\n      });\n    }\n    return container;\n  }\n\n  private processInlineToken(node: ASTNode | any) {\n    const div = this.renderer.createElement('div');\n    let html = '';\n    try {\n      if (!node.openNode) {\n        return null;\n      }\n      html = this.mdt.renderer.render([node.openNode], this.mdt.options, {});\n    } catch (error) {\n      console.error('Error rendering inline token:', node);\n      return null;\n    }\n\n    // 将HTML字符串转换为DOM节点\n    this.renderer.setProperty(div, 'innerHTML', html);\n\n    // 如果只有一个子节点，直接返回子节点而不是包含div\n    if (div.firstChild && div.childNodes.length === 1) {\n      return div.firstChild;\n    }\n\n    return div;\n  }\n\n  private processFenceNode(token: Token) {\n    const language =\n      token.info?.replace(/<span\\b[^>]*>/i, '').replace('</span>', '') || '';\n    const code = token.content || '';\n    return this.createCodeBlock(language, code, (token as any).tokenIndex || 0);\n  }\n\n  private processASTNodeInternal(node: ASTNode | any) {\n    let tagName = 'div';\n    if (node.openNode?.tag && this.parser.isValidTagName(node.openNode?.tag)) {\n      tagName = node.openNode?.tag;\n    }\n    const element = this.renderer.createElement(tagName);\n\n    // 设置属性\n    if (node.openNode.attrs) {\n      node.openNode.attrs.forEach(([key, value]) => {\n        this.renderer.setAttribute(element, key, value);\n      });\n    }\n\n    // 特殊处理fence类型的token\n    if (node.openNode.type === 'fence') {\n      return this.processFenceNode(node.openNode as unknown as Token);\n    }\n\n    // 处理所有带tag的AST节点\n    if (node.openNode?.tag) {\n      let tagName = this.parser.isValidTagName(node.openNode?.tag)\n        ? node.openNode?.tag\n        : 'div';\n      const element = this.renderer.createElement(tagName);\n\n      // 递归处理所有子节点并添加到当前元素\n      node.children.forEach((child) => {\n        const childNode = this.processASTNode(child);\n        if (childNode) {\n          this.renderer.appendChild(element, childNode);\n        }\n      });\n      return element;\n    }\n\n    node.children.forEach((child) => {\n      const childNode = this.processASTNode(child);\n      if (childNode) {\n        this.renderer.appendChild(element, childNode);\n      }\n    });\n    return element;\n  }\n\n  private processToken(token: Token) {\n    if (token.type === 'text') {\n      return this.renderer.createText(token.content || '');\n    }\n\n    if (token.type === 'inline') {\n      return this.processInlineToken(token);\n    }\n\n    if (token.type === 'fence') {\n      return this.processFenceNode(token);\n    }\n\n    if (token.type === 'softbreak') {\n      if (this.mdt.options.breaks) {\n        return this.renderer.createElement('br');\n      } else {\n        return this.renderer.createText('\\n');\n      }\n    }\n\n    if (token.type === 'html_block' || token.type === 'html_inline') {\n      const htmlContainer = this.renderer.createElement(\n        token.type === 'html_block' ? 'div' : 'span'\n      );\n      this.renderer.setProperty(\n        htmlContainer,\n        'innerHTML',\n        token.content || ''\n      );\n      return htmlContainer;\n    }\n\n    if (token.tag) {\n      const tagName = this.parser.isValidTagName(token.tag) ? token.tag : 'div';\n      const element = this.renderer.createElement(tagName);\n\n      if (token.attrs) {\n        token.attrs.forEach(([key, value]) => {\n          this.renderer.setAttribute(element, key, value);\n        });\n      }\n\n      // 设置内容\n      if (token.content) {\n        const textNode = this.renderer.createText(token.content);\n        this.renderer.appendChild(element, textNode);\n      }\n      return element;\n    }\n\n    return this.renderer.createText(token.content || '');\n  }\n\n  private createCodeBlock(language: string, code: string, blockIndex: number) {\n    const key = `code-block-${blockIndex}`;\n    \n    // 检查缓存中是否已存在相同blockIndex的组件\n    if (this.codeBlockComponentsCache.has(key)) {\n      const cachedItem = this.codeBlockComponentsCache.get(key);\n      if (cachedItem) {\n        // 更新现有组件的属性\n        const componentRef = cachedItem.componentRef;\n        componentRef.setInput('language', language);\n        componentRef.setInput('code', code);\n        componentRef.setInput('theme', this.theme);\n        \n        // 触发变更检测\n        componentRef.changeDetectorRef.detectChanges();\n        // 返回缓存的容器，无需重新创建\n        return cachedItem.container;\n      }\n    }\n    \n    // 缓存中不存在，创建新组件\n    const codeBlockContainer = this.renderer.createElement('div');\n    this.renderer.setAttribute(codeBlockContainer, 'key', key);\n    \n    const componentRef = this.markdownContainer.createComponent(CodeBlockComponent, {\n      projectableNodes: [],\n      injector: this.markdownContainer.injector,\n    });\n    \n    // 设置组件属性\n    componentRef.instance.language = language;\n    componentRef.instance.code = code;\n    componentRef.instance.blockIndex = blockIndex;\n    componentRef.instance.theme = this.theme;\n    componentRef.instance.enableMermaid = this.enableMermaid;\n    componentRef.instance.mermaidConfig = this.mermaidConfig || {};\n    componentRef.instance.actionsTemplate = this.actionsTemplate;\n    componentRef.instance.headerTemplate = this.headerTemplate;\n    componentRef.instance.contentTemplate = this.contentTemplate;\n    \n    // 触发变更检测\n    componentRef.changeDetectorRef.detectChanges();\n    \n    // 将组件的DOM元素附加到容器中\n    this.renderer.appendChild(codeBlockContainer, componentRef.location.nativeElement);\n    \n    // 添加样式类\n    this.renderer.addClass(codeBlockContainer, 'code-block-wrapper');\n    \n    // 缓存组件实例和容器\n    this.codeBlockComponentsCache.set(key, {\n      componentRef: componentRef,\n      container: codeBlockContainer\n    });\n    \n    // 返回创建的DOM容器\n    return codeBlockContainer;\n  }\n\n  private typewriterStart(): void {\n    this.foundation.typewriterStart();\n  }\n  \n  // 在组件销毁时清理缓存，避免内存泄漏\n  override ngOnDestroy(): void {\n    // 销毁所有缓存的组件实例\n    this.codeBlockComponentsCache.forEach((cachedItem) => {\n      cachedItem.componentRef.destroy();\n    });\n    this.codeBlockComponentsCache.clear();\n  }\n}\n","<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n  <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>"]}
436
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-card.component.js","sourceRoot":"","sources":["../../../../projects/components-ng/src/MarkdownCard/markdown-card.component.ts","../../../../projects/components-ng/src/MarkdownCard/markdown-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DiffDOM } from 'diff-dom';\nimport {\n  Component,\n  Input,\n  OnInit,\n  OnChanges,\n  OnDestroy,\n  ChangeDetectorRef,\n  SimpleChanges,\n  ViewChild,\n  Output,\n  EventEmitter,\n  Renderer2,\n  ViewContainerRef,\n  TemplateRef,\n} from '@angular/core';\nimport markdownit from 'markdown-it';\nimport type { Token } from 'markdown-it';\nimport { MDCardService } from '../components-common/MarkdownCard/common/MDCardService';\nimport type { ASTNode } from '../components-common/MarkdownCard/common/mdCard.types';\nimport { CodeBlockComponent } from './code-block.component';\nimport {\n  MarkdownCardProps,\n  defaultTypingConfig,\n} from '../components-common/MarkdownCard/common/mdCard.types';\nimport BaseComponent from '../Base/base.component';\nimport {\n  MarkdownCardAdapter,\n  MarkdownCardFoundation,\n} from '../components-common/MarkdownCard/foundation';\nimport MdParserUtils from '../components-common/MarkdownCard/common/parser';\n\n@Component({\n  selector: 'mc-markdown-card',\n  templateUrl: './markdown-card.component.html',\n  styleUrls: ['./markdown-card.component.scss'],\n})\nexport class MarkdownCardComponent\n  extends BaseComponent<MarkdownCardFoundation>\n  implements OnInit, OnChanges, OnDestroy\n{\n  private diffDom: DiffDOM;\n  @Input() content: string = '';\n  @Input() typing: boolean = false;\n  @Input() enableThink: boolean = false;\n  @Input() typingOptions: MarkdownCardProps['typingOptions'] | any = {};\n  @Input() thinkOptions: MarkdownCardProps['thinkOptions'] = {};\n  @Input() mdOptions: MarkdownCardProps['mdOptions'] = {};\n  @Input() mdPlugins: MarkdownCardProps['mdPlugins'] = [];\n  @Input() customXssRules: MarkdownCardProps['customXssRules'] = [];\n  @Input() theme: 'light' | 'dark' | any = 'light';\n  @Input() enableMermaid: boolean = false;\n  @Input() mermaidConfig: MarkdownCardProps['mermaidConfig'] = {};\n  @Input() actionsTemplate: TemplateRef<any> | null = null;\n  @Input() headerTemplate: TemplateRef<any> | null = null;\n  @Input() contentTemplate: TemplateRef<any> | null = null;\n\n  // 组件缓存映射表，用于存储已创建的CodeBlockComponent实例\n  private codeBlockComponentsCache: Map<\n    string,\n    { componentRef: any; container: HTMLElement }\n  > = new Map();\n\n  @Output() afterMdtInit = new EventEmitter<markdownit>();\n  @Output() typingStart = new EventEmitter<void>();\n  @Output() typingEvent = new EventEmitter<void>();\n  @Output() typingEnd = new EventEmitter<void>();\n\n  @ViewChild('markdownContainer', { read: ViewContainerRef, static: true })\n  markdownContainer!: ViewContainerRef;\n\n  private mdt: markdownit;\n  typingIndex: number = 0;\n  isTyping: boolean = false;\n  timer: number | null = null;\n  parser = MdParserUtils;\n  mdCardService;\n  noDiff: boolean = false;\n\n  constructor(private renderer: Renderer2, public cdr: ChangeDetectorRef) {\n    super();\n    this.mdt = markdownit({\n      breaks: true,\n      linkify: true,\n      html: true,\n      highlight: (str, lang) => {\n        // 与Vue组件保持一致的高亮处理\n        return '';\n      },\n      ...this.mdOptions,\n    });\n    this.mdCardService = new MDCardService();\n    this.foundation = new MarkdownCardFoundation(this.adapter);\n\n    // 初始化 diffDom 实例\n    this.diffDom = new DiffDOM({\n      // 配置filterOuterDiff钩子，识别code-block-wrapper元素并直接替换\n      filterOuterDiff: (t1, t2, diffs) => {\n        // 检查是否是class为code-block-wrapper的div元素\n        const isTargetElement =\n          t2.nodeName === 'DIV' &&\n          t2.attributes &&\n          t2.attributes.class &&\n          t2.attributes.class.includes('code-block-wrapper');\n\n        if (isTargetElement) {\n          t1.innerDone = true;\n          t2.innerDone = true;\n        }\n      },\n    });\n  }\n\n  ngOnInit(): void {\n    this.mdCardService.setMdPlugins(this.mdPlugins || [], this.mdt);\n    this.parseContent();\n    this.afterMdtInit.emit(this.mdt);\n  }\n\n  override get adapter(): MarkdownCardAdapter {\n    return {\n      ...super.adapter,\n      locale: (key: string, params?: Record<string, string>) =>\n        this.adapter.locale(key, params),\n      typingStart: () => this.typingStart.emit(),\n      typingEnd: () => this.typingEnd.emit(),\n      typingEvent: () => this.typingEvent.emit(),\n      parseContent: (content: string) => {\n        // 解析 Markdown 内容\n        const tokens: any = this.mdt.parse(content, {});\n        const ast = this.parser.tokensToAst(tokens);\n        const vnodes = this.astToVnodes(ast);\n        this.renderContent(vnodes);\n      },\n    };\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['content']) {\n      if (!this.typing) {\n        this.typingIndex = this.content?.length || 0;\n        this.parseContent();\n        return;\n      }\n      if (this.content.indexOf(changes['content']?.previousValue) === -1) {\n        this.typingIndex = 0;\n      }\n      // 使用setTimeout模拟Vue的nextTick行为\n      setTimeout(() => this.typewriterStart());\n    }\n\n    if (changes['enableThink'] || changes['thinkOptions'] || changes['theme']) {\n      this.parseContent();\n    }\n\n    if (changes['customXssRules']) {\n      this.mdCardService.setCustomXssRules(this.customXssRules || []);\n      this.parseContent();\n    }\n\n    if (changes['mdPlugins']) {\n      this.mdCardService.setMdPlugins(this.mdPlugins || [], this.mdt);\n      this.parseContent();\n    }\n  }\n\n  private parseContent() {\n    this.foundation.parseContent();\n  }\n\n  private renderContent(vnodes) {\n    if (!this.markdownContainer || !this.markdownContainer.element) {\n      return;\n    }\n\n    if (this.noDiff) {\n      this.renderContentNoDiff(vnodes);\n      return;\n    }\n\n    const container = this.markdownContainer.element.nativeElement;\n    const parser = new DOMParser();\n    const newContainerDiv = parser.parseFromString(`<div></div>`, 'text/html');\n    const codeBlockWrappers = vnodes.filter((node) => {\n      return (\n        node.nodeName === 'DIV' &&\n        node.className?.includes('code-block-wrapper')\n      );\n    });\n\n    vnodes.forEach((node) => {\n      if (\n        node &&\n        (node.nodeType ||\n          typeof node === 'string' ||\n          node instanceof HTMLElement)\n      ) {\n        if (codeBlockWrappers.includes(node)) {\n          newContainerDiv.body.firstChild?.appendChild(this.getEmptyCodeBlock(node));\n        } else {\n          newContainerDiv.body.firstChild?.appendChild(node);\n        }\n      }\n    });\n    let newContainerDivHTML =\n      (newContainerDiv.body?.firstChild as HTMLElement)?.outerHTML || '';\n    const patches = this.diffDom.diff(container, newContainerDivHTML);\n    this.diffDom.apply(container, patches);\n    // 将codeBlockWrappers中的每个div元素替换container中的对应key属性的元素\n    codeBlockWrappers.forEach((newCodeBlock) => {\n      if (\n        newCodeBlock &&\n        newCodeBlock.attributes &&\n        newCodeBlock.attributes.key\n      ) {\n        const key = newCodeBlock?.attributes?.key?.value;\n        const existingElement = container.querySelector(`[key=\"${key}\"]`);\n        if (\n          existingElement &&\n          newCodeBlock instanceof HTMLElement &&\n          existingElement !== newCodeBlock\n        ) {\n          existingElement.replaceWith(newCodeBlock);\n        }\n      }\n    });\n  }\n\n  private getEmptyCodeBlock(node) {\n    const codeNode = document.createElement('div');\n    codeNode.className = 'code-block-wrapper';\n    codeNode.setAttribute('key', node?.attributes?.key?.value);\n    return codeNode;\n  }\n\n  private astToVnodes(nodes: ASTNode[]) {\n    return nodes.map((node) => this.processASTNode(node));\n  }\n\n  private processASTNode(node: ASTNode | Token | any) {\n    if (node.nodeType === 'html_inline' || node.nodeType === 'html_block') {\n      return this.processHTMLNode(node);\n    }\n\n    if (node.nodeType === 'inline') {\n      return this.processInlineToken(node);\n    }\n    if (this.foundation.isToken(node)) {\n      return this.processToken(node);\n    }\n\n    return this.processASTNodeInternal(node);\n  }\n\n  private processHTMLNode(node: ASTNode) {\n    if (!node.openNode?.content) return;\n\n    const parser = new DOMParser();\n    const tagName = node.nodeType === 'html_block' ? 'div' : 'span';\n    const containerDocument = parser.parseFromString(\n      `<${tagName}>${node.openNode.content}</${tagName}>`,\n      'text/html'\n    );\n    const containerBody = containerDocument.body.firstChild;\n    // 处理子节点\n    if (node.children && node.children.length > 0) {\n      node.children.forEach((child) => {\n        const childVnode = this.processASTNode(child as any);\n        if (childVnode && containerBody) {\n          (containerBody?.firstChild || containerBody).appendChild(childVnode);\n        }\n      });\n    }\n    return containerBody;\n  }\n\n  private renderContentNoDiff(vnodes) {\n    const container = this.markdownContainer.element.nativeElement;\n    const newContentFragement = this.renderer.createElement('div');\n    vnodes.forEach((node) => {\n      if (\n        node &&\n        (node.nodeType ||\n          typeof node === 'string' ||\n          node instanceof HTMLElement)\n      ) {\n        newContentFragement.appendChild(node);\n      }\n    });\n    while (container.firstChild) {\n      container.removeChild(container.firstChild);\n    }\n    container.appendChild(newContentFragement);\n  }\n\n  private processInlineToken(node: ASTNode | any) {\n    let html = '';\n    try {\n      if (!node.openNode) {\n        return null;\n      }\n      html = this.mdt.renderer.render([node.openNode], this.mdt.options, {});\n    } catch (error) {\n      console.error('Error rendering inline token:', node);\n      return null;\n    }\n\n    // 将HTML字符串转换为DOM节点\n    const parser = new DOMParser();\n    const doc = parser.parseFromString(`<div>${html}</div>`, 'text/html');\n    const token = doc.body.firstChild;\n    // 如果只有一个子节点，直接返回子节点而不是包含div\n    if (token && token.childNodes.length === 1) {\n      return token.firstChild;\n    }\n    return token;\n  }\n\n  private processFenceNode(token: Token) {\n    const language =\n      token.info?.replace(/<span\\b[^>]*>/i, '').replace('</span>', '') || '';\n    const code = token.content || '';\n    return this.createCodeBlock(language, code, (token as any).tokenIndex || 0);\n  }\n\n  private processASTNodeInternal(node: ASTNode | any) {\n    let tagName = 'div';\n    if (node.openNode?.tag && this.parser.isValidTagName(node.openNode?.tag)) {\n      tagName = node.openNode?.tag;\n    }\n    const element = this.renderer.createElement(tagName);\n\n    // 设置属性\n    if (node.openNode.attrs) {\n      node.openNode.attrs.forEach(([key, value]) => {\n        this.renderer.setAttribute(element, key, value);\n      });\n    }\n\n    // 特殊处理fence类型的token\n    if (node.openNode.type === 'fence') {\n      return this.processFenceNode(node.openNode as unknown as Token);\n    }\n\n    // 处理所有带tag的AST节点\n    if (node.openNode?.tag) {\n      let tagName = this.parser.isValidTagName(node.openNode?.tag)\n        ? node.openNode?.tag\n        : 'div';\n      const element = this.renderer.createElement(tagName);\n\n      // 递归处理所有子节点并添加到当前元素\n      node.children.forEach((child) => {\n        const childNode = this.processASTNode(child);\n        if (childNode) {\n          element.appendChild(childNode);\n        }\n      });\n      return element;\n    }\n\n    node.children.forEach((child) => {\n      const childNode = this.processASTNode(child);\n      if (childNode) {\n        element.appendChild(childNode);\n      }\n    });\n    return element;\n  }\n\n  private processToken(token: Token) {\n    if (token.type === 'text') {\n      return this.renderer.createText(token.content || '');\n    }\n\n    if (token.type === 'inline') {\n      return this.processInlineToken(token);\n    }\n\n    if (token.type === 'fence') {\n      return this.processFenceNode(token);\n    }\n\n    if (token.type === 'softbreak') {\n      if (this.mdt.options.breaks) {\n        return this.renderer.createElement('br');\n      } else {\n        return this.renderer.createText('\\n');\n      }\n    }\n\n    if (token.type === 'html_block' || token.type === 'html_inline') {\n      const parser = new DOMParser();\n      const tagName = token.type === 'html_block' ? 'div' : 'span';\n      const doc = parser.parseFromString(\n        `<${tagName}>${token.content}</${tagName}>`,\n        'text/html'\n      );\n      const tokenDom = doc.body;\n      // 如果只有一个子节点，直接返回子节点而不是包含div\n      if (tokenDom.firstChild && tokenDom.childNodes.length === 1) {\n        return tokenDom.firstChild;\n      }\n      return tokenDom;\n    }\n\n    if (token.tag) {\n      const tagName = this.parser.isValidTagName(token.tag) ? token.tag : 'div';\n      const element = this.renderer.createElement(tagName);\n\n      if (token.attrs) {\n        token.attrs.forEach(([key, value]) => {\n          this.renderer.setAttribute(element, key, value);\n        });\n      }\n\n      // 设置内容\n      if (token.content) {\n        const textNode = this.renderer.createText(token.content);\n        element.appendChild(textNode);\n      }\n      return element;\n    }\n\n    return this.renderer.createText(token.content || '');\n  }\n\n  private createCodeBlock(language: string, code: string, blockIndex: number) {\n    const key = `code-block-${blockIndex}`;\n\n    // 检查缓存中是否已存在相同blockIndex的组件\n    if (this.codeBlockComponentsCache.has(key)) {\n      const cachedItem = this.codeBlockComponentsCache.get(key);\n      if (cachedItem) {\n        // 更新现有组件的属性\n        const componentRef = cachedItem.componentRef;\n        componentRef.setInput('language', language);\n        componentRef.setInput('code', code);\n        componentRef.setInput('theme', this.theme);\n\n        // 触发变更检测\n        componentRef.changeDetectorRef.detectChanges();\n        // 返回缓存的容器，无需重新创建\n        return cachedItem.container;\n      }\n    }\n\n    // 缓存中不存在，创建新组件\n    const codeBlockContainer = this.renderer.createElement('div');\n    this.renderer.setAttribute(codeBlockContainer, 'key', key);\n\n    const componentRef = this.markdownContainer.createComponent(\n      CodeBlockComponent,\n      {\n        projectableNodes: [],\n        injector: this.markdownContainer.injector,\n      }\n    );\n\n    // 设置组件属性\n    componentRef.instance.language = language;\n    componentRef.instance.code = code;\n    componentRef.instance.blockIndex = blockIndex;\n    componentRef.instance.theme = this.theme;\n    componentRef.instance.enableMermaid = this.enableMermaid;\n    componentRef.instance.mermaidConfig = this.mermaidConfig || {};\n    componentRef.instance.actionsTemplate = this.actionsTemplate;\n    componentRef.instance.headerTemplate = this.headerTemplate;\n    componentRef.instance.contentTemplate = this.contentTemplate;\n\n    // 触发变更检测\n    componentRef.changeDetectorRef.detectChanges();\n\n    // 将组件的DOM元素附加到容器中\n    this.renderer.appendChild(\n      codeBlockContainer,\n      componentRef.location.nativeElement\n    );\n\n    // 添加样式类\n    this.renderer.addClass(codeBlockContainer, 'code-block-wrapper');\n\n    // 缓存组件实例和容器\n    this.codeBlockComponentsCache.set(key, {\n      componentRef: componentRef,\n      container: codeBlockContainer,\n    });\n\n    // 返回创建的DOM容器\n    return codeBlockContainer;\n  }\n\n  private typewriterStart(): void {\n    this.foundation.typewriterStart();\n  }\n\n  // 在组件销毁时清理缓存，避免内存泄漏\n  override ngOnDestroy(): void {\n    // 销毁所有缓存的组件实例\n    this.codeBlockComponentsCache.forEach((cachedItem) => {\n      cachedItem.componentRef.destroy();\n    });\n    this.codeBlockComponentsCache.clear();\n  }\n}\n","<div class=\"mc-markdown-render\" [ngClass]=\"theme === 'dark' ? 'mc-markdown-render-dark' : 'mc-markdown-render-light'\">\n  <div #markdownContainer></div>\n</div>\n<ng-content></ng-content>"]}
@@ -73,7 +73,7 @@ export class CodeBlockFoundation extends BaseFoundation {
73
73
  catch (_) {
74
74
  highlightedCode = code;
75
75
  }
76
- this.setState({ highlightedCode });
76
+ this._adapter.highlightCodeChange(highlightedCode, language);
77
77
  };
78
78
  this.renderMermaid = async () => {
79
79
  const { code, theme, mermaidConfig, } = this.getProps();
@@ -129,4 +129,4 @@ export class CodeBlockFoundation extends BaseFoundation {
129
129
  }
130
130
  }
131
131
  }
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codeblock-foundation.js","sourceRoot":"","sources":["../../../../../projects/components-ng/src/components-common/MarkdownCard/codeblock-foundation.ts"],"names":[],"mappings":"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","sourcesContent":["import BaseFoundation, { DefaultAdapter } from '../Base/foundation';\nimport type { Token } from 'markdown-it';\nimport type { ASTNode, MermaidConfig } from './common/mdCard.types';\nimport { defaultTypingConfig } from './common/mdCard.types';\nimport { MermaidService } from './common/MermaidService';\nimport hljs from 'highlight.js';\nimport { MDCardService } from './common/MDCardService';\n\nexport interface CodeBlockAdapter extends DefaultAdapter {\n  getContainer(): HTMLElement | null;\n}\n\nexport class CodeBlockFoundation extends BaseFoundation<CodeBlockAdapter> {\n  mermaidService?: MermaidService;\n  mdCardService: MDCardService;\n  constructor(adapter: CodeBlockAdapter) {\n    super({ ...adapter });\n    this.mdCardService = new MDCardService();\n  }\n\n  toggleExpand = () => {\n    this.setState({ expanded: !this.getStates().expanded });\n  };\n\n  zoomOut = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.zoomOut(container);\n    }\n  };\n\n  zoomIn = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.zoomIn(container);\n    }\n  };\n\n  checkIsMermaid = () => {\n    const { enableMermaid, language } = this.getProps();\n    return enableMermaid && language?.toLowerCase() === 'mermaid';\n  };\n\n  download = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.download(container);\n    }\n  };\n\n  handleCopySuccess = () => {\n    this.setState({ copied: true });\n    setTimeout(() => {\n      this.setState({ copied: false });\n    }, 1500);\n  };\n\n  copyCodeInternal() {\n    const { code } = this.getProps();\n    if (navigator.clipboard) {\n      navigator.clipboard.writeText(code).then(() => {\n        this.handleCopySuccess();\n      });\n    } else {\n      const textarea = document.createElement('textarea');\n      textarea.style.position = 'fixed';\n      textarea.style.top = '-9999px';\n      textarea.style.left = '-9999px';\n      textarea.style.zIndex = '-1';\n      textarea.value = code;\n      document.body.appendChild(textarea);\n      textarea.select();\n      document.execCommand('copy');\n      document.body.removeChild(textarea);\n      this.handleCopySuccess();\n    }\n  }\n\n  updateHighlightedCode = () => {\n    const { code, language } = this.getProps();\n    let highlightedCode = '';\n    try {\n      const typeIndex = code.indexOf(`<span class=\"mc-typewriter`);\n\n      if (language && hljs.getLanguage(language)) {\n        if (typeIndex !== -1) {\n          highlightedCode =\n            hljs.highlight(code.slice(0, typeIndex), {\n              language,\n            }).value + code.slice(typeIndex);\n        } else {\n          highlightedCode = hljs.highlight(code, {\n            language,\n          }).value;\n        }\n      } else {\n        if (typeof hljs.highlightAuto !== 'undefined') {\n          if (typeIndex !== -1) {\n            highlightedCode =\n              hljs.highlightAuto(code.slice(0, typeIndex)).value +\n              code.slice(typeIndex);\n          } else {\n            highlightedCode = hljs.highlightAuto(code).value;\n          }\n        } else {\n          highlightedCode = this.mdCardService.filterHtml(code);\n        }\n      }\n    } catch (_) {\n      highlightedCode = code;\n    }\n    this.setState({ highlightedCode });\n  };\n\n  renderMermaid = async () => {\n    const {\n      code,\n      theme,\n      mermaidConfig,\n    } = this.getProps();\n    const { mermaidContentRef} = this.getStates();\n    const isMermaid = this.checkIsMermaid();\n    if (!isMermaid || !code || !mermaidContentRef) {\n      return;\n    }\n\n    if (!this.mermaidService) {\n      try {\n        this.mermaidService = new MermaidService();\n        const config: MermaidConfig = {\n          theme: theme === 'dark' ? 'dark' : 'default',\n          ...mermaidConfig,\n        };\n        this.mermaidService.setConfig(config);\n      } catch (error) {\n        console.error('Failed to load MermaidService:', error);\n        return;\n      }\n    }\n    this.nextTick(async () => {\n      const container = mermaidContentRef.nativeElement;\n      if (container) {\n        // 移除打字效果相关的span标签\n        const cleanCode = code.replace(\n          /<span[^>]*\\bclass\\s*=\\s*['\"]mc-typewriter[^>]*>([\\s\\S]*?)<\\/span>/g,\n          `$1`\n        );\n        await this.mermaidService?.renderToContainer(\n          container,\n          cleanCode,\n          theme\n        );\n      }\n    });\n  };\n}\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codeblock-foundation.js","sourceRoot":"","sources":["../../../../../projects/components-ng/src/components-common/MarkdownCard/codeblock-foundation.ts"],"names":[],"mappings":"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","sourcesContent":["import BaseFoundation, { DefaultAdapter } from '../Base/foundation';\nimport type { Token } from 'markdown-it';\nimport type { ASTNode, MermaidConfig } from './common/mdCard.types';\nimport { defaultTypingConfig } from './common/mdCard.types';\nimport { MermaidService } from './common/MermaidService';\nimport hljs from 'highlight.js';\nimport { MDCardService } from './common/MDCardService';\n\nexport interface CodeBlockAdapter extends DefaultAdapter {\n  getContainer(): HTMLElement | null;\n  highlightCodeChange(code: string, language: string): void;\n}\n\nexport class CodeBlockFoundation extends BaseFoundation<CodeBlockAdapter> {\n  mermaidService?: MermaidService;\n  mdCardService: MDCardService;\n  constructor(adapter: CodeBlockAdapter) {\n    super({ ...adapter });\n    this.mdCardService = new MDCardService();\n  }\n\n  toggleExpand = () => {\n    this.setState({ expanded: !this.getStates().expanded });\n  };\n\n  zoomOut = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.zoomOut(container);\n    }\n  };\n\n  zoomIn = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.zoomIn(container);\n    }\n  };\n\n  checkIsMermaid = () => {\n    const { enableMermaid, language } = this.getProps();\n    return enableMermaid && language?.toLowerCase() === 'mermaid';\n  };\n\n  download = () => {\n    const container = this._adapter.getContainer();\n    if (container && this.mermaidService) {\n      this.mermaidService.download(container);\n    }\n  };\n\n  handleCopySuccess = () => {\n    this.setState({ copied: true });\n    setTimeout(() => {\n      this.setState({ copied: false });\n    }, 1500);\n  };\n\n  copyCodeInternal() {\n    const { code } = this.getProps();\n    if (navigator.clipboard) {\n      navigator.clipboard.writeText(code).then(() => {\n        this.handleCopySuccess();\n      });\n    } else {\n      const textarea = document.createElement('textarea');\n      textarea.style.position = 'fixed';\n      textarea.style.top = '-9999px';\n      textarea.style.left = '-9999px';\n      textarea.style.zIndex = '-1';\n      textarea.value = code;\n      document.body.appendChild(textarea);\n      textarea.select();\n      document.execCommand('copy');\n      document.body.removeChild(textarea);\n      this.handleCopySuccess();\n    }\n  }\n\n  updateHighlightedCode = () => {\n    const { code, language } = this.getProps();\n    let highlightedCode = '';\n    try {\n      const typeIndex = code.indexOf(`<span class=\"mc-typewriter`);\n\n      if (language && hljs.getLanguage(language)) {\n        if (typeIndex !== -1) {\n          highlightedCode =\n            hljs.highlight(code.slice(0, typeIndex), {\n              language,\n            }).value + code.slice(typeIndex);\n        } else {\n          highlightedCode = hljs.highlight(code, {\n            language,\n          }).value;\n        }\n      } else {\n        if (typeof hljs.highlightAuto !== 'undefined') {\n          if (typeIndex !== -1) {\n            highlightedCode =\n              hljs.highlightAuto(code.slice(0, typeIndex)).value +\n              code.slice(typeIndex);\n          } else {\n            highlightedCode = hljs.highlightAuto(code).value;\n          }\n        } else {\n          highlightedCode = this.mdCardService.filterHtml(code);\n        }\n      }\n    } catch (_) {\n      highlightedCode = code;\n    }\n    this._adapter.highlightCodeChange(highlightedCode, language);\n  };\n\n  renderMermaid = async () => {\n    const {\n      code,\n      theme,\n      mermaidConfig,\n    } = this.getProps();\n    const { mermaidContentRef} = this.getStates();\n    const isMermaid = this.checkIsMermaid();\n    if (!isMermaid || !code || !mermaidContentRef) {\n      return;\n    }\n\n    if (!this.mermaidService) {\n      try {\n        this.mermaidService = new MermaidService();\n        const config: MermaidConfig = {\n          theme: theme === 'dark' ? 'dark' : 'default',\n          ...mermaidConfig,\n        };\n        this.mermaidService.setConfig(config);\n      } catch (error) {\n        console.error('Failed to load MermaidService:', error);\n        return;\n      }\n    }\n    this.nextTick(async () => {\n      const container = mermaidContentRef.nativeElement;\n      if (container) {\n        // 移除打字效果相关的span标签\n        const cleanCode = code.replace(\n          /<span[^>]*\\bclass\\s*=\\s*['\"]mc-typewriter[^>]*>([\\s\\S]*?)<\\/span>/g,\n          `$1`\n        );\n        await this.mermaidService?.renderToContainer(\n          container,\n          cleanCode,\n          theme\n        );\n      }\n    });\n  };\n}\n"]}