@ngez/core
Version:
A collection of minimalistic, easy-to-use and fully customizable Angular components, directives and services
203 lines • 20.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, ViewEncapsulation, ViewChild, ElementRef, ContentChild, Output, EventEmitter, HostBinding, PLATFORM_ID, Inject } from "@angular/core";
import { PrettifyService } from "./prettify.service";
import { CodeService } from "./code.service";
import { map, tap } from "rxjs/operators";
import { DomSanitizer } from "@angular/platform-browser";
import { NgEzCodeLoadingComponent } from "./code-loading.component";
import { NgEzCodeLoadingErrorComponent } from "./code-loading-error.component";
import { of } from "rxjs";
import { faClone } from '@fortawesome/free-regular-svg-icons';
import { isPlatformBrowser } from "@angular/common";
var NgEzCodePrettifyComponent = /** @class */ (function () {
function NgEzCodePrettifyComponent(platformId, sanitizer, prettify, service) {
this.platformId = platformId;
this.sanitizer = sanitizer;
this.prettify = prettify;
this.service = service;
this.reload = new EventEmitter();
this.faClone = faClone;
this._loading = false;
this._error = false;
}
Object.defineProperty(NgEzCodePrettifyComponent.prototype, "classes", {
get: /**
* @return {?}
*/
function () {
return this.config && this.config.theme ? this.config.theme : 'dark';
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NgEzCodePrettifyComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
this.update();
};
/**
* @return {?}
*/
NgEzCodePrettifyComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.update();
};
/**
* @return {?}
*/
NgEzCodePrettifyComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
if (!this.codeLoadingErrorComponent || !this.codeLoadingErrorComponent.reloadDirective)
return;
this.subscription = this.codeLoadingErrorComponent.reloadDirective.reload.subscribe(function () {
_this.reload.emit();
_this.update();
});
};
/**
* @return {?}
*/
NgEzCodePrettifyComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this.subscription)
this.subscription.unsubscribe();
};
/**
* @private
* @return {?}
*/
NgEzCodePrettifyComponent.prototype.update = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (!isPlatformBrowser(this.platformId) || !this.config || !(this.config.code || this.config.path))
return;
this._loading = true;
this._error = false;
/** @type {?} */
var code$ = this.config.code
? of(this.config.code)
: this.service.get(this.config.path);
/** @type {?} */
var prettifiedCode$ = code$.pipe(tap(function (code) { return _this._code = code; }), map(function (code) { return _this.prettify.formatCode(code, _this.config.language, _this.config.linenums); }), map(function (code) { return _this.sanitizer.bypassSecurityTrustHtml(code); }), tap(function () { return _this._loading = false; }, function () {
_this._loading = false;
_this._error = true;
}));
this.prettifiedCode$ = prettifiedCode$;
};
Object.defineProperty(NgEzCodePrettifyComponent.prototype, "isLoading", {
get: /**
* @return {?}
*/
function () {
return this.loading || this._loading;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NgEzCodePrettifyComponent.prototype, "hasError", {
get: /**
* @return {?}
*/
function () {
return this.error || this._error;
},
enumerable: true,
configurable: true
});
NgEzCodePrettifyComponent.decorators = [
{ type: Component, args: [{
selector: 'ngez-code-prettify',
template: "<div *ngIf=\"config && config.header\" class=\"ngez-code-prettify-header\">\r\n {{config.header}}\r\n</div>\r\n<div class=\"ngez-code-prettify-content-container\" style=\"position: relative\">\r\n <div *ngIf=\"config && config.canCopy && !isLoading && !hasError\" class=\"ngez-copy-container\">\r\n <button [ngezClipboard]=\"_code\" class=\"ngez-copy-button\">\r\n <fa-icon size=\"2x\" [icon]=\"faClone\"></fa-icon>\r\n </button>\r\n </div>\r\n <div [style.max-height.px]=\"config ? config.maxHeight : null\" class=\"ngez-code-prettify-content\">\r\n <ng-container *ngIf=\"codeLoadingComponent && isLoading\">\r\n <ng-container *ngTemplateOutlet=\"codeLoadingComponent.template\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"codeLoadingErrorComponent && hasError\">\r\n <ng-container *ngTemplateOutlet=\"codeLoadingErrorComponent.template\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"(prettifiedCode$ | async) as code\">\r\n <pre #pre class=\"ngez-code-prettify\" [innerHTML]=\"code\"></pre>\r\n </ng-container>\r\n </div>\r\n</div>",
encapsulation: ViewEncapsulation.None,
styles: ["ngez-code-prettify{display:block}.ngez-code-prettify{margin-top:0;margin-bottom:0}.ngez-code-prettify-content-container:hover .ngez-copy-button{display:inline-block}.ngez-code-prettify-content{overflow:auto;padding:12px}.ngez-copy-container{z-index:2;position:absolute;top:5px;right:16px}.ngez-copy-container .ngez-copy-button{outline:0;display:none;border:none;background-color:transparent;margin:0;text-decoration:none;cursor:pointer;text-align:center;transition:background 250ms ease-in-out,transform 150ms,-webkit-transform 150ms;-webkit-appearance:none;-moz-appearance:none}ol.linenums{margin-top:0;margin-bottom:0;color:#aeaeae}ol.linenums li.L0,ol.linenums li.L1,ol.linenums li.L2,ol.linenums li.L3,ol.linenums li.L5,ol.linenums li.L6,ol.linenums li.L7,ol.linenums li.L8,ol.linenums li.L9{list-style-type:decimal;background-color:inherit}.ngez-code-prettify-header{padding:10px}.light .ngez-copy-button:hover{color:#000b29}.light .ngez-code-prettify-header{background-color:#000b29;color:#fff}.light .ngez-code-prettify-content{background-color:rgba(241,241,241,.2)}.light .ngez-copy-button{color:#1e1e1e}.light .ngez-code-prettify{background-color:rgba(241,241,241,.2)}.light .ngez-code-prettify .str{color:#183691}.light .ngez-code-prettify .kwd{color:#a71d5d}.light .ngez-code-prettify .com{color:#969896}.light .ngez-code-prettify .lit,.light .ngez-code-prettify .typ{color:#0086b3}.light .ngez-code-prettify .clo,.light .ngez-code-prettify .opn,.light .ngez-code-prettify .pun{color:#333}.light .ngez-code-prettify .tag{color:navy}.light .ngez-code-prettify .atn{color:#795da3}.light .ngez-code-prettify .atv{color:#183691}.light .ngez-code-prettify .dec{color:#333}.light .ngez-code-prettify .var{color:teal}.light .ngez-code-prettify .fun{color:#900}.dark .ngez-copy-button:hover{color:#d70026}.dark .ngez-code-prettify-header{background-color:#d70026;color:#fff}.dark .ngez-code-prettify-content{border:0;background-color:#1e1e1e}.dark .ngez-copy-button{color:#fff}.dark .ngez-code-prettify{background-color:#1e1e1e}.dark .ngez-code-prettify.nocode{color:#fff}.dark .ngez-code-prettify .str{color:#b5bd68}.dark .ngez-code-prettify .kwd{color:#b294bb}.dark .ngez-code-prettify .pln{color:#fff}.dark .ngez-code-prettify .com{color:#969896}.dark .ngez-code-prettify .typ{color:#81a2be}.dark .ngez-code-prettify .lit{color:#de935f}.dark .ngez-code-prettify .clo,.dark .ngez-code-prettify .opn,.dark .ngez-code-prettify .pun{color:#c5c8c6}.dark .ngez-code-prettify .tag{color:#c66}.dark .ngez-code-prettify .atn{color:#de935f}.dark .ngez-code-prettify .atv{color:#8abeb7}.dark .ngez-code-prettify .dec{color:#de935f}.dark .ngez-code-prettify .var{color:#c66}.dark .ngez-code-prettify .fun{color:#81a2be}"]
}] }
];
/** @nocollapse */
NgEzCodePrettifyComponent.ctorParameters = function () { return [
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] },
{ type: DomSanitizer },
{ type: PrettifyService },
{ type: CodeService }
]; };
NgEzCodePrettifyComponent.propDecorators = {
config: [{ type: Input }],
loading: [{ type: Input }],
error: [{ type: Input }],
reload: [{ type: Output }],
pre: [{ type: ViewChild, args: ['pre',] }],
codeLoadingComponent: [{ type: ContentChild, args: [NgEzCodeLoadingComponent,] }],
codeLoadingErrorComponent: [{ type: ContentChild, args: [NgEzCodeLoadingErrorComponent,] }],
classes: [{ type: HostBinding, args: ['class',] }]
};
return NgEzCodePrettifyComponent;
}());
export { NgEzCodePrettifyComponent };
if (false) {
/** @type {?} */
NgEzCodePrettifyComponent.prototype.config;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.loading;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.error;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.reload;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.pre;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.codeLoadingComponent;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.codeLoadingErrorComponent;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.faClone;
/** @type {?} */
NgEzCodePrettifyComponent.prototype._code;
/** @type {?} */
NgEzCodePrettifyComponent.prototype._loading;
/** @type {?} */
NgEzCodePrettifyComponent.prototype._error;
/** @type {?} */
NgEzCodePrettifyComponent.prototype.prettifiedCode$;
/**
* @type {?}
* @private
*/
NgEzCodePrettifyComponent.prototype.subscription;
/**
* @type {?}
* @private
*/
NgEzCodePrettifyComponent.prototype.platformId;
/**
* @type {?}
* @private
*/
NgEzCodePrettifyComponent.prototype.sanitizer;
/**
* @type {?}
* @private
*/
NgEzCodePrettifyComponent.prototype.prettify;
/**
* @type {?}
* @private
*/
NgEzCodePrettifyComponent.prototype.service;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-prettify.component.js","sourceRoot":"ng://@ngez/core/","sources":["code-prettify/code-prettify.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { \r\n    Component, \r\n    Input, \r\n    ViewEncapsulation, \r\n    ViewChild, \r\n    ElementRef, \r\n    ContentChild,  \r\n    AfterContentInit, \r\n    Output, \r\n    EventEmitter, \r\n    OnDestroy, \r\n    HostBinding,\r\n    OnChanges,\r\n    OnInit,\r\n    PLATFORM_ID, \r\n    Inject} from \"@angular/core\";\r\nimport { PrettifyService } from \"./prettify.service\";\r\nimport { CodeService } from \"./code.service\";\r\nimport { map, switchMap, tap, delay } from \"rxjs/operators\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { NgEzCodeLoadingComponent } from \"./code-loading.component\";\r\nimport { NgEzCodeLoadingErrorComponent } from \"./code-loading-error.component\";\r\nimport { Observable, of, Subscription } from \"rxjs\";\r\nimport { NgEzCodePrettifyConfig } from \"./models\";\r\nimport { NgEzReloadDirective } from \"./reload.directive\";\r\nimport { faClone, IconDefinition } from '@fortawesome/free-regular-svg-icons';\r\nimport { isPlatformBrowser } from \"@angular/common\";\r\n\r\n@Component({\r\n    selector: 'ngez-code-prettify',\r\n    templateUrl: './code-prettify.component.html',\r\n    styleUrls: ['./code-prettify.component.scss'],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class NgEzCodePrettifyComponent implements OnChanges, OnInit, AfterContentInit, OnDestroy {\r\n\r\n    @Input() config: NgEzCodePrettifyConfig;\r\n\r\n    @Input() loading: boolean;\r\n\r\n    @Input() error: boolean;\r\n\r\n    @Output() reload = new EventEmitter();\r\n\r\n    @ViewChild('pre') pre: ElementRef;\r\n\r\n    @ContentChild(NgEzCodeLoadingComponent) codeLoadingComponent: NgEzCodeLoadingComponent;\r\n\r\n    @ContentChild(NgEzCodeLoadingErrorComponent) codeLoadingErrorComponent: NgEzCodeLoadingErrorComponent;\r\n\r\n    @HostBinding('class') get classes(): string {\r\n        return this.config && this.config.theme ? this.config.theme : 'dark';\r\n    }\r\n\r\n    faClone: IconDefinition = faClone;\r\n\r\n    _code: string;\r\n    \r\n    _loading = false;\r\n\r\n    _error = false;\r\n\r\n    prettifiedCode$: Observable<SafeHtml>;\r\n\r\n    private subscription: Subscription;\r\n\r\n    constructor(\r\n        @Inject(PLATFORM_ID) private platformId: Object,\r\n        private sanitizer: DomSanitizer,\r\n        private prettify: PrettifyService,\r\n        private service: CodeService) { }\r\n\r\n    ngOnChanges() {\r\n        this.update();\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.update();\r\n    }\r\n\r\n    ngAfterContentInit() {\r\n        if (!this.codeLoadingErrorComponent || !this.codeLoadingErrorComponent.reloadDirective)\r\n            return;\r\n        this.subscription = this.codeLoadingErrorComponent.reloadDirective.reload.subscribe(() => {\r\n            this.reload.emit();\r\n            this.update();\r\n        });\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if(this.subscription)\r\n            this.subscription.unsubscribe();\r\n    }\r\n\r\n    private update() {\r\n\r\n        if (!isPlatformBrowser(this.platformId) || !this.config || !(this.config.code || this.config.path))\r\n            return;\r\n\r\n        this._loading = true;\r\n        this._error = false;\r\n\r\n        const code$ = this.config.code\r\n            ? of(this.config.code)\r\n            : this.service.get(this.config.path);\r\n\r\n        const prettifiedCode$ = code$.pipe(\r\n            tap(code => this._code = code),\r\n            map(code => this.prettify.formatCode(code, this.config.language, this.config.linenums)),\r\n            map(code => this.sanitizer.bypassSecurityTrustHtml(code)),\r\n            tap(() => this._loading = false, () => {\r\n                this._loading = false;\r\n                this._error = true;\r\n            })\r\n        );\r\n\r\n        this.prettifiedCode$ = prettifiedCode$;\r\n    }\r\n\r\n    get isLoading(): boolean {\r\n        return this.loading || this._loading;\r\n    }\r\n\r\n    get hasError(): boolean {\r\n        return this.error || this._error;\r\n    }\r\n}"]}