UNPKG

@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>

380 lines 24.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, EventEmitter, Output, HostBinding, ElementRef, HostListener, ViewChild } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; var Search = /** @class */ (function () { /** * Creates an instance of `Search`. */ function Search(elementRef) { this.elementRef = elementRef; /** * Set to `true` for a disabled search input. */ this.disabled = false; /** * Set to `true` for a toolbar search component. */ this.toolbar = false; /** * Set to `true` for a loading search component. */ this.skeleton = false; /** * Set to `true` to expand the toolbar search component. */ this.active = false; /** * Specifies whether the search component is used in the table toolbar. */ this.tableSearch = false; /** * The unique id for the search component. */ this.id = "search-" + Search.searchCount; /** * Sets the value attribute on the `input` element. */ this.value = ''; /** * Sets the autocomplete attribute on the `input` element. * For refernece: https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete#Values */ this.autocomplete = 'on'; /** * Sets the text inside the `label` tag. */ this.label = 'Búsqueda'; // TODO: i18n // TODO: i18n /** * Sets the placeholder attribute on the `input` element. */ this.placeholder = 'Buscar'; // TODO: i18n // TODO: i18n /** * Used to set the `title` attribute of the clear button. */ this.clearButtonTitle = 'Limpiar'; // TODO: i18n // TODO: i18n /** * Emits an event when value is changed. */ this.valueChange = new EventEmitter(); /** * Emits an event when the clear button is clicked. */ this.clear = new EventEmitter(); /** * Called when search input is blurred. Needed to properly implement `ControlValueAccessor`. */ this.onTouched = (/** * @return {?} */ function () { }); /** * Method set in `registerOnChange` to propagate changes back to the form. */ this.propagateChange = (/** * @param {?} _ * @return {?} */ function (_) { }); Search.searchCount++; } Object.defineProperty(Search.prototype, "containerClass", { get: /** * @return {?} */ function () { return !this.toolbar; }, enumerable: true, configurable: true }); /** * This is the initial value set to the component * @param value The input value. */ /** * This is the initial value set to the component * @param {?} value The input value. * @return {?} */ Search.prototype.writeValue = /** * This is the initial value set to the component * @param {?} value The input value. * @return {?} */ function (value) { this.value = value; }; /** * Sets a method in order to propagate changes back to the form. */ /** * Sets a method in order to propagate changes back to the form. * @param {?} fn * @return {?} */ Search.prototype.registerOnChange = /** * Sets a method in order to propagate changes back to the form. * @param {?} fn * @return {?} */ function (fn) { this.propagateChange = fn; }; /** * Registers a callback to be triggered when the control has been touched. * @param fn Callback to be triggered when the search input is touched. */ /** * Registers a callback to be triggered when the control has been touched. * @param {?} fn Callback to be triggered when the search input is touched. * @return {?} */ Search.prototype.registerOnTouched = /** * Registers a callback to be triggered when the control has been touched. * @param {?} fn Callback to be triggered when the search input is touched. * @return {?} */ function (fn) { this.onTouched = fn; }; /** * Called when text is written in the input. * @param search The input text. */ /** * Called when text is written in the input. * @param {?} search The input text. * @return {?} */ Search.prototype.onSearch = /** * Called when text is written in the input. * @param {?} search The input text. * @return {?} */ function (search) { this.value = search; this.doValueChange(); }; /** * Called when clear button is clicked. */ /** * Called when clear button is clicked. * @return {?} */ Search.prototype.clearSearch = /** * Called when clear button is clicked. * @return {?} */ function () { this.value = ''; this.clear.emit(); this.propagateChange(this.value); }; /** * @return {?} */ Search.prototype.doValueChange = /** * @return {?} */ function () { this.valueChange.emit(this.value); this.propagateChange(this.value); }; /** * @return {?} */ Search.prototype.openSearch = /** * @return {?} */ function () { var _this = this; this.active = true; setTimeout((/** * @return {?} */ function () { return _this.inputRef.nativeElement.focus(); })); }; /** * @param {?} event * @return {?} */ Search.prototype.keyDown = /** * @param {?} event * @return {?} */ function (event) { if (this.toolbar) { if (event.key === 'Escape') { this.active = false; } else if (event.key === 'Enter') { this.openSearch(); } } }; /** * @param {?} event * @return {?} */ Search.prototype.focusOut = /** * @param {?} event * @return {?} */ function (event) { if (this.toolbar && this.inputRef.nativeElement.value === '' && event.relatedTarget === null) { this.active = false; } }; /** * Variable used for creating unique ids for search components. */ Search.searchCount = 0; Search.decorators = [ { type: Component, args: [{ selector: 'suka-search', template: "\n <div\n class=\"search\"\n [ngClass]=\"{\n 'skeleton': skeleton,\n 'toolbar-search': toolbar,\n 'toolbar-search--active': toolbar && active\n }\"\n role=\"search\"\n >\n <label class=\"label\" [for]=\"id\">{{label}}</label>\n\n <div *ngIf=\"skeleton; else enableInput\" class=\"search-input\"></div>\n <ng-template #enableInput>\n <input\n #input\n *ngIf=\"!toolbar || active || value !== ''\"\n class=\"search-input\"\n [type]=\"tableSearch || !toolbar ? 'text' : 'search'\"\n role=\"search\"\n [id]=\"id\"\n [value]=\"value\"\n [autocomplete]=\"autocomplete\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n (input)=\"onSearch($event.target.value)\"/>\n <button *ngIf=\"!tableSearch && toolbar\" class=\"toolbar-search__btn\" (click)=\"openSearch()\">\n <suka-icon icon=\"search\"></suka-icon>\n </button>\n <suka-icon icon=\"search\" *ngIf=\"tableSearch || !toolbar\" (click)=\"openSearch()\" class=\"search-magnifier\"></suka-icon>\n </ng-template>\n\n <button\n *ngIf=\"tableSearch || !toolbar\"\n class=\"search-close\"\n [ngClass]=\"{\n 'search-close--hidden': !value || value.length === 0\n }\"\n [title]=\"clearButtonTitle\"\n [attr.aria-label]=\"clearButtonTitle\"\n (click)=\"clearSearch()\"\n >\n <suka-icon icon=\"x-circle\"></suka-icon>\n </button>\n </div>\n ", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: Search, multi: true } ] }] } ]; /** @nocollapse */ Search.ctorParameters = function () { return [ { type: ElementRef } ]; }; Search.propDecorators = { containerClass: [{ type: HostBinding, args: ['class.form-item',] }], disabled: [{ type: Input }], toolbar: [{ type: Input }], skeleton: [{ type: Input }], active: [{ type: Input }], tableSearch: [{ type: Input }], name: [{ type: Input }], id: [{ type: Input }], required: [{ type: Input }], value: [{ type: Input }], autocomplete: [{ type: Input }], label: [{ type: Input }], placeholder: [{ type: Input }], clearButtonTitle: [{ type: Input }], valueChange: [{ type: Output }], clear: [{ type: Output }], inputRef: [{ type: ViewChild, args: ['input', { static: false },] }], keyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }], focusOut: [{ type: HostListener, args: ['focusout', ['$event'],] }] }; return Search; }()); export { Search }; if (false) { /** * Variable used for creating unique ids for search components. * @type {?} */ Search.searchCount; /** * Set to `true` for a disabled search input. * @type {?} */ Search.prototype.disabled; /** * Set to `true` for a toolbar search component. * @type {?} */ Search.prototype.toolbar; /** * Set to `true` for a loading search component. * @type {?} */ Search.prototype.skeleton; /** * Set to `true` to expand the toolbar search component. * @type {?} */ Search.prototype.active; /** * Specifies whether the search component is used in the table toolbar. * @type {?} */ Search.prototype.tableSearch; /** * Sets the name attribute on the `input` element. * @type {?} */ Search.prototype.name; /** * The unique id for the search component. * @type {?} */ Search.prototype.id; /** * Reflects the required attribute of the `input` element. * @type {?} */ Search.prototype.required; /** * Sets the value attribute on the `input` element. * @type {?} */ Search.prototype.value; /** * Sets the autocomplete attribute on the `input` element. * For refernece: https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete#Values * @type {?} */ Search.prototype.autocomplete; /** * Sets the text inside the `label` tag. * @type {?} */ Search.prototype.label; /** * Sets the placeholder attribute on the `input` element. * @type {?} */ Search.prototype.placeholder; /** * Used to set the `title` attribute of the clear button. * @type {?} */ Search.prototype.clearButtonTitle; /** * Emits an event when value is changed. * @type {?} */ Search.prototype.valueChange; /** * Emits an event when the clear button is clicked. * @type {?} */ Search.prototype.clear; /** @type {?} */ Search.prototype.inputRef; /** * Called when search input is blurred. Needed to properly implement `ControlValueAccessor`. * @type {?} */ Search.prototype.onTouched; /** * Method set in `registerOnChange` to propagate changes back to the form. * @type {?} */ Search.prototype.propagateChange; /** * @type {?} * @protected */ Search.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/search/search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  EventEmitter,\n  Output,\n  HostBinding,\n  ElementRef,\n  HostListener,\n  ViewChild\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\n@Component({\n  selector: 'suka-search',\n  template: `\n  <div\n    class=\"search\"\n    [ngClass]=\"{\n      'skeleton': skeleton,\n      'toolbar-search': toolbar,\n      'toolbar-search--active': toolbar && active\n    }\"\n    role=\"search\"\n  >\n    <label class=\"label\" [for]=\"id\">{{label}}</label>\n\n    <div *ngIf=\"skeleton; else enableInput\" class=\"search-input\"></div>\n    <ng-template #enableInput>\n      <input\n        #input\n        *ngIf=\"!toolbar || active || value !== ''\"\n        class=\"search-input\"\n        [type]=\"tableSearch || !toolbar ? 'text' : 'search'\"\n        role=\"search\"\n        [id]=\"id\"\n        [value]=\"value\"\n        [autocomplete]=\"autocomplete\"\n        [placeholder]=\"placeholder\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        (input)=\"onSearch($event.target.value)\"/>\n      <button *ngIf=\"!tableSearch && toolbar\" class=\"toolbar-search__btn\" (click)=\"openSearch()\">\n        <suka-icon icon=\"search\"></suka-icon>\n      </button>\n      <suka-icon icon=\"search\"  *ngIf=\"tableSearch || !toolbar\" (click)=\"openSearch()\" class=\"search-magnifier\"></suka-icon>\n    </ng-template>\n\n    <button\n      *ngIf=\"tableSearch || !toolbar\"\n      class=\"search-close\"\n      [ngClass]=\"{\n        'search-close--hidden': !value || value.length === 0\n      }\"\n      [title]=\"clearButtonTitle\"\n      [attr.aria-label]=\"clearButtonTitle\"\n      (click)=\"clearSearch()\"\n    >\n      <suka-icon icon=\"x-circle\"></suka-icon>\n    </button>\n  </div>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: Search,\n      multi: true\n    }\n  ]\n})\n// tslint:disable-next-line: component-class-suffix\nexport class Search implements ControlValueAccessor {\n  /**\n   * Variable used for creating unique ids for search components.\n   */\n  static searchCount = 0;\n\n  @HostBinding('class.form-item') get containerClass() { return !this.toolbar; }\n\n  /**\n   * Set to `true` for a disabled search input.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to `true` for a toolbar search component.\n   */\n  @Input() toolbar = false;\n  /**\n   * Set to `true` for a loading search component.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` to expand the toolbar search component.\n   */\n  @Input() active = false;\n  /**\n   * Specifies whether the search component is used in the table toolbar.\n   */\n  @Input() tableSearch = false;\n  /**\n   * Sets the name attribute on the `input` element.\n   */\n  @Input() name: string;\n  /**\n   * The unique id for the search component.\n   */\n  @Input() id = `search-${Search.searchCount}`;\n  /**\n   * Reflects the required attribute of the `input` element.\n   */\n  @Input() required: boolean;\n  /**\n   * Sets the value attribute on the `input` element.\n   */\n  @Input() value = '';\n  /**\n   * Sets the autocomplete attribute on the `input` element.\n   * For refernece: https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete#Values\n   */\n  @Input() autocomplete = 'on';\n  /**\n   * Sets the text inside the `label` tag.\n   */\n  @Input() label = 'Búsqueda'; // TODO: i18n\n  /**\n   * Sets the placeholder attribute on the `input` element.\n   */\n  @Input() placeholder = 'Buscar'; // TODO: i18n\n  /**\n   * Used to set the `title` attribute of the clear button.\n   */\n  @Input() clearButtonTitle = 'Limpiar'; // TODO: i18n\n  /**\n   * Emits an event when value is changed.\n   */\n  @Output() valueChange = new EventEmitter<string>();\n  /**\n   * Emits an event when the clear button is clicked.\n   */\n  @Output() clear = new EventEmitter();\n\n  @ViewChild('input', {static: false}) inputRef: ElementRef;\n\n  /**\n   * Creates an instance of `Search`.\n   */\n  constructor(protected elementRef: ElementRef) {\n    Search.searchCount++;\n  }\n\n  /**\n   * This is the initial value set to the component\n   * @param value The input value.\n   */\n  public writeValue(value: any) {\n    this.value = value;\n  }\n\n  /**\n   * Sets a method in order to propagate changes back to the form.\n   */\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /**\n   * Registers a callback to be triggered when the control has been touched.\n   * @param fn Callback to be triggered when the search input is touched.\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  /**\n   * Called when search input is blurred. Needed to properly implement `ControlValueAccessor`.\n   */\n  onTouched: () => any = () => { };\n\n  /**\n   * Method set in `registerOnChange` to propagate changes back to the form.\n   */\n  propagateChange = (_: any) => { };\n\n  /**\n   * Called when text is written in the input.\n   * @param search The input text.\n   */\n  onSearch(search: string) {\n    this.value = search;\n    this.doValueChange();\n  }\n\n  /**\n   * Called when clear button is clicked.\n   */\n  clearSearch(): void {\n    this.value = '';\n    this.clear.emit();\n    this.propagateChange(this.value);\n  }\n\n  doValueChange() {\n    this.valueChange.emit(this.value);\n    this.propagateChange(this.value);\n  }\n\n  openSearch() {\n    this.active = true;\n    setTimeout(() => this.inputRef.nativeElement.focus());\n  }\n\n  @HostListener('keydown', ['$event'])\n  keyDown(event: KeyboardEvent) {\n    if (this.toolbar) {\n      if (event.key === 'Escape') {\n        this.active = false;\n      } else if (event.key === 'Enter') {\n        this.openSearch();\n      }\n    }\n  }\n\n  @HostListener('focusout', ['$event'])\n  focusOut(event) {\n    if (this.toolbar &&\n      this.inputRef.nativeElement.value === '' &&\n      event.relatedTarget === null) {\n      this.active = false;\n    }\n  }\n}\n"]}