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>

365 lines (363 loc) 22.5 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'; // tslint:disable-next-line: component-class-suffix export class Search { /** * Creates an instance of `Search`. * @param {?} elementRef */ constructor(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 reference: 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 {?} */ () => { }); /** * Method set in `registerOnChange` to propagate changes back to the form. */ this.propagateChange = (/** * @param {?} _ * @return {?} */ (_) => { }); Search.searchCount++; } /** * @return {?} */ get containerClass() { return !this.toolbar; } /** * This is the initial value set to the component * @param {?} value The input value. * @return {?} */ writeValue(value) { this.value = value; } /** * Sets a method in order to propagate changes back to the form. * @param {?} fn * @return {?} */ registerOnChange(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. * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * Called when text is written in the input. * @param {?} search The input text. * @return {?} */ onSearch(search) { this.value = search; this.doValueChange(); } /** * Called when clear button is clicked. * @return {?} */ clearSearch() { this.value = ''; this.clear.emit(); this.propagateChange(this.value); } /** * @return {?} */ doValueChange() { this.valueChange.emit(this.value); this.propagateChange(this.value); } /** * @return {?} */ openSearch() { this.active = true; setTimeout((/** * @return {?} */ () => this.inputRef.nativeElement.focus())); } /** * @param {?} event * @return {?} */ keyDown(event) { if (this.toolbar) { if (event.key === 'Escape') { this.active = false; } else if (event.key === 'Enter') { this.openSearch(); } } } /** * @param {?} event * @return {?} */ focusOut(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: ` <div class="search" [ngClass]="{ 'skeleton': skeleton, 'toolbar-search': toolbar, 'toolbar-search--active': toolbar && active }" role="search" > <label class="label" [for]="id">{{label}}</label> <div *ngIf="skeleton; else enableInput" class="search-input"></div> <ng-template #enableInput> <input #input *ngIf="!toolbar || active || value !== ''" class="search-input" [type]="tableSearch || !toolbar ? 'text' : 'search'" role="search" [id]="id" [value]="value" [autocomplete]="autocomplete" [placeholder]="placeholder" [disabled]="disabled" [required]="required" (input)="onSearch($event.target.value)"/> <button *ngIf="!tableSearch && toolbar" class="toolbar-search__btn" (click)="openSearch()"> <suka-icon icon="search"></suka-icon> </button> <suka-icon icon="search" *ngIf="tableSearch || !toolbar" (click)="openSearch()" class="search-magnifier"></suka-icon> </ng-template> <button *ngIf="tableSearch || !toolbar" class="search-close" [ngClass]="{ 'search-close--hidden': !value || value.length === 0 }" [title]="clearButtonTitle" [attr.aria-label]="clearButtonTitle" (click)="clearSearch()" > <suka-icon icon="x-circle"></suka-icon> </button> </div> `, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: Search, multi: true } ] }] } ]; /** @nocollapse */ Search.ctorParameters = () => [ { 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'],] }] }; 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 reference: 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 reference: 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"]}