@covalent/highlight 6.3.0-beta.4 → 6.3.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.
- package/_highlight-theme.scss +120 -52
- package/esm2020/lib/copy-code-button/copy-code-button.component.mjs +44 -8
- package/esm2020/lib/highlight.component.mjs +46 -11
- package/esm2020/lib/highlight.module.mjs +8 -1
- package/fesm2015/covalent-highlight.mjs +97 -20
- package/fesm2015/covalent-highlight.mjs.map +1 -1
- package/fesm2020/covalent-highlight.mjs +94 -18
- package/fesm2020/covalent-highlight.mjs.map +1 -1
- package/lib/copy-code-button/copy-code-button.component.d.ts +16 -1
- package/lib/highlight.component.d.ts +16 -2
- package/lib/highlight.module.d.ts +3 -2
- package/package.json +1 -1
package/_highlight-theme.scss
CHANGED
|
@@ -3,98 +3,166 @@
|
|
|
3
3
|
/**
|
|
4
4
|
* Mimicking VS Dark+ theme as closely as possible
|
|
5
5
|
*/
|
|
6
|
-
@mixin covalent-highlight-theme($theme
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
@mixin covalent-highlight-theme($theme) {
|
|
7
|
+
$foreground: map-get($theme, foreground);
|
|
8
|
+
$background: map-get($theme, background);
|
|
9
|
+
|
|
10
|
+
.raw-and-copy-buttons {
|
|
11
|
+
border-color: map-get($foreground, divider);
|
|
12
|
+
|
|
13
|
+
.mat-button-toggle {
|
|
14
|
+
background-color: inherit;
|
|
15
|
+
color: map-get($foreground, text);
|
|
16
|
+
|
|
17
|
+
mat-icon {
|
|
18
|
+
color: map-get($foreground, icon);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
& + .mat-button-toggle {
|
|
22
|
+
border-left-color: map-get($foreground, divider);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.dark-theme td-highlight {
|
|
28
|
+
background-color: #1a1c1d;
|
|
9
29
|
|
|
10
30
|
.highlight {
|
|
11
|
-
color:
|
|
31
|
+
color: #abb2bf;
|
|
12
32
|
}
|
|
13
33
|
|
|
14
|
-
.
|
|
15
|
-
color:
|
|
34
|
+
.raw {
|
|
35
|
+
color: rgba(255, 255, 255, 87%);
|
|
16
36
|
}
|
|
17
37
|
|
|
18
38
|
.hljs-comment,
|
|
19
39
|
.hljs-quote {
|
|
20
|
-
color: #
|
|
40
|
+
color: #5c6370;
|
|
41
|
+
font-style: italic;
|
|
21
42
|
}
|
|
22
43
|
|
|
23
|
-
.hljs-
|
|
24
|
-
.hljs-
|
|
25
|
-
.hljs-
|
|
26
|
-
|
|
27
|
-
color: #569cd6;
|
|
44
|
+
.hljs-doctag,
|
|
45
|
+
.hljs-formula,
|
|
46
|
+
.hljs-keyword {
|
|
47
|
+
color: #c678dd;
|
|
28
48
|
}
|
|
29
49
|
|
|
30
|
-
.hljs-
|
|
31
|
-
|
|
50
|
+
.hljs-deletion,
|
|
51
|
+
.hljs-name,
|
|
52
|
+
.hljs-tag,
|
|
53
|
+
.hljs-section,
|
|
54
|
+
.hljs-selector-tag,
|
|
55
|
+
.hljs-subst {
|
|
56
|
+
color: #e06c75;
|
|
32
57
|
}
|
|
33
58
|
|
|
34
|
-
.hljs-
|
|
35
|
-
|
|
36
|
-
.hljs-attribute {
|
|
37
|
-
color: #9cdcfe;
|
|
59
|
+
.hljs-literal {
|
|
60
|
+
color: #56b6c2;
|
|
38
61
|
}
|
|
39
62
|
|
|
40
|
-
.hljs-
|
|
41
|
-
.hljs-
|
|
63
|
+
.hljs-addition,
|
|
64
|
+
.hljs-attribute,
|
|
65
|
+
.hljs-meta .hljs-string,
|
|
42
66
|
.hljs-regexp,
|
|
43
|
-
.hljs-
|
|
44
|
-
color: #
|
|
67
|
+
.hljs-string {
|
|
68
|
+
color: #98c379;
|
|
45
69
|
}
|
|
46
70
|
|
|
47
|
-
.hljs-
|
|
71
|
+
.hljs-attr,
|
|
72
|
+
.hljs-number,
|
|
73
|
+
.hljs-selector-attr,
|
|
48
74
|
.hljs-selector-class,
|
|
49
|
-
.hljs-selector-pseudo
|
|
50
|
-
|
|
75
|
+
.hljs-selector-pseudo,
|
|
76
|
+
.hljs-template-variable,
|
|
77
|
+
.hljs-type,
|
|
78
|
+
.hljs-variable {
|
|
79
|
+
color: #d19a66;
|
|
51
80
|
}
|
|
52
81
|
|
|
53
|
-
.hljs-
|
|
54
|
-
|
|
82
|
+
.hljs-bullet,
|
|
83
|
+
.hljs-link,
|
|
84
|
+
.hljs-meta,
|
|
85
|
+
.hljs-selector-id,
|
|
86
|
+
.hljs-symbol,
|
|
87
|
+
.hljs-title {
|
|
88
|
+
color: #61aeee;
|
|
55
89
|
}
|
|
56
90
|
|
|
57
|
-
/* stylelint-disable selector-class-pattern */
|
|
58
91
|
.hljs-built_in,
|
|
59
|
-
.hljs-builtin-name,
|
|
60
|
-
.hljs-type,
|
|
61
|
-
.hljs-section,
|
|
62
92
|
.hljs-class .hljs-title,
|
|
63
|
-
.hljs-
|
|
64
|
-
|
|
65
|
-
color: #4ec9b0;
|
|
93
|
+
.hljs-title.class_ {
|
|
94
|
+
color: #e6c07b;
|
|
66
95
|
}
|
|
67
|
-
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
td-highlight {
|
|
99
|
+
background-color: #eeeeee;
|
|
68
100
|
|
|
69
|
-
.
|
|
70
|
-
color: #
|
|
101
|
+
.highlight {
|
|
102
|
+
color: #383a42;
|
|
71
103
|
}
|
|
72
104
|
|
|
73
|
-
.
|
|
74
|
-
|
|
75
|
-
color: #9fddfc;
|
|
105
|
+
.raw {
|
|
106
|
+
color: rgba(0, 0, 0, 87%);
|
|
76
107
|
}
|
|
77
108
|
|
|
78
|
-
.hljs-
|
|
79
|
-
|
|
109
|
+
.hljs-comment,
|
|
110
|
+
.hljs-quote {
|
|
111
|
+
color: #a0a1a7;
|
|
112
|
+
font-style: italic;
|
|
80
113
|
}
|
|
81
114
|
|
|
82
|
-
.hljs-
|
|
83
|
-
|
|
115
|
+
.hljs-doctag,
|
|
116
|
+
.hljs-formula,
|
|
117
|
+
.hljs-keyword {
|
|
118
|
+
color: #a626a4;
|
|
84
119
|
}
|
|
85
120
|
|
|
86
|
-
.hljs-
|
|
87
|
-
|
|
121
|
+
.hljs-deletion,
|
|
122
|
+
.hljs-name,
|
|
123
|
+
.hljs-tag,
|
|
124
|
+
.hljs-section,
|
|
125
|
+
.hljs-selector-tag,
|
|
126
|
+
.hljs-subst {
|
|
127
|
+
color: #e45649;
|
|
88
128
|
}
|
|
89
129
|
|
|
90
|
-
.hljs-
|
|
91
|
-
|
|
92
|
-
font-weight: bold;
|
|
130
|
+
.hljs-literal {
|
|
131
|
+
color: #0184bb;
|
|
93
132
|
}
|
|
94
133
|
|
|
95
|
-
.hljs-
|
|
96
|
-
|
|
97
|
-
|
|
134
|
+
.hljs-addition,
|
|
135
|
+
.hljs-attribute,
|
|
136
|
+
.hljs-meta .hljs-string,
|
|
137
|
+
.hljs-regexp,
|
|
138
|
+
.hljs-string {
|
|
139
|
+
color: #50a14f;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
.hljs-attr,
|
|
143
|
+
.hljs-number,
|
|
144
|
+
.hljs-selector-attr,
|
|
145
|
+
.hljs-selector-class,
|
|
146
|
+
.hljs-selector-pseudo,
|
|
147
|
+
.hljs-template-variable,
|
|
148
|
+
.hljs-type,
|
|
149
|
+
.hljs-variable {
|
|
150
|
+
color: #986801;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
.hljs-bullet,
|
|
154
|
+
.hljs-link,
|
|
155
|
+
.hljs-meta,
|
|
156
|
+
.hljs-selector-id,
|
|
157
|
+
.hljs-symbol,
|
|
158
|
+
.hljs-title {
|
|
159
|
+
color: #4078f2;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
.hljs-built_in,
|
|
163
|
+
.hljs-class .hljs-title,
|
|
164
|
+
.hljs-title.class_ {
|
|
165
|
+
color: #c18401;
|
|
98
166
|
}
|
|
99
167
|
}
|
|
100
168
|
}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
import { Component, Input, ViewChild, HostListener } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewChild, HostListener, EventEmitter, Output, } from '@angular/core';
|
|
2
|
+
import { MatButtonToggle } from '@angular/material/button-toggle';
|
|
2
3
|
import { MatTooltip } from '@angular/material/tooltip';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/
|
|
5
|
-
import * as i2 from "@angular/
|
|
6
|
-
import * as i3 from "@angular/material/
|
|
7
|
-
import * as i4 from "@angular/material/button";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/cdk/clipboard";
|
|
7
|
+
import * as i3 from "@angular/material/icon";
|
|
8
|
+
import * as i4 from "@angular/material/button-toggle";
|
|
9
|
+
import * as i5 from "@angular/material/button";
|
|
10
|
+
import * as i6 from "@angular/material/tooltip";
|
|
8
11
|
export class TdCopyCodeButtonComponent {
|
|
9
12
|
constructor() {
|
|
10
13
|
this.copyCodeToClipboard = false;
|
|
@@ -14,6 +17,10 @@ export class TdCopyCodeButtonComponent {
|
|
|
14
17
|
* Tooltips for copy button to copy and upon copying.
|
|
15
18
|
*/
|
|
16
19
|
this.copyCodeTooltips = {};
|
|
20
|
+
this.toggleRawButton = false;
|
|
21
|
+
this.rawToggleLabels = {};
|
|
22
|
+
this.rawToggle = false;
|
|
23
|
+
this.toggleRaw = new EventEmitter();
|
|
17
24
|
}
|
|
18
25
|
get copyTooltip() {
|
|
19
26
|
return (this.copyCodeTooltips && this.copyCodeTooltips.copy) || 'Copy';
|
|
@@ -21,6 +28,14 @@ export class TdCopyCodeButtonComponent {
|
|
|
21
28
|
get copiedTooltip() {
|
|
22
29
|
return (this.copyCodeTooltips && this.copyCodeTooltips.copied) || 'Copied';
|
|
23
30
|
}
|
|
31
|
+
get rawToggleText() {
|
|
32
|
+
if (this.rawToggle) {
|
|
33
|
+
return this.rawToggleLabels?.viewCode || 'View code';
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
return this.rawToggleLabels?.viewRaw || 'Raw';
|
|
37
|
+
}
|
|
38
|
+
}
|
|
24
39
|
textCopied(event) {
|
|
25
40
|
if (event) {
|
|
26
41
|
this.tooltip.hide();
|
|
@@ -33,18 +48,39 @@ export class TdCopyCodeButtonComponent {
|
|
|
33
48
|
this.tooltip.message = this.copyTooltip;
|
|
34
49
|
}, 200);
|
|
35
50
|
}
|
|
51
|
+
toggleRawClicked() {
|
|
52
|
+
this.rawToggle = !this.rawToggle;
|
|
53
|
+
this.toggleRaw.emit();
|
|
54
|
+
this.rawButton.checked = false;
|
|
55
|
+
}
|
|
56
|
+
copyClicked() {
|
|
57
|
+
console.log('copyClicked');
|
|
58
|
+
this.copyButton.checked = false;
|
|
59
|
+
}
|
|
36
60
|
}
|
|
37
61
|
TdCopyCodeButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdCopyCodeButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
-
TdCopyCodeButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: TdCopyCodeButtonComponent, selector: "td-copy-code-button", inputs: { copiedContent: "copiedContent", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips" }, host: { listeners: { "mouseleave": "initializeTooltip()" } }, viewQueries: [{ propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], ngImport: i0, template: "<button\n mat-icon-button\n [cdkCopyToClipboard]=\"copiedContent\"\n
|
|
62
|
+
TdCopyCodeButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: TdCopyCodeButtonComponent, selector: "td-copy-code-button", inputs: { copiedContent: "copiedContent", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", toggleRawButton: "toggleRawButton", rawToggleLabels: "rawToggleLabels" }, outputs: { toggleRaw: "toggleRaw" }, host: { listeners: { "mouseleave": "initializeTooltip()" } }, viewQueries: [{ propertyName: "copyButton", first: true, predicate: ["copyButton"], descendants: true }, { propertyName: "rawButton", first: true, predicate: ["rawButton"], descendants: true }, { propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], ngImport: i0, template: "<mat-button-toggle-group\n multiple\n class=\"raw-and-copy-buttons\"\n *ngIf=\"toggleRawButton; else button\"\n>\n <mat-button-toggle (click)=\"toggleRawClicked()\" #rawButton>{{\n rawToggleText\n }}</mat-button-toggle>\n <mat-button-toggle\n [cdkCopyToClipboard]=\"copiedContent\"\n [matTooltip]=\"copyTooltip\"\n #tooltip=\"matTooltip\"\n #copyButton\n (click)=\"copyClicked()\"\n (cdkCopyToClipboardCopied)=\"textCopied($event)\"\n >\n <mat-icon width>content_copy</mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n\n<ng-template #button>\n <button\n mat-icon-button\n [cdkCopyToClipboard]=\"copiedContent\"\n class=\"copy-button\"\n [matTooltip]=\"copyTooltip\"\n #tooltip=\"matTooltip\"\n (cdkCopyToClipboardCopied)=\"textCopied($event)\"\n >\n <mat-icon role=\"img\">content_copy</mat-icon>\n </button>\n</ng-template>\n", styles: ["mat-button-toggle-group.raw-and-copy-buttons{margin-top:-8px;margin-right:-8px;margin-left:8px}mat-button-toggle-group.raw-and-copy-buttons ::ng-deep .mat-button-toggle-label-content{font-size:12px;line-height:28px}mat-button-toggle-group.raw-and-copy-buttons ::ng-deep .mat-button-toggle-label-content mat-icon{width:16px;height:16px;font-size:16px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.CdkCopyToClipboard, selector: "[cdkCopyToClipboard]", inputs: ["cdkCopyToClipboard", "cdkCopyToClipboardAttempts"], outputs: ["cdkCopyToClipboardCopied"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i4.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "appearance", "checked", "disabled"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
|
|
39
63
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdCopyCodeButtonComponent, decorators: [{
|
|
40
64
|
type: Component,
|
|
41
|
-
args: [{ selector: 'td-copy-code-button', template: "<button\n mat-icon-button\n [cdkCopyToClipboard]=\"copiedContent\"\n
|
|
65
|
+
args: [{ selector: 'td-copy-code-button', template: "<mat-button-toggle-group\n multiple\n class=\"raw-and-copy-buttons\"\n *ngIf=\"toggleRawButton; else button\"\n>\n <mat-button-toggle (click)=\"toggleRawClicked()\" #rawButton>{{\n rawToggleText\n }}</mat-button-toggle>\n <mat-button-toggle\n [cdkCopyToClipboard]=\"copiedContent\"\n [matTooltip]=\"copyTooltip\"\n #tooltip=\"matTooltip\"\n #copyButton\n (click)=\"copyClicked()\"\n (cdkCopyToClipboardCopied)=\"textCopied($event)\"\n >\n <mat-icon width>content_copy</mat-icon>\n </mat-button-toggle>\n</mat-button-toggle-group>\n\n<ng-template #button>\n <button\n mat-icon-button\n [cdkCopyToClipboard]=\"copiedContent\"\n class=\"copy-button\"\n [matTooltip]=\"copyTooltip\"\n #tooltip=\"matTooltip\"\n (cdkCopyToClipboardCopied)=\"textCopied($event)\"\n >\n <mat-icon role=\"img\">content_copy</mat-icon>\n </button>\n</ng-template>\n", styles: ["mat-button-toggle-group.raw-and-copy-buttons{margin-top:-8px;margin-right:-8px;margin-left:8px}mat-button-toggle-group.raw-and-copy-buttons ::ng-deep .mat-button-toggle-label-content{font-size:12px;line-height:28px}mat-button-toggle-group.raw-and-copy-buttons ::ng-deep .mat-button-toggle-label-content mat-icon{width:16px;height:16px;font-size:16px}\n"] }]
|
|
42
66
|
}], propDecorators: { copiedContent: [{
|
|
43
67
|
type: Input
|
|
44
68
|
}], copyCodeToClipboard: [{
|
|
45
69
|
type: Input
|
|
46
70
|
}], copyCodeTooltips: [{
|
|
47
71
|
type: Input
|
|
72
|
+
}], toggleRawButton: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}], rawToggleLabels: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], toggleRaw: [{
|
|
77
|
+
type: Output
|
|
78
|
+
}], copyButton: [{
|
|
79
|
+
type: ViewChild,
|
|
80
|
+
args: ['copyButton']
|
|
81
|
+
}], rawButton: [{
|
|
82
|
+
type: ViewChild,
|
|
83
|
+
args: ['rawButton']
|
|
48
84
|
}], tooltip: [{
|
|
49
85
|
type: ViewChild,
|
|
50
86
|
args: ['tooltip']
|
|
@@ -52,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
52
88
|
type: HostListener,
|
|
53
89
|
args: ['mouseleave']
|
|
54
90
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS1jb2RlLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItaGlnaGxpZ2h0L3NyYy9saWIvY29weS1jb2RlLWJ1dHRvbi9jb3B5LWNvZGUtYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci1oaWdobGlnaHQvc3JjL2xpYi9jb3B5LWNvZGUtYnV0dG9uL2NvcHktY29kZS1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7Ozs7Ozs7O0FBaUJ2RCxNQUFNLE9BQU8seUJBQXlCO0lBTHRDO1FBUVcsd0JBQW1CLEdBQUcsS0FBSyxDQUFDO1FBQ3JDOzs7O1dBSUc7UUFDTSxxQkFBZ0IsR0FBdUIsRUFBRSxDQUFDO1FBRTFDLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLG9CQUFlLEdBQXNCLEVBQUUsQ0FBQztRQUVqRCxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBRVIsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7S0ErQ25EO0lBMUNDLElBQUksV0FBVztRQUNiLE9BQU8sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLElBQUksSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLE1BQU0sQ0FBQztJQUN6RSxDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLElBQUksUUFBUSxDQUFDO0lBQzdFLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDZixJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsT0FBTyxJQUFJLENBQUMsZUFBZSxFQUFFLFFBQVEsSUFBSSxXQUFXLENBQUM7U0FDdEQ7YUFBTTtZQUNMLE9BQU8sSUFBSSxDQUFDLGVBQWUsRUFBRSxPQUFPLElBQUksS0FBSyxDQUFDO1NBQy9DO0lBQ0gsQ0FBQztJQUlELFVBQVUsQ0FBQyxLQUFjO1FBQ3ZCLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDO1lBQzFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDckI7SUFDSCxDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDMUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsQ0FBQztJQUVELGdCQUFnQjtRQUNkLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMzQixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDbEMsQ0FBQzs7c0hBOURVLHlCQUF5QjswR0FBekIseUJBQXlCLDRuQkMxQnRDLGk0QkFnQ0E7MkZETmEseUJBQXlCO2tCQUxyQyxTQUFTOytCQUNFLHFCQUFxQjs4QkFNdEIsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxtQkFBbUI7c0JBQTNCLEtBQUs7Z0JBTUcsZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUVHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFJSSxTQUFTO3NCQUFsQixNQUFNO2dCQUVrQixVQUFVO3NCQUFsQyxTQUFTO3VCQUFDLFlBQVk7Z0JBQ0MsU0FBUztzQkFBaEMsU0FBUzt1QkFBQyxXQUFXO2dCQWtCQSxPQUFPO3NCQUE1QixTQUFTO3VCQUFDLFNBQVM7Z0JBVXBCLGlCQUFpQjtzQkFEaEIsWUFBWTt1QkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgVmlld0NoaWxkLFxuICBIb3N0TGlzdGVuZXIsXG4gIEV2ZW50RW1pdHRlcixcbiAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdEJ1dHRvblRvZ2dsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbi10b2dnbGUnO1xuaW1wb3J0IHsgTWF0VG9vbHRpcCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElDb3B5Q29kZVRvb2x0aXBzIHtcbiAgY29weT86IHN0cmluZztcbiAgY29waWVkPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElSYXdUb2dnbGVMYWJlbHMge1xuICB2aWV3UmF3Pzogc3RyaW5nO1xuICB2aWV3Q29kZT86IHN0cmluZztcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndGQtY29weS1jb2RlLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3B5LWNvZGUtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29weS1jb2RlLWJ1dHRvbi5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBUZENvcHlDb2RlQnV0dG9uQ29tcG9uZW50IHtcbiAgLy8gcHJpdmF0ZSBfY29weUNvZGVUb29sdGlwczogSUNvcHlDb2RlVG9vbHRpcHMgPSB7fTtcbiAgQElucHV0KCkgY29waWVkQ29udGVudCE6IHN0cmluZztcbiAgQElucHV0KCkgY29weUNvZGVUb0NsaXBib2FyZCA9IGZhbHNlO1xuICAvKipcbiAgICogY29weUNvZGVUb29sdGlwcz86IElDb3B5Q29kZVRvb2x0aXBzXG4gICAqXG4gICAqIFRvb2x0aXBzIGZvciBjb3B5IGJ1dHRvbiB0byBjb3B5IGFuZCB1cG9uIGNvcHlpbmcuXG4gICAqL1xuICBASW5wdXQoKSBjb3B5Q29kZVRvb2x0aXBzPzogSUNvcHlDb2RlVG9vbHRpcHMgPSB7fTtcblxuICBASW5wdXQoKSB0b2dnbGVSYXdCdXR0b24gPSBmYWxzZTtcbiAgQElucHV0KCkgcmF3VG9nZ2xlTGFiZWxzPzogSVJhd1RvZ2dsZUxhYmVscyA9IHt9O1xuXG4gIHJhd1RvZ2dsZSA9IGZhbHNlO1xuXG4gIEBPdXRwdXQoKSB0b2dnbGVSYXcgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG5cbiAgQFZpZXdDaGlsZCgnY29weUJ1dHRvbicpIGNvcHlCdXR0b24hOiBNYXRCdXR0b25Ub2dnbGU7XG4gIEBWaWV3Q2hpbGQoJ3Jhd0J1dHRvbicpIHJhd0J1dHRvbiE6IE1hdEJ1dHRvblRvZ2dsZTtcblxuICBnZXQgY29weVRvb2x0aXAoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gKHRoaXMuY29weUNvZGVUb29sdGlwcyAmJiB0aGlzLmNvcHlDb2RlVG9vbHRpcHMuY29weSkgfHwgJ0NvcHknO1xuICB9XG5cbiAgZ2V0IGNvcGllZFRvb2x0aXAoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gKHRoaXMuY29weUNvZGVUb29sdGlwcyAmJiB0aGlzLmNvcHlDb2RlVG9vbHRpcHMuY29waWVkKSB8fCAnQ29waWVkJztcbiAgfVxuXG4gIGdldCByYXdUb2dnbGVUZXh0KCk6IHN0cmluZyB7XG4gICAgaWYgKHRoaXMucmF3VG9nZ2xlKSB7XG4gICAgICByZXR1cm4gdGhpcy5yYXdUb2dnbGVMYWJlbHM/LnZpZXdDb2RlIHx8ICdWaWV3IGNvZGUnO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gdGhpcy5yYXdUb2dnbGVMYWJlbHM/LnZpZXdSYXcgfHwgJ1Jhdyc7XG4gICAgfVxuICB9XG5cbiAgQFZpZXdDaGlsZCgndG9vbHRpcCcpIHRvb2x0aXAhOiBNYXRUb29sdGlwO1xuXG4gIHRleHRDb3BpZWQoZXZlbnQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICBpZiAoZXZlbnQpIHtcbiAgICAgIHRoaXMudG9vbHRpcC5oaWRlKCk7XG4gICAgICB0aGlzLnRvb2x0aXAubWVzc2FnZSA9IHRoaXMuY29waWVkVG9vbHRpcDtcbiAgICAgIHRoaXMudG9vbHRpcC5zaG93KCk7XG4gICAgfVxuICB9XG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKVxuICBpbml0aWFsaXplVG9vbHRpcCgpOiB2b2lkIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMudG9vbHRpcC5tZXNzYWdlID0gdGhpcy5jb3B5VG9vbHRpcDtcbiAgICB9LCAyMDApO1xuICB9XG5cbiAgdG9nZ2xlUmF3Q2xpY2tlZCgpOiB2b2lkIHtcbiAgICB0aGlzLnJhd1RvZ2dsZSA9ICF0aGlzLnJhd1RvZ2dsZTtcbiAgICB0aGlzLnRvZ2dsZVJhdy5lbWl0KCk7XG4gICAgdGhpcy5yYXdCdXR0b24uY2hlY2tlZCA9IGZhbHNlO1xuICB9XG5cbiAgY29weUNsaWNrZWQoKTogdm9pZCB7XG4gICAgY29uc29sZS5sb2coJ2NvcHlDbGlja2VkJyk7XG4gICAgdGhpcy5jb3B5QnV0dG9uLmNoZWNrZWQgPSBmYWxzZTtcbiAgfVxufVxuIiwiPG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwXG4gIG11bHRpcGxlXG4gIGNsYXNzPVwicmF3LWFuZC1jb3B5LWJ1dHRvbnNcIlxuICAqbmdJZj1cInRvZ2dsZVJhd0J1dHRvbjsgZWxzZSBidXR0b25cIlxuPlxuICA8bWF0LWJ1dHRvbi10b2dnbGUgKGNsaWNrKT1cInRvZ2dsZVJhd0NsaWNrZWQoKVwiICNyYXdCdXR0b24+e3tcbiAgICByYXdUb2dnbGVUZXh0XG4gIH19PC9tYXQtYnV0dG9uLXRvZ2dsZT5cbiAgPG1hdC1idXR0b24tdG9nZ2xlXG4gICAgW2Nka0NvcHlUb0NsaXBib2FyZF09XCJjb3BpZWRDb250ZW50XCJcbiAgICBbbWF0VG9vbHRpcF09XCJjb3B5VG9vbHRpcFwiXG4gICAgI3Rvb2x0aXA9XCJtYXRUb29sdGlwXCJcbiAgICAjY29weUJ1dHRvblxuICAgIChjbGljayk9XCJjb3B5Q2xpY2tlZCgpXCJcbiAgICAoY2RrQ29weVRvQ2xpcGJvYXJkQ29waWVkKT1cInRleHRDb3BpZWQoJGV2ZW50KVwiXG4gID5cbiAgICA8bWF0LWljb24gd2lkdGg+Y29udGVudF9jb3B5PC9tYXQtaWNvbj5cbiAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cbjwvbWF0LWJ1dHRvbi10b2dnbGUtZ3JvdXA+XG5cbjxuZy10ZW1wbGF0ZSAjYnV0dG9uPlxuICA8YnV0dG9uXG4gICAgbWF0LWljb24tYnV0dG9uXG4gICAgW2Nka0NvcHlUb0NsaXBib2FyZF09XCJjb3BpZWRDb250ZW50XCJcbiAgICBjbGFzcz1cImNvcHktYnV0dG9uXCJcbiAgICBbbWF0VG9vbHRpcF09XCJjb3B5VG9vbHRpcFwiXG4gICAgI3Rvb2x0aXA9XCJtYXRUb29sdGlwXCJcbiAgICAoY2RrQ29weVRvQ2xpcGJvYXJkQ29waWVkKT1cInRleHRDb3BpZWQoJGV2ZW50KVwiXG4gID5cbiAgICA8bWF0LWljb24gcm9sZT1cImltZ1wiPmNvbnRlbnRfY29weTwvbWF0LWljb24+XG4gIDwvYnV0dG9uPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -17,6 +17,7 @@ export class TdHighlightComponent {
|
|
|
17
17
|
*/
|
|
18
18
|
set content(content) {
|
|
19
19
|
this._content = content;
|
|
20
|
+
console.log(this._content);
|
|
20
21
|
if (this._initialized) {
|
|
21
22
|
this._loadContent(this._content);
|
|
22
23
|
}
|
|
@@ -45,6 +46,7 @@ export class TdHighlightComponent {
|
|
|
45
46
|
this.cdr = cdr;
|
|
46
47
|
this._initialized = false;
|
|
47
48
|
this._lang = 'typescript';
|
|
49
|
+
this._showRaw = false;
|
|
48
50
|
/**
|
|
49
51
|
* copyCodeToClipboard?: boolean
|
|
50
52
|
*
|
|
@@ -57,6 +59,18 @@ export class TdHighlightComponent {
|
|
|
57
59
|
* Tooltips for copy button to copy and upon copying.
|
|
58
60
|
*/
|
|
59
61
|
this.copyCodeTooltips = {};
|
|
62
|
+
/**
|
|
63
|
+
* toggleRawButton?: boolean
|
|
64
|
+
*
|
|
65
|
+
* Display button to toggle raw code.
|
|
66
|
+
*/
|
|
67
|
+
this.toggleRawButton = false;
|
|
68
|
+
/**
|
|
69
|
+
* rawToggleLabels?: IRawToggleLabels
|
|
70
|
+
*
|
|
71
|
+
* Labels for raw toggle button.
|
|
72
|
+
*/
|
|
73
|
+
this.rawToggleLabels = {};
|
|
60
74
|
/**
|
|
61
75
|
* contentReady?: function
|
|
62
76
|
* Event emitted after the highlight content rendering is finished.
|
|
@@ -68,11 +82,10 @@ export class TdHighlightComponent {
|
|
|
68
82
|
}
|
|
69
83
|
ngAfterViewInit() {
|
|
70
84
|
if (!this._content) {
|
|
71
|
-
this.
|
|
72
|
-
|
|
73
|
-
else {
|
|
74
|
-
this._loadContent(this._content);
|
|
85
|
+
this._content =
|
|
86
|
+
this.highlightComp.nativeElement.textContent || '';
|
|
75
87
|
}
|
|
88
|
+
this._loadContent(this._content);
|
|
76
89
|
this._initialized = true;
|
|
77
90
|
}
|
|
78
91
|
setLanguage(lang) {
|
|
@@ -84,6 +97,17 @@ export class TdHighlightComponent {
|
|
|
84
97
|
this._loadContent(this._content);
|
|
85
98
|
}
|
|
86
99
|
}
|
|
100
|
+
toggleRawClicked() {
|
|
101
|
+
this._showRaw = !this._showRaw;
|
|
102
|
+
this._elementRef.nativeElement.querySelector('pre').style.display = this
|
|
103
|
+
._showRaw
|
|
104
|
+
? 'none'
|
|
105
|
+
: 'block';
|
|
106
|
+
this._elementRef.nativeElement.querySelector('.raw').style.display = this
|
|
107
|
+
._showRaw
|
|
108
|
+
? 'block'
|
|
109
|
+
: 'none';
|
|
110
|
+
}
|
|
87
111
|
/**
|
|
88
112
|
* General method to parse a string of code into HTML Elements and load them into the container
|
|
89
113
|
*/
|
|
@@ -91,8 +115,7 @@ export class TdHighlightComponent {
|
|
|
91
115
|
if (code && code.trim().length > 0) {
|
|
92
116
|
// Clean container
|
|
93
117
|
this._renderer.setProperty(this._elementRef.nativeElement, 'innerHTML', '');
|
|
94
|
-
|
|
95
|
-
this._elementFromString(this._render(code));
|
|
118
|
+
this._elementFromString(code);
|
|
96
119
|
if (this.copyCodeToClipboard) {
|
|
97
120
|
this._renderer.appendChild(this._elementRef.nativeElement, this.copyComp.nativeElement);
|
|
98
121
|
}
|
|
@@ -108,9 +131,17 @@ export class TdHighlightComponent {
|
|
|
108
131
|
this._renderer.appendChild(preElement, codeElement);
|
|
109
132
|
// Set .highlight class into <code> element
|
|
110
133
|
this._renderer.addClass(codeElement, 'highlight');
|
|
134
|
+
const highlightedCode = this._render(codeStr);
|
|
111
135
|
codeElement.innerHTML =
|
|
112
|
-
this._domSanitizer.sanitize(SecurityContext.HTML,
|
|
113
|
-
|
|
136
|
+
this._domSanitizer.sanitize(SecurityContext.HTML, highlightedCode) ?? '';
|
|
137
|
+
if (this.toggleRawButton) {
|
|
138
|
+
const divElement = this._renderer.createElement('div');
|
|
139
|
+
divElement.className = 'raw';
|
|
140
|
+
this._renderer.appendChild(this._elementRef.nativeElement, divElement);
|
|
141
|
+
divElement.innerHTML =
|
|
142
|
+
this._domSanitizer.sanitize(SecurityContext.HTML, codeStr) ?? '';
|
|
143
|
+
this._renderer.setStyle(divElement, 'display', 'none');
|
|
144
|
+
}
|
|
114
145
|
}
|
|
115
146
|
_render(contents) {
|
|
116
147
|
// Trim leading and trailing newlines
|
|
@@ -149,16 +180,20 @@ export class TdHighlightComponent {
|
|
|
149
180
|
}
|
|
150
181
|
}
|
|
151
182
|
TdHighlightComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdHighlightComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.DomSanitizer }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
152
|
-
TdHighlightComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: TdHighlightComponent, selector: "td-highlight", inputs: { content: "content", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", codeLang: "codeLang", lang: "lang" }, outputs: { contentReady: "contentReady" }, viewQueries: [{ propertyName: "highlightComp", first: true, predicate: ["highlightComponent"], descendants: true }, { propertyName: "copyComp", first: true, predicate: ["copyComponent"], descendants: true }, { propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], ngImport: i0, template: "<div>\n <div #highlightComponent>\n <ng-content></ng-content>\n </div>\n\n <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n <td-copy-code-button\n [copiedContent]=\"copyContent\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n ></td-copy-code-button>\n </div>\n</div>\n", styles: [":host ::ng-deep{overflow-x:auto;padding:16px;display:flex}:host ::ng-deep pre,:host ::ng-deep code,:host ::ng-deep .highlight{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace}:host ::ng-deep pre{display:block;overflow-x:auto;padding:0;margin:0;background:transparent;font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;line-height:1.45;tab-size:2;-webkit-font-smoothing:auto;-webkit-text-size-adjust:none;text-size-adjust:none;position:relative;border-radius:2px;font-size:.8rem;width:100%}:host ::ng-deep code{margin:0;padding:0;overflow-wrap:break-word;white-space:pre-wrap}:host ::ng-deep .highlight{display:block;overflow-wrap:break-word;line-height:1.5;margin:0}:host ::ng-deep .copy-button{border:none;background:inherit;margin-top:-8px;margin-right:-8px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TdCopyCodeButtonComponent, selector: "td-copy-code-button", inputs: ["copiedContent", "copyCodeToClipboard", "copyCodeTooltips"] }] });
|
|
183
|
+
TdHighlightComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: TdHighlightComponent, selector: "td-highlight", inputs: { content: "content", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", toggleRawButton: "toggleRawButton", rawToggleLabels: "rawToggleLabels", codeLang: "codeLang", lang: "lang" }, outputs: { contentReady: "contentReady" }, viewQueries: [{ propertyName: "highlightComp", first: true, predicate: ["highlightComponent"], descendants: true }, { propertyName: "copyComp", first: true, predicate: ["copyComponent"], descendants: true }, { propertyName: "tooltip", first: true, predicate: ["tooltip"], descendants: true }], ngImport: i0, template: "<div>\n <div #highlightComponent>\n <ng-content></ng-content>\n </div>\n\n <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n <td-copy-code-button\n [toggleRawButton]=\"toggleRawButton\"\n [rawToggleLabels]=\"rawToggleLabels\"\n (toggleRaw)=\"toggleRawClicked()\"\n [copiedContent]=\"copyContent\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n ></td-copy-code-button>\n </div>\n</div>\n", styles: [":host ::ng-deep{overflow-x:auto;padding:16px;display:flex;position:relative}:host ::ng-deep pre,:host ::ng-deep code,:host ::ng-deep .highlight{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace}:host ::ng-deep pre{display:block;overflow-x:auto;padding:0;margin:0;background:transparent;font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;line-height:1.45;tab-size:2;-webkit-font-smoothing:auto;-webkit-text-size-adjust:none;text-size-adjust:none;position:relative;border-radius:2px;font-size:.8rem;width:100%}:host ::ng-deep code{margin:0;padding:0;overflow-wrap:break-word;white-space:pre-wrap}:host ::ng-deep div.raw{flex-grow:1}:host ::ng-deep .highlight{display:block;overflow-wrap:break-word;line-height:1.5;margin:0}:host ::ng-deep .copy-button{border:none;background:inherit;margin-top:-8px;margin-right:-8px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TdCopyCodeButtonComponent, selector: "td-copy-code-button", inputs: ["copiedContent", "copyCodeToClipboard", "copyCodeTooltips", "toggleRawButton", "rawToggleLabels"], outputs: ["toggleRaw"] }] });
|
|
153
184
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: TdHighlightComponent, decorators: [{
|
|
154
185
|
type: Component,
|
|
155
|
-
args: [{ selector: 'td-highlight', template: "<div>\n <div #highlightComponent>\n <ng-content></ng-content>\n </div>\n\n <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n <td-copy-code-button\n [copiedContent]=\"copyContent\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n ></td-copy-code-button>\n </div>\n</div>\n", styles: [":host ::ng-deep{overflow-x:auto;padding:16px;display:flex}:host ::ng-deep pre,:host ::ng-deep code,:host ::ng-deep .highlight{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace}:host ::ng-deep pre{display:block;overflow-x:auto;padding:0;margin:0;background:transparent;font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;line-height:1.45;tab-size:2;-webkit-font-smoothing:auto;-webkit-text-size-adjust:none;text-size-adjust:none;position:relative;border-radius:2px;font-size:.8rem;width:100%}:host ::ng-deep code{margin:0;padding:0;overflow-wrap:break-word;white-space:pre-wrap}:host ::ng-deep .highlight{display:block;overflow-wrap:break-word;line-height:1.5;margin:0}:host ::ng-deep .copy-button{border:none;background:inherit;margin-top:-8px;margin-right:-8px}\n"] }]
|
|
186
|
+
args: [{ selector: 'td-highlight', template: "<div>\n <div #highlightComponent>\n <ng-content></ng-content>\n </div>\n\n <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n <td-copy-code-button\n [toggleRawButton]=\"toggleRawButton\"\n [rawToggleLabels]=\"rawToggleLabels\"\n (toggleRaw)=\"toggleRawClicked()\"\n [copiedContent]=\"copyContent\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n ></td-copy-code-button>\n </div>\n</div>\n", styles: [":host ::ng-deep{overflow-x:auto;padding:16px;display:flex;position:relative}:host ::ng-deep pre,:host ::ng-deep code,:host ::ng-deep .highlight{font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace}:host ::ng-deep pre{display:block;overflow-x:auto;padding:0;margin:0;background:transparent;font-family:Menlo,Monaco,Andale Mono,lucida console,Courier New,monospace;line-height:1.45;tab-size:2;-webkit-font-smoothing:auto;-webkit-text-size-adjust:none;text-size-adjust:none;position:relative;border-radius:2px;font-size:.8rem;width:100%}:host ::ng-deep code{margin:0;padding:0;overflow-wrap:break-word;white-space:pre-wrap}:host ::ng-deep div.raw{flex-grow:1}:host ::ng-deep .highlight{display:block;overflow-wrap:break-word;line-height:1.5;margin:0}:host ::ng-deep .copy-button{border:none;background:inherit;margin-top:-8px;margin-right:-8px}\n"] }]
|
|
156
187
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.DomSanitizer }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { content: [{
|
|
157
188
|
type: Input
|
|
158
189
|
}], copyCodeToClipboard: [{
|
|
159
190
|
type: Input
|
|
160
191
|
}], copyCodeTooltips: [{
|
|
161
192
|
type: Input
|
|
193
|
+
}], toggleRawButton: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], rawToggleLabels: [{
|
|
196
|
+
type: Input
|
|
162
197
|
}], codeLang: [{
|
|
163
198
|
type: Input
|
|
164
199
|
}], lang: [{
|
|
@@ -175,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
175
210
|
type: ViewChild,
|
|
176
211
|
args: ['tooltip']
|
|
177
212
|
}] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.component.js","sourceRoot":"","sources":["../../../../../libs/angular-highlight/src/lib/highlight.component.ts","../../../../../libs/angular-highlight/src/lib/highlight.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  AfterViewInit,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter,\n  Renderer2,\n  SecurityContext,\n  ViewChild,\n  ChangeDetectorRef,\n  AfterViewChecked,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { MatTooltip } from '@angular/material/tooltip';\nimport { ICopyCodeTooltips } from './copy-code-button/copy-code-button.component';\n\nimport hljs from 'highlight.js';\n\n@Component({\n  selector: 'td-highlight',\n  styleUrls: ['./highlight.component.scss'],\n  templateUrl: './highlight.component.html',\n})\nexport class TdHighlightComponent implements AfterViewInit, AfterViewChecked {\n  private _initialized = false;\n\n  private _content!: string;\n  private _lang = 'typescript';\n\n  /**\n   * content?: string\n   *\n   * Code content to be parsed as highlighted html.\n   * Used to load data dynamically.\n   *\n   * e.g. `.html`, `.ts` , etc.\n   */\n  @Input()\n  set content(content: string) {\n    this._content = content;\n    if (this._initialized) {\n      this._loadContent(this._content);\n    }\n  }\n\n  /**\n   * copyCodeToClipboard?: boolean\n   *\n   * Display copy button on code snippets to copy code to clipboard.\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   * lang?: string\n   *\n   * Language of the code content to be parsed as highlighted html.\n   * Defaults to `typescript`\n   *\n   * e.g. `typescript`, `html` , etc.\n   */\n\n  @Input()\n  set codeLang(lang: string) {\n    this.setLanguage(lang);\n  }\n  /** @deprecated - removed completely @4.0.0 */\n  @Input()\n  set lang(lang: string) {\n    // tslint:disable-next-line: no-console\n    console.warn(\n      'DEPRECATION WARNING: switch to codeLang attribute as lang attribute is deprecated.'\n    );\n    this.setLanguage(lang);\n  }\n\n  copyContent!: string;\n\n  /**\n   * contentReady?: function\n   * Event emitted after the highlight content rendering is finished.\n   */\n  @Output() contentReady: EventEmitter<void> = new EventEmitter<void>();\n  @ViewChild('highlightComponent') highlightComp!: ElementRef;\n  @ViewChild('copyComponent') copyComp!: ElementRef;\n\n  @ViewChild('tooltip') tooltip!: MatTooltip;\n\n  constructor(\n    private _renderer: Renderer2,\n    private _elementRef: ElementRef,\n    private _domSanitizer: DomSanitizer,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewChecked(): void {\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n    if (!this._content) {\n      this._loadContent(\n        (<HTMLElement>this.highlightComp.nativeElement).textContent\n      );\n    } else {\n      this._loadContent(this._content);\n    }\n    this._initialized = true;\n  }\n\n  setLanguage(lang: string): void {\n    if (!lang) {\n      throw new Error(\n        'Error: language attribute must be defined in TdHighlightComponent.'\n      );\n    }\n    this._lang = lang;\n    if (this._initialized) {\n      this._loadContent(this._content);\n    }\n  }\n\n  /**\n   * General method to parse a string of code into HTML Elements and load them into the container\n   */\n  private _loadContent(code: string | null): void {\n    if (code && code.trim().length > 0) {\n      // Clean container\n      this._renderer.setProperty(\n        this._elementRef.nativeElement,\n        'innerHTML',\n        ''\n      );\n      // Parse html string into actual HTML elements.\n      this._elementFromString(this._render(code));\n      if (this.copyCodeToClipboard) {\n        this._renderer.appendChild(\n          this._elementRef.nativeElement,\n          this.copyComp.nativeElement\n        );\n      }\n    }\n    this.contentReady.emit();\n  }\n\n  private _elementFromString(codeStr: string): HTMLPreElement {\n    // Renderer2 doesnt have a parsing method, so we have to sanitize and use [innerHTML]\n    // to parse the string into DOM element for now.\n    const preElement: HTMLPreElement = this._renderer.createElement('pre');\n    this._renderer.appendChild(this._elementRef.nativeElement, preElement);\n    const codeElement: HTMLElement = this._renderer.createElement('code');\n    this._renderer.appendChild(preElement, codeElement);\n    // Set .highlight class into <code> element\n    this._renderer.addClass(codeElement, 'highlight');\n    codeElement.innerHTML =\n      this._domSanitizer.sanitize(SecurityContext.HTML, codeStr) ?? '';\n    return preElement;\n  }\n\n  private _render(contents: string): string {\n    // Trim leading and trailing newlines\n    contents = contents\n      .replace(/^(\\s|\\t)*\\n+/g, '')\n      .replace(/(\\s|\\t)*\\n+(\\s|\\t)*$/g, '');\n    // Split markup by line characters\n    let lines: string[] = contents.split('\\n');\n\n    // check how much indentation is used by the first actual code 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 code can be parsed correctly\n    const startingWhitespaceRegex = new RegExp('^' + firstLineWhitespace);\n    lines = lines.map(function (line: string): string {\n      return line\n        .replace('=\"\"', '') // remove empty values\n        .replace(startingWhitespaceRegex, '')\n        .replace(/\\s+$/, ''); // remove trailing white spaces\n    });\n\n    const codeToParse: string = lines\n      .join('\\n')\n      .replace(/\\{ \\{/gi, '{{')\n      .replace(/\\} \\}/gi, '}}')\n      .replace(/&lt;/gi, '<')\n      .replace(/&gt;/gi, '>'); // replace with < and > to render HTML in Angular\n    this.copyContent = codeToParse;\n    // Parse code with highlight.js depending on language\n    const highlightedCode: any = hljs.highlight(this._lang, codeToParse, true);\n    highlightedCode.value = highlightedCode.value\n      .replace(/=<span class=\"hljs-value\">\"\"<\\/span>/gi, '')\n      .replace('<head>', '')\n      .replace('<head/>', '');\n    return highlightedCode.value;\n  }\n}\n","<div>\n  <div #highlightComponent>\n    <ng-content></ng-content>\n  </div>\n\n  <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n    <td-copy-code-button\n      [copiedContent]=\"copyContent\"\n      [copyCodeToClipboard]=\"copyCodeToClipboard\"\n      [copyCodeTooltips]=\"copyCodeTooltips\"\n    ></td-copy-code-button>\n  </div>\n</div>\n"]}
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.component.js","sourceRoot":"","sources":["../../../../../libs/angular-highlight/src/lib/highlight.component.ts","../../../../../libs/angular-highlight/src/lib/highlight.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,UAAU,EACV,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,eAAe,EACf,SAAS,EACT,iBAAiB,GAElB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAMvD,OAAO,IAAI,MAAM,cAAc,CAAC;;;;;AAOhC,MAAM,OAAO,oBAAoB;IAQ/B;;;;;;;OAOG;IACH,IACI,OAAO,CAAC,OAAe;QACzB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3B,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAClC;IACH,CAAC;IA8BD;;;;;;;OAOG;IAEH,IACI,QAAQ,CAAC,IAAY;QACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IACD,8CAA8C;IAC9C,IACI,IAAI,CAAC,IAAY;QACnB,uCAAuC;QACvC,OAAO,CAAC,IAAI,CACV,oFAAoF,CACrF,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAcD,YACU,SAAoB,EACpB,WAAuB,EACvB,aAA2B,EAC3B,GAAsB;QAHtB,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QACvB,kBAAa,GAAb,aAAa,CAAc;QAC3B,QAAG,GAAH,GAAG,CAAmB;QA3FxB,iBAAY,GAAG,KAAK,CAAC;QAGrB,UAAK,GAAG,YAAY,CAAC;QAErB,aAAQ,GAAG,KAAK,CAAC;QAmBzB;;;;WAIG;QACM,wBAAmB,GAAI,KAAK,CAAC;QAEtC;;;;WAIG;QACM,qBAAgB,GAAuB,EAAE,CAAC;QAEnD;;;;WAIG;QACM,oBAAe,GAAG,KAAK,CAAC;QAEjC;;;;WAIG;QACM,oBAAe,GAAsB,EAAE,CAAC;QA2BjD;;;WAGG;QACO,iBAAY,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAWnE,CAAC;IAEJ,kBAAkB;QAChB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ;gBACG,IAAI,CAAC,aAAa,CAAC,aAAc,CAAC,WAAW,IAAI,EAAE,CAAC;SACrE;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,IAAI,CAAC,IAAI,EAAE;YACT,MAAM,IAAI,KAAK,CACb,oEAAoE,CACrE,CAAC;SACH;QACD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAClC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI;aACrE,QAAQ;YACT,CAAC,CAAC,MAAM;YACR,CAAC,CAAC,OAAO,CAAC;QACZ,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI;aACtE,QAAQ;YACT,CAAC,CAAC,OAAO;YACT,CAAC,CAAC,MAAM,CAAC;IACb,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,IAAmB;QACtC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE;YAClC,kBAAkB;YAClB,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,IAAI,CAAC,WAAW,CAAC,aAAa,EAC9B,WAAW,EACX,EAAE,CACH,CAAC;YAEF,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAE9B,IAAI,IAAI,CAAC,mBAAmB,EAAE;gBAC5B,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,IAAI,CAAC,WAAW,CAAC,aAAa,EAC9B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAC5B,CAAC;aACH;SACF;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAEO,kBAAkB,CAAC,OAAe;QACxC,qFAAqF;QACrF,gDAAgD;QAChD,MAAM,UAAU,GAAmB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;QACvE,MAAM,WAAW,GAAgB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACtE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QACpD,2CAA2C;QAC3C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QAElD,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE9C,WAAW,CAAC,SAAS;YACnB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,eAAe,CAAC,IAAI,EAAE,CAAC;QAE3E,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,MAAM,UAAU,GAAmB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACvE,UAAU,CAAC,SAAS,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;YACvE,UAAU,CAAC,SAAS;gBAClB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;YACnE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;SACxD;IACH,CAAC;IAEO,OAAO,CAAC,QAAgB;QAC9B,qCAAqC;QACrC,QAAQ,GAAG,QAAQ;aAChB,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC;aAC5B,OAAO,CAAC,uBAAuB,EAAE,EAAE,CAAC,CAAC;QACxC,kCAAkC;QAClC,IAAI,KAAK,GAAa,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAE3C,mEAAmE;QACnE,MAAM,wBAAwB,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC7D,MAAM,mBAAmB,GAAG,wBAAwB;YAClD,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC;YAC7B,CAAC,CAAC,IAAI,CAAC;QAET,gEAAgE;QAChE,MAAM,uBAAuB,GAAG,IAAI,MAAM,CAAC,GAAG,GAAG,mBAAmB,CAAC,CAAC;QACtE,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,UAAU,IAAY;YACtC,OAAO,IAAI;iBACR,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,sBAAsB;iBACzC,OAAO,CAAC,uBAAuB,EAAE,EAAE,CAAC;iBACpC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,+BAA+B;QACzD,CAAC,CAAC,CAAC;QAEH,MAAM,WAAW,GAAW,KAAK;aAC9B,IAAI,CAAC,IAAI,CAAC;aACV,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC;aACxB,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC;aACxB,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC;aACtB,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,iDAAiD;QAC5E,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,qDAAqD;QACrD,MAAM,eAAe,GAAQ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC3E,eAAe,CAAC,KAAK,GAAG,eAAe,CAAC,KAAK;aAC1C,OAAO,CAAC,wCAAwC,EAAE,EAAE,CAAC;aACrD,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC;aACrB,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QAC1B,OAAO,eAAe,CAAC,KAAK,CAAC;IAC/B,CAAC;;iHA3NU,oBAAoB;qGAApB,oBAAoB,mmBC3BjC,+dAgBA;2FDWa,oBAAoB;kBALhC,SAAS;+BACE,cAAc;oLAqBpB,OAAO;sBADV,KAAK;gBAcG,mBAAmB;sBAA3B,KAAK;gBAOG,gBAAgB;sBAAxB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAYF,QAAQ;sBADX,KAAK;gBAMF,IAAI;sBADP,KAAK;gBAeI,YAAY;sBAArB,MAAM;gBAC0B,aAAa;sBAA7C,SAAS;uBAAC,oBAAoB;gBACH,QAAQ;sBAAnC,SAAS;uBAAC,eAAe;gBAEJ,OAAO;sBAA5B,SAAS;uBAAC,SAAS","sourcesContent":["import {\n  Component,\n  AfterViewInit,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter,\n  Renderer2,\n  SecurityContext,\n  ViewChild,\n  ChangeDetectorRef,\n  AfterViewChecked,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { MatTooltip } from '@angular/material/tooltip';\nimport {\n  ICopyCodeTooltips,\n  IRawToggleLabels,\n} from './copy-code-button/copy-code-button.component';\n\nimport hljs from 'highlight.js';\n\n@Component({\n  selector: 'td-highlight',\n  styleUrls: ['./highlight.component.scss'],\n  templateUrl: './highlight.component.html',\n})\nexport class TdHighlightComponent implements AfterViewInit, AfterViewChecked {\n  private _initialized = false;\n\n  private _content!: string;\n  private _lang = 'typescript';\n\n  private _showRaw = false;\n\n  /**\n   * content?: string\n   *\n   * Code content to be parsed as highlighted html.\n   * Used to load data dynamically.\n   *\n   * e.g. `.html`, `.ts` , etc.\n   */\n  @Input()\n  set content(content: string) {\n    this._content = content;\n    console.log(this._content);\n    if (this._initialized) {\n      this._loadContent(this._content);\n    }\n  }\n\n  /**\n   * copyCodeToClipboard?: boolean\n   *\n   * Display copy button on code snippets to copy code to clipboard.\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   * toggleRawButton?: boolean\n   *\n   * Display button to toggle raw code.\n   */\n  @Input() toggleRawButton = false;\n\n  /**\n   * rawToggleLabels?: IRawToggleLabels\n   *\n   * Labels for raw toggle button.\n   */\n  @Input() rawToggleLabels?: IRawToggleLabels = {};\n\n  /**\n   * lang?: string\n   *\n   * Language of the code content to be parsed as highlighted html.\n   * Defaults to `typescript`\n   *\n   * e.g. `typescript`, `html` , etc.\n   */\n\n  @Input()\n  set codeLang(lang: string) {\n    this.setLanguage(lang);\n  }\n  /** @deprecated - removed completely @4.0.0 */\n  @Input()\n  set lang(lang: string) {\n    // tslint:disable-next-line: no-console\n    console.warn(\n      'DEPRECATION WARNING: switch to codeLang attribute as lang attribute is deprecated.'\n    );\n    this.setLanguage(lang);\n  }\n\n  copyContent!: string;\n\n  /**\n   * contentReady?: function\n   * Event emitted after the highlight content rendering is finished.\n   */\n  @Output() contentReady: EventEmitter<void> = new EventEmitter<void>();\n  @ViewChild('highlightComponent') highlightComp!: ElementRef;\n  @ViewChild('copyComponent') copyComp!: ElementRef;\n\n  @ViewChild('tooltip') tooltip!: MatTooltip;\n\n  constructor(\n    private _renderer: Renderer2,\n    private _elementRef: ElementRef,\n    private _domSanitizer: DomSanitizer,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewChecked(): void {\n    this.cdr.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n    if (!this._content) {\n      this._content =\n        (<HTMLElement>this.highlightComp.nativeElement).textContent || '';\n    }\n    this._loadContent(this._content);\n\n    this._initialized = true;\n  }\n\n  setLanguage(lang: string): void {\n    if (!lang) {\n      throw new Error(\n        'Error: language attribute must be defined in TdHighlightComponent.'\n      );\n    }\n    this._lang = lang;\n    if (this._initialized) {\n      this._loadContent(this._content);\n    }\n  }\n\n  toggleRawClicked(): void {\n    this._showRaw = !this._showRaw;\n    this._elementRef.nativeElement.querySelector('pre').style.display = this\n      ._showRaw\n      ? 'none'\n      : 'block';\n    this._elementRef.nativeElement.querySelector('.raw').style.display = this\n      ._showRaw\n      ? 'block'\n      : 'none';\n  }\n\n  /**\n   * General method to parse a string of code into HTML Elements and load them into the container\n   */\n  private _loadContent(code: string | null): void {\n    if (code && code.trim().length > 0) {\n      // Clean container\n      this._renderer.setProperty(\n        this._elementRef.nativeElement,\n        'innerHTML',\n        ''\n      );\n\n      this._elementFromString(code);\n\n      if (this.copyCodeToClipboard) {\n        this._renderer.appendChild(\n          this._elementRef.nativeElement,\n          this.copyComp.nativeElement\n        );\n      }\n    }\n    this.contentReady.emit();\n  }\n\n  private _elementFromString(codeStr: string): void {\n    // Renderer2 doesnt have a parsing method, so we have to sanitize and use [innerHTML]\n    // to parse the string into DOM element for now.\n    const preElement: HTMLPreElement = this._renderer.createElement('pre');\n    this._renderer.appendChild(this._elementRef.nativeElement, preElement);\n    const codeElement: HTMLElement = this._renderer.createElement('code');\n    this._renderer.appendChild(preElement, codeElement);\n    // Set .highlight class into <code> element\n    this._renderer.addClass(codeElement, 'highlight');\n\n    const highlightedCode = this._render(codeStr);\n\n    codeElement.innerHTML =\n      this._domSanitizer.sanitize(SecurityContext.HTML, highlightedCode) ?? '';\n\n    if (this.toggleRawButton) {\n      const divElement: HTMLDivElement = this._renderer.createElement('div');\n      divElement.className = 'raw';\n      this._renderer.appendChild(this._elementRef.nativeElement, divElement);\n      divElement.innerHTML =\n        this._domSanitizer.sanitize(SecurityContext.HTML, codeStr) ?? '';\n      this._renderer.setStyle(divElement, 'display', 'none');\n    }\n  }\n\n  private _render(contents: string): string {\n    // Trim leading and trailing newlines\n    contents = contents\n      .replace(/^(\\s|\\t)*\\n+/g, '')\n      .replace(/(\\s|\\t)*\\n+(\\s|\\t)*$/g, '');\n    // Split markup by line characters\n    let lines: string[] = contents.split('\\n');\n\n    // check how much indentation is used by the first actual code 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 code can be parsed correctly\n    const startingWhitespaceRegex = new RegExp('^' + firstLineWhitespace);\n    lines = lines.map(function (line: string): string {\n      return line\n        .replace('=\"\"', '') // remove empty values\n        .replace(startingWhitespaceRegex, '')\n        .replace(/\\s+$/, ''); // remove trailing white spaces\n    });\n\n    const codeToParse: string = lines\n      .join('\\n')\n      .replace(/\\{ \\{/gi, '{{')\n      .replace(/\\} \\}/gi, '}}')\n      .replace(/&lt;/gi, '<')\n      .replace(/&gt;/gi, '>'); // replace with < and > to render HTML in Angular\n    this.copyContent = codeToParse;\n    // Parse code with highlight.js depending on language\n    const highlightedCode: any = hljs.highlight(this._lang, codeToParse, true);\n    highlightedCode.value = highlightedCode.value\n      .replace(/=<span class=\"hljs-value\">\"\"<\\/span>/gi, '')\n      .replace('<head>', '')\n      .replace('<head/>', '');\n    return highlightedCode.value;\n  }\n}\n","<div>\n  <div #highlightComponent>\n    <ng-content></ng-content>\n  </div>\n\n  <div #copyComponent *ngIf=\"copyCodeToClipboard\">\n    <td-copy-code-button\n      [toggleRawButton]=\"toggleRawButton\"\n      [rawToggleLabels]=\"rawToggleLabels\"\n      (toggleRaw)=\"toggleRawClicked()\"\n      [copiedContent]=\"copyContent\"\n      [copyCodeToClipboard]=\"copyCodeToClipboard\"\n      [copyCodeTooltips]=\"copyCodeTooltips\"\n    ></td-copy-code-button>\n  </div>\n</div>\n"]}
|
|
@@ -5,6 +5,7 @@ import { TdHighlightComponent } from './highlight.component';
|
|
|
5
5
|
import { MatIconModule } from '@angular/material/icon';
|
|
6
6
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
7
7
|
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
+
import { MatButtonToggleModule } from '@angular/material/button-toggle';
|
|
8
9
|
import { TdCopyCodeButtonComponent } from './copy-code-button/copy-code-button.component';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export class CovalentHighlightModule {
|
|
@@ -13,11 +14,15 @@ CovalentHighlightModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0",
|
|
|
13
14
|
CovalentHighlightModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.5", ngImport: i0, type: CovalentHighlightModule, declarations: [TdHighlightComponent, TdCopyCodeButtonComponent], imports: [CommonModule,
|
|
14
15
|
ClipboardModule,
|
|
15
16
|
MatIconModule,
|
|
17
|
+
MatButtonToggleModule,
|
|
18
|
+
MatButtonModule,
|
|
16
19
|
MatTooltipModule,
|
|
17
20
|
MatButtonModule], exports: [TdHighlightComponent] });
|
|
18
21
|
CovalentHighlightModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: CovalentHighlightModule, imports: [CommonModule,
|
|
19
22
|
ClipboardModule,
|
|
20
23
|
MatIconModule,
|
|
24
|
+
MatButtonToggleModule,
|
|
25
|
+
MatButtonModule,
|
|
21
26
|
MatTooltipModule,
|
|
22
27
|
MatButtonModule] });
|
|
23
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: CovalentHighlightModule, decorators: [{
|
|
@@ -27,6 +32,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
27
32
|
CommonModule,
|
|
28
33
|
ClipboardModule,
|
|
29
34
|
MatIconModule,
|
|
35
|
+
MatButtonToggleModule,
|
|
36
|
+
MatButtonModule,
|
|
30
37
|
MatTooltipModule,
|
|
31
38
|
MatButtonModule,
|
|
32
39
|
],
|
|
@@ -34,4 +41,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
|
|
|
34
41
|
exports: [TdHighlightComponent],
|
|
35
42
|
}]
|
|
36
43
|
}] });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlnaGxpZ2h0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci1oaWdobGlnaHQvc3JjL2xpYi9oaWdobGlnaHQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDOztBQWUxRixNQUFNLE9BQU8sdUJBQXVCOztvSEFBdkIsdUJBQXVCO3FIQUF2Qix1QkFBdUIsaUJBSG5CLG9CQUFvQixFQUFFLHlCQUF5QixhQVI1RCxZQUFZO1FBQ1osZUFBZTtRQUNmLGFBQWE7UUFDYixxQkFBcUI7UUFDckIsZUFBZTtRQUNmLGdCQUFnQjtRQUNoQixlQUFlLGFBR1Asb0JBQW9CO3FIQUVuQix1QkFBdUIsWUFYaEMsWUFBWTtRQUNaLGVBQWU7UUFDZixhQUFhO1FBQ2IscUJBQXFCO1FBQ3JCLGVBQWU7UUFDZixnQkFBZ0I7UUFDaEIsZUFBZTsyRkFLTix1QkFBdUI7a0JBYm5DLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixhQUFhO3dCQUNiLHFCQUFxQjt3QkFDckIsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLHlCQUF5QixDQUFDO29CQUMvRCxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENsaXBib2FyZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jbGlwYm9hcmQnO1xuaW1wb3J0IHsgVGRIaWdobGlnaHRDb21wb25lbnQgfSBmcm9tICcuL2hpZ2hsaWdodC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0VG9vbHRpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IE1hdEJ1dHRvblRvZ2dsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbi10b2dnbGUnO1xuaW1wb3J0IHsgVGRDb3B5Q29kZUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vY29weS1jb2RlLWJ1dHRvbi9jb3B5LWNvZGUtYnV0dG9uLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgQ2xpcGJvYXJkTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbVGRIaWdobGlnaHRDb21wb25lbnQsIFRkQ29weUNvZGVCdXR0b25Db21wb25lbnRdLFxuICBleHBvcnRzOiBbVGRIaWdobGlnaHRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3ZhbGVudEhpZ2hsaWdodE1vZHVsZSB7fVxuIl19
|