UNPKG

ng2-prism

Version:

An Angular2 codeblock highlighting component using Prismjs.

213 lines 25.8 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var core_1 = require('angular2/core'); require('prismjs/components/prism-bash'); require('prismjs/components/prism-powershell'); require('prismjs/components/prism-javascript'); Prism.languages.undefined = {}; require('prismjs/plugins/line-numbers/prism-line-numbers'); require('prismjs/plugins/command-line/prism-command-line'); require('prismjs/plugins/normalize-whitespace/prism-normalize-whitespace'); var TEMPLATE_REGEX = /<!--template\sbindings={[^\}]*}-->/g; var CodeRenderer = (function () { function CodeRenderer(_renderer) { this._renderer = _renderer; } CodeRenderer.prototype.render = function () { this._replaceCode(); this._highlight(); }; CodeRenderer.prototype.empty = function () { if (this._pre) { this._pre.nativeElement.innerHTML = ""; } }; CodeRenderer.prototype._replaceCode = function () { this._renderer.setElementProperty(this._pre.nativeElement, 'innerHTML', this._buildCodeElement()); }; CodeRenderer.prototype._highlight = function () { Prism.highlightElement(this._pre.nativeElement.querySelector('code'), false, null); if (this.shell && this.outputLines) { this._fixPromptOutputPadding(); } }; Object.defineProperty(CodeRenderer.prototype, "_processedCode", { get: function () { return this._isMarkup(this.language) ? this._processMarkup(this.code) : this.code; }, enumerable: true, configurable: true }); CodeRenderer.prototype._processMarkup = function (text) { return this._replaceTags(this._removeAngularMarkup(text)); }; CodeRenderer.prototype._replaceTags = function (text) { return text.replace(/(<)([!\/A-Za-z](.|[\n\r])*?>)/g, '&lt;$2'); }; CodeRenderer.prototype._removeAngularMarkup = function (html) { html = html.replace(/\s_ng[^-]+-[^-]+-[^=]+="[^"]*"/g, ''); var lines = this._fixIndentation(html); lines = lines.filter(function (line) { if (line.trim() === '') { return true; } var replaced = line.replace(TEMPLATE_REGEX, '').trim(); return replaced !== ''; }); html = lines.join("\n"); return html.replace(TEMPLATE_REGEX, ''); }; CodeRenderer.prototype._isMarkup = function (language) { return language === 'markup' || language === 'markdown'; }; CodeRenderer.prototype._buildCodeElement = function () { return "<code class=\"" + this.codeClasses + "\">" + this._processedCode + "</code>"; }; Object.defineProperty(CodeRenderer.prototype, "languageClass", { get: function () { return 'language-' + this.language; }, enumerable: true, configurable: true }); Object.defineProperty(CodeRenderer.prototype, "lineNumbersClass", { get: function () { return this.lineNumbers ? "line-numbers" : ""; }, enumerable: true, configurable: true }); Object.defineProperty(CodeRenderer.prototype, "shellClass", { get: function () { return this.shell ? "command-line" : ""; }, enumerable: true, configurable: true }); Object.defineProperty(CodeRenderer.prototype, "codeClasses", { get: function () { return this.languageClass + " " + this.language; }, enumerable: true, configurable: true }); Object.defineProperty(CodeRenderer.prototype, "preClasses", { get: function () { return this.lineNumbersClass + ' ' + this.languageClass + ' ' + this.shellClass; }, enumerable: true, configurable: true }); Object.defineProperty(CodeRenderer.prototype, "_codeEl", { get: function () { return this._pre.nativeElement.querySelector('code'); }, enumerable: true, configurable: true }); CodeRenderer.prototype._fixPromptOutputPadding = function () { if (this._codeEl) { var clp = this._codeEl.querySelector('.command-line-prompt'); if (clp) { var promptWidth = this._codeEl.querySelector('.command-line-prompt').clientWidth; var prePadding = parseInt(this._getStyle(this._pre.nativeElement, 'padding-left').replace('px', ''), 10); this._pre.nativeElement.style.paddingRight = (2 * prePadding + promptWidth / 2) + 'px'; } } }; CodeRenderer.prototype._getStyle = function (oElm, strCssRule) { var strValue = ""; if (document.defaultView && document.defaultView.getComputedStyle) { strValue = document.defaultView.getComputedStyle(oElm, "").getPropertyValue(strCssRule); } else if (oElm.currentStyle) { strCssRule = strCssRule.replace(/\-(\w)/g, function (strMatch, p1) { return p1.toUpperCase(); }); strValue = oElm.currentStyle[strCssRule]; } return strValue; }; CodeRenderer.prototype._fixIndentation = function (html) { var indent = 0; var diff = 0; var removeLines = []; var lines = html.split("\n").map(function (line, index) { if (line.trim() === '') { if (indent > 0) { removeLines.push(index); } indent = 0; return ''; } var a = line.replace(TEMPLATE_REGEX, '').trim(); if (a === '') { indent = line.match(/^\s*/)[0].length; return line; } else if (indent > 0) { length = line.match(/^\s*/)[0].length; if (diff === 0) { diff = length - indent; } if (length >= indent) { return line.slice(diff); } else { indent = 0; } } return line; }); removeLines.forEach(function (removalIndex) { lines.splice(removalIndex, 1); }); return lines; }; __decorate([ core_1.Input(), __metadata('design:type', String) ], CodeRenderer.prototype, "code", void 0); __decorate([ core_1.Input(), __metadata('design:type', String) ], CodeRenderer.prototype, "language", void 0); __decorate([ core_1.Input(), __metadata('design:type', Boolean) ], CodeRenderer.prototype, "lineNumbers", void 0); __decorate([ core_1.Input(), __metadata('design:type', String) ], CodeRenderer.prototype, "shell", void 0); __decorate([ core_1.Input(), __metadata('design:type', String) ], CodeRenderer.prototype, "prompt", void 0); __decorate([ core_1.Input(), __metadata('design:type', String) ], CodeRenderer.prototype, "outputLines", void 0); __decorate([ core_1.ViewChild('preEl'), __metadata('design:type', Object) ], CodeRenderer.prototype, "_pre", void 0); CodeRenderer = __decorate([ core_1.Component({ selector: 'code-renderer', template: "\n <pre #preEl [class]=\"preClasses\"\n [attr.data-prompt]=\"prompt\"\n [attr.data-output]=\"outputLines\"\n ></pre>\n " }), __metadata('design:paramtypes', [core_1.Renderer]) ], CodeRenderer); return CodeRenderer; }()); exports.CodeRenderer = CodeRenderer; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-renderer.component.js","sourceRoot":"","sources":["code-renderer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Renderer,\n  ViewChild\n} from 'angular2/core';\n\n\ndeclare var Prism: any;\n/**\n * Language files that all components should recognize\n */\nimport 'prismjs/components/prism-bash';\nimport 'prismjs/components/prism-powershell';\nimport 'prismjs/components/prism-javascript';\nPrism.languages.undefined = {};\n\n/**\n * Prism plugins\n */\nimport 'prismjs/plugins/line-numbers/prism-line-numbers';\nimport 'prismjs/plugins/command-line/prism-command-line';\nimport 'prismjs/plugins/normalize-whitespace/prism-normalize-whitespace';\n\n/**\n * Represent template tags added by angular structural directives\n */\nconst TEMPLATE_REGEX = /<!--template\\sbindings={[^\\}]*}-->/g;\n\n/**\n * Code highlighting component\n *\n * Used internally by a codeblock to perform the actual highlighting.\n */\n@Component({\n  selector: 'code-renderer',\n  template: `\n    <pre #preEl [class]=\"preClasses\"\n      [attr.data-prompt]=\"prompt\"\n      [attr.data-output]=\"outputLines\"\n    ></pre>\n  `\n})\nexport class CodeRenderer {\n\n  /**\n   * The code to highlight\n   */\n  @Input() code: string;\n\n  /**\n   * The language to use when highlighting the code.\n   */\n  @Input() language: string;\n\n  /**\n   * Whether or not to display line numbers.\n   */\n  @Input() lineNumbers: boolean;\n\n  /**\n   * Display a prompt in the codeblock. Set to 'bash' or 'powershell'.\n   */\n  @Input() shell: string;\n\n  /**\n   * The prompt to use when displaying as a shell.\n   */\n  @Input() prompt: string;\n\n  /**\n   * A comma separated list of lines or groups of lines to treat as output\n   * in a shell display.\n   */\n  @Input() outputLines: string;\n\n  /**\n   * The template <pre> that will contain the code.\n   */\n  @ViewChild('preEl') _pre;\n\n  constructor(\n    private _renderer: Renderer) { }\n\n  render() {\n    this._replaceCode();\n    this._highlight();\n  }\n\n  /**\n   * Clear the code.\n   */\n  empty() {\n    if (this._pre) { this._pre.nativeElement.innerHTML = \"\"; }\n  }\n\n\n\n  /**\n   * Place the new code element in the template\n   */\n  _replaceCode() {\n    this._renderer.setElementProperty(\n      this._pre.nativeElement,\n      'innerHTML',\n      this._buildCodeElement()\n    );\n  }\n\n  /**\n   * Perform the actual highlighting\n   */\n  _highlight() {\n    // this._truncateLargeFiles();\n    Prism.highlightElement(this._pre.nativeElement.querySelector('code'), false, null);\n    if (this.shell && this.outputLines) { this._fixPromptOutputPadding(); }\n  }\n\n  /**\n   * Code prepared for highlighting and display\n   */\n  get _processedCode() {\n    return this._isMarkup(this.language) ? this._processMarkup(this.code) : this.code;\n  }\n\n  /**\n   * Format markup for display.\n   */\n  _processMarkup(text) {\n    return this._replaceTags(this._removeAngularMarkup(text));\n  }\n\n  /**\n   * Change all opening < changed to &lt; to render markup correctly inside pre tags\n   */\n  _replaceTags(text): string {\n    return text.replace(/(<)([!\\/A-Za-z](.|[\\n\\r])*?>)/g, '&lt;$2');\n  }\n\n  /**\n   * Remove both template tags and styling attributes added by the angular2 parser\n   * and fix indentation within code elements created by structural directives.\n   */\n  _removeAngularMarkup(html): string {\n    // remove styling attributes (_ngcontent etc.)\n    html = html.replace(/\\s_ng[^-]+-[^-]+-[^=]+=\"[^\"]*\"/g, '');\n\n    let lines = this._fixIndentation(html);\n\n    // remove empty <!--template--> lines\n    lines = lines.filter(line => {\n      if (line.trim() === '') { return true; }\n      let replaced = line.replace(TEMPLATE_REGEX, '').trim();\n      return replaced !== '';\n    });\n\n    html = lines.join(\"\\n\");\n\n    // remove <!--template--> tags on lines with code\n    return html.replace(TEMPLATE_REGEX, '');\n  }\n\n  /**\n   * Is the language given a markup language?\n   */\n  _isMarkup(language): boolean {\n    return language === 'markup' || language === 'markdown';\n  }\n\n  /**\n   * Create a <code> element with the proper classes and formatted code\n   */\n  _buildCodeElement(): string {\n    return `<code class=\"${this.codeClasses}\">${this._processedCode}</code>`;\n  }\n\n  /** Styling classes **/\n\n  get languageClass() {\n    return 'language-' + this.language;\n  }\n\n  get lineNumbersClass(): string {\n    return this.lineNumbers ? \"line-numbers\" : \"\";\n  }\n\n  get shellClass(): string {\n    return this.shell ? \"command-line\" : \"\";\n  }\n\n  get codeClasses(): string {\n    return this.languageClass + \" \" + this.language;\n  }\n\n  get preClasses(): string {\n    return this.lineNumbersClass + ' ' + this.languageClass + ' ' + this.shellClass;\n  }\n\n\n  /** Code Styling **/\n\n  /**\n   * The code element within <pre>\n   */\n  get _codeEl() {\n    return this._pre.nativeElement.querySelector('code');\n  }\n\n  /**\n   * Adds back padding on output shells because of floated left prompt\n   */\n  _fixPromptOutputPadding() {\n    if (this._codeEl) {\n      let clp = this._codeEl.querySelector('.command-line-prompt');\n      if (clp) {\n        let promptWidth = this._codeEl.querySelector('.command-line-prompt').clientWidth;\n        let prePadding = parseInt(this._getStyle(this._pre.nativeElement,\n          'padding-left').replace('px', ''), 10);\n          this._pre.nativeElement.style.paddingRight = (2 * prePadding + promptWidth / 2) + 'px';\n      }\n    }\n  }\n\n  /**\n   * Get the actually applied style of an element\n   */\n  _getStyle(oElm, strCssRule) {\n    let strValue = \"\";\n    if (document.defaultView && document.defaultView.getComputedStyle) {\n      strValue = document.defaultView.getComputedStyle(oElm, \"\").getPropertyValue(strCssRule);\n    } else if (oElm.currentStyle) {\n      strCssRule = strCssRule.replace(/\\-(\\w)/g, function (strMatch, p1){\n        return p1.toUpperCase();\n      });\n      strValue = oElm.currentStyle[strCssRule];\n    }\n    return strValue;\n  }\n\n  // _truncateLargeFiles() {\n  //   if (this._codeEl.innerHTML.length > this.truncationSize) {\n  //     this._codeEl.innerHTML = this._codeEl.innerHTML.slice(0, this.truncationSize) +\n  //                             \"\\n\" + this.truncationMessage + \"\\n\";\n  //   }\n  // }\n\n  /**\n   * Remove extra indentation in ngSwitches\n   */\n  _fixIndentation(html: string): Array<string> {\n    let indent = 0;\n    let diff = 0;\n    let removeLines = [];\n    let lines = html.split(\"\\n\").map((line, index) => {\n      if (line.trim() === '') { // empty line\n        if (indent > 0) { removeLines.push(index); }\n        indent = 0;\n        return '';\n      }\n      let a = line.replace(TEMPLATE_REGEX, '').trim();\n      if (a === '') { // template line\n        indent = line.match(/^\\s*/)[0].length;\n        return line;\n      } else if (indent > 0) { // lines after template need fixing\n        length = line.match(/^\\s*/)[0].length;\n        if (diff === 0) { // find the amount to fix indentation\n          diff = length - indent;\n        }\n        if (length >= indent) { // fix it\n          return line.slice(diff);\n        } else { // stop indenting\n          indent = 0;\n        }\n      }\n      return line;\n    });\n\n    // remove empty lines added by ngSwitch\n    removeLines.forEach(removalIndex => {\n      lines.splice(removalIndex, 1);\n    });\n\n    return lines;\n  }\n\n}\n"]}