@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>
305 lines • 21.1 kB
JavaScript
/**
* @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, forwardRef, } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
var Select = /** @class */ (function () {
function Select() {
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.valueChange = new EventEmitter();
/**
* placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched`
*/
this.onChangeHandler = (/**
* @param {?} _
* @return {?}
*/
function (_) { });
this.onTouchedHandler = (/**
* @return {?}
*/
function () { });
}
Object.defineProperty(Select.prototype, "value", {
get: /**
* @return {?}
*/
function () {
// return this._value;
return this.select.nativeElement.value || this._value;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._value = v;
this.select.nativeElement.value = v;
},
enumerable: true,
configurable: true
});
/**
* Receives a value from the model.
*/
/**
* Receives a value from the model.
* @param {?} obj
* @return {?}
*/
Select.prototype.writeValue = /**
* Receives a value from the model.
* @param {?} obj
* @return {?}
*/
function (obj) {
this.value = obj;
};
/**
* Registers a listener that notifies the model when the control updates
*/
/**
* Registers a listener that notifies the model when the control updates
* @param {?} fn
* @return {?}
*/
Select.prototype.registerOnChange = /**
* Registers a listener that notifies the model when the control updates
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChangeHandler = fn;
};
/**
* Registers a listener that notifies the model when the control is blurred
*/
/**
* Registers a listener that notifies the model when the control is blurred
* @param {?} fn
* @return {?}
*/
Select.prototype.registerOnTouched = /**
* Registers a listener that notifies the model when the control is blurred
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouchedHandler = fn;
};
/**
* Sets the disabled state through the model
*/
/**
* Sets the disabled state through the model
* @param {?} isDisabled
* @return {?}
*/
Select.prototype.setDisabledState = /**
* Sets the disabled state through the model
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
};
/**
* Handles the change event from the `select`.
* Sends events to the change handler and emits a `selected` event.
*/
/**
* Handles the change event from the `select`.
* Sends events to the change handler and emits a `selected` event.
* @param {?} event
* @return {?}
*/
Select.prototype.onChange = /**
* Handles the change event from the `select`.
* Sends events to the change handler and emits a `selected` event.
* @param {?} event
* @return {?}
*/
function (event) {
this.onChangeHandler(event.target.value);
this.valueChange.emit(event.target.value);
};
/**
* Listens for the host blurring, and notifies the model
*/
/**
* Listens for the host blurring, and notifies the model
* @param {?} target
* @return {?}
*/
Select.prototype.onBlur = /**
* Listens for the host blurring, and notifies the model
* @param {?} target
* @return {?}
*/
function (target) {
this.onTouchedHandler();
};
/**
* @param {?} value
* @return {?}
*/
Select.prototype.isTemplate = /**
* @param {?} value
* @return {?}
*/
function (value) {
return value instanceof TemplateRef;
};
/**
* @return {?}
*/
Select.prototype.ngOnInit = /**
* @return {?}
*/
function () {
// console.log(this.select.nativeElement);
this.value = this.select.nativeElement.value;
};
/**
* Tracks the total number of selects instantiated. Used to generate unique IDs
*/
Select.selectCount = 0;
Select.decorators = [
{ type: Component, args: [{
selector: 'suka-select',
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 #selectInput\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 ",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return Select; })),
multi: true
}
],
styles: ["\n [data-invalid] ~ .select__arrow {\n bottom: 2.25rem;\n }\n "]
}] }
];
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 }],
valueChange: [{ type: Output }],
select: [{ type: ViewChild, args: ['selectInput', { static: true },] }],
onBlur: [{ type: HostListener, args: ['blur', ['$event.target'],] }]
};
return Select;
}());
export { Select };
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.valueChange;
/** @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  forwardRef,\n  OnInit,\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            #selectInput\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: forwardRef(() => Select),\n      multi: true\n    }\n  ]\n})\nexport class Select implements ControlValueAccessor, OnInit {\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() valueChange = new EventEmitter();\n\n  @ViewChild('selectInput', { static: true }) select: ElementRef;\n\n  get value() {\n    // return this._value;\n    return this.select.nativeElement.value || this._value;\n  }\n\n  set value(v) {\n    this._value = v;\n    this.select.nativeElement.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.valueChange.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  ngOnInit() {\n    // console.log(this.select.nativeElement);\n    this.value = this.select.nativeElement.value;\n  }\n}\n"]}