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>

275 lines 17.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ // tslint:disable: max-line-length import { Component, Input, Output, ViewChild, ElementRef, HostListener, EventEmitter, TemplateRef, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; // tslint:disable-next-line: component-class-suffix export class Select { constructor() { this._value = ''; /** * `inline` or `default` select displays */ this.display = 'default'; /** * Sets the unique ID. Defaults to `select-${total count of selects instantiated}` */ this.id = `select-${Select.selectCount++}`; /** * Set to true to disable component. */ this.disabled = false; /** * Set to true for a loading select. */ this.skeleton = false; /** * Set to `true` for an invalid select component. */ this.invalid = false; /** * Set to `true` for an valid select component. */ this.valid = false; /** * emits the selected options `value` */ this.selected = new EventEmitter(); /** * placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched` */ this.onChangeHandler = (/** * @param {?} _ * @return {?} */ (_) => { }); this.onTouchedHandler = (/** * @return {?} */ () => { }); } /** * @return {?} */ get value() { // return this.select.nativeElement.value; return this._value; } /** * @param {?} v * @return {?} */ set value(v) { this._value = v; } /** * Receives a value from the model. * @param {?} obj * @return {?} */ writeValue(obj) { this.value = obj; } /** * Registers a listener that notifies the model when the control updates * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChangeHandler = fn; } /** * Registers a listener that notifies the model when the control is blurred * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouchedHandler = fn; } /** * Sets the disabled state through the model * @param {?} isDisabled * @return {?} */ setDisabledState(isDisabled) { this.disabled = isDisabled; } /** * Handles the change event from the `select`. * Sends events to the change handler and emits a `selected` event. * @param {?} event * @return {?} */ onChange(event) { this.onChangeHandler(event.target.value); this.selected.emit(event.target.value); } /** * Listens for the host blurring, and notifies the model * @param {?} target * @return {?} */ onBlur(target) { this.onTouchedHandler(); } /** * @param {?} value * @return {?} */ isTemplate(value) { return value instanceof TemplateRef; } } /** * Tracks the total number of selects instantiated. Used to generate unique IDs */ Select.selectCount = 0; Select.decorators = [ { type: Component, args: [{ selector: 'suka-select', template: ` <div class="form-item"> <div [ngClass]="{ 'select--inline': display === 'inline', 'skeleton': skeleton }" class="select" > <label *ngIf="skeleton && label" [for]="id" class="label skeleton"></label> <label *ngIf="!skeleton && label" [for]="id" class="label"> <ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container> <ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template> </label> <div *ngIf="helperText" class="form__helper-text"> <ng-container *ngIf="!isTemplate(helperText)">{{helperText}}</ng-container> <ng-template *ngIf="isTemplate(helperText)" [ngTemplateOutlet]="helperText"></ng-template> </div> <div class="select-input__wrapper" [attr.data-invalid]="(invalid ? true : null)" [attr.data-valid]="(valid ? true : null)"> <select #select [attr.id]="id" [disabled]="disabled" (change)="onChange($event)" [value]="value" (blur)="onBlur($event)" class="select-input"> <ng-content></ng-content> </select> <suka-icon *ngIf="invalid" icon="alert-circle" class="select__invalid-icon"></suka-icon> <suka-icon *ngIf="valid" icon="check" class="select__valid-icon"></suka-icon> <suka-icon *ngIf="!skeleton" class="select__arrow" icon="chevron-down"></suka-icon> </div> <div *ngIf="invalid" class="form-requirement"> <ng-container *ngIf="!isTemplate(invalidText)">{{invalidText}}</ng-container> <ng-template *ngIf="isTemplate(invalidText)" [ngTemplateOutlet]="invalidText"></ng-template> </div> </div> </div> `, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: Select, multi: true } ], styles: [` [data-invalid] ~ .select__arrow { bottom: 2.25rem; } `] }] } ]; Select.propDecorators = { display: [{ type: Input }], label: [{ type: Input }], helperText: [{ type: Input }], invalidText: [{ type: Input }], id: [{ type: Input }], disabled: [{ type: Input }], skeleton: [{ type: Input }], invalid: [{ type: Input }], valid: [{ type: Input }], selected: [{ type: Output }], select: [{ type: ViewChild, args: ['select', { static: false },] }], onBlur: [{ type: HostListener, args: ['blur', ['$event.target'],] }] }; if (false) { /** * Tracks the total number of selects instantiated. Used to generate unique IDs * @type {?} */ Select.selectCount; /** * @type {?} * @private */ Select.prototype._value; /** * `inline` or `default` select displays * @type {?} */ Select.prototype.display; /** * Label for the select. Appears above the input. * @type {?} */ Select.prototype.label; /** * Optional helper text that appears under the label. * @type {?} */ Select.prototype.helperText; /** * Sets the invalid text. * @type {?} */ Select.prototype.invalidText; /** * Sets the unique ID. Defaults to `select-${total count of selects instantiated}` * @type {?} */ Select.prototype.id; /** * Set to true to disable component. * @type {?} */ Select.prototype.disabled; /** * Set to true for a loading select. * @type {?} */ Select.prototype.skeleton; /** * Set to `true` for an invalid select component. * @type {?} */ Select.prototype.invalid; /** * Set to `true` for an valid select component. * @type {?} */ Select.prototype.valid; /** * emits the selected options `value` * @type {?} */ Select.prototype.selected; /** @type {?} */ Select.prototype.select; /** * placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched` * @type {?} * @protected */ Select.prototype.onChangeHandler; /** * @type {?} * @protected */ Select.prototype.onTouchedHandler; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable: max-line-length\n\nimport {\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  ElementRef,\n  HostListener,\n  EventEmitter,\n  TemplateRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'suka-select',\n  template: `\n    <div class=\"form-item\">\n      <div\n        [ngClass]=\"{\n          'select--inline': display === 'inline',\n          'skeleton': skeleton\n        }\"\n        class=\"select\"\n      >\n        <label *ngIf=\"skeleton && label\" [for]=\"id\" class=\"label skeleton\"></label>\n        <label *ngIf=\"!skeleton && label\" [for]=\"id\" class=\"label\">\n          <ng-container *ngIf=\"!isTemplate(label)\">{{label}}</ng-container>\n          <ng-template *ngIf=\"isTemplate(label)\" [ngTemplateOutlet]=\"label\"></ng-template>\n        </label>\n        <div *ngIf=\"helperText\" class=\"form__helper-text\">\n          <ng-container *ngIf=\"!isTemplate(helperText)\">{{helperText}}</ng-container>\n          <ng-template *ngIf=\"isTemplate(helperText)\" [ngTemplateOutlet]=\"helperText\"></ng-template>\n        </div>\n        <div class=\"select-input__wrapper\" [attr.data-invalid]=\"(invalid ? true : null)\" [attr.data-valid]=\"(valid ? true : null)\">\n          <select\n            #select\n            [attr.id]=\"id\"\n            [disabled]=\"disabled\"\n            (change)=\"onChange($event)\"\n            [value]=\"value\"\n            (blur)=\"onBlur($event)\"\n            class=\"select-input\">\n            <ng-content></ng-content>\n          </select>\n          <suka-icon *ngIf=\"invalid\" icon=\"alert-circle\" class=\"select__invalid-icon\"></suka-icon>\n          <suka-icon *ngIf=\"valid\" icon=\"check\" class=\"select__valid-icon\"></suka-icon>\n          <suka-icon *ngIf=\"!skeleton\" class=\"select__arrow\" icon=\"chevron-down\"></suka-icon>\n        </div>\n        <div *ngIf=\"invalid\" class=\"form-requirement\">\n          <ng-container *ngIf=\"!isTemplate(invalidText)\">{{invalidText}}</ng-container>\n          <ng-template *ngIf=\"isTemplate(invalidText)\" [ngTemplateOutlet]=\"invalidText\"></ng-template>\n        </div>\n      </div>\n    </div>\n  `,\n  styles: [`\n    [data-invalid] ~ .select__arrow {\n      bottom: 2.25rem;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: Select,\n      multi: true\n    }\n  ]\n})\n// tslint:disable-next-line: component-class-suffix\nexport class Select implements ControlValueAccessor {\n  /**\n   * Tracks the total number of selects instantiated. Used to generate unique IDs\n   */\n  static selectCount = 0;\n\n  private _value = '';\n\n  /**\n   * `inline` or `default` select displays\n   */\n  @Input() display: 'inline' | 'default' = 'default';\n  /**\n   * Label for the select. Appears above the input.\n   */\n  @Input() label: string | TemplateRef<any>;\n  /**\n   * Optional helper text that appears under the label.\n   */\n  @Input() helperText: string | TemplateRef<any>;\n  /**\n   * Sets the invalid text.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n  /**\n   * Sets the unique ID. Defaults to `select-${total count of selects instantiated}`\n   */\n  @Input() id = `select-${Select.selectCount++}`;\n  /**\n   * Set to true to disable component.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to true for a loading select.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` for an invalid select component.\n   */\n  @Input() invalid = false;\n\n  /**\n   * Set to `true` for an valid select component.\n   */\n  @Input() valid = false;\n\n  /**\n   * emits the selected options `value`\n   */\n  @Output() selected = new EventEmitter();\n\n  @ViewChild('select', {static: false}) select: ElementRef;\n\n  get value() {\n    // return this.select.nativeElement.value;\n    return this._value;\n  }\n\n  set value(v) {\n    this._value = v;\n  }\n\n  /**\n   * Receives a value from the model.\n   */\n  writeValue(obj: any) {\n    this.value = obj;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control updates\n   */\n  registerOnChange(fn: any) {\n    this.onChangeHandler = fn;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control is blurred\n   */\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler = fn;\n  }\n\n  /**\n   * Sets the disabled state through the model\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * Handles the change event from the `select`.\n   * Sends events to the change handler and emits a `selected` event.\n   */\n  onChange(event) {\n    this.onChangeHandler(event.target.value);\n    this.selected.emit(event.target.value);\n  }\n\n  /**\n   * Listens for the host blurring, and notifies the model\n   */\n  @HostListener('blur', ['$event.target'])\n  onBlur(target) {\n    this.onTouchedHandler();\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n\n  /**\n   * placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched`\n   */\n  protected onChangeHandler = (_: any) => { };\n  protected onTouchedHandler = () => { };\n}\n"]}