@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
JavaScript
/**
* @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"]}