@blackbaud/skyux-lib-code-block 7.0.0 → 8.0.0-alpha.1
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/README.md +4 -36
- package/esm2020/blackbaud-skyux-lib-code-block.mjs +2 -2
- package/esm2020/index.mjs +7 -0
- package/esm2020/{modules → lib/modules}/code/code.component.mjs +1 -1
- package/esm2020/lib/modules/code/code.module.mjs +18 -0
- package/esm2020/lib/modules/code-block/code-block.component.mjs +115 -0
- package/esm2020/lib/modules/code-block/code-block.module.mjs +20 -0
- package/esm2020/lib/modules/code-block/prism-languages.mjs +307 -0
- package/esm2020/lib/modules/shared/sky-code-block-resources.module.mjs +49 -0
- package/fesm2015/blackbaud-skyux-lib-code-block.mjs +396 -389
- package/fesm2015/blackbaud-skyux-lib-code-block.mjs.map +1 -1
- package/fesm2020/blackbaud-skyux-lib-code-block.mjs +396 -389
- package/fesm2020/blackbaud-skyux-lib-code-block.mjs.map +1 -1
- package/index.d.ts +4 -5
- package/{modules → lib/modules}/code/code.component.d.ts +0 -0
- package/{modules → lib/modules}/code/code.module.d.ts +0 -0
- package/lib/modules/code-block/code-block.component.d.ts +23 -0
- package/{modules → lib/modules}/code-block/code-block.module.d.ts +0 -0
- package/lib/modules/code-block/prism-languages.d.ts +154 -0
- package/{modules → lib/modules}/shared/sky-code-block-resources.module.d.ts +1 -1
- package/package.json +18 -3
- package/LICENSE +0 -21
- package/esm2020/modules/code/code.module.mjs +0 -24
- package/esm2020/modules/code-block/code-block.component.mjs +0 -98
- package/esm2020/modules/code-block/code-block.module.mjs +0 -32
- package/esm2020/modules/code-block/prism-languages.mjs +0 -307
- package/esm2020/modules/shared/sky-code-block-resources.module.mjs +0 -41
- package/esm2020/public-api.mjs +0 -7
- package/modules/code-block/code-block.component.d.ts +0 -32
- package/modules/code-block/prism-languages.d.ts +0 -154
- package/public-api.d.ts +0 -4
package/README.md
CHANGED
|
@@ -1,39 +1,7 @@
|
|
|
1
|
-
#
|
|
1
|
+
# code-block
|
|
2
2
|
|
|
3
|
-
[
|
|
4
|
-

|
|
5
|
-
[](https://codecov.io/gh/blackbaud/skyux-lib-code-block/branch/master)
|
|
3
|
+
This library was generated with [Nx](https://nx.dev).
|
|
6
4
|
|
|
7
|
-
|
|
5
|
+
## Running unit tests
|
|
8
6
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
All feature requests, bug reports, or issues should be filed within the [Stache issues](https://github.com/blackbaud/stache2/issues) in the main Stache repository.
|
|
12
|
-
|
|
13
|
-
#### Install dependencies
|
|
14
|
-
|
|
15
|
-
```
|
|
16
|
-
npm install
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
#### Serve the SPA
|
|
20
|
-
|
|
21
|
-
```
|
|
22
|
-
skyux serve
|
|
23
|
-
```
|
|
24
|
-
|
|
25
|
-
#### Test the components
|
|
26
|
-
|
|
27
|
-
```
|
|
28
|
-
skyux test
|
|
29
|
-
```
|
|
30
|
-
|
|
31
|
-
#### Build the components
|
|
32
|
-
|
|
33
|
-
```
|
|
34
|
-
skyux build-public-library
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
## Contributing
|
|
38
|
-
|
|
39
|
-
Read our [contribution guidelines](https://github.com/blackbaud/stache2/blob/master/CONTRIBUTING.md).
|
|
7
|
+
Run `nx test code-block` to execute the unit tests.
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Generated bundle index. Do not edit.
|
|
3
3
|
*/
|
|
4
|
-
export * from './
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxhY2tiYXVkLXNreXV4LWxpYi1jb2RlLWJsb2NrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy9jb2RlLWJsb2NrL3NyYy9ibGFja2JhdWQtc2t5dXgtbGliLWNvZGUtYmxvY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './lib/modules/code-block/code-block.module';
|
|
2
|
+
export * from './lib/modules/code/code.module';
|
|
3
|
+
// Components and directives must be exported to support Angular's "partial" Ivy compiler.
|
|
4
|
+
// Obscure names are used to indicate types are not part of the public API.
|
|
5
|
+
export { SkyCodeComponent as λ1 } from './lib/modules/code/code.component';
|
|
6
|
+
export { SkyCodeBlockComponent as λ2 } from './lib/modules/code-block/code-block.component';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvZGUtYmxvY2svc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNENBQTRDLENBQUM7QUFFM0QsY0FBYyxnQ0FBZ0MsQ0FBQztBQUUvQywwRkFBMEY7QUFDMUYsMkVBQTJFO0FBQzNFLE9BQU8sRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUMzRSxPQUFPLEVBQUUscUJBQXFCLElBQUksRUFBRSxFQUFFLE1BQU0sK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvZGUtYmxvY2svY29kZS1ibG9jay5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvZGUvY29kZS5tb2R1bGUnO1xuXG4vLyBDb21wb25lbnRzIGFuZCBkaXJlY3RpdmVzIG11c3QgYmUgZXhwb3J0ZWQgdG8gc3VwcG9ydCBBbmd1bGFyJ3MgXCJwYXJ0aWFsXCIgSXZ5IGNvbXBpbGVyLlxuLy8gT2JzY3VyZSBuYW1lcyBhcmUgdXNlZCB0byBpbmRpY2F0ZSB0eXBlcyBhcmUgbm90IHBhcnQgb2YgdGhlIHB1YmxpYyBBUEkuXG5leHBvcnQgeyBTa3lDb2RlQ29tcG9uZW50IGFzIM67MSB9IGZyb20gJy4vbGliL21vZHVsZXMvY29kZS9jb2RlLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lDb2RlQmxvY2tDb21wb25lbnQgYXMgzrsyIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9jb2RlLWJsb2NrL2NvZGUtYmxvY2suY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -8,4 +8,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
8
8
|
type: Component,
|
|
9
9
|
args: [{ selector: 'sky-code', changeDetection: ChangeDetectionStrategy.OnPush, template: "<code class=\"sky-code\"><ng-content></ng-content></code>\n", styles: [".sky-code{border-top:1px solid #cdcfd2;border-right:1px solid #cdcfd2;border-bottom:1px solid #cdcfd2;border-left:1px solid #cdcfd2;overflow-wrap:break-word;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:90%;color:#d1282c;padding:0 4px;background-color:#f1eef6}.sky-code ::ng-deep a{color:#d93a3d;text-decoration:underline}::ng-deep a .sky-code{text-decoration:underline}\n"] }]
|
|
10
10
|
}] });
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvZGUtYmxvY2svc3JjL2xpYi9tb2R1bGVzL2NvZGUvY29kZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvZGUtYmxvY2svc3JjL2xpYi9tb2R1bGVzL2NvZGUvY29kZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFuRSxNQUFNLE9BQU8sZ0JBQWdCOzs4R0FBaEIsZ0JBQWdCO2tHQUFoQixnQkFBZ0IsZ0RDUjdCLDZEQUNBOzRGRE9hLGdCQUFnQjtrQkFONUIsU0FBUzsrQkFDRSxVQUFVLG1CQUdILHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1jb2RlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvZGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jb2RlLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lDb2RlQ29tcG9uZW50IHt9XG4iLCI8Y29kZSBjbGFzcz1cInNreS1jb2RlXCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvY29kZT5cbiJdfQ==
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { SkyCodeComponent } from './code.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class SkyCodeModule {
|
|
6
|
+
}
|
|
7
|
+
SkyCodeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
SkyCodeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeModule, declarations: [SkyCodeComponent], imports: [CommonModule], exports: [SkyCodeComponent] });
|
|
9
|
+
SkyCodeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeModule, imports: [CommonModule] });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
declarations: [SkyCodeComponent],
|
|
14
|
+
imports: [CommonModule],
|
|
15
|
+
exports: [SkyCodeComponent],
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvZGUtYmxvY2svc3JjL2xpYi9tb2R1bGVzL2NvZGUvY29kZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBT3BELE1BQU0sT0FBTyxhQUFhOzsyR0FBYixhQUFhOzRHQUFiLGFBQWEsaUJBSlQsZ0JBQWdCLGFBQ3JCLFlBQVksYUFDWixnQkFBZ0I7NEdBRWYsYUFBYSxZQUhkLFlBQVk7NEZBR1gsYUFBYTtrQkFMekIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5Q29kZUNvbXBvbmVudCB9IGZyb20gJy4vY29kZS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lDb2RlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtTa3lDb2RlQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Q29kZU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
var _SkyCodeBlockComponent_instances, _SkyCodeBlockComponent__code, _SkyCodeBlockComponent__languageType, _SkyCodeBlockComponent_changeDetector, _SkyCodeBlockComponent_sanitizer, _SkyCodeBlockComponent_validLanguages, _SkyCodeBlockComponent_updateHeaderVisibility, _SkyCodeBlockComponent_updateCodeBlockClassName, _SkyCodeBlockComponent_setDisplayName, _SkyCodeBlockComponent_formatCode, _SkyCodeBlockComponent_highlightCode, _SkyCodeBlockComponent_updateCodeBlockDisplay;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { Component, ElementRef, Input, ViewChild, } from '@angular/core';
|
|
4
|
+
import Prism from 'prismjs';
|
|
5
|
+
import 'prismjs/plugins/normalize-whitespace/prism-normalize-whitespace';
|
|
6
|
+
import { prismLanguages } from './prism-languages';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/platform-browser";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
import * as i3 from "@blackbaud/skyux-lib-clipboard";
|
|
11
|
+
import * as i4 from "@skyux/i18n";
|
|
12
|
+
const DEFAULT_LANGUAGE = 'markup';
|
|
13
|
+
export class SkyCodeBlockComponent {
|
|
14
|
+
constructor(changeDetector, sanitizer) {
|
|
15
|
+
_SkyCodeBlockComponent_instances.add(this);
|
|
16
|
+
this.hideCopyToClipboard = false;
|
|
17
|
+
_SkyCodeBlockComponent__code.set(this, void 0);
|
|
18
|
+
_SkyCodeBlockComponent__languageType.set(this, DEFAULT_LANGUAGE);
|
|
19
|
+
_SkyCodeBlockComponent_changeDetector.set(this, void 0);
|
|
20
|
+
_SkyCodeBlockComponent_sanitizer.set(this, void 0);
|
|
21
|
+
_SkyCodeBlockComponent_validLanguages.set(this, void 0);
|
|
22
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent_changeDetector, changeDetector, "f");
|
|
23
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent_sanitizer, sanitizer, "f");
|
|
24
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent_validLanguages, Object.keys(Prism.languages), "f");
|
|
25
|
+
// Create an empty SafeHtml value on init since output cannot be undefined.
|
|
26
|
+
this.output = sanitizer.bypassSecurityTrustHtml('');
|
|
27
|
+
}
|
|
28
|
+
set code(value) {
|
|
29
|
+
if (value !== __classPrivateFieldGet(this, _SkyCodeBlockComponent__code, "f")) {
|
|
30
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent__code, value, "f");
|
|
31
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_updateCodeBlockDisplay).call(this);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
get code() {
|
|
35
|
+
return __classPrivateFieldGet(this, _SkyCodeBlockComponent__code, "f");
|
|
36
|
+
}
|
|
37
|
+
set languageType(value) {
|
|
38
|
+
if (value && __classPrivateFieldGet(this, _SkyCodeBlockComponent_validLanguages, "f").indexOf(value) > -1) {
|
|
39
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent__languageType, value, "f");
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
__classPrivateFieldSet(this, _SkyCodeBlockComponent__languageType, DEFAULT_LANGUAGE, "f");
|
|
43
|
+
}
|
|
44
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_setDisplayName).call(this, value);
|
|
45
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_updateCodeBlockClassName).call(this);
|
|
46
|
+
}
|
|
47
|
+
get languageType() {
|
|
48
|
+
return __classPrivateFieldGet(this, _SkyCodeBlockComponent__languageType, "f");
|
|
49
|
+
}
|
|
50
|
+
ngAfterViewInit() {
|
|
51
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_updateCodeBlockClassName).call(this);
|
|
52
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_updateCodeBlockDisplay).call(this);
|
|
53
|
+
}
|
|
54
|
+
ngOnChanges(changes) {
|
|
55
|
+
if (changes['fileName'] ||
|
|
56
|
+
changes['hideCopyToClipboard'] ||
|
|
57
|
+
changes['hideHeader']) {
|
|
58
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_updateHeaderVisibility).call(this);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
_SkyCodeBlockComponent__code = new WeakMap(), _SkyCodeBlockComponent__languageType = new WeakMap(), _SkyCodeBlockComponent_changeDetector = new WeakMap(), _SkyCodeBlockComponent_sanitizer = new WeakMap(), _SkyCodeBlockComponent_validLanguages = new WeakMap(), _SkyCodeBlockComponent_instances = new WeakSet(), _SkyCodeBlockComponent_updateHeaderVisibility = function _SkyCodeBlockComponent_updateHeaderVisibility() {
|
|
63
|
+
this.hideHeader =
|
|
64
|
+
this.hideHeader ||
|
|
65
|
+
(!this.displayName && !this.fileName && this.hideCopyToClipboard);
|
|
66
|
+
}, _SkyCodeBlockComponent_updateCodeBlockClassName = function _SkyCodeBlockComponent_updateCodeBlockClassName() {
|
|
67
|
+
this.codeBlockClassName = `language-${this.languageType}`;
|
|
68
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_changeDetector, "f").markForCheck();
|
|
69
|
+
}, _SkyCodeBlockComponent_setDisplayName = function _SkyCodeBlockComponent_setDisplayName(value = '') {
|
|
70
|
+
this.displayName = value ? prismLanguages[value] : undefined;
|
|
71
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_changeDetector, "f").markForCheck();
|
|
72
|
+
}, _SkyCodeBlockComponent_formatCode = function _SkyCodeBlockComponent_formatCode(code) {
|
|
73
|
+
return Prism.plugins['NormalizeWhitespace'].normalize(code, {
|
|
74
|
+
'remove-trailing': true,
|
|
75
|
+
'remove-indent': true,
|
|
76
|
+
'left-trim': true,
|
|
77
|
+
'right-trim': true,
|
|
78
|
+
indent: 0,
|
|
79
|
+
'remove-initial-line-feed': true,
|
|
80
|
+
'tabs-to-spaces': 2,
|
|
81
|
+
});
|
|
82
|
+
}, _SkyCodeBlockComponent_highlightCode = function _SkyCodeBlockComponent_highlightCode(code) {
|
|
83
|
+
return Prism.highlight(code, Prism.languages[this.languageType], this.languageType);
|
|
84
|
+
}, _SkyCodeBlockComponent_updateCodeBlockDisplay = function _SkyCodeBlockComponent_updateCodeBlockDisplay() {
|
|
85
|
+
if (this.codeTemplateRef) {
|
|
86
|
+
const textContent = this.codeTemplateRef.nativeElement.textContent;
|
|
87
|
+
let code = this.code || textContent;
|
|
88
|
+
if (code) {
|
|
89
|
+
code = __classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_formatCode).call(this, code);
|
|
90
|
+
code = __classPrivateFieldGet(this, _SkyCodeBlockComponent_instances, "m", _SkyCodeBlockComponent_highlightCode).call(this, code);
|
|
91
|
+
}
|
|
92
|
+
this.output = __classPrivateFieldGet(this, _SkyCodeBlockComponent_sanitizer, "f").bypassSecurityTrustHtml(code);
|
|
93
|
+
__classPrivateFieldGet(this, _SkyCodeBlockComponent_changeDetector, "f").detectChanges();
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
SkyCodeBlockComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
97
|
+
SkyCodeBlockComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SkyCodeBlockComponent, selector: "sky-code-block", inputs: { code: "code", fileName: "fileName", languageType: "languageType", hideCopyToClipboard: "hideCopyToClipboard", hideHeader: "hideHeader" }, viewQueries: [{ propertyName: "codeTemplateRef", first: true, predicate: ["codeFromContent"], descendants: true, read: ElementRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"sky-code-block\">\n <div *ngIf=\"!hideHeader\" class=\"sky-code-block-header\">\n <div>\n <span *ngIf=\"fileName\" class=\"sky-emphasized sky-margin-inline-default\">\n {{ fileName }}\n </span>\n <span *ngIf=\"displayName\" class=\"sky-deemphasized\">\n {{ displayName }}\n </span>\n </div>\n <sky-copy-to-clipboard\n *ngIf=\"!hideCopyToClipboard\"\n [copyTarget]=\"skyCodeOutput\"\n buttonText=\"{{ 'sky_copy_to_clipboard_button' | skyLibResources }}\"\n buttonClickedText=\"{{\n 'sky_copy_to_clipboard_button_success' | skyLibResources\n }}\"\n >\n </sky-copy-to-clipboard>\n </div>\n <div #codeFromContent class=\"sky-code-input\">\n <ng-content></ng-content>\n </div>\n <div>\n <pre #skyCodeOutput class=\"sky-code-output\"><code\n [ngClass]=\"codeBlockClassName\"\n [innerHTML]=\"output\"></code></pre>\n </div>\n</div>\n", styles: ["::ng-deep code[class*=language-],pre[class*=language-]{color:#000;text-shadow:0 1px white;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;tab-size:4;-webkit-hyphens:none;hyphens:none}::ng-deep code[class*=language-] .token.comment,::ng-deep code[class*=language-] .token.prolog,::ng-deep code[class*=language-] .token.doctype,::ng-deep code[class*=language-] .token.cdata,pre[class*=language-] .token.comment,pre[class*=language-] .token.prolog,pre[class*=language-] .token.doctype,pre[class*=language-] .token.cdata{color:#5f6c79}::ng-deep code[class*=language-] .token.punctuation,pre[class*=language-] .token.punctuation{color:#5f6c79}::ng-deep code[class*=language-] .namespace,pre[class*=language-] .namespace{color:#10776e}::ng-deep code[class*=language-] .token.property,::ng-deep code[class*=language-] .token.tag,::ng-deep code[class*=language-] .token.boolean,::ng-deep code[class*=language-] .token.number,::ng-deep code[class*=language-] .token.constant,::ng-deep code[class*=language-] .token.symbol,::ng-deep code[class*=language-] .token.deleted,pre[class*=language-] .token.property,pre[class*=language-] .token.tag,pre[class*=language-] .token.boolean,pre[class*=language-] .token.number,pre[class*=language-] .token.constant,pre[class*=language-] .token.symbol,pre[class*=language-] .token.deleted{color:#c50028}::ng-deep code[class*=language-] .token.selector,::ng-deep code[class*=language-] .token.attr-name,::ng-deep code[class*=language-] .token.string,::ng-deep code[class*=language-] .token.char,::ng-deep code[class*=language-] .token.builtin,::ng-deep code[class*=language-] .token.inserted,pre[class*=language-] .token.selector,pre[class*=language-] .token.attr-name,pre[class*=language-] .token.string,pre[class*=language-] .token.char,pre[class*=language-] .token.builtin,pre[class*=language-] .token.inserted{color:#627932}::ng-deep code[class*=language-] .token.operator,::ng-deep code[class*=language-] .token.entity,::ng-deep code[class*=language-] .token.url,::ng-deep code[class*=language-] .language-css .token.string,::ng-deep code[class*=language-] .style .token.string,pre[class*=language-] .token.operator,pre[class*=language-] .token.entity,pre[class*=language-] .token.url,pre[class*=language-] .language-css .token.string,pre[class*=language-] .style .token.string{color:#996525}::ng-deep code[class*=language-] .token.atrule,::ng-deep code[class*=language-] .token.attr-value,::ng-deep code[class*=language-] .token.keyword,pre[class*=language-] .token.atrule,pre[class*=language-] .token.attr-value,pre[class*=language-] .token.keyword{color:#07a}::ng-deep code[class*=language-] .token.function,::ng-deep code[class*=language-] .token.class-name,pre[class*=language-] .token.function,pre[class*=language-] .token.class-name{color:#c50028}::ng-deep code[class*=language-] .token.regex,::ng-deep code[class*=language-] .token.important,::ng-deep code[class*=language-] .token.variable,pre[class*=language-] .token.regex,pre[class*=language-] .token.important,pre[class*=language-] .token.variable{color:#9a690f}::ng-deep code[class*=language-] .token.important,::ng-deep code[class*=language-] .token.bold,pre[class*=language-] .token.important,pre[class*=language-] .token.bold{font-weight:700}::ng-deep code[class*=language-] .token.italic,pre[class*=language-] .token.italic{font-style:italic}::ng-deep code[class*=language-] .token.entity,pre[class*=language-] .token.entity{cursor:help}pre[class*=language-]::selection,pre[class*=language-] ::selection,code[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}.sky-code-input{display:none}.sky-code-output{border-top:1px solid #cdcfd2;border-right:1px solid #cdcfd2;border-bottom:1px solid #cdcfd2;border-left:1px solid #cdcfd2;margin-top:0;padding:20px;background-color:#fff;overflow-x:auto;margin-bottom:20px}.sky-code-block-header{height:45px;border-top:1px solid #cdcfd2;border-right:1px solid #cdcfd2;border-left:1px solid #cdcfd2;background-color:#fff;display:flex;justify-content:space-between;align-items:center;padding:5px 5px 5px 20px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.λ1, selector: "sky-copy-to-clipboard", inputs: ["ariaLabel", "ariaLabelledBy", "copyTarget", "buttonText", "buttonClickedText", "title"] }, { kind: "pipe", type: i4.SkyLibResourcesPipe, name: "skyLibResources" }] });
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockComponent, decorators: [{
|
|
99
|
+
type: Component,
|
|
100
|
+
args: [{ selector: 'sky-code-block', template: "<div class=\"sky-code-block\">\n <div *ngIf=\"!hideHeader\" class=\"sky-code-block-header\">\n <div>\n <span *ngIf=\"fileName\" class=\"sky-emphasized sky-margin-inline-default\">\n {{ fileName }}\n </span>\n <span *ngIf=\"displayName\" class=\"sky-deemphasized\">\n {{ displayName }}\n </span>\n </div>\n <sky-copy-to-clipboard\n *ngIf=\"!hideCopyToClipboard\"\n [copyTarget]=\"skyCodeOutput\"\n buttonText=\"{{ 'sky_copy_to_clipboard_button' | skyLibResources }}\"\n buttonClickedText=\"{{\n 'sky_copy_to_clipboard_button_success' | skyLibResources\n }}\"\n >\n </sky-copy-to-clipboard>\n </div>\n <div #codeFromContent class=\"sky-code-input\">\n <ng-content></ng-content>\n </div>\n <div>\n <pre #skyCodeOutput class=\"sky-code-output\"><code\n [ngClass]=\"codeBlockClassName\"\n [innerHTML]=\"output\"></code></pre>\n </div>\n</div>\n", styles: ["::ng-deep code[class*=language-],pre[class*=language-]{color:#000;text-shadow:0 1px white;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;tab-size:4;-webkit-hyphens:none;hyphens:none}::ng-deep code[class*=language-] .token.comment,::ng-deep code[class*=language-] .token.prolog,::ng-deep code[class*=language-] .token.doctype,::ng-deep code[class*=language-] .token.cdata,pre[class*=language-] .token.comment,pre[class*=language-] .token.prolog,pre[class*=language-] .token.doctype,pre[class*=language-] .token.cdata{color:#5f6c79}::ng-deep code[class*=language-] .token.punctuation,pre[class*=language-] .token.punctuation{color:#5f6c79}::ng-deep code[class*=language-] .namespace,pre[class*=language-] .namespace{color:#10776e}::ng-deep code[class*=language-] .token.property,::ng-deep code[class*=language-] .token.tag,::ng-deep code[class*=language-] .token.boolean,::ng-deep code[class*=language-] .token.number,::ng-deep code[class*=language-] .token.constant,::ng-deep code[class*=language-] .token.symbol,::ng-deep code[class*=language-] .token.deleted,pre[class*=language-] .token.property,pre[class*=language-] .token.tag,pre[class*=language-] .token.boolean,pre[class*=language-] .token.number,pre[class*=language-] .token.constant,pre[class*=language-] .token.symbol,pre[class*=language-] .token.deleted{color:#c50028}::ng-deep code[class*=language-] .token.selector,::ng-deep code[class*=language-] .token.attr-name,::ng-deep code[class*=language-] .token.string,::ng-deep code[class*=language-] .token.char,::ng-deep code[class*=language-] .token.builtin,::ng-deep code[class*=language-] .token.inserted,pre[class*=language-] .token.selector,pre[class*=language-] .token.attr-name,pre[class*=language-] .token.string,pre[class*=language-] .token.char,pre[class*=language-] .token.builtin,pre[class*=language-] .token.inserted{color:#627932}::ng-deep code[class*=language-] .token.operator,::ng-deep code[class*=language-] .token.entity,::ng-deep code[class*=language-] .token.url,::ng-deep code[class*=language-] .language-css .token.string,::ng-deep code[class*=language-] .style .token.string,pre[class*=language-] .token.operator,pre[class*=language-] .token.entity,pre[class*=language-] .token.url,pre[class*=language-] .language-css .token.string,pre[class*=language-] .style .token.string{color:#996525}::ng-deep code[class*=language-] .token.atrule,::ng-deep code[class*=language-] .token.attr-value,::ng-deep code[class*=language-] .token.keyword,pre[class*=language-] .token.atrule,pre[class*=language-] .token.attr-value,pre[class*=language-] .token.keyword{color:#07a}::ng-deep code[class*=language-] .token.function,::ng-deep code[class*=language-] .token.class-name,pre[class*=language-] .token.function,pre[class*=language-] .token.class-name{color:#c50028}::ng-deep code[class*=language-] .token.regex,::ng-deep code[class*=language-] .token.important,::ng-deep code[class*=language-] .token.variable,pre[class*=language-] .token.regex,pre[class*=language-] .token.important,pre[class*=language-] .token.variable{color:#9a690f}::ng-deep code[class*=language-] .token.important,::ng-deep code[class*=language-] .token.bold,pre[class*=language-] .token.important,pre[class*=language-] .token.bold{font-weight:700}::ng-deep code[class*=language-] .token.italic,pre[class*=language-] .token.italic{font-style:italic}::ng-deep code[class*=language-] .token.entity,pre[class*=language-] .token.entity{cursor:help}pre[class*=language-]::selection,pre[class*=language-] ::selection,code[class*=language-]::selection,code[class*=language-] ::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}.sky-code-input{display:none}.sky-code-output{border-top:1px solid #cdcfd2;border-right:1px solid #cdcfd2;border-bottom:1px solid #cdcfd2;border-left:1px solid #cdcfd2;margin-top:0;padding:20px;background-color:#fff;overflow-x:auto;margin-bottom:20px}.sky-code-block-header{height:45px;border-top:1px solid #cdcfd2;border-right:1px solid #cdcfd2;border-left:1px solid #cdcfd2;background-color:#fff;display:flex;justify-content:space-between;align-items:center;padding:5px 5px 5px 20px}\n"] }]
|
|
101
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, propDecorators: { code: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], fileName: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], languageType: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], hideCopyToClipboard: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], hideHeader: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], codeTemplateRef: [{
|
|
112
|
+
type: ViewChild,
|
|
113
|
+
args: ['codeFromContent', { read: ElementRef, static: true }]
|
|
114
|
+
}] } });
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-block.component.js","sourceRoot":"","sources":["../../../../../../../libs/code-block/src/lib/modules/code-block/code-block.component.ts","../../../../../../../libs/code-block/src/lib/modules/code-block/code-block.component.html"],"names":[],"mappings":";;AAAA,OAAO,EAGL,SAAS,EACT,UAAU,EACV,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AAGvB,OAAO,KAAK,MAAM,SAAS,CAAC;AAC5B,OAAO,iEAAiE,CAAC;AAEzE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;;;;;;AAEnD,MAAM,gBAAgB,GAAG,QAAQ,CAAC;AAOlC,MAAM,OAAO,qBAAqB;IAmDhC,YAAY,cAAiC,EAAE,SAAuB;;QAlB/D,wBAAmB,GAAwB,KAAK,CAAC;QAYxD,+CAA2B;QAC3B,+CAAyB,gBAAgB,EAAC;QAC1C,wDAAmC;QACnC,mDAAyB;QACzB,wDAA0B;QAGxB,uBAAA,IAAI,yCAAmB,cAAc,MAAA,CAAC;QACtC,uBAAA,IAAI,oCAAc,SAAS,MAAA,CAAC;QAC5B,uBAAA,IAAI,yCAAmB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAA,CAAC;QAEpD,2EAA2E;QAC3E,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAC;IACtD,CAAC;IAzDD,IACW,IAAI,CAAC,KAAyB;QACvC,IAAI,KAAK,KAAK,uBAAA,IAAI,oCAAO,EAAE;YACzB,uBAAA,IAAI,gCAAU,KAAK,MAAA,CAAC;YACpB,uBAAA,IAAI,uFAAwB,MAA5B,IAAI,CAA0B,CAAC;SAChC;IACH,CAAC;IAED,IAAW,IAAI;QACb,OAAO,uBAAA,IAAI,oCAAO,CAAC;IACrB,CAAC;IAKD,IACW,YAAY,CAAC,KAAyB;QAC/C,IAAI,KAAK,IAAI,uBAAA,IAAI,6CAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE;YACrD,uBAAA,IAAI,wCAAkB,KAAK,MAAA,CAAC;SAC7B;aAAM;YACL,uBAAA,IAAI,wCAAkB,gBAAgB,MAAA,CAAC;SACxC;QAED,uBAAA,IAAI,+EAAgB,MAApB,IAAI,EAAiB,KAAK,CAAC,CAAC;QAC5B,uBAAA,IAAI,yFAA0B,MAA9B,IAAI,CAA4B,CAAC;IACnC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,uBAAA,IAAI,4CAAe,CAAC;IAC7B,CAAC;IA8BM,eAAe;QACpB,uBAAA,IAAI,yFAA0B,MAA9B,IAAI,CAA4B,CAAC;QACjC,uBAAA,IAAI,uFAAwB,MAA5B,IAAI,CAA0B,CAAC;IACjC,CAAC;IAEM,WAAW,CAAC,OAAsB;QACvC,IACE,OAAO,CAAC,UAAU,CAAC;YACnB,OAAO,CAAC,qBAAqB,CAAC;YAC9B,OAAO,CAAC,YAAY,CAAC,EACrB;YACA,uBAAA,IAAI,uFAAwB,MAA5B,IAAI,CAA0B,CAAC;SAChC;IACH,CAAC;;;IAGC,IAAI,CAAC,UAAU;QACb,IAAI,CAAC,UAAU;YACf,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,mBAAmB,CAAC,CAAC;AACtE,CAAC;IAGC,IAAI,CAAC,kBAAkB,GAAG,YAAY,IAAI,CAAC,YAAY,EAAE,CAAC;IAC1D,uBAAA,IAAI,6CAAgB,CAAC,YAAY,EAAE,CAAC;AACtC,CAAC,yFAEe,KAAK,GAAG,EAAE;IACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7D,uBAAA,IAAI,6CAAgB,CAAC,YAAY,EAAE,CAAC;AACtC,CAAC,iFAEW,IAAY;IACtB,OAAO,KAAK,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE;QAC1D,iBAAiB,EAAE,IAAI;QACvB,eAAe,EAAE,IAAI;QACrB,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,IAAI;QAClB,MAAM,EAAE,CAAC;QACT,0BAA0B,EAAE,IAAI;QAChC,gBAAgB,EAAE,CAAC;KACpB,CAAC,CAAC;AACL,CAAC,uFAEc,IAAY;IACzB,OAAO,KAAK,CAAC,SAAS,CACpB,IAAI,EACJ,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAClC,IAAI,CAAC,YAAY,CAClB,CAAC;AACJ,CAAC;IAGC,IAAI,IAAI,CAAC,eAAe,EAAE;QACxB,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,WAAW,CAAC;QACnE,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,WAAW,CAAC;QAEpC,IAAI,IAAI,EAAE;YACR,IAAI,GAAG,uBAAA,IAAI,2EAAY,MAAhB,IAAI,EAAa,IAAI,CAAC,CAAC;YAC9B,IAAI,GAAG,uBAAA,IAAI,8EAAe,MAAnB,IAAI,EAAgB,IAAI,CAAC,CAAC;SAClC;QAED,IAAI,CAAC,MAAM,GAAG,uBAAA,IAAI,wCAAW,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC5D,uBAAA,IAAI,6CAAgB,CAAC,aAAa,EAAE,CAAC;KACtC;AACH,CAAC;mHA5HU,qBAAqB;uGAArB,qBAAqB,ySAsCM,UAAU,gEC9DlD,o7BA6BA;4FDLa,qBAAqB;kBALjC,SAAS;+BACE,gBAAgB;mIAMf,IAAI;sBADd,KAAK;gBAaC,QAAQ;sBADd,KAAK;gBAIK,YAAY;sBADtB,KAAK;gBAiBC,mBAAmB;sBADzB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,eAAe;sBADrB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport Prism from 'prismjs';\nimport 'prismjs/plugins/normalize-whitespace/prism-normalize-whitespace';\n\nimport { prismLanguages } from './prism-languages';\n\nconst DEFAULT_LANGUAGE = 'markup';\n\n@Component({\n  selector: 'sky-code-block',\n  templateUrl: './code-block.component.html',\n  styleUrls: ['./code-block.component.scss'],\n})\nexport class SkyCodeBlockComponent implements AfterViewInit, OnChanges {\n  @Input()\n  public set code(value: string | undefined) {\n    if (value !== this.#_code) {\n      this.#_code = value;\n      this.#updateCodeBlockDisplay();\n    }\n  }\n\n  public get code(): string | undefined {\n    return this.#_code;\n  }\n\n  @Input()\n  public fileName: string | undefined;\n\n  @Input()\n  public set languageType(value: string | undefined) {\n    if (value && this.#validLanguages.indexOf(value) > -1) {\n      this.#_languageType = value;\n    } else {\n      this.#_languageType = DEFAULT_LANGUAGE;\n    }\n\n    this.#setDisplayName(value);\n    this.#updateCodeBlockClassName();\n  }\n\n  public get languageType(): string {\n    return this.#_languageType;\n  }\n\n  @Input()\n  public hideCopyToClipboard: boolean | undefined = false;\n\n  @Input()\n  public hideHeader: boolean | undefined;\n\n  @ViewChild('codeFromContent', { read: ElementRef, static: true })\n  public codeTemplateRef: ElementRef | undefined;\n\n  public codeBlockClassName: string | undefined;\n  public displayName: string | undefined;\n  public output: SafeHtml;\n\n  #_code: string | undefined;\n  #_languageType: string = DEFAULT_LANGUAGE;\n  #changeDetector: ChangeDetectorRef;\n  #sanitizer: DomSanitizer;\n  #validLanguages: string[];\n\n  constructor(changeDetector: ChangeDetectorRef, sanitizer: DomSanitizer) {\n    this.#changeDetector = changeDetector;\n    this.#sanitizer = sanitizer;\n    this.#validLanguages = Object.keys(Prism.languages);\n\n    // Create an empty SafeHtml value on init since output cannot be undefined.\n    this.output = sanitizer.bypassSecurityTrustHtml('');\n  }\n\n  public ngAfterViewInit(): void {\n    this.#updateCodeBlockClassName();\n    this.#updateCodeBlockDisplay();\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes['fileName'] ||\n      changes['hideCopyToClipboard'] ||\n      changes['hideHeader']\n    ) {\n      this.#updateHeaderVisibility();\n    }\n  }\n\n  #updateHeaderVisibility(): void {\n    this.hideHeader =\n      this.hideHeader ||\n      (!this.displayName && !this.fileName && this.hideCopyToClipboard);\n  }\n\n  #updateCodeBlockClassName(): void {\n    this.codeBlockClassName = `language-${this.languageType}`;\n    this.#changeDetector.markForCheck();\n  }\n\n  #setDisplayName(value = ''): void {\n    this.displayName = value ? prismLanguages[value] : undefined;\n    this.#changeDetector.markForCheck();\n  }\n\n  #formatCode(code: string): string {\n    return Prism.plugins['NormalizeWhitespace'].normalize(code, {\n      'remove-trailing': true,\n      'remove-indent': true,\n      'left-trim': true,\n      'right-trim': true,\n      indent: 0,\n      'remove-initial-line-feed': true,\n      'tabs-to-spaces': 2,\n    });\n  }\n\n  #highlightCode(code: string): string {\n    return Prism.highlight(\n      code,\n      Prism.languages[this.languageType],\n      this.languageType\n    );\n  }\n\n  #updateCodeBlockDisplay(): void {\n    if (this.codeTemplateRef) {\n      const textContent = this.codeTemplateRef.nativeElement.textContent;\n      let code = this.code || textContent;\n\n      if (code) {\n        code = this.#formatCode(code);\n        code = this.#highlightCode(code);\n      }\n\n      this.output = this.#sanitizer.bypassSecurityTrustHtml(code);\n      this.#changeDetector.detectChanges();\n    }\n  }\n}\n","<div class=\"sky-code-block\">\n  <div *ngIf=\"!hideHeader\" class=\"sky-code-block-header\">\n    <div>\n      <span *ngIf=\"fileName\" class=\"sky-emphasized sky-margin-inline-default\">\n        {{ fileName }}\n      </span>\n      <span *ngIf=\"displayName\" class=\"sky-deemphasized\">\n        {{ displayName }}\n      </span>\n    </div>\n    <sky-copy-to-clipboard\n      *ngIf=\"!hideCopyToClipboard\"\n      [copyTarget]=\"skyCodeOutput\"\n      buttonText=\"{{ 'sky_copy_to_clipboard_button' | skyLibResources }}\"\n      buttonClickedText=\"{{\n        'sky_copy_to_clipboard_button_success' | skyLibResources\n      }}\"\n    >\n    </sky-copy-to-clipboard>\n  </div>\n  <div #codeFromContent class=\"sky-code-input\">\n    <ng-content></ng-content>\n  </div>\n  <div>\n    <pre #skyCodeOutput class=\"sky-code-output\"><code\n        [ngClass]=\"codeBlockClassName\"\n        [innerHTML]=\"output\"></code></pre>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { SkyClipboardModule } from '@blackbaud/skyux-lib-clipboard';
|
|
4
|
+
import { SkyCodeBlockResourcesModule } from '../shared/sky-code-block-resources.module';
|
|
5
|
+
import { SkyCodeBlockComponent } from './code-block.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class SkyCodeBlockModule {
|
|
8
|
+
}
|
|
9
|
+
SkyCodeBlockModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
SkyCodeBlockModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockModule, declarations: [SkyCodeBlockComponent], imports: [CommonModule, SkyClipboardModule, SkyCodeBlockResourcesModule], exports: [SkyCodeBlockComponent] });
|
|
11
|
+
SkyCodeBlockModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockModule, imports: [CommonModule, SkyClipboardModule, SkyCodeBlockResourcesModule] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SkyCodeBlockModule, decorators: [{
|
|
13
|
+
type: NgModule,
|
|
14
|
+
args: [{
|
|
15
|
+
declarations: [SkyCodeBlockComponent],
|
|
16
|
+
imports: [CommonModule, SkyClipboardModule, SkyCodeBlockResourcesModule],
|
|
17
|
+
exports: [SkyCodeBlockComponent],
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1ibG9jay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvZGUtYmxvY2svc3JjL2xpYi9tb2R1bGVzL2NvZGUtYmxvY2svY29kZS1ibG9jay5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFcEUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFFeEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBTy9ELE1BQU0sT0FBTyxrQkFBa0I7O2dIQUFsQixrQkFBa0I7aUhBQWxCLGtCQUFrQixpQkFKZCxxQkFBcUIsYUFDMUIsWUFBWSxFQUFFLGtCQUFrQixFQUFFLDJCQUEyQixhQUM3RCxxQkFBcUI7aUhBRXBCLGtCQUFrQixZQUhuQixZQUFZLEVBQUUsa0JBQWtCLEVBQUUsMkJBQTJCOzRGQUc1RCxrQkFBa0I7a0JBTDlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLENBQUM7b0JBQ3JDLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxrQkFBa0IsRUFBRSwyQkFBMkIsQ0FBQztvQkFDeEUsT0FBTyxFQUFFLENBQUMscUJBQXFCLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lDbGlwYm9hcmRNb2R1bGUgfSBmcm9tICdAYmxhY2tiYXVkL3NreXV4LWxpYi1jbGlwYm9hcmQnO1xuXG5pbXBvcnQgeyBTa3lDb2RlQmxvY2tSZXNvdXJjZXNNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQvc2t5LWNvZGUtYmxvY2stcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreUNvZGVCbG9ja0NvbXBvbmVudCB9IGZyb20gJy4vY29kZS1ibG9jay5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lDb2RlQmxvY2tDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBTa3lDbGlwYm9hcmRNb2R1bGUsIFNreUNvZGVCbG9ja1Jlc291cmNlc01vZHVsZV0sXG4gIGV4cG9ydHM6IFtTa3lDb2RlQmxvY2tDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lDb2RlQmxvY2tNb2R1bGUge31cbiJdfQ==
|