ngx-highlightjs
Advanced tools
Comparing version 4.0.1 to 4.0.2
@@ -878,3 +878,3 @@ (function (global, factory) { | ||
// Set code text before highlighting | ||
this.setCode(code); | ||
this.setTextContent(code); | ||
this._hljs.highlightAuto(code, languages).subscribe((/** | ||
@@ -886,3 +886,3 @@ * @param {?} res | ||
// Set highlighted code | ||
_this.setCode(res.value); | ||
_this.setInnerHTML(res.value); | ||
// Check if user want to show line numbers | ||
@@ -947,3 +947,3 @@ if (_this.lineNumbers && _this._options && _this._options.lineNumbers) { | ||
*/ | ||
Highlight.prototype.setCode = /** | ||
Highlight.prototype.setTextContent = /** | ||
* @private | ||
@@ -959,2 +959,21 @@ * @param {?} content | ||
function () { | ||
return _this._nativeElement.textContent = content; | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
Highlight.prototype.setInnerHTML = /** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
function (content) { | ||
var _this = this; | ||
rxjs.animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
return _this._nativeElement.innerHTML = _this._sanitizer.sanitize(core.SecurityContext.HTML, content); | ||
@@ -961,0 +980,0 @@ })); |
@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/platform-browser"),require("rxjs"),require("rxjs/operators"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-highlightjs",["exports","@angular/core","@angular/platform-browser","rxjs","rxjs/operators","@angular/common"],t):t((e=e||self)["ngx-highlightjs"]={},e.ng.core,e.ng.platformBrowser,e.rxjs,e.rxjs.operators,e.ng.common)}(this,(function(e,t,r,n,i,o){"use strict"; | ||
and limitations under the License. | ||
***************************************************************************** */function a(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,i,o=r.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)a.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(i)throw i.error}}return a}var u=new t.InjectionToken("HIGHLIGHT_OPTIONS"),s=function(){function e(e,t,r){var a=this;this._options=r,this._ready=new n.BehaviorSubject(null),this.ready=this._ready.asObservable().pipe(i.filter((function(e){return!!e})),i.take(1)),o.isPlatformBrowser(t)&&e.defaultView.hljs?this._ready.next(e.defaultView.hljs):this._loadLibrary().pipe(i.switchMap((function(t){return a._options&&a._options.lineNumbers?(e.defaultView.hljs=t,l(import("highlightjs-line-numbers.js")).pipe(i.tap((function(){return a._ready.next(t)})))):(a._ready.next(t),n.EMPTY)})),i.catchError((function(e){return console.error("Unable to load hljs library",e),n.EMPTY}))).subscribe()}return e.prototype._loadLibrary=function(){var e=this;return this._options&&this._options.languages&&Object.keys(this._options.languages).length?n.from(l(import("highlight.js/lib/highlight"))).pipe(i.switchMap((function(t){return e._loadLanguages(t)}))):n.from(l(import("highlight.js")))},e.prototype._loadLanguages=function(e){var t=Object.entries(this._options.languages).map((function(t){var r=a(t,2),n=r[0],o=r[1];return l(o()).pipe(i.tap((function(t){return e.registerLanguage(n,t)})))}));return n.zip.apply(void 0,function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}(t)).pipe(i.map((function(){return e})))},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[o.DOCUMENT]}]},{type:Object,decorators:[{type:t.Inject,args:[t.PLATFORM_ID]}]},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e(t.ɵɵinject(o.DOCUMENT),t.ɵɵinject(t.PLATFORM_ID),t.ɵɵinject(u,8))},token:e,providedIn:"root"}),e}();var l=function(e){return n.from(e).pipe(i.filter((function(e){return!!e&&!!e.default})),i.map((function(e){return e.default})))},p=function(){function e(e,t){var r=this;this._loader=e,e.ready.pipe().subscribe((function(e){r._hljs=e,t&&t.config&&(e.configure(t.config),e.listLanguages().length<1&&console.error("[HighlightJS]: No languages were registered!"))}))}return Object.defineProperty(e.prototype,"hljs",{get:function(){return this._hljs},enumerable:!0,configurable:!0}),e.prototype.highlight=function(e,t,r,n){return this._loader.ready.pipe(i.map((function(i){return i.highlight(e,t,r,n)})))},e.prototype.highlightAuto=function(e,t){return this._loader.ready.pipe(i.map((function(r){return r.highlightAuto(e,t)})))},e.prototype.fixMarkup=function(e){return this._loader.ready.pipe(i.map((function(t){return t.fixMarkup(e)})))},e.prototype.highlightBlock=function(e){return this._loader.ready.pipe(i.map((function(t){return t.highlightBlock(e)})))},e.prototype.configure=function(e){return this._loader.ready.pipe(i.map((function(t){return t.configure(e)})))},e.prototype.initHighlighting=function(){return this._loader.ready.pipe(i.map((function(e){return e.initHighlighting()})))},e.prototype.registerLanguage=function(e,t){return this._loader.ready.pipe(i.tap((function(r){return r.registerLanguage(e,t)})))},e.prototype.listLanguages=function(){return this._loader.ready.pipe(i.map((function(e){return e.listLanguages()})))},e.prototype.getLanguage=function(e){return this._loader.ready.pipe(i.map((function(t){return t.getLanguage(e)})))},e.prototype.lineNumbersBlock=function(e){return this._loader.ready.pipe(i.filter((function(e){return!!e.lineNumbersBlock})),i.tap((function(t){return t.lineNumbersBlock(e)})))},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:s},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e(t.ɵɵinject(s),t.ɵɵinject(u,8))},token:e,providedIn:"root"}),e}();var c=function(){function e(e,r,n,i){this._hljs=r,this._sanitizer=n,this._options=i,this.highlighted=new t.EventEmitter,this._nativeElement=e.nativeElement}return e.prototype.ngOnChanges=function(e){e.code&&e.code.currentValue&&e.code.currentValue!==e.code.previousValue&&this.highlightElement(this.code,this.languages)},e.prototype.highlightElement=function(e,t){var r=this;this.setCode(e),this._hljs.highlightAuto(e,t).subscribe((function(e){r.setCode(e.value),r.lineNumbers&&r._options&&r._options.lineNumbers&&r.addLineNumbers(),r.highlighted.emit(e)}))},e.prototype.addLineNumbers=function(){var e=this;this.destroyLineNumbersObserver(),n.animationFrameScheduler.schedule((function(){e._hljs.lineNumbersBlock(e._nativeElement).subscribe(),e._lineNumbersObs=new MutationObserver((function(){e._nativeElement.firstElementChild&&"TABLE"===e._nativeElement.firstElementChild.tagName.toUpperCase()&&e._nativeElement.classList.add("hljs-line-numbers"),e.destroyLineNumbersObserver()})),e._lineNumbersObs.observe(e._nativeElement,{childList:!0})}))},e.prototype.destroyLineNumbersObserver=function(){this._lineNumbersObs&&(this._lineNumbersObs.disconnect(),this._lineNumbersObs=null)},e.prototype.setCode=function(e){var r=this;n.animationFrameScheduler.schedule((function(){return r._nativeElement.innerHTML=r._sanitizer.sanitize(t.SecurityContext.HTML,e)}))},e.decorators=[{type:t.Directive,args:[{host:{"[class.hljs]":"true"},selector:"[highlight]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:p},{type:r.DomSanitizer},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.propDecorators={code:[{type:t.Input,args:["highlight"]}],languages:[{type:t.Input}],lineNumbers:[{type:t.Input}],highlighted:[{type:t.Output}]},e}();var h=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[c],exports:[c]}]}],e}();e.HIGHLIGHT_OPTIONS=u,e.Highlight=c,e.HighlightJS=p,e.HighlightLoader=s,e.HighlightModule=h,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
***************************************************************************** */function a(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,i,o=r.call(e),a=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)a.push(n.value)}catch(e){i={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(i)throw i.error}}return a}var u=new t.InjectionToken("HIGHLIGHT_OPTIONS"),s=function(){function e(e,t,r){var a=this;this._options=r,this._ready=new n.BehaviorSubject(null),this.ready=this._ready.asObservable().pipe(i.filter((function(e){return!!e})),i.take(1)),o.isPlatformBrowser(t)&&e.defaultView.hljs?this._ready.next(e.defaultView.hljs):this._loadLibrary().pipe(i.switchMap((function(t){return a._options&&a._options.lineNumbers?(e.defaultView.hljs=t,l(import("highlightjs-line-numbers.js")).pipe(i.tap((function(){return a._ready.next(t)})))):(a._ready.next(t),n.EMPTY)})),i.catchError((function(e){return console.error("Unable to load hljs library",e),n.EMPTY}))).subscribe()}return e.prototype._loadLibrary=function(){var e=this;return this._options&&this._options.languages&&Object.keys(this._options.languages).length?n.from(l(import("highlight.js/lib/highlight"))).pipe(i.switchMap((function(t){return e._loadLanguages(t)}))):n.from(l(import("highlight.js")))},e.prototype._loadLanguages=function(e){var t=Object.entries(this._options.languages).map((function(t){var r=a(t,2),n=r[0],o=r[1];return l(o()).pipe(i.tap((function(t){return e.registerLanguage(n,t)})))}));return n.zip.apply(void 0,function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(a(arguments[t]));return e}(t)).pipe(i.map((function(){return e})))},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:void 0,decorators:[{type:t.Inject,args:[o.DOCUMENT]}]},{type:Object,decorators:[{type:t.Inject,args:[t.PLATFORM_ID]}]},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e(t.ɵɵinject(o.DOCUMENT),t.ɵɵinject(t.PLATFORM_ID),t.ɵɵinject(u,8))},token:e,providedIn:"root"}),e}();var l=function(e){return n.from(e).pipe(i.filter((function(e){return!!e&&!!e.default})),i.map((function(e){return e.default})))},p=function(){function e(e,t){var r=this;this._loader=e,e.ready.pipe().subscribe((function(e){r._hljs=e,t&&t.config&&(e.configure(t.config),e.listLanguages().length<1&&console.error("[HighlightJS]: No languages were registered!"))}))}return Object.defineProperty(e.prototype,"hljs",{get:function(){return this._hljs},enumerable:!0,configurable:!0}),e.prototype.highlight=function(e,t,r,n){return this._loader.ready.pipe(i.map((function(i){return i.highlight(e,t,r,n)})))},e.prototype.highlightAuto=function(e,t){return this._loader.ready.pipe(i.map((function(r){return r.highlightAuto(e,t)})))},e.prototype.fixMarkup=function(e){return this._loader.ready.pipe(i.map((function(t){return t.fixMarkup(e)})))},e.prototype.highlightBlock=function(e){return this._loader.ready.pipe(i.map((function(t){return t.highlightBlock(e)})))},e.prototype.configure=function(e){return this._loader.ready.pipe(i.map((function(t){return t.configure(e)})))},e.prototype.initHighlighting=function(){return this._loader.ready.pipe(i.map((function(e){return e.initHighlighting()})))},e.prototype.registerLanguage=function(e,t){return this._loader.ready.pipe(i.tap((function(r){return r.registerLanguage(e,t)})))},e.prototype.listLanguages=function(){return this._loader.ready.pipe(i.map((function(e){return e.listLanguages()})))},e.prototype.getLanguage=function(e){return this._loader.ready.pipe(i.map((function(t){return t.getLanguage(e)})))},e.prototype.lineNumbersBlock=function(e){return this._loader.ready.pipe(i.filter((function(e){return!!e.lineNumbersBlock})),i.tap((function(t){return t.lineNumbersBlock(e)})))},e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ctorParameters=function(){return[{type:s},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.ngInjectableDef=t.ɵɵdefineInjectable({factory:function(){return new e(t.ɵɵinject(s),t.ɵɵinject(u,8))},token:e,providedIn:"root"}),e}();var c=function(){function e(e,r,n,i){this._hljs=r,this._sanitizer=n,this._options=i,this.highlighted=new t.EventEmitter,this._nativeElement=e.nativeElement}return e.prototype.ngOnChanges=function(e){e.code&&e.code.currentValue&&e.code.currentValue!==e.code.previousValue&&this.highlightElement(this.code,this.languages)},e.prototype.highlightElement=function(e,t){var r=this;this.setTextContent(e),this._hljs.highlightAuto(e,t).subscribe((function(e){r.setInnerHTML(e.value),r.lineNumbers&&r._options&&r._options.lineNumbers&&r.addLineNumbers(),r.highlighted.emit(e)}))},e.prototype.addLineNumbers=function(){var e=this;this.destroyLineNumbersObserver(),n.animationFrameScheduler.schedule((function(){e._hljs.lineNumbersBlock(e._nativeElement).subscribe(),e._lineNumbersObs=new MutationObserver((function(){e._nativeElement.firstElementChild&&"TABLE"===e._nativeElement.firstElementChild.tagName.toUpperCase()&&e._nativeElement.classList.add("hljs-line-numbers"),e.destroyLineNumbersObserver()})),e._lineNumbersObs.observe(e._nativeElement,{childList:!0})}))},e.prototype.destroyLineNumbersObserver=function(){this._lineNumbersObs&&(this._lineNumbersObs.disconnect(),this._lineNumbersObs=null)},e.prototype.setTextContent=function(e){var t=this;n.animationFrameScheduler.schedule((function(){return t._nativeElement.textContent=e}))},e.prototype.setInnerHTML=function(e){var r=this;n.animationFrameScheduler.schedule((function(){return r._nativeElement.innerHTML=r._sanitizer.sanitize(t.SecurityContext.HTML,e)}))},e.decorators=[{type:t.Directive,args:[{host:{"[class.hljs]":"true"},selector:"[highlight]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:p},{type:r.DomSanitizer},{type:void 0,decorators:[{type:t.Optional},{type:t.Inject,args:[u]}]}]},e.propDecorators={code:[{type:t.Input,args:["highlight"]}],languages:[{type:t.Input}],lineNumbers:[{type:t.Input}],highlighted:[{type:t.Output}]},e}();var h=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[c],exports:[c]}]}],e}();e.HIGHLIGHT_OPTIONS=u,e.Highlight=c,e.HighlightJS=p,e.HighlightLoader=s,e.HighlightModule=h,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=ngx-highlightjs.umd.min.js.map |
@@ -45,3 +45,3 @@ /** | ||
// Set code text before highlighting | ||
this.setCode(code); | ||
this.setTextContent(code); | ||
this._hljs.highlightAuto(code, languages).subscribe((/** | ||
@@ -53,3 +53,3 @@ * @param {?} res | ||
// Set highlighted code | ||
this.setCode(res.value); | ||
this.setInnerHTML(res.value); | ||
// Check if user want to show line numbers | ||
@@ -105,6 +105,17 @@ if (this.lineNumbers && this._options && this._options.lineNumbers) { | ||
*/ | ||
setCode(content) { | ||
setTextContent(content) { | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
() => this._nativeElement.textContent = content)); | ||
} | ||
/** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
setInnerHTML(content) { | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
() => this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content))); | ||
@@ -169,2 +180,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.js","sourceRoot":"ng://ngx-highlightjs/","sources":["lib/highlight.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  Input,\r\n  Output,\r\n  Inject,\r\n  Optional,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SecurityContext\r\n} from '@angular/core';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { animationFrameScheduler } from 'rxjs';\r\nimport { HighlightJS } from './highlight.service';\r\nimport { HIGHLIGHT_OPTIONS, HighlightOptions, HighlightResult } from './highlight.model';\r\n\r\n@Directive({\r\n  host: {\r\n    '[class.hljs]': 'true'\r\n  },\r\n  selector: '[highlight]'\r\n})\r\nexport class Highlight implements OnChanges {\r\n\r\n  // Highlighted Code\r\n  private readonly _nativeElement: HTMLElement;\r\n\r\n  // Temp observer to observe when line numbers has been added to code element\r\n  private _lineNumbersObs: any;\r\n\r\n  // Highlight code input\r\n  @Input('highlight') code!: string;\r\n\r\n  // An optional array of language names and aliases restricting detection to only those languages.\r\n  // The subset can also be set with configure, but the local parameter overrides the option if set.\r\n  @Input() languages!: string[];\r\n\r\n  // Show line numbers\r\n  @Input() lineNumbers!: boolean;\r\n\r\n  // Stream that emits when code string is highlighted\r\n  @Output() highlighted = new EventEmitter<HighlightResult>();\r\n\r\n  constructor(el: ElementRef,\r\n              private _hljs: HighlightJS,\r\n              private _sanitizer: DomSanitizer,\r\n              @Optional() @Inject(HIGHLIGHT_OPTIONS) private _options: HighlightOptions) {\r\n    this._nativeElement = el.nativeElement;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (\r\n      changes.code &&\r\n      changes.code.currentValue &&\r\n      changes.code.currentValue !== changes.code.previousValue\r\n    ) {\r\n      this.highlightElement(this.code, this.languages);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Highlighting with language detection and fix markup.\r\n   * @param code Accepts a string with the code to highlight\r\n   * @param languages An optional array of language names and aliases restricting detection to only those languages.\r\n   * The subset can also be set with configure, but the local parameter overrides the option if set.\r\n   */\r\n  highlightElement(code: string, languages?: string[]): void {\r\n    // Set code text before highlighting\r\n    this.setCode(code);\r\n    this._hljs.highlightAuto(code, languages).subscribe((res: any) => {\r\n      // Set highlighted code\r\n      this.setCode(res.value);\r\n      // Check if user want to show line numbers\r\n      if (this.lineNumbers && this._options && this._options.lineNumbers) {\r\n        this.addLineNumbers();\r\n      }\r\n      // Forward highlight response to the highlighted output\r\n      this.highlighted.emit(res);\r\n    });\r\n  }\r\n\r\n  private addLineNumbers() {\r\n    // Clean up line numbers observer\r\n    this.destroyLineNumbersObserver();\r\n    animationFrameScheduler.schedule(() => {\r\n      // Add line numbers\r\n      this._hljs.lineNumbersBlock(this._nativeElement).subscribe();\r\n      // If lines count is 1, the line numbers library will not add numbers\r\n      // Observe changes to add 'hljs-line-numbers' class only when line numbers is added to the code element\r\n      this._lineNumbersObs = new MutationObserver(() => {\r\n        if (this._nativeElement.firstElementChild && this._nativeElement.firstElementChild.tagName.toUpperCase() === 'TABLE') {\r\n          this._nativeElement.classList.add('hljs-line-numbers');\r\n        }\r\n        this.destroyLineNumbersObserver();\r\n      });\r\n      this._lineNumbersObs.observe(this._nativeElement, { childList: true });\r\n    });\r\n  }\r\n\r\n  private destroyLineNumbersObserver() {\r\n    if (this._lineNumbersObs) {\r\n      this._lineNumbersObs.disconnect();\r\n      this._lineNumbersObs = null;\r\n    }\r\n  }\r\n\r\n  private setCode(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content)\r\n    );\r\n  }\r\n}\r\n\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.js","sourceRoot":"ng://ngx-highlightjs/","sources":["lib/highlight.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  Input,\r\n  Output,\r\n  Inject,\r\n  Optional,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SecurityContext\r\n} from '@angular/core';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { animationFrameScheduler } from 'rxjs';\r\nimport { HighlightJS } from './highlight.service';\r\nimport { HIGHLIGHT_OPTIONS, HighlightOptions, HighlightResult } from './highlight.model';\r\n\r\n@Directive({\r\n  host: {\r\n    '[class.hljs]': 'true'\r\n  },\r\n  selector: '[highlight]'\r\n})\r\nexport class Highlight implements OnChanges {\r\n\r\n  // Highlighted Code\r\n  private readonly _nativeElement: HTMLElement;\r\n\r\n  // Temp observer to observe when line numbers has been added to code element\r\n  private _lineNumbersObs: any;\r\n\r\n  // Highlight code input\r\n  @Input('highlight') code!: string;\r\n\r\n  // An optional array of language names and aliases restricting detection to only those languages.\r\n  // The subset can also be set with configure, but the local parameter overrides the option if set.\r\n  @Input() languages!: string[];\r\n\r\n  // Show line numbers\r\n  @Input() lineNumbers!: boolean;\r\n\r\n  // Stream that emits when code string is highlighted\r\n  @Output() highlighted = new EventEmitter<HighlightResult>();\r\n\r\n  constructor(el: ElementRef,\r\n              private _hljs: HighlightJS,\r\n              private _sanitizer: DomSanitizer,\r\n              @Optional() @Inject(HIGHLIGHT_OPTIONS) private _options: HighlightOptions) {\r\n    this._nativeElement = el.nativeElement;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (\r\n      changes.code &&\r\n      changes.code.currentValue &&\r\n      changes.code.currentValue !== changes.code.previousValue\r\n    ) {\r\n      this.highlightElement(this.code, this.languages);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Highlighting with language detection and fix markup.\r\n   * @param code Accepts a string with the code to highlight\r\n   * @param languages An optional array of language names and aliases restricting detection to only those languages.\r\n   * The subset can also be set with configure, but the local parameter overrides the option if set.\r\n   */\r\n  highlightElement(code: string, languages?: string[]): void {\r\n    // Set code text before highlighting\r\n    this.setTextContent(code);\r\n    this._hljs.highlightAuto(code, languages).subscribe((res: any) => {\r\n      // Set highlighted code\r\n      this.setInnerHTML(res.value);\r\n      // Check if user want to show line numbers\r\n      if (this.lineNumbers && this._options && this._options.lineNumbers) {\r\n        this.addLineNumbers();\r\n      }\r\n      // Forward highlight response to the highlighted output\r\n      this.highlighted.emit(res);\r\n    });\r\n  }\r\n\r\n  private addLineNumbers() {\r\n    // Clean up line numbers observer\r\n    this.destroyLineNumbersObserver();\r\n    animationFrameScheduler.schedule(() => {\r\n      // Add line numbers\r\n      this._hljs.lineNumbersBlock(this._nativeElement).subscribe();\r\n      // If lines count is 1, the line numbers library will not add numbers\r\n      // Observe changes to add 'hljs-line-numbers' class only when line numbers is added to the code element\r\n      this._lineNumbersObs = new MutationObserver(() => {\r\n        if (this._nativeElement.firstElementChild && this._nativeElement.firstElementChild.tagName.toUpperCase() === 'TABLE') {\r\n          this._nativeElement.classList.add('hljs-line-numbers');\r\n        }\r\n        this.destroyLineNumbersObserver();\r\n      });\r\n      this._lineNumbersObs.observe(this._nativeElement, { childList: true });\r\n    });\r\n  }\r\n\r\n  private destroyLineNumbersObserver() {\r\n    if (this._lineNumbersObs) {\r\n      this._lineNumbersObs.disconnect();\r\n      this._lineNumbersObs = null;\r\n    }\r\n  }\r\n\r\n  private setTextContent(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.textContent = content\r\n    );\r\n  }\r\n\r\n  private setInnerHTML(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content)\r\n    );\r\n  }\r\n}\r\n\r\n"]} |
@@ -57,3 +57,3 @@ /** | ||
// Set code text before highlighting | ||
this.setCode(code); | ||
this.setTextContent(code); | ||
this._hljs.highlightAuto(code, languages).subscribe((/** | ||
@@ -65,3 +65,3 @@ * @param {?} res | ||
// Set highlighted code | ||
_this.setCode(res.value); | ||
_this.setInnerHTML(res.value); | ||
// Check if user want to show line numbers | ||
@@ -126,3 +126,3 @@ if (_this.lineNumbers && _this._options && _this._options.lineNumbers) { | ||
*/ | ||
Highlight.prototype.setCode = /** | ||
Highlight.prototype.setTextContent = /** | ||
* @private | ||
@@ -138,2 +138,21 @@ * @param {?} content | ||
function () { | ||
return _this._nativeElement.textContent = content; | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
Highlight.prototype.setInnerHTML = /** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
function (content) { | ||
var _this = this; | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
return _this._nativeElement.innerHTML = _this._sanitizer.sanitize(SecurityContext.HTML, content); | ||
@@ -201,2 +220,2 @@ })); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.js","sourceRoot":"ng://ngx-highlightjs/","sources":["lib/highlight.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  Input,\r\n  Output,\r\n  Inject,\r\n  Optional,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SecurityContext\r\n} from '@angular/core';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { animationFrameScheduler } from 'rxjs';\r\nimport { HighlightJS } from './highlight.service';\r\nimport { HIGHLIGHT_OPTIONS, HighlightOptions, HighlightResult } from './highlight.model';\r\n\r\n@Directive({\r\n  host: {\r\n    '[class.hljs]': 'true'\r\n  },\r\n  selector: '[highlight]'\r\n})\r\nexport class Highlight implements OnChanges {\r\n\r\n  // Highlighted Code\r\n  private readonly _nativeElement: HTMLElement;\r\n\r\n  // Temp observer to observe when line numbers has been added to code element\r\n  private _lineNumbersObs: any;\r\n\r\n  // Highlight code input\r\n  @Input('highlight') code!: string;\r\n\r\n  // An optional array of language names and aliases restricting detection to only those languages.\r\n  // The subset can also be set with configure, but the local parameter overrides the option if set.\r\n  @Input() languages!: string[];\r\n\r\n  // Show line numbers\r\n  @Input() lineNumbers!: boolean;\r\n\r\n  // Stream that emits when code string is highlighted\r\n  @Output() highlighted = new EventEmitter<HighlightResult>();\r\n\r\n  constructor(el: ElementRef,\r\n              private _hljs: HighlightJS,\r\n              private _sanitizer: DomSanitizer,\r\n              @Optional() @Inject(HIGHLIGHT_OPTIONS) private _options: HighlightOptions) {\r\n    this._nativeElement = el.nativeElement;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (\r\n      changes.code &&\r\n      changes.code.currentValue &&\r\n      changes.code.currentValue !== changes.code.previousValue\r\n    ) {\r\n      this.highlightElement(this.code, this.languages);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Highlighting with language detection and fix markup.\r\n   * @param code Accepts a string with the code to highlight\r\n   * @param languages An optional array of language names and aliases restricting detection to only those languages.\r\n   * The subset can also be set with configure, but the local parameter overrides the option if set.\r\n   */\r\n  highlightElement(code: string, languages?: string[]): void {\r\n    // Set code text before highlighting\r\n    this.setCode(code);\r\n    this._hljs.highlightAuto(code, languages).subscribe((res: any) => {\r\n      // Set highlighted code\r\n      this.setCode(res.value);\r\n      // Check if user want to show line numbers\r\n      if (this.lineNumbers && this._options && this._options.lineNumbers) {\r\n        this.addLineNumbers();\r\n      }\r\n      // Forward highlight response to the highlighted output\r\n      this.highlighted.emit(res);\r\n    });\r\n  }\r\n\r\n  private addLineNumbers() {\r\n    // Clean up line numbers observer\r\n    this.destroyLineNumbersObserver();\r\n    animationFrameScheduler.schedule(() => {\r\n      // Add line numbers\r\n      this._hljs.lineNumbersBlock(this._nativeElement).subscribe();\r\n      // If lines count is 1, the line numbers library will not add numbers\r\n      // Observe changes to add 'hljs-line-numbers' class only when line numbers is added to the code element\r\n      this._lineNumbersObs = new MutationObserver(() => {\r\n        if (this._nativeElement.firstElementChild && this._nativeElement.firstElementChild.tagName.toUpperCase() === 'TABLE') {\r\n          this._nativeElement.classList.add('hljs-line-numbers');\r\n        }\r\n        this.destroyLineNumbersObserver();\r\n      });\r\n      this._lineNumbersObs.observe(this._nativeElement, { childList: true });\r\n    });\r\n  }\r\n\r\n  private destroyLineNumbersObserver() {\r\n    if (this._lineNumbersObs) {\r\n      this._lineNumbersObs.disconnect();\r\n      this._lineNumbersObs = null;\r\n    }\r\n  }\r\n\r\n  private setCode(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content)\r\n    );\r\n  }\r\n}\r\n\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.js","sourceRoot":"ng://ngx-highlightjs/","sources":["lib/highlight.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  Input,\r\n  Output,\r\n  Inject,\r\n  Optional,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  EventEmitter,\r\n  ElementRef,\r\n  SecurityContext\r\n} from '@angular/core';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { animationFrameScheduler } from 'rxjs';\r\nimport { HighlightJS } from './highlight.service';\r\nimport { HIGHLIGHT_OPTIONS, HighlightOptions, HighlightResult } from './highlight.model';\r\n\r\n@Directive({\r\n  host: {\r\n    '[class.hljs]': 'true'\r\n  },\r\n  selector: '[highlight]'\r\n})\r\nexport class Highlight implements OnChanges {\r\n\r\n  // Highlighted Code\r\n  private readonly _nativeElement: HTMLElement;\r\n\r\n  // Temp observer to observe when line numbers has been added to code element\r\n  private _lineNumbersObs: any;\r\n\r\n  // Highlight code input\r\n  @Input('highlight') code!: string;\r\n\r\n  // An optional array of language names and aliases restricting detection to only those languages.\r\n  // The subset can also be set with configure, but the local parameter overrides the option if set.\r\n  @Input() languages!: string[];\r\n\r\n  // Show line numbers\r\n  @Input() lineNumbers!: boolean;\r\n\r\n  // Stream that emits when code string is highlighted\r\n  @Output() highlighted = new EventEmitter<HighlightResult>();\r\n\r\n  constructor(el: ElementRef,\r\n              private _hljs: HighlightJS,\r\n              private _sanitizer: DomSanitizer,\r\n              @Optional() @Inject(HIGHLIGHT_OPTIONS) private _options: HighlightOptions) {\r\n    this._nativeElement = el.nativeElement;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (\r\n      changes.code &&\r\n      changes.code.currentValue &&\r\n      changes.code.currentValue !== changes.code.previousValue\r\n    ) {\r\n      this.highlightElement(this.code, this.languages);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Highlighting with language detection and fix markup.\r\n   * @param code Accepts a string with the code to highlight\r\n   * @param languages An optional array of language names and aliases restricting detection to only those languages.\r\n   * The subset can also be set with configure, but the local parameter overrides the option if set.\r\n   */\r\n  highlightElement(code: string, languages?: string[]): void {\r\n    // Set code text before highlighting\r\n    this.setTextContent(code);\r\n    this._hljs.highlightAuto(code, languages).subscribe((res: any) => {\r\n      // Set highlighted code\r\n      this.setInnerHTML(res.value);\r\n      // Check if user want to show line numbers\r\n      if (this.lineNumbers && this._options && this._options.lineNumbers) {\r\n        this.addLineNumbers();\r\n      }\r\n      // Forward highlight response to the highlighted output\r\n      this.highlighted.emit(res);\r\n    });\r\n  }\r\n\r\n  private addLineNumbers() {\r\n    // Clean up line numbers observer\r\n    this.destroyLineNumbersObserver();\r\n    animationFrameScheduler.schedule(() => {\r\n      // Add line numbers\r\n      this._hljs.lineNumbersBlock(this._nativeElement).subscribe();\r\n      // If lines count is 1, the line numbers library will not add numbers\r\n      // Observe changes to add 'hljs-line-numbers' class only when line numbers is added to the code element\r\n      this._lineNumbersObs = new MutationObserver(() => {\r\n        if (this._nativeElement.firstElementChild && this._nativeElement.firstElementChild.tagName.toUpperCase() === 'TABLE') {\r\n          this._nativeElement.classList.add('hljs-line-numbers');\r\n        }\r\n        this.destroyLineNumbersObserver();\r\n      });\r\n      this._lineNumbersObs.observe(this._nativeElement, { childList: true });\r\n    });\r\n  }\r\n\r\n  private destroyLineNumbersObserver() {\r\n    if (this._lineNumbersObs) {\r\n      this._lineNumbersObs.disconnect();\r\n      this._lineNumbersObs = null;\r\n    }\r\n  }\r\n\r\n  private setTextContent(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.textContent = content\r\n    );\r\n  }\r\n\r\n  private setInnerHTML(content: string) {\r\n    animationFrameScheduler.schedule(() =>\r\n      this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content)\r\n    );\r\n  }\r\n}\r\n\r\n"]} |
@@ -535,3 +535,3 @@ import { InjectionToken, Injectable, Inject, PLATFORM_ID, Optional, ɵɵdefineInjectable, ɵɵinject, EventEmitter, SecurityContext, Directive, ElementRef, Input, Output, NgModule } from '@angular/core'; | ||
// Set code text before highlighting | ||
this.setCode(code); | ||
this.setTextContent(code); | ||
this._hljs.highlightAuto(code, languages).subscribe((/** | ||
@@ -543,3 +543,3 @@ * @param {?} res | ||
// Set highlighted code | ||
this.setCode(res.value); | ||
this.setInnerHTML(res.value); | ||
// Check if user want to show line numbers | ||
@@ -595,6 +595,17 @@ if (this.lineNumbers && this._options && this._options.lineNumbers) { | ||
*/ | ||
setCode(content) { | ||
setTextContent(content) { | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
() => this._nativeElement.textContent = content)); | ||
} | ||
/** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
setInnerHTML(content) { | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
() => this._nativeElement.innerHTML = this._sanitizer.sanitize(SecurityContext.HTML, content))); | ||
@@ -601,0 +612,0 @@ } |
@@ -682,3 +682,3 @@ import { InjectionToken, Injectable, Inject, PLATFORM_ID, Optional, ɵɵdefineInjectable, ɵɵinject, EventEmitter, SecurityContext, Directive, ElementRef, Input, Output, NgModule } from '@angular/core'; | ||
// Set code text before highlighting | ||
this.setCode(code); | ||
this.setTextContent(code); | ||
this._hljs.highlightAuto(code, languages).subscribe((/** | ||
@@ -690,3 +690,3 @@ * @param {?} res | ||
// Set highlighted code | ||
_this.setCode(res.value); | ||
_this.setInnerHTML(res.value); | ||
// Check if user want to show line numbers | ||
@@ -751,3 +751,3 @@ if (_this.lineNumbers && _this._options && _this._options.lineNumbers) { | ||
*/ | ||
Highlight.prototype.setCode = /** | ||
Highlight.prototype.setTextContent = /** | ||
* @private | ||
@@ -763,2 +763,21 @@ * @param {?} content | ||
function () { | ||
return _this._nativeElement.textContent = content; | ||
})); | ||
}; | ||
/** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
Highlight.prototype.setInnerHTML = /** | ||
* @private | ||
* @param {?} content | ||
* @return {?} | ||
*/ | ||
function (content) { | ||
var _this = this; | ||
animationFrameScheduler.schedule((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
return _this._nativeElement.innerHTML = _this._sanitizer.sanitize(SecurityContext.HTML, content); | ||
@@ -765,0 +784,0 @@ })); |
@@ -26,3 +26,4 @@ import { OnChanges, SimpleChanges, EventEmitter, ElementRef } from '@angular/core'; | ||
private destroyLineNumbersObserver; | ||
private setCode; | ||
private setTextContent; | ||
private setInnerHTML; | ||
} |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"Highlight":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":17,"character":1},"arguments":[{"host":{"[class.hljs]":"true","$quoted$":["[class.hljs]"]},"selector":"[highlight]"}]}],"members":{"code":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3},"arguments":["highlight"]}]}],"languages":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"lineNumbers":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"highlighted":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":47,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":47,"character":27},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":44,"character":18},{"__symbolic":"reference","name":"HighlightJS"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":46,"character":34},{"__symbolic":"reference","name":"HighlightOptions"}]}],"ngOnChanges":[{"__symbolic":"method"}],"highlightElement":[{"__symbolic":"method"}],"addLineNumbers":[{"__symbolic":"method"}],"destroyLineNumbersObserver":[{"__symbolic":"method"}],"setCode":[{"__symbolic":"method"}]}},"HighlightLibrary":{"__symbolic":"interface"},"HighlightConfig":{"__symbolic":"interface"},"HighlightResult":{"__symbolic":"interface"},"HighlightOptions":{"__symbolic":"interface"},"HIGHLIGHT_OPTIONS":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":102,"character":37},"arguments":["HIGHLIGHT_OPTIONS"]},"HighlightModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"Highlight"}],"exports":[{"__symbolic":"reference","name":"Highlight"}]}]}],"members":{}},"HighlightJS":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":18,"character":49}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":61},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","name":"HighlightLoader"},{"__symbolic":"reference","name":"HighlightOptions"}]}],"highlight":[{"__symbolic":"method"}],"highlightAuto":[{"__symbolic":"method"}],"fixMarkup":[{"__symbolic":"method"}],"highlightBlock":[{"__symbolic":"method"}],"configure":[{"__symbolic":"method"}],"initHighlighting":[{"__symbolic":"method"}],"registerLanguage":[{"__symbolic":"method"}],"listLanguages":[{"__symbolic":"method"}],"getLanguage":[{"__symbolic":"method"}],"lineNumbersBlock":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"HighlightLoader":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":18,"character":22}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":19,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":19,"character":22}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":20,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":20,"character":27},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","name":"any"},{"__symbolic":"error","message":"Expression form not supported","line":19,"character":47,"module":"./lib/highlight.loader"},{"__symbolic":"reference","name":"HighlightOptions"}]}],"_loadLibrary":[{"__symbolic":"method"}],"_loadLanguages":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"Highlight":"./lib/highlight","HighlightLibrary":"./lib/highlight.model","HighlightConfig":"./lib/highlight.model","HighlightResult":"./lib/highlight.model","HighlightOptions":"./lib/highlight.model","HIGHLIGHT_OPTIONS":"./lib/highlight.model","HighlightModule":"./lib/highlight.module","HighlightJS":"./lib/highlight.service","HighlightLoader":"./lib/highlight.loader"},"importAs":"ngx-highlightjs"} | ||
{"__symbolic":"module","version":4,"metadata":{"Highlight":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":17,"character":1},"arguments":[{"host":{"[class.hljs]":"true","$quoted$":["[class.hljs]"]},"selector":"[highlight]"}]}],"members":{"code":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3},"arguments":["highlight"]}]}],"languages":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"lineNumbers":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":39,"character":3}}]}],"highlighted":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":42,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":47,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":47,"character":27},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":44,"character":18},{"__symbolic":"reference","name":"HighlightJS"},{"__symbolic":"reference","module":"@angular/platform-browser","name":"DomSanitizer","line":46,"character":34},{"__symbolic":"reference","name":"HighlightOptions"}]}],"ngOnChanges":[{"__symbolic":"method"}],"highlightElement":[{"__symbolic":"method"}],"addLineNumbers":[{"__symbolic":"method"}],"destroyLineNumbersObserver":[{"__symbolic":"method"}],"setTextContent":[{"__symbolic":"method"}],"setInnerHTML":[{"__symbolic":"method"}]}},"HighlightLibrary":{"__symbolic":"interface"},"HighlightConfig":{"__symbolic":"interface"},"HighlightResult":{"__symbolic":"interface"},"HighlightOptions":{"__symbolic":"interface"},"HIGHLIGHT_OPTIONS":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":102,"character":37},"arguments":["HIGHLIGHT_OPTIONS"]},"HighlightModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"Highlight"}],"exports":[{"__symbolic":"reference","name":"Highlight"}]}]}],"members":{}},"HighlightJS":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":18,"character":49}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":61},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","name":"HighlightLoader"},{"__symbolic":"reference","name":"HighlightOptions"}]}],"highlight":[{"__symbolic":"method"}],"highlightAuto":[{"__symbolic":"method"}],"fixMarkup":[{"__symbolic":"method"}],"highlightBlock":[{"__symbolic":"method"}],"configure":[{"__symbolic":"method"}],"initHighlighting":[{"__symbolic":"method"}],"registerLanguage":[{"__symbolic":"method"}],"listLanguages":[{"__symbolic":"method"}],"getLanguage":[{"__symbolic":"method"}],"lineNumbersBlock":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}},"HighlightLoader":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":7,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":18,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/common","name":"DOCUMENT","line":18,"character":22}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":19,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/core","name":"PLATFORM_ID","line":19,"character":22}]}],[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":20,"character":15}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":20,"character":27},"arguments":[{"__symbolic":"reference","name":"HIGHLIGHT_OPTIONS"}]}]],"parameters":[{"__symbolic":"reference","name":"any"},{"__symbolic":"error","message":"Expression form not supported","line":19,"character":47,"module":"./lib/highlight.loader"},{"__symbolic":"reference","name":"HighlightOptions"}]}],"_loadLibrary":[{"__symbolic":"method"}],"_loadLanguages":[{"__symbolic":"method"}]},"statics":{"ngInjectableDef":{}}}},"origins":{"Highlight":"./lib/highlight","HighlightLibrary":"./lib/highlight.model","HighlightConfig":"./lib/highlight.model","HighlightResult":"./lib/highlight.model","HighlightOptions":"./lib/highlight.model","HIGHLIGHT_OPTIONS":"./lib/highlight.model","HighlightModule":"./lib/highlight.module","HighlightJS":"./lib/highlight.service","HighlightLoader":"./lib/highlight.loader"},"importAs":"ngx-highlightjs"} |
{ | ||
"name": "ngx-highlightjs", | ||
"version": "4.0.1", | ||
"version": "4.0.2", | ||
"description": "Instant code highlighting, auto-detect language, super easy to use.", | ||
@@ -5,0 +5,0 @@ "homepage": "http://github.com/murhafsousli/ngx-highlightjs", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
555488
6845