@kushki/ng-suka
Version:
<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>
350 lines • 27.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, HostBinding, ViewChild, HostListener, SecurityContext } from '@angular/core';
import * as prism from 'prismjs';
import 'prismjs/components/prism-markup-templating.js';
import 'prismjs/components/prism-typescript';
import 'prismjs/components/prism-php';
import 'prismjs/components/prism-ruby';
import 'prismjs/components/prism-json';
import 'prismjs/components/prism-java';
import 'prismjs/components/prism-markdown';
import 'prismjs/components/prism-scss';
import 'prismjs/components/prism-swift';
import { DomSanitizer } from '@angular/platform-browser';
/** @enum {string} */
var SnippetType = {
single: 'single',
multi: 'multi',
inline: 'inline',
};
export { SnippetType };
/** @enum {string} */
var SnippetLanguage = {
javascript: 'javascript',
json: 'json',
typescript: 'typescript',
markup: 'markup',
markdown: 'markdown',
php: 'php',
ruby: 'ruby',
scss: 'scss',
css: 'css',
html: 'html',
xml: 'xml',
clike: 'clike',
java: 'java',
swift: 'swift',
};
export { SnippetLanguage };
var CodeSnippet = /** @class */ (function () {
/**
* Creates an instance of CodeSnippet.
*/
function CodeSnippet(sanitizer) {
this.sanitizer = sanitizer;
/**
* It can be `"single"`, `"multi"` or `"inline"`
*/
this.display = SnippetType.single;
/**
* Text displayed in the tooltip when user clicks button to copy code.
*
*/
this.feedbackText = 'Copiado'; // TODO: i18n
/**
* Snippet highlight language
*
*/
this.language = SnippetLanguage.javascript;
/**
* Time in miliseconds to keep the feedback tooltip displayed.
*
*/
this.feedbackTimeout = 3000;
/**
* Set to `true` to show an expanded code snippet.
*/
this.expanded = false;
/**
* Set to `true` to show a loading code snippet.
*/
this.skeleton = false;
this.snippetClass = true;
this.showFeedback = false;
CodeSnippet.codeSnippetCount++;
}
Object.defineProperty(CodeSnippet.prototype, "snippetSingleClass", {
get: /**
* @return {?}
*/
function () {
return this.display === SnippetType.single;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "snippetMultiClass", {
get: /**
* @return {?}
*/
function () {
return this.display === SnippetType.multi;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "snippetInlineClass", {
get: /**
* @return {?}
*/
function () {
return this.display === SnippetType.inline;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "btnCopyClass", {
get: /**
* @return {?}
*/
function () {
return this.display === SnippetType.inline;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "displayStyle", {
get: /**
* @return {?}
*/
function () {
return this.display !== SnippetType.inline ? 'block' : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "attrType", {
get: /**
* @return {?}
*/
function () {
return this.display === SnippetType.inline ? 'button' : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CodeSnippet.prototype, "shouldShowExpandButton", {
get: /**
* @return {?}
*/
function () {
return this.code ? this.code.nativeElement.getBoundingClientRect().height > 255 : false;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
CodeSnippet.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.highlight) {
this.content = prism.highlight(this.content, prism.languages[this.language], this.language);
}
this.codeHtml = this.sanitizer.sanitize(SecurityContext.HTML, this.content);
};
/**
* @return {?}
*/
CodeSnippet.prototype.toggleSnippetExpansion = /**
* @return {?}
*/
function () {
this.expanded = !this.expanded;
};
/**
* Copies the code from the `<code>` block to clipboard.
*/
/**
* Copies the code from the `<code>` block to clipboard.
* @return {?}
*/
CodeSnippet.prototype.copyCode = /**
* Copies the code from the `<code>` block to clipboard.
* @return {?}
*/
function () {
// create invisible, uneditable textarea with our code in it
/** @type {?} */
var textarea = document.createElement('textarea');
textarea.value = this.code.nativeElement.innerText || this.code.nativeElement.textContent;
textarea.setAttribute('readonly', '');
textarea.style.position = 'absolute';
textarea.style.right = '-99999px';
document.body.appendChild(textarea);
// save user selection
/** @type {?} */
var selected = document.getSelection().rangeCount ? document.getSelection().getRangeAt(0) : null;
// copy to clipboard
textarea.select();
document.execCommand('copy');
// remove textarea
document.body.removeChild(textarea);
// restore user selection
if (selected) {
document.getSelection().removeAllRanges();
document.getSelection().addRange(selected);
}
};
/**
* On copy button click, copies the code and shows feedback.
*/
/**
* On copy button click, copies the code and shows feedback.
* @return {?}
*/
CodeSnippet.prototype.onCopyButtonClicked = /**
* On copy button click, copies the code and shows feedback.
* @return {?}
*/
function () {
var _this = this;
this.copyCode();
this.showFeedback = true;
setTimeout((/**
* @return {?}
*/
function () {
_this.showFeedback = false;
}), this.feedbackTimeout);
};
/**
* Inline code snippet acts as button and makes the whole component clickable.
*
* This handles clicks in that case.
*/
/**
* Inline code snippet acts as button and makes the whole component clickable.
*
* This handles clicks in that case.
* @return {?}
*/
CodeSnippet.prototype.hostClick = /**
* Inline code snippet acts as button and makes the whole component clickable.
*
* This handles clicks in that case.
* @return {?}
*/
function () {
if (this.display !== SnippetType.inline) {
return;
}
this.onCopyButtonClicked();
};
/**
* Variable used for creating unique ids for code-snippet components.
*/
CodeSnippet.codeSnippetCount = 0;
CodeSnippet.decorators = [
{ type: Component, args: [{
selector: 'suka-code-snippet',
template: "\n <ng-container *ngIf=\"display === 'inline'; else notInline\">\n <span\n sukaTooltip=\"Copiado\"\n tooltipTrigger=\"click\"\n tooltipDuration=\"3000\"\n >\n <ng-container *ngTemplateOutlet=\"codeTemplate\"></ng-container>\n </span>\n </ng-container>\n\n <ng-template #notInline>\n <div class=\"snippet-container\" attr.aria-label=\"Copy code snippet\">\n <ng-container *ngIf=\"skeleton\">\n <span *ngIf=\"display === 'single'; else multiSkeleton\"></span>\n <ng-template #multiSkeleton>\n <span></span>\n <span></span>\n <span></span>\n </ng-template>\n </ng-container>\n <pre *ngIf=\"!skeleton\"><ng-container *ngTemplateOutlet=\"codeTemplate\"></ng-container></pre>\n </div>\n\n <button\n *ngIf=\"!skeleton\"\n class=\"snippet-button\"\n attr.aria-label=\"Copiar\"\n (click)=\"onCopyButtonClicked()\"\n [ngClass]=\"{\n 'snippet-button--copied': showFeedback\n }\"\n sukaTooltip=\"Copiado\"\n tooltipTrigger=\"click\"\n tooltipDuration=\"3000\"\n tabindex=\"0\">\n <suka-icon icon=\"copy\"></suka-icon>\n </button>\n\n <button\n *ngIf=\"display === 'multi' && shouldShowExpandButton\"\n class=\"btn snippet-btn--expand\"\n (click)=\"toggleSnippetExpansion()\"\n type=\"button\">\n <span class=\"snippet-btn--text\">{{expanded ? 'Mostrar menos' : 'Mostrar mas'}}\n <suka-icon icon=\"chevron-down\"></suka-icon>\n </span>\n </button>\n </ng-template>\n <ng-template #codeTemplate>\n <code #code [innerHtml]=\"codeHtml\"></code>\n </ng-template>\n "
}] }
];
/** @nocollapse */
CodeSnippet.ctorParameters = function () { return [
{ type: DomSanitizer }
]; };
CodeSnippet.propDecorators = {
display: [{ type: Input }],
feedbackText: [{ type: Input }],
content: [{ type: Input }],
highlight: [{ type: Input }],
language: [{ type: Input }],
feedbackTimeout: [{ type: Input }],
expanded: [{ type: HostBinding, args: ['class.snippet--expand',] }, { type: Input }],
skeleton: [{ type: HostBinding, args: ['class.skeleton',] }, { type: Input }],
snippetClass: [{ type: HostBinding, args: ['class.snippet',] }],
snippetSingleClass: [{ type: HostBinding, args: ['class.snippet--single',] }],
snippetMultiClass: [{ type: HostBinding, args: ['class.snippet--multi',] }],
snippetInlineClass: [{ type: HostBinding, args: ['class.snippet--inline',] }],
btnCopyClass: [{ type: HostBinding, args: ['class.btn--copy',] }],
displayStyle: [{ type: HostBinding, args: ['style.display',] }],
attrType: [{ type: HostBinding, args: ['attr.type',] }],
code: [{ type: ViewChild, args: ['code', { static: false },] }],
hostClick: [{ type: HostListener, args: ['click',] }]
};
return CodeSnippet;
}());
export { CodeSnippet };
if (false) {
/**
* Variable used for creating unique ids for code-snippet components.
* @type {?}
*/
CodeSnippet.codeSnippetCount;
/** @type {?} */
CodeSnippet.prototype.codeHtml;
/**
* It can be `"single"`, `"multi"` or `"inline"`
* @type {?}
*/
CodeSnippet.prototype.display;
/**
* Text displayed in the tooltip when user clicks button to copy code.
*
* @type {?}
*/
CodeSnippet.prototype.feedbackText;
/**
* Code content
*
* @type {?}
*/
CodeSnippet.prototype.content;
/**
* Code highlight
*
* @type {?}
*/
CodeSnippet.prototype.highlight;
/**
* Snippet highlight language
*
* @type {?}
*/
CodeSnippet.prototype.language;
/**
* Time in miliseconds to keep the feedback tooltip displayed.
*
* @type {?}
*/
CodeSnippet.prototype.feedbackTimeout;
/**
* Set to `true` to show an expanded code snippet.
* @type {?}
*/
CodeSnippet.prototype.expanded;
/**
* Set to `true` to show a loading code snippet.
* @type {?}
*/
CodeSnippet.prototype.skeleton;
/** @type {?} */
CodeSnippet.prototype.snippetClass;
/** @type {?} */
CodeSnippet.prototype.code;
/** @type {?} */
CodeSnippet.prototype.showFeedback;
/**
* @type {?}
* @private
*/
CodeSnippet.prototype.sanitizer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-snippet.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/code-snippet/code-snippet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostBinding,\n  ViewChild,\n  HostListener,\n  OnInit,\n  SecurityContext\n} from '@angular/core';\nimport * as prism from 'prismjs';\nimport 'prismjs/components/prism-markup-templating.js';\nimport 'prismjs/components/prism-typescript';\nimport 'prismjs/components/prism-php';\nimport 'prismjs/components/prism-ruby';\nimport 'prismjs/components/prism-json';\nimport 'prismjs/components/prism-java';\nimport 'prismjs/components/prism-markdown';\nimport 'prismjs/components/prism-scss';\nimport 'prismjs/components/prism-swift';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nexport enum SnippetType {\n  single = 'single',\n  multi = 'multi',\n  inline = 'inline'\n}\n\nexport enum SnippetLanguage {\n  javascript  = 'javascript',\n  json        = 'json',\n  typescript  = 'typescript',\n  markup      = 'markup',\n  markdown    = 'markdown',\n  php         = 'php',\n  ruby        = 'ruby',\n  scss        = 'scss',\n  css         = 'css',\n  html        = 'html',\n  xml         = 'xml',\n  clike       = 'clike',\n  java        = 'java',\n  swift       = 'swift',\n}\n\n@Component({\n  selector: 'suka-code-snippet',\n  template: `\n    <ng-container *ngIf=\"display === 'inline'; else notInline\">\n      <span\n        sukaTooltip=\"Copiado\"\n        tooltipTrigger=\"click\"\n        tooltipDuration=\"3000\"\n      >\n        <ng-container *ngTemplateOutlet=\"codeTemplate\"></ng-container>\n      </span>\n    </ng-container>\n\n    <ng-template #notInline>\n      <div class=\"snippet-container\" attr.aria-label=\"Copy code snippet\">\n        <ng-container *ngIf=\"skeleton\">\n          <span *ngIf=\"display === 'single'; else multiSkeleton\"></span>\n          <ng-template #multiSkeleton>\n            <span></span>\n            <span></span>\n            <span></span>\n          </ng-template>\n        </ng-container>\n        <pre *ngIf=\"!skeleton\"><ng-container *ngTemplateOutlet=\"codeTemplate\"></ng-container></pre>\n      </div>\n\n      <button\n        *ngIf=\"!skeleton\"\n        class=\"snippet-button\"\n        attr.aria-label=\"Copiar\"\n        (click)=\"onCopyButtonClicked()\"\n        [ngClass]=\"{\n          'snippet-button--copied': showFeedback\n        }\"\n        sukaTooltip=\"Copiado\"\n        tooltipTrigger=\"click\"\n        tooltipDuration=\"3000\"\n        tabindex=\"0\">\n        <suka-icon icon=\"copy\"></suka-icon>\n      </button>\n\n      <button\n        *ngIf=\"display === 'multi' && shouldShowExpandButton\"\n        class=\"btn snippet-btn--expand\"\n        (click)=\"toggleSnippetExpansion()\"\n        type=\"button\">\n        <span class=\"snippet-btn--text\">{{expanded ? 'Mostrar menos' : 'Mostrar mas'}}\n          <suka-icon icon=\"chevron-down\"></suka-icon>\n        </span>\n      </button>\n    </ng-template>\n    <ng-template #codeTemplate>\n      <code #code [innerHtml]=\"codeHtml\"></code>\n    </ng-template>\n  `\n})\n// tslint:disable-next-line: component-class-suffix\nexport class CodeSnippet implements OnInit {\n  /**\n   * Variable used for creating unique ids for code-snippet components.\n   */\n  static codeSnippetCount = 0;\n  public codeHtml: SafeHtml;\n\n  /**\n   * It can be `\"single\"`, `\"multi\"` or `\"inline\"`\n   */\n  @Input() display: SnippetType = SnippetType.single;\n  /**\n   * Text displayed in the tooltip when user clicks button to copy code.\n   *\n   */\n  @Input() feedbackText = 'Copiado'; // TODO: i18n\n\n  /**\n   * Code content\n   *\n   */\n  @Input() content: string;\n\n  /**\n   * Code highlight\n   *\n   */\n  @Input() highlight: false;\n\n  /**\n   * Snippet highlight language\n   *\n   */\n  @Input() language: SnippetLanguage = SnippetLanguage.javascript;\n\n  /**\n   * Time in miliseconds to keep the feedback tooltip displayed.\n   *\n   */\n  @Input() feedbackTimeout = 3000;\n\n  /**\n   * Set to `true` to show an expanded code snippet.\n   */\n  @HostBinding('class.snippet--expand') @Input() expanded = false;\n\n  /**\n   * Set to `true` to show a loading code snippet.\n   */\n  @HostBinding('class.skeleton') @Input() skeleton = false;\n\n  @HostBinding('class.snippet') snippetClass = true;\n  @HostBinding('class.snippet--single') get snippetSingleClass() {\n    return this.display === SnippetType.single;\n  }\n  @HostBinding('class.snippet--multi') get snippetMultiClass() {\n    return this.display === SnippetType.multi;\n  }\n  @HostBinding('class.snippet--inline') get snippetInlineClass() {\n    return this.display === SnippetType.inline;\n  }\n  @HostBinding('class.btn--copy') get btnCopyClass() {\n    return this.display === SnippetType.inline;\n  }\n\n  @HostBinding('style.display') get displayStyle() {\n    return this.display !== SnippetType.inline ? 'block' : null;\n  }\n  @HostBinding('attr.type') get attrType() {\n    return this.display === SnippetType.inline ? 'button' : null;\n  }\n\n  @ViewChild('code', { static: false }) code;\n\n  get shouldShowExpandButton() {\n    return this.code ? this.code.nativeElement.getBoundingClientRect().height > 255 : false;\n  }\n\n  showFeedback = false;\n\n  /**\n   * Creates an instance of CodeSnippet.\n   */\n  constructor(private sanitizer: DomSanitizer) {\n    CodeSnippet.codeSnippetCount++;\n  }\n\n  ngOnInit() {\n    if (this.highlight) {\n      this.content = prism.highlight(this.content, prism.languages[this.language], this.language);\n    }\n\n    this.codeHtml = this.sanitizer.sanitize(SecurityContext.HTML, this.content);\n  }\n\n  toggleSnippetExpansion() {\n    this.expanded = !this.expanded;\n  }\n\n  /**\n   * Copies the code from the `<code>` block to clipboard.\n   */\n  public copyCode() {\n    // create invisible, uneditable textarea with our code in it\n    const textarea = document.createElement('textarea');\n    textarea.value = this.code.nativeElement.innerText || this.code.nativeElement.textContent;\n    textarea.setAttribute('readonly', '');\n    textarea.style.position = 'absolute';\n    textarea.style.right = '-99999px';\n    document.body.appendChild(textarea);\n\n    // save user selection\n    const selected = document.getSelection().rangeCount ? document.getSelection().getRangeAt(0) : null;\n\n    // copy to clipboard\n    textarea.select();\n    document.execCommand('copy');\n\n    // remove textarea\n    document.body.removeChild(textarea);\n\n    // restore user selection\n    if (selected) {\n      document.getSelection().removeAllRanges();\n      document.getSelection().addRange(selected);\n    }\n  }\n\n  /**\n   * On copy button click, copies the code and shows feedback.\n   */\n  onCopyButtonClicked() {\n    this.copyCode();\n\n    this.showFeedback = true;\n\n    setTimeout(() => {\n      this.showFeedback = false;\n    }, this.feedbackTimeout);\n  }\n\n  /**\n   * Inline code snippet acts as button and makes the whole component clickable.\n   *\n   * This handles clicks in that case.\n   */\n  @HostListener('click')\n  hostClick() {\n    if (this.display !== SnippetType.inline) {\n      return;\n    }\n\n    this.onCopyButtonClicked();\n  }\n}\n"]}