@covalent/flavored-markdown 9.1.3 → 10.0.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.
@@ -1,598 +0,0 @@
1
- import { Component, Directive, Input, Renderer2, ChangeDetectorRef, EventEmitter, Output, ViewContainerRef, ComponentFactoryResolver, Injector, ViewChild, ChangeDetectionStrategy, ElementRef, HostBinding, } from '@angular/core';
2
- import { MatCheckbox } from '@angular/material/checkbox';
3
- import { MatSort } from '@angular/material/sort';
4
- import { MatTableDataSource } from '@angular/material/table';
5
- import { Subject } from 'rxjs';
6
- import { takeUntil } from 'rxjs/operators';
7
- import { TdFlavoredListComponent, } from './cfm-list/cfm-list.component';
8
- import { TdHighlightComponent, } from '@covalent/highlight';
9
- import { TdMarkdownComponent, scrollToAnchor } from '@covalent/markdown';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@angular/common";
12
- import * as i2 from "@covalent/markdown";
13
- import * as i3 from "@angular/material/table";
14
- import * as i4 from "@angular/material/sort";
15
- import * as i5 from "@angular/material/button";
16
- const _c0 = (a0, a1) => ({ "align-right": a0, "align-center": a1 });
17
- function TdFlavoredMarkdownTableComponent_ng_template_1_mat_header_cell_1_Template(rf, ctx) { if (rf & 1) {
18
- i0.ɵɵelementStart(0, "mat-header-cell", 7);
19
- i0.ɵɵtext(1);
20
- i0.ɵɵelementEnd();
21
- } if (rf & 2) {
22
- const column_r1 = i0.ɵɵnextContext().$implicit;
23
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c0, column_r1.numeric, column_r1.centered));
24
- i0.ɵɵadvance();
25
- i0.ɵɵtextInterpolate(column_r1.label);
26
- } }
27
- function TdFlavoredMarkdownTableComponent_ng_template_1_mat_cell_2_Template(rf, ctx) { if (rf & 1) {
28
- i0.ɵɵelementStart(0, "mat-cell", 8)(1, "td-markdown");
29
- i0.ɵɵtext(2);
30
- i0.ɵɵelementEnd()();
31
- } if (rf & 2) {
32
- const row_r2 = ctx.$implicit;
33
- const column_r1 = i0.ɵɵnextContext().$implicit;
34
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c0, column_r1.numeric, column_r1.centered));
35
- i0.ɵɵadvance(2);
36
- i0.ɵɵtextInterpolate(row_r2[column_r1.name]);
37
- } }
38
- function TdFlavoredMarkdownTableComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
39
- i0.ɵɵelementContainerStart(0, 4);
40
- i0.ɵɵtemplate(1, TdFlavoredMarkdownTableComponent_ng_template_1_mat_header_cell_1_Template, 2, 5, "mat-header-cell", 5)(2, TdFlavoredMarkdownTableComponent_ng_template_1_mat_cell_2_Template, 3, 5, "mat-cell", 6);
41
- i0.ɵɵelementContainerEnd();
42
- } if (rf & 2) {
43
- const column_r1 = ctx.$implicit;
44
- i0.ɵɵproperty("matColumnDef", column_r1.name);
45
- } }
46
- function TdFlavoredMarkdownTableComponent_mat_header_row_2_Template(rf, ctx) { if (rf & 1) {
47
- i0.ɵɵelement(0, "mat-header-row");
48
- } }
49
- function TdFlavoredMarkdownTableComponent_mat_row_3_Template(rf, ctx) { if (rf & 1) {
50
- i0.ɵɵelement(0, "mat-row");
51
- } }
52
- const _c1 = ["*"];
53
- export class TdFlavoredMarkdownTableComponent {
54
- columnDefs = [];
55
- data;
56
- sort;
57
- displayedColumns;
58
- dataSource;
59
- ngOnInit() {
60
- // Check if the first column is empty
61
- const isFirstColumnEmpty = this.columnDefs.length > 0 &&
62
- this.columnDefs[0].label.trim() === '' && // Check if the header cell is empty
63
- this.data.every((row) => !row[this.columnDefs[0].name]); // Check if all cells in the first column are empty
64
- // If the first column is empty, remove it
65
- if (isFirstColumnEmpty) {
66
- this.columnDefs.shift(); // Remove the first column definition
67
- }
68
- this.displayedColumns = this.columnDefs.map((c) => c.name);
69
- this.dataSource = new MatTableDataSource(this.data);
70
- }
71
- ngAfterViewInit() {
72
- this.dataSource.sort = this.sort;
73
- }
74
- static ɵfac = function TdFlavoredMarkdownTableComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFlavoredMarkdownTableComponent)(); };
75
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TdFlavoredMarkdownTableComponent, selectors: [["ng-component"]], viewQuery: function TdFlavoredMarkdownTableComponent_Query(rf, ctx) { if (rf & 1) {
76
- i0.ɵɵviewQuery(MatSort, 5);
77
- } if (rf & 2) {
78
- let _t;
79
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.sort = _t.first);
80
- } }, inputs: { columnDefs: "columnDefs", data: "data" }, decls: 4, vars: 4, consts: [["matSort", "", 3, "dataSource"], ["ngFor", "", 3, "ngForOf"], [4, "matHeaderRowDef"], [4, "matRowDef", "matRowDefColumns"], [3, "matColumnDef"], ["mat-sort-header", "", 3, "ngClass", 4, "matHeaderCellDef"], [3, "ngClass", 4, "matCellDef"], ["mat-sort-header", "", 3, "ngClass"], [3, "ngClass"]], template: function TdFlavoredMarkdownTableComponent_Template(rf, ctx) { if (rf & 1) {
81
- i0.ɵɵelementStart(0, "mat-table", 0);
82
- i0.ɵɵtemplate(1, TdFlavoredMarkdownTableComponent_ng_template_1_Template, 3, 1, "ng-template", 1)(2, TdFlavoredMarkdownTableComponent_mat_header_row_2_Template, 1, 0, "mat-header-row", 2)(3, TdFlavoredMarkdownTableComponent_mat_row_3_Template, 1, 0, "mat-row", 3);
83
- i0.ɵɵelementEnd();
84
- } if (rf & 2) {
85
- i0.ɵɵproperty("dataSource", ctx.dataSource);
86
- i0.ɵɵadvance();
87
- i0.ɵɵproperty("ngForOf", ctx.columnDefs);
88
- i0.ɵɵadvance();
89
- i0.ɵɵproperty("matHeaderRowDef", ctx.displayedColumns);
90
- i0.ɵɵadvance();
91
- i0.ɵɵproperty("matRowDefColumns", ctx.displayedColumns);
92
- } }, dependencies: [i1.NgClass, i1.NgForOf, i2.TdMarkdownComponent, i3.MatTable, i3.MatHeaderCellDef, i3.MatHeaderRowDef, i3.MatColumnDef, i3.MatCellDef, i3.MatRowDef, i3.MatHeaderCell, i3.MatCell, i3.MatHeaderRow, i3.MatRow, i4.MatSort, i4.MatSortHeader], encapsulation: 2 });
93
- }
94
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdFlavoredMarkdownTableComponent, [{
95
- type: Component,
96
- args: [{
97
- template: `
98
- <mat-table [dataSource]="dataSource" matSort>
99
- <!-- Column Definition -->
100
- <ng-template ngFor let-column [ngForOf]="columnDefs">
101
- <ng-container [matColumnDef]="column.name">
102
- <mat-header-cell
103
- [ngClass]="{
104
- 'align-right': column.numeric,
105
- 'align-center': column.centered
106
- }"
107
- *matHeaderCellDef
108
- mat-sort-header
109
- >{{ column.label }}</mat-header-cell
110
- >
111
- <mat-cell
112
- *matCellDef="let row"
113
- [ngClass]="{
114
- 'align-right': column.numeric,
115
- 'align-center': column.centered
116
- }"
117
- ><td-markdown>{{ row[column.name] }}</td-markdown></mat-cell
118
- >
119
- </ng-container>
120
- </ng-template>
121
- <!-- Header and Row Declarations -->
122
- <mat-header-row *matHeaderRowDef="displayedColumns"></mat-header-row>
123
- <mat-row *matRowDef="let row; columns: displayedColumns"></mat-row>
124
- </mat-table>
125
- `,
126
- }]
127
- }], null, { columnDefs: [{
128
- type: Input
129
- }], data: [{
130
- type: Input
131
- }], sort: [{
132
- type: ViewChild,
133
- args: [MatSort]
134
- }] }); })();
135
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TdFlavoredMarkdownTableComponent, { className: "TdFlavoredMarkdownTableComponent", filePath: "lib/flavored-markdown.component.ts", lineNumber: 87 }); })();
136
- export class TdFlavoredMarkdownButtonComponent {
137
- display = 'inline-block';
138
- text = '';
139
- data = '';
140
- clicked = new EventEmitter();
141
- emitClick() {
142
- this.clicked.emit({ text: this.text, data: this.data });
143
- }
144
- static ɵfac = function TdFlavoredMarkdownButtonComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFlavoredMarkdownButtonComponent)(); };
145
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TdFlavoredMarkdownButtonComponent, selectors: [["ng-component"]], hostVars: 2, hostBindings: function TdFlavoredMarkdownButtonComponent_HostBindings(rf, ctx) { if (rf & 2) {
146
- i0.ɵɵstyleProp("display", ctx.display);
147
- } }, inputs: { text: "text", data: "data" }, outputs: { clicked: "clicked" }, decls: 2, vars: 1, consts: [["mat-raised-button", "", 3, "click"]], template: function TdFlavoredMarkdownButtonComponent_Template(rf, ctx) { if (rf & 1) {
148
- i0.ɵɵelementStart(0, "button", 0);
149
- i0.ɵɵlistener("click", function TdFlavoredMarkdownButtonComponent_Template_button_click_0_listener() { return ctx.emitClick(); });
150
- i0.ɵɵtext(1);
151
- i0.ɵɵelementEnd();
152
- } if (rf & 2) {
153
- i0.ɵɵadvance();
154
- i0.ɵɵtextInterpolate1(" ", ctx.text, " ");
155
- } }, dependencies: [i5.MatButton], encapsulation: 2 });
156
- }
157
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdFlavoredMarkdownButtonComponent, [{
158
- type: Component,
159
- args: [{
160
- template: `
161
- <button mat-raised-button (click)="emitClick()">
162
- {{ text }}
163
- </button>
164
- `,
165
- }]
166
- }], null, { display: [{
167
- type: HostBinding,
168
- args: ['style.display']
169
- }], text: [{
170
- type: Input
171
- }], data: [{
172
- type: Input
173
- }], clicked: [{
174
- type: Output
175
- }] }); })();
176
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TdFlavoredMarkdownButtonComponent, { className: "TdFlavoredMarkdownButtonComponent", filePath: "lib/flavored-markdown.component.ts", lineNumber: 125 }); })();
177
- export class TdFlavoredMarkdownContainerDirective {
178
- viewContainerRef;
179
- _renderer;
180
- constructor(viewContainerRef, _renderer) {
181
- this.viewContainerRef = viewContainerRef;
182
- this._renderer = _renderer;
183
- }
184
- clear() {
185
- this._renderer.setProperty(this.viewContainerRef.element.nativeElement, 'innerHTML', '');
186
- this.viewContainerRef.clear();
187
- }
188
- static ɵfac = function TdFlavoredMarkdownContainerDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFlavoredMarkdownContainerDirective)(i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i0.Renderer2)); };
189
- static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TdFlavoredMarkdownContainerDirective, selectors: [["", "tdFlavoredMarkdownContainer", ""]] });
190
- }
191
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdFlavoredMarkdownContainerDirective, [{
192
- type: Directive,
193
- args: [{
194
- selector: '[tdFlavoredMarkdownContainer]',
195
- }]
196
- }], () => [{ type: i0.ViewContainerRef }, { type: i0.Renderer2 }], null); })();
197
- export class TdFlavoredMarkdownComponent {
198
- _componentFactoryResolver;
199
- _renderer;
200
- _changeDetectorRef;
201
- _injector;
202
- _elementRef;
203
- _content;
204
- _simpleLineBreaks = false;
205
- _hostedUrl;
206
- _anchor;
207
- _components = {};
208
- _viewInit = false;
209
- /**
210
- * content?: string
211
- *
212
- * Markdown format content to be parsed as material/covalent markup.
213
- *
214
- * e.g. README.md content.
215
- */
216
- set content(content) {
217
- this._content = content;
218
- }
219
- /**
220
- * simpleLineBreaks?: string
221
- *
222
- * Sets whether newline characters inside paragraphs and spans are parsed as <br/>.
223
- * Defaults to false.
224
- */
225
- set simpleLineBreaks(simpleLineBreaks) {
226
- this._simpleLineBreaks = simpleLineBreaks;
227
- }
228
- /**
229
- * hostedUrl?: string
230
- *
231
- * If markdown contains relative paths, this is required to generate correct urls
232
- *
233
- */
234
- set hostedUrl(hostedUrl) {
235
- this._hostedUrl = hostedUrl;
236
- }
237
- /**
238
- * anchor?: string
239
- *
240
- * Anchor to jump to
241
- *
242
- */
243
- set anchor(anchor) {
244
- this._anchor = anchor;
245
- }
246
- /**
247
- * copyCodeToClipboard?: boolean
248
- *
249
- * Display copy button on code snippets to copy code to clipboard.
250
- *
251
- */
252
- copyCodeToClipboard = false;
253
- /**
254
- * copyCodeTooltips?: ICopyCodeTooltips
255
- *
256
- * Tooltips for copy button to copy and upon copying.
257
- */
258
- copyCodeTooltips = {};
259
- /**
260
- * toggleRawCode?: boolean
261
- *
262
- * Display button to toggle raw code view
263
- */
264
- toggleRawCode = false;
265
- /**
266
- * rawToggleLabels?: IRawToggleLabels
267
- *
268
- * Labels for raw code toggle button
269
- */
270
- rawToggleLabels = {};
271
- /**
272
- * useCfmList?: boolean = false;
273
- * Use CFM list component instead of vanilla markdown list. Used in covalent documentation app.
274
- */
275
- useCfmList = false;
276
- /**
277
- * The file extensions to monitor for in anchor tags. If an anchor's `href` ends
278
- * with this extension, an event will be triggered insetad of performing the default action.
279
- * Example values: ".ipynb", ".zip", ".docx"
280
- */
281
- fileLinkExtensions;
282
- /**
283
- * Event emitted when an anchor tag with an `href` matching the specified
284
- * file link extension is clicked. The emitted value is the `href` of the clicked anchor.
285
- */
286
- fileLinkClicked = new EventEmitter();
287
- /**
288
- * contentReady?: function
289
- * Event emitted after the markdown content rendering is finished.
290
- */
291
- contentReady = new EventEmitter();
292
- /**
293
- * buttonClicked?: ITdFlavoredMarkdownButtonClickEvent
294
- * Event emitted when a button is clicked
295
- * Is an object containing text and data of button
296
- */
297
- buttonClicked = new EventEmitter();
298
- container;
299
- _destroy$ = new Subject();
300
- constructor(_componentFactoryResolver, _renderer, _changeDetectorRef, _injector, _elementRef) {
301
- this._componentFactoryResolver = _componentFactoryResolver;
302
- this._renderer = _renderer;
303
- this._changeDetectorRef = _changeDetectorRef;
304
- this._injector = _injector;
305
- this._elementRef = _elementRef;
306
- }
307
- ngOnChanges(changes) {
308
- // only anchor changed
309
- if (changes['anchor'] &&
310
- !changes['content'] &&
311
- !changes['simpleLineBreaks'] &&
312
- !changes['hostedUrl']) {
313
- scrollToAnchor(this._elementRef.nativeElement, this._anchor, false);
314
- }
315
- else {
316
- this.refresh();
317
- }
318
- }
319
- ngAfterViewInit() {
320
- if (!this._content) {
321
- this._loadContent(this.container.viewContainerRef.element.nativeElement
322
- .textContent ?? '');
323
- Promise.resolve().then(() => {
324
- this._viewInit = true;
325
- this._changeDetectorRef.markForCheck();
326
- });
327
- }
328
- }
329
- ngOnDestroy() {
330
- this._destroy$.next();
331
- }
332
- refresh() {
333
- if (this._content) {
334
- this._loadContent(this._content);
335
- }
336
- else if (this._viewInit) {
337
- this._loadContent(this.container.viewContainerRef.element.nativeElement
338
- .textContent ?? '');
339
- }
340
- this._changeDetectorRef.markForCheck();
341
- }
342
- _loadContent(markdown) {
343
- if (markdown && markdown.trim().length > 0) {
344
- this.container.clear();
345
- markdown = markdown
346
- .replace(/^(\s|\t)*\n+/g, '')
347
- .replace(/(\s|\t)*\n+(\s|\t)*$/g, '');
348
- // Split markdown by line characters
349
- let lines = markdown.split('\n');
350
- // check how much indentation is used by the first actual markdown line
351
- const firstLineWhitespaceMatch = lines[0].match(/^(\s|\t)*/);
352
- const firstLineWhitespace = firstLineWhitespaceMatch
353
- ? firstLineWhitespaceMatch[0]
354
- : null;
355
- // Remove all indentation spaces so markdown can be parsed correctly
356
- // Remove all \r characters
357
- const startingWhitespaceRegex = new RegExp('^' + firstLineWhitespace);
358
- lines = lines.map(function (line) {
359
- return line.replace(startingWhitespaceRegex, '').replace('\r', '');
360
- });
361
- // Join lines again with line characters
362
- markdown = [...lines, '', ''].join('\n');
363
- markdown = this._replaceCodeBlocks(markdown);
364
- markdown = this._replaceCheckbox(markdown);
365
- markdown = this._replaceTables(markdown);
366
- markdown = this._replaceButtons(markdown);
367
- if (this.useCfmList) {
368
- markdown = this._replaceLists(markdown);
369
- }
370
- const keys = Object.keys(this._components);
371
- // need to sort the placeholders in order of encounter in markdown content
372
- keys.sort((compA, compB) => {
373
- return markdown.indexOf(compA) > markdown.indexOf(compB) ? 1 : -1;
374
- });
375
- this._render(markdown, keys[0], keys);
376
- // TODO: timeout required since resizing of html elements occurs which causes a change in the scroll position
377
- setTimeout(() => scrollToAnchor(this._elementRef.nativeElement, this._anchor, false), 250);
378
- this.contentReady.emit();
379
- Promise.resolve().then(() => {
380
- this._changeDetectorRef.markForCheck();
381
- });
382
- }
383
- }
384
- _render(markdown, key, keys) {
385
- if (!markdown) {
386
- return;
387
- }
388
- if (key && markdown.indexOf(key) > -1) {
389
- const markdownParts = markdown.split(key);
390
- keys.shift();
391
- this._render(markdownParts[0], '', []);
392
- this.container.viewContainerRef.insert(this._components[key].hostView, this.container.viewContainerRef.length);
393
- delete this._components[key];
394
- this._render(markdownParts[1], keys[0], keys);
395
- }
396
- else {
397
- const contentRef = this._componentFactoryResolver
398
- .resolveComponentFactory(TdMarkdownComponent)
399
- .create(this._injector);
400
- contentRef.instance.content = markdown;
401
- contentRef.instance.hostedUrl = this._hostedUrl;
402
- contentRef.instance.simpleLineBreaks = this._simpleLineBreaks;
403
- contentRef.instance.fileLinkExtensions = this.fileLinkExtensions;
404
- contentRef.instance.fileLinkClicked
405
- .pipe(takeUntil(this._destroy$))
406
- .subscribe((url) => {
407
- this.fileLinkClicked.emit(url);
408
- });
409
- contentRef.instance.refresh();
410
- this.container.viewContainerRef.insert(contentRef.hostView, this.container.viewContainerRef.length);
411
- }
412
- }
413
- _replaceComponent(markdown, type, regExp, replacerFunc) {
414
- let componentIndex = 0;
415
- return markdown.replace(regExp, (...args) => {
416
- const componentFactory = this._componentFactoryResolver.resolveComponentFactory(type);
417
- const componentRef = componentFactory.create(this._injector);
418
- replacerFunc(componentRef, ...args);
419
- const key = '[' +
420
- componentFactory.selector +
421
- '-placeholder-' +
422
- componentIndex++ +
423
- ']';
424
- this._components[key] = componentRef;
425
- return key;
426
- });
427
- }
428
- _replaceCheckbox(markdown) {
429
- const checkboxRegExp = /(?:^|\n)- \[(x| )\](.*)/gi;
430
- return this._replaceComponent(markdown, MatCheckbox, checkboxRegExp, (componentRef, match, checked, label) => {
431
- componentRef.instance.checked = !!checked.trim();
432
- componentRef.instance.ariaLabel = label;
433
- componentRef.instance.labelPosition = 'after';
434
- this._renderer.setProperty((componentRef.instance._elementRef.nativeElement).getElementsByTagName('label')[0], 'innerHTML', label);
435
- });
436
- }
437
- _replaceButtons(markdown) {
438
- const buttonRegExp = /\[([^[]+)\](\(#data=(.*?)\))/i;
439
- const globalButtonRegExp = new RegExp(buttonRegExp.source, buttonRegExp.flags + 'g');
440
- return this._replaceComponent(markdown, TdFlavoredMarkdownButtonComponent, globalButtonRegExp, (componentRef, match) => {
441
- const matches = buttonRegExp.exec(match);
442
- if (!matches) {
443
- return;
444
- }
445
- const text = matches[1];
446
- const data = matches[3];
447
- componentRef.instance.text = text;
448
- componentRef.instance.data = data;
449
- componentRef.instance.clicked
450
- .pipe(takeUntil(this._destroy$))
451
- .subscribe((clickEvent) => this.buttonClicked.emit(clickEvent));
452
- });
453
- }
454
- _replaceCodeBlocks(markdown) {
455
- const codeBlockRegExp = /(?:^|\n)```(.*)\n([\s\S]*?)\n```/g;
456
- return this._replaceComponent(markdown, TdHighlightComponent, codeBlockRegExp, (componentRef, match, language, codeblock) => {
457
- if (language) {
458
- componentRef.instance.codeLang = language;
459
- }
460
- componentRef.instance.copyCodeToClipboard = this.copyCodeToClipboard;
461
- componentRef.instance.copyCodeTooltips = this.copyCodeTooltips;
462
- componentRef.instance.toggleRawButton = this.toggleRawCode;
463
- componentRef.instance.rawToggleLabels = this.rawToggleLabels;
464
- componentRef.instance.content = codeblock;
465
- });
466
- }
467
- _replaceTables(markdown) {
468
- const tableRgx = /^ {0,3}\|?.+\|.+\n[ \t]{0,3}\|?[ \t]*:?[ \t]*(?:-|=){2,}[ \t]*:?[ \t]*\|[ \t]*:?[ \t]*(?:-|=){2,}[\s\S]+?(?:\n\n|~0)/gm;
469
- return this._replaceComponent(markdown, TdFlavoredMarkdownTableComponent, tableRgx, (componentRef, match) => {
470
- const dataTableLines = match
471
- .replace(/(\s|\t)*\n+(\s|\t)*$/g, '')
472
- .split('\n');
473
- const columns = dataTableLines[0]
474
- .split('|')
475
- .filter((col) => {
476
- return col;
477
- })
478
- .map((s) => {
479
- return s.trim();
480
- });
481
- const alignment = dataTableLines[1]
482
- .split('|')
483
- .filter((v) => {
484
- return v;
485
- })
486
- .map((s) => {
487
- return s.trim();
488
- });
489
- const data = [];
490
- for (let i = 2; i < dataTableLines.length; i++) {
491
- const rowSplit = dataTableLines[i]
492
- .split('|')
493
- .filter((cell) => {
494
- return cell;
495
- })
496
- .map((s) => {
497
- return s.trim();
498
- });
499
- const row = {};
500
- columns.forEach((col, index) => {
501
- const rowSplitCell = rowSplit[index];
502
- if (rowSplitCell) {
503
- row[col.toLowerCase().trim()] = rowSplitCell.replace(/`(.*)`/, (m, value) => {
504
- return value;
505
- });
506
- }
507
- });
508
- data.push(row);
509
- }
510
- componentRef.instance.columnDefs = columns.map((col, index) => {
511
- return {
512
- label: col,
513
- name: col ? col.toLowerCase().trim() : `column ${index}`,
514
- numeric: /^--*[ \t]*:[ \t]*$/.test(alignment[index]),
515
- centered: /^:--*[ \t]*:[ \t]*$/.test(alignment[index]),
516
- };
517
- });
518
- componentRef.instance.data = data;
519
- });
520
- }
521
- _replaceLists(markdown) {
522
- const listRegExp = /(?:^|\n)(( *(\+|\*|-))[ |\t](.*)\n)+/g;
523
- const listCharRegExp = new RegExp(/^(\+|\*|-)/);
524
- return this._replaceComponent(markdown, TdFlavoredListComponent, listRegExp, (componentRef, match) => {
525
- const start = /(\+|\*|-)/.exec(match);
526
- const matchIndex = start !== null ? start.index : 1;
527
- const lineTexts = match.split(new RegExp('\\n {' + (matchIndex - 1).toString() + '}(\\+|\\*|\\-)[ |\\t]'));
528
- lineTexts.shift();
529
- const lines = [];
530
- lineTexts.forEach((text) => {
531
- const sublineTexts = text.split(/\n *(\+|\*|-) /);
532
- const lineText = sublineTexts.shift() ?? '';
533
- if (listCharRegExp.test(lineText)) {
534
- return;
535
- }
536
- lines.push({
537
- line: lineText,
538
- sublines: sublineTexts
539
- .map((subline) => {
540
- if (listCharRegExp.test(subline)) {
541
- return '';
542
- }
543
- return subline.trim();
544
- })
545
- .filter((line) => !!line),
546
- });
547
- });
548
- componentRef.instance.lines = lines;
549
- });
550
- }
551
- static ɵfac = function TdFlavoredMarkdownComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFlavoredMarkdownComponent)(i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.ElementRef)); };
552
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TdFlavoredMarkdownComponent, selectors: [["td-flavored-markdown"]], viewQuery: function TdFlavoredMarkdownComponent_Query(rf, ctx) { if (rf & 1) {
553
- i0.ɵɵviewQuery(TdFlavoredMarkdownContainerDirective, 7);
554
- } if (rf & 2) {
555
- let _t;
556
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.container = _t.first);
557
- } }, inputs: { content: "content", simpleLineBreaks: "simpleLineBreaks", hostedUrl: "hostedUrl", anchor: "anchor", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", toggleRawCode: "toggleRawCode", rawToggleLabels: "rawToggleLabels", useCfmList: "useCfmList", fileLinkExtensions: "fileLinkExtensions" }, outputs: { fileLinkClicked: "fileLinkClicked", contentReady: "contentReady", buttonClicked: "buttonClicked" }, features: [i0.ɵɵNgOnChangesFeature], ngContentSelectors: _c1, decls: 2, vars: 0, consts: [["tdFlavoredMarkdownContainer", ""]], template: function TdFlavoredMarkdownComponent_Template(rf, ctx) { if (rf & 1) {
558
- i0.ɵɵprojectionDef();
559
- i0.ɵɵelementStart(0, "div", 0);
560
- i0.ɵɵprojection(1);
561
- i0.ɵɵelementEnd();
562
- } }, dependencies: [TdFlavoredMarkdownContainerDirective], styles: ["[_nghost-%COMP%] td-markdown:first-of-type>div:first-of-type>h1:first-of-type, [_nghost-%COMP%] td-markdown:first-of-type>div:first-of-type>h2:first-of-type{margin-top:0}[_nghost-%COMP%] mat-checkbox{display:block}[_nghost-%COMP%] td-highlight, [_nghost-%COMP%] mat-table, [_nghost-%COMP%] mat-checkbox:last-of-type{margin-bottom:16px}[_nghost-%COMP%] :not(pre)>code{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;padding-left:2px;padding-right:2px}[_nghost-%COMP%] td-highlight{display:flex;flex-direction:row;justify-content:space-between}[_nghost-%COMP%] mat-table .align-right{justify-content:flex-end}[_nghost-%COMP%] mat-table .align-center{justify-content:center}"], changeDetection: 0 });
563
- }
564
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdFlavoredMarkdownComponent, [{
565
- type: Component,
566
- args: [{ selector: 'td-flavored-markdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div tdFlavoredMarkdownContainer>\n <ng-content></ng-content>\n</div>\n", styles: [":host ::ng-deep td-markdown:first-of-type>div:first-of-type>h1:first-of-type,:host ::ng-deep td-markdown:first-of-type>div:first-of-type>h2:first-of-type{margin-top:0}:host ::ng-deep mat-checkbox{display:block}:host ::ng-deep td-highlight,:host ::ng-deep mat-table,:host ::ng-deep mat-checkbox:last-of-type{margin-bottom:16px}:host ::ng-deep :not(pre)>code{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;padding-left:2px;padding-right:2px}:host ::ng-deep td-highlight{display:flex;flex-direction:row;justify-content:space-between}:host ::ng-deep mat-table .align-right{justify-content:flex-end}:host ::ng-deep mat-table .align-center{justify-content:center}\n"] }]
567
- }], () => [{ type: i0.ComponentFactoryResolver }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i0.ElementRef }], { content: [{
568
- type: Input
569
- }], simpleLineBreaks: [{
570
- type: Input
571
- }], hostedUrl: [{
572
- type: Input
573
- }], anchor: [{
574
- type: Input
575
- }], copyCodeToClipboard: [{
576
- type: Input
577
- }], copyCodeTooltips: [{
578
- type: Input
579
- }], toggleRawCode: [{
580
- type: Input
581
- }], rawToggleLabels: [{
582
- type: Input
583
- }], useCfmList: [{
584
- type: Input
585
- }], fileLinkExtensions: [{
586
- type: Input
587
- }], fileLinkClicked: [{
588
- type: Output
589
- }], contentReady: [{
590
- type: Output
591
- }], buttonClicked: [{
592
- type: Output
593
- }], container: [{
594
- type: ViewChild,
595
- args: [TdFlavoredMarkdownContainerDirective, { static: true }]
596
- }] }); })();
597
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TdFlavoredMarkdownComponent, { className: "TdFlavoredMarkdownComponent", filePath: "lib/flavored-markdown.component.ts", lineNumber: 167 }); })();
598
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flavored-markdown.component.js","sourceRoot":"","sources":["../../../../../libs/markdown-flavored/src/lib/flavored-markdown.component.ts","../../../../../libs/markdown-flavored/src/lib/flavored-markdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Directive,\n  AfterViewInit,\n  Input,\n  Renderer2,\n  Type,\n  ComponentFactory,\n  ChangeDetectorRef,\n  EventEmitter,\n  Output,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  Injector,\n  ComponentRef,\n  ViewChild,\n  ChangeDetectionStrategy,\n  OnChanges,\n  SimpleChanges,\n  ElementRef,\n  HostBinding,\n  OnInit,\n  OnDestroy,\n} from '@angular/core';\n\nimport { MatCheckbox } from '@angular/material/checkbox';\nimport { MatSort } from '@angular/material/sort';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport {\n  TdFlavoredListComponent,\n  IFlavoredListItem,\n} from './cfm-list/cfm-list.component';\nimport {\n  TdHighlightComponent,\n  ICopyCodeTooltips,\n  IRawToggleLabels,\n} from '@covalent/highlight';\n\nimport { TdMarkdownComponent, scrollToAnchor } from '@covalent/markdown';\n\nexport interface ITdFlavoredMarkdownButtonClickEvent {\n  text: string;\n  data: string;\n}\n\nexport interface ITdFlavoredMarkDownTableColumn {\n  label: string;\n  name: string;\n  numeric: boolean;\n  centered: boolean;\n}\n\n@Component({\n  template: `\n    <mat-table [dataSource]=\"dataSource\" matSort>\n      <!-- Column Definition -->\n      <ng-template ngFor let-column [ngForOf]=\"columnDefs\">\n        <ng-container [matColumnDef]=\"column.name\">\n          <mat-header-cell\n            [ngClass]=\"{\n              'align-right': column.numeric,\n              'align-center': column.centered\n            }\"\n            *matHeaderCellDef\n            mat-sort-header\n            >{{ column.label }}</mat-header-cell\n          >\n          <mat-cell\n            *matCellDef=\"let row\"\n            [ngClass]=\"{\n              'align-right': column.numeric,\n              'align-center': column.centered\n            }\"\n            ><td-markdown>{{ row[column.name] }}</td-markdown></mat-cell\n          >\n        </ng-container>\n      </ng-template>\n      <!-- Header and Row Declarations -->\n      <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n      <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n  `,\n})\nexport class TdFlavoredMarkdownTableComponent implements OnInit, AfterViewInit {\n  @Input() columnDefs: ITdFlavoredMarkDownTableColumn[] = [];\n  @Input() data!: unknown[];\n  @ViewChild(MatSort) sort!: MatSort;\n\n  displayedColumns!: string[];\n  dataSource!: MatTableDataSource<unknown>;\n\n  ngOnInit(): void {\n    // Check if the first column is empty\n    const isFirstColumnEmpty =\n      this.columnDefs.length > 0 &&\n      this.columnDefs[0].label.trim() === '' && // Check if the header cell is empty\n      this.data.every((row: any) => !row[this.columnDefs[0].name]); // Check if all cells in the first column are empty\n\n    // If the first column is empty, remove it\n    if (isFirstColumnEmpty) {\n      this.columnDefs.shift(); // Remove the first column definition\n    }\n\n    this.displayedColumns = this.columnDefs.map(\n      (c: ITdFlavoredMarkDownTableColumn) => c.name\n    );\n    this.dataSource = new MatTableDataSource(this.data);\n  }\n\n  ngAfterViewInit(): void {\n    this.dataSource.sort = this.sort;\n  }\n}\n\n@Component({\n  template: `\n    <button mat-raised-button (click)=\"emitClick()\">\n      {{ text }}\n    </button>\n  `,\n})\nexport class TdFlavoredMarkdownButtonComponent {\n  @HostBinding('style.display') display = 'inline-block';\n  @Input() text = '';\n  @Input() data = '';\n  @Output()\n  clicked: EventEmitter<ITdFlavoredMarkdownButtonClickEvent> =\n    new EventEmitter<ITdFlavoredMarkdownButtonClickEvent>();\n  emitClick(): void {\n    this.clicked.emit({ text: this.text, data: this.data });\n  }\n}\n\n@Directive({\n  selector: '[tdFlavoredMarkdownContainer]',\n})\nexport class TdFlavoredMarkdownContainerDirective {\n  constructor(\n    public viewContainerRef: ViewContainerRef,\n    private _renderer: Renderer2\n  ) {}\n\n  clear(): void {\n    this._renderer.setProperty(\n      this.viewContainerRef.element.nativeElement,\n      'innerHTML',\n      ''\n    );\n    this.viewContainerRef.clear();\n  }\n}\n\nexport type IReplacerFunc<T> = (\n  componentRef: ComponentRef<T>,\n  ...args: any[]\n) => void;\n\n@Component({\n  selector: 'td-flavored-markdown',\n  styleUrls: ['./flavored-markdown.component.scss'],\n  templateUrl: './flavored-markdown.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdFlavoredMarkdownComponent\n  implements AfterViewInit, OnChanges, OnDestroy\n{\n  private _content!: string;\n  private _simpleLineBreaks = false;\n  private _hostedUrl!: string;\n  private _anchor!: string;\n\n  private _components: { [key: string]: ComponentRef<unknown> } = {};\n  private _viewInit = false;\n  /**\n   * content?: string\n   *\n   * Markdown format content to be parsed as material/covalent markup.\n   *\n   * e.g. README.md content.\n   */\n  @Input()\n  set content(content: string) {\n    this._content = content;\n  }\n\n  /**\n   * simpleLineBreaks?: string\n   *\n   * Sets whether newline characters inside paragraphs and spans are parsed as <br/>.\n   * Defaults to false.\n   */\n  @Input()\n  set simpleLineBreaks(simpleLineBreaks: boolean) {\n    this._simpleLineBreaks = simpleLineBreaks;\n  }\n\n  /**\n   * hostedUrl?: string\n   *\n   * If markdown contains relative paths, this is required to generate correct urls\n   *\n   */\n  @Input()\n  set hostedUrl(hostedUrl: string) {\n    this._hostedUrl = hostedUrl;\n  }\n\n  /**\n   * anchor?: string\n   *\n   * Anchor to jump to\n   *\n   */\n  @Input()\n  set anchor(anchor: string) {\n    this._anchor = anchor;\n  }\n\n  /**\n   * copyCodeToClipboard?: boolean\n   *\n   * Display copy button on code snippets to copy code to clipboard.\n   *\n   */\n  @Input() copyCodeToClipboard? = false;\n\n  /**\n   * copyCodeTooltips?: ICopyCodeTooltips\n   *\n   * Tooltips for copy button to copy and upon copying.\n   */\n  @Input() copyCodeTooltips?: ICopyCodeTooltips = {};\n\n  /**\n   * toggleRawCode?: boolean\n   *\n   * Display button to toggle raw code view\n   */\n  @Input() toggleRawCode = false;\n\n  /**\n   * rawToggleLabels?: IRawToggleLabels\n   *\n   * Labels for raw code toggle button\n   */\n  @Input() rawToggleLabels?: IRawToggleLabels = {};\n\n  /**\n   * useCfmList?: boolean = false;\n   * Use CFM list component instead of vanilla markdown list. Used in covalent documentation app.\n   */\n  @Input() useCfmList? = false;\n\n  /**\n   * The file extensions to monitor for in anchor tags. If an anchor's `href` ends\n   * with this extension, an event will be triggered insetad of performing the default action.\n   * Example values: \".ipynb\", \".zip\", \".docx\"\n   */\n  @Input()\n  fileLinkExtensions?: string[];\n\n  /**\n   * Event emitted when an anchor tag with an `href` matching the specified\n   * file link extension is clicked. The emitted value is the `href` of the clicked anchor.\n   */\n  @Output() fileLinkClicked = new EventEmitter<URL>();\n\n  /**\n   * contentReady?: function\n   * Event emitted after the markdown content rendering is finished.\n   */\n  @Output() contentReady: EventEmitter<undefined> =\n    new EventEmitter<undefined>();\n\n  /**\n   * buttonClicked?: ITdFlavoredMarkdownButtonClickEvent\n   * Event emitted when a button is clicked\n   * Is an object containing text and data of button\n   */\n  @Output()\n  buttonClicked: EventEmitter<ITdFlavoredMarkdownButtonClickEvent> =\n    new EventEmitter<ITdFlavoredMarkdownButtonClickEvent>();\n\n  @ViewChild(TdFlavoredMarkdownContainerDirective, { static: true })\n  container!: TdFlavoredMarkdownContainerDirective;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _renderer: Renderer2,\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _injector: Injector,\n    private _elementRef: ElementRef\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // only anchor changed\n    if (\n      changes['anchor'] &&\n      !changes['content'] &&\n      !changes['simpleLineBreaks'] &&\n      !changes['hostedUrl']\n    ) {\n      scrollToAnchor(this._elementRef.nativeElement, this._anchor, false);\n    } else {\n      this.refresh();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (!this._content) {\n      this._loadContent(\n        (<HTMLElement>this.container.viewContainerRef.element.nativeElement)\n          .textContent ?? ''\n      );\n      Promise.resolve().then(() => {\n        this._viewInit = true;\n        this._changeDetectorRef.markForCheck();\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  refresh(): void {\n    if (this._content) {\n      this._loadContent(this._content);\n    } else if (this._viewInit) {\n      this._loadContent(\n        (<HTMLElement>this.container.viewContainerRef.element.nativeElement)\n          .textContent ?? ''\n      );\n    }\n    this._changeDetectorRef.markForCheck();\n  }\n\n  private _loadContent(markdown: string): void {\n    if (markdown && markdown.trim().length > 0) {\n      this.container.clear();\n      markdown = markdown\n        .replace(/^(\\s|\\t)*\\n+/g, '')\n        .replace(/(\\s|\\t)*\\n+(\\s|\\t)*$/g, '');\n      // Split markdown by line characters\n      let lines: string[] = markdown.split('\\n');\n\n      // check how much indentation is used by the first actual markdown line\n      const firstLineWhitespaceMatch = lines[0].match(/^(\\s|\\t)*/);\n      const firstLineWhitespace = firstLineWhitespaceMatch\n        ? firstLineWhitespaceMatch[0]\n        : null;\n\n      // Remove all indentation spaces so markdown can be parsed correctly\n      // Remove all \\r characters\n      const startingWhitespaceRegex = new RegExp('^' + firstLineWhitespace);\n      lines = lines.map(function (line: string): string {\n        return line.replace(startingWhitespaceRegex, '').replace('\\r', '');\n      });\n\n      // Join lines again with line characters\n      markdown = [...lines, '', ''].join('\\n');\n      markdown = this._replaceCodeBlocks(markdown);\n      markdown = this._replaceCheckbox(markdown);\n      markdown = this._replaceTables(markdown);\n      markdown = this._replaceButtons(markdown);\n\n      if (this.useCfmList) {\n        markdown = this._replaceLists(markdown);\n      }\n\n      const keys: string[] = Object.keys(this._components);\n      // need to sort the placeholders in order of encounter in markdown content\n      keys.sort((compA: string, compB: string) => {\n        return markdown.indexOf(compA) > markdown.indexOf(compB) ? 1 : -1;\n      });\n      this._render(markdown, keys[0], keys);\n      // TODO: timeout required since resizing of html elements occurs which causes a change in the scroll position\n      setTimeout(\n        () =>\n          scrollToAnchor(this._elementRef.nativeElement, this._anchor, false),\n        250\n      );\n      this.contentReady.emit();\n      Promise.resolve().then(() => {\n        this._changeDetectorRef.markForCheck();\n      });\n    }\n  }\n\n  private _render(markdown: string, key: string, keys: string[]): void {\n    if (!markdown) {\n      return;\n    }\n    if (key && markdown.indexOf(key) > -1) {\n      const markdownParts: string[] = markdown.split(key);\n      keys.shift();\n      this._render(markdownParts[0], '', []);\n      this.container.viewContainerRef.insert(\n        this._components[key].hostView,\n        this.container.viewContainerRef.length\n      );\n      delete this._components[key];\n      this._render(markdownParts[1], keys[0], keys);\n    } else {\n      const contentRef: ComponentRef<TdMarkdownComponent> =\n        this._componentFactoryResolver\n          .resolveComponentFactory(TdMarkdownComponent)\n          .create(this._injector);\n      contentRef.instance.content = markdown;\n      contentRef.instance.hostedUrl = this._hostedUrl;\n      contentRef.instance.simpleLineBreaks = this._simpleLineBreaks;\n      contentRef.instance.fileLinkExtensions = this.fileLinkExtensions;\n      contentRef.instance.fileLinkClicked\n        .pipe(takeUntil(this._destroy$))\n        .subscribe((url: URL) => {\n          this.fileLinkClicked.emit(url);\n        });\n      contentRef.instance.refresh();\n      this.container.viewContainerRef.insert(\n        contentRef.hostView,\n        this.container.viewContainerRef.length\n      );\n    }\n  }\n\n  private _replaceComponent<T>(\n    markdown: string,\n    type: Type<T>,\n    regExp: RegExp,\n    replacerFunc: IReplacerFunc<T>\n  ): string {\n    let componentIndex = 0;\n    return markdown.replace(regExp, (...args: any[]) => {\n      const componentFactory: ComponentFactory<T> =\n        this._componentFactoryResolver.resolveComponentFactory(type);\n      const componentRef: ComponentRef<T> = componentFactory.create(\n        this._injector\n      );\n      replacerFunc(componentRef, ...args);\n      const key: string =\n        '[' +\n        componentFactory.selector +\n        '-placeholder-' +\n        componentIndex++ +\n        ']';\n      this._components[key] = componentRef;\n      return key;\n    });\n  }\n\n  private _replaceCheckbox(markdown: string): string {\n    const checkboxRegExp = /(?:^|\\n)- \\[(x| )\\](.*)/gi;\n    return this._replaceComponent(\n      markdown,\n      MatCheckbox,\n      checkboxRegExp,\n      (\n        componentRef: ComponentRef<MatCheckbox>,\n        match: string,\n        checked: string,\n        label: string\n      ) => {\n        componentRef.instance.checked = !!checked.trim();\n        componentRef.instance.ariaLabel = label;\n        componentRef.instance.labelPosition = 'after';\n        this._renderer.setProperty(\n          (<HTMLElement>(\n            componentRef.instance._elementRef.nativeElement\n          )).getElementsByTagName('label')[0],\n          'innerHTML',\n          label\n        );\n      }\n    );\n  }\n\n  private _replaceButtons(markdown: string): string {\n    const buttonRegExp = /\\[([^[]+)\\](\\(#data=(.*?)\\))/i;\n    const globalButtonRegExp = new RegExp(\n      buttonRegExp.source,\n      buttonRegExp.flags + 'g'\n    );\n    return this._replaceComponent(\n      markdown,\n      TdFlavoredMarkdownButtonComponent,\n      globalButtonRegExp,\n      (\n        componentRef: ComponentRef<TdFlavoredMarkdownButtonComponent>,\n        match: string\n      ) => {\n        const matches = buttonRegExp.exec(match);\n        if (!matches) {\n          return;\n        }\n        const text: string = matches[1];\n        const data: string = matches[3];\n        componentRef.instance.text = text;\n        componentRef.instance.data = data;\n        componentRef.instance.clicked\n          .pipe(takeUntil(this._destroy$))\n          .subscribe((clickEvent: ITdFlavoredMarkdownButtonClickEvent) =>\n            this.buttonClicked.emit(clickEvent)\n          );\n      }\n    );\n  }\n\n  private _replaceCodeBlocks(markdown: string): string {\n    const codeBlockRegExp = /(?:^|\\n)```(.*)\\n([\\s\\S]*?)\\n```/g;\n    return this._replaceComponent(\n      markdown,\n      TdHighlightComponent,\n      codeBlockRegExp,\n      (\n        componentRef: ComponentRef<TdHighlightComponent>,\n        match: string,\n        language: string,\n        codeblock: string\n      ) => {\n        if (language) {\n          componentRef.instance.codeLang = language;\n        }\n        componentRef.instance.copyCodeToClipboard = this.copyCodeToClipboard;\n        componentRef.instance.copyCodeTooltips = this.copyCodeTooltips;\n        componentRef.instance.toggleRawButton = this.toggleRawCode;\n        componentRef.instance.rawToggleLabels = this.rawToggleLabels;\n        componentRef.instance.content = codeblock;\n      }\n    );\n  }\n\n  private _replaceTables(markdown: string): string {\n    const tableRgx =\n      /^ {0,3}\\|?.+\\|.+\\n[ \\t]{0,3}\\|?[ \\t]*:?[ \\t]*(?:-|=){2,}[ \\t]*:?[ \\t]*\\|[ \\t]*:?[ \\t]*(?:-|=){2,}[\\s\\S]+?(?:\\n\\n|~0)/gm;\n    return this._replaceComponent(\n      markdown,\n      TdFlavoredMarkdownTableComponent,\n      tableRgx,\n      (\n        componentRef: ComponentRef<TdFlavoredMarkdownTableComponent>,\n        match: string\n      ) => {\n        const dataTableLines: string[] = match\n          .replace(/(\\s|\\t)*\\n+(\\s|\\t)*$/g, '')\n          .split('\\n');\n        const columns: string[] = dataTableLines[0]\n          .split('|')\n          .filter((col: string) => {\n            return col;\n          })\n          .map((s: string) => {\n            return s.trim();\n          });\n        const alignment: string[] = dataTableLines[1]\n          .split('|')\n          .filter((v: string) => {\n            return v;\n          })\n          .map((s: string) => {\n            return s.trim();\n          });\n\n        const data: any[] = [];\n        for (let i = 2; i < dataTableLines.length; i++) {\n          const rowSplit: string[] = dataTableLines[i]\n            .split('|')\n            .filter((cell: string) => {\n              return cell;\n            })\n            .map((s: string) => {\n              return s.trim();\n            });\n          const row: any = {};\n          columns.forEach((col: string, index: number) => {\n            const rowSplitCell: string = rowSplit[index];\n            if (rowSplitCell) {\n              row[col.toLowerCase().trim()] = rowSplitCell.replace(\n                /`(.*)`/,\n                (m: string, value: string) => {\n                  return value;\n                }\n              );\n            }\n          });\n          data.push(row);\n        }\n        componentRef.instance.columnDefs = columns.map(\n          (col: string, index: number) => {\n            return {\n              label: col,\n              name: col ? col.toLowerCase().trim() : `column ${index}`,\n              numeric: /^--*[ \\t]*:[ \\t]*$/.test(alignment[index]),\n              centered: /^:--*[ \\t]*:[ \\t]*$/.test(alignment[index]),\n            };\n          }\n        );\n        componentRef.instance.data = data;\n      }\n    );\n  }\n\n  private _replaceLists(markdown: string): string {\n    const listRegExp = /(?:^|\\n)(( *(\\+|\\*|-))[ |\\t](.*)\\n)+/g;\n    const listCharRegExp = new RegExp(/^(\\+|\\*|-)/);\n    return this._replaceComponent(\n      markdown,\n      TdFlavoredListComponent,\n      listRegExp,\n      (componentRef: ComponentRef<TdFlavoredListComponent>, match: string) => {\n        const start = /(\\+|\\*|-)/.exec(match);\n        const matchIndex = start !== null ? start.index : 1;\n\n        const lineTexts: string[] = match.split(\n          new RegExp(\n            '\\\\n {' + (matchIndex - 1).toString() + '}(\\\\+|\\\\*|\\\\-)[ |\\\\t]'\n          )\n        );\n        lineTexts.shift();\n        const lines: IFlavoredListItem[] = [];\n        lineTexts.forEach((text: string) => {\n          const sublineTexts: string[] = text.split(/\\n *(\\+|\\*|-) /);\n          const lineText = sublineTexts.shift() ?? '';\n\n          if (listCharRegExp.test(lineText)) {\n            return;\n          }\n\n          lines.push({\n            line: lineText,\n            sublines: sublineTexts\n              .map((subline: string) => {\n                if (listCharRegExp.test(subline)) {\n                  return '';\n                }\n                return subline.trim();\n              })\n              .filter((line) => !!line),\n          });\n        });\n        componentRef.instance.lines = lines;\n      }\n    );\n  }\n}\n","<div tdFlavoredMarkdownContainer>\n  <ng-content></ng-content>\n</div>\n"]}