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>

244 lines 16.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, ElementRef, TemplateRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; var DatePickerInput = /** @class */ (function () { function DatePickerInput(elementRef) { this.elementRef = elementRef; /** * Select a calendar type for the `model`. */ this.type = 'simple'; /** * Sets the id for the `DatePickerInput`. */ this.id = "datepicker-" + DatePickerInput.datePickerCount++; /** * Set to `true` to display a calendar icon */ this.hasIcon = false; /** * Sets the input's placeholder. */ this.placeholder = 'dd/mm/yyyy'; /** * Sets the pattern to follow. */ this.pattern = '^\\d{1,2}/\\d{1,2}/\\d{4}$'; /** * Emits event notifying other classes of a value change. */ this.valueChange = new EventEmitter(); /** * Set to `true` to disable the input */ this.disabled = false; /** * Set to `true` to display invalid state. */ this.invalid = false; /** * Sets a time picker icon for input */ this.timePicker = false; /** * Skeleton state. */ this.skeleton = false; /** * Sets the `DatepickerInput` value. */ this.value = ''; this.onTouched = (/** * @return {?} */ function () { }); this.propagateChange = (/** * @param {?} _ * @return {?} */ function (_) { }); } /** * Sets the value, marks the input as touched and emits a value change event. */ /** * Sets the value, marks the input as touched and emits a value change event. * @param {?} event * @return {?} */ DatePickerInput.prototype.onChange = /** * Sets the value, marks the input as touched and emits a value change event. * @param {?} event * @return {?} */ function (event) { this.value = event.target.value; this.valueChange.emit(this.value); this.propagateChange(this.value); this.onTouched(); }; /** * @param {?} value * @return {?} */ DatePickerInput.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this.value = value; }; /** * @param {?} fn * @return {?} */ DatePickerInput.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.propagateChange = fn; }; /** * @param {?} fn * @return {?} */ DatePickerInput.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} value * @return {?} */ DatePickerInput.prototype.isTemplate = /** * @param {?} value * @return {?} */ function (value) { return value instanceof TemplateRef; }; DatePickerInput.datePickerCount = 0; DatePickerInput.decorators = [ { type: Component, args: [{ selector: 'suka-date-picker-input', template: "\n <div class=\"date-picker-input\"\n [ngClass]=\"{\n 'date-picker--single' : type === 'single',\n 'date-picker--range' : type === 'range',\n 'skeleton' : skeleton\n }\">\n <div class=\"date-picker-input-container\">\n <label *ngIf=\"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 class=\"date-picker-input__wrapper\">\n <input\n *ngIf=\"!skeleton\"\n autocomplete=\"off\"\n type=\"text\"\n class=\"date-picker__input\"\n [value]=\"value\"\n [pattern]=\"pattern\"\n [placeholder]=\"placeholder\"\n [id]= \"id\"\n [disabled]=\"disabled\"\n (change)=\"onChange($event)\"/>\n <suka-icon\n icon=\"calendar\"\n class=\"date-picker__icon\"\n *ngIf=\"!timePicker\"\n >\n </suka-icon>\n <suka-icon\n icon=\"clock\"\n class=\"date-picker__icon\"\n *ngIf=\"timePicker\"\n >\n </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: DatePickerInput, multi: true } ] }] } ]; /** @nocollapse */ DatePickerInput.ctorParameters = function () { return [ { type: ElementRef } ]; }; DatePickerInput.propDecorators = { type: [{ type: Input }], id: [{ type: Input }], hasIcon: [{ type: Input }], label: [{ type: Input }], placeholder: [{ type: Input }], pattern: [{ type: Input }], valueChange: [{ type: Output }], disabled: [{ type: Input }], invalid: [{ type: Input }], invalidText: [{ type: Input }], timePicker: [{ type: Input }], skeleton: [{ type: Input }], value: [{ type: Input }] }; return DatePickerInput; }()); export { DatePickerInput }; if (false) { /** * @type {?} * @private */ DatePickerInput.datePickerCount; /** * Select a calendar type for the `model`. * @type {?} */ DatePickerInput.prototype.type; /** * Sets the id for the `DatePickerInput`. * @type {?} */ DatePickerInput.prototype.id; /** * Set to `true` to display a calendar icon * @type {?} */ DatePickerInput.prototype.hasIcon; /** * label content. * @type {?} */ DatePickerInput.prototype.label; /** * Sets the input's placeholder. * @type {?} */ DatePickerInput.prototype.placeholder; /** * Sets the pattern to follow. * @type {?} */ DatePickerInput.prototype.pattern; /** * Emits event notifying other classes of a value change. * @type {?} */ DatePickerInput.prototype.valueChange; /** * Set to `true` to disable the input * @type {?} */ DatePickerInput.prototype.disabled; /** * Set to `true` to display invalid state. * @type {?} */ DatePickerInput.prototype.invalid; /** * Feedback message to display when `DatepickerInput` is invalid. * @type {?} */ DatePickerInput.prototype.invalidText; /** * Sets a time picker icon for input * @type {?} */ DatePickerInput.prototype.timePicker; /** * Skeleton state. * @type {?} */ DatePickerInput.prototype.skeleton; /** * Sets the `DatepickerInput` value. * @type {?} */ DatePickerInput.prototype.value; /** @type {?} */ DatePickerInput.prototype.onTouched; /** @type {?} */ DatePickerInput.prototype.propagateChange; /** * @type {?} * @protected */ DatePickerInput.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/datepicker-input/datepicker-input.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,UAAU,EACV,WAAW,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD;IA0HE,yBAAsB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;;;;QA9DnC,SAAI,GAAkC,QAAQ,CAAC;;;;QAK/C,OAAE,GAAG,gBAAc,eAAe,CAAC,eAAe,EAAI,CAAC;;;;QAKvD,YAAO,GAAG,KAAK,CAAC;;;;QAUhB,gBAAW,GAAG,YAAY,CAAC;;;;QAK3B,YAAO,GAAG,4BAA4B,CAAC;;;;QAKtC,gBAAW,GAAyB,IAAI,YAAY,EAAE,CAAC;;;;QAKxD,aAAQ,GAAG,KAAK,CAAC;;;;QAKjB,YAAO,GAAG,KAAK,CAAC;;;;QAUhB,eAAU,GAAG,KAAK,CAAC;;;;QAKnB,aAAQ,GAAG,KAAK,CAAC;;;;QAKjB,UAAK,GAAG,EAAE,CAAC;QA0BpB,cAAS;;;QAAc,cAAQ,CAAC,EAAC;QAEjC,oBAAe;;;;QAAG,UAAC,CAAM,IAAO,CAAC,EAAC;IA1Bc,CAAC;IAEjD;;OAEG;;;;;;IACH,kCAAQ;;;;;IAAR,UAAS,KAAK;QACZ,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IAEM,oCAAU;;;;IAAjB,UAAkB,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;;;;IAEM,0CAAgB;;;;IAAvB,UAAwB,EAAO;QAC7B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;;;;;IAEM,2CAAiB;;;;IAAxB,UAAyB,EAAO;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IAMM,oCAAU;;;;IAAjB,UAAkB,KAAK;QACrB,OAAO,KAAK,YAAY,WAAW,CAAC;IACtC,CAAC;IAjGc,+BAAe,GAAG,CAAC,CAAC;;gBAvDpC,SAAS,SAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,QAAQ,EAAE,wkDA2CT;oBACD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,eAAe;4BAC5B,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF;;;;gBA1DC,UAAU;;;uBAiET,KAAK;qBAKL,KAAK;0BAKL,KAAK;wBAKL,KAAK;8BAKL,KAAK;0BAKL,KAAK;8BAKL,MAAM;2BAKN,KAAK;0BAKL,KAAK;8BAKL,KAAK;6BAKL,KAAK;2BAKL,KAAK;wBAKL,KAAK;;IAiCR,sBAAC;CAAA,AAzJD,IAyJC;SAnGY,eAAe;;;;;;IAC1B,gCAAmC;;;;;IAKnC,+BAAwD;;;;;IAKxD,6BAAgE;;;;;IAKhE,kCAAyB;;;;;IAKzB,gCAA0C;;;;;IAK1C,sCAAoC;;;;;IAKpC,kCAAgD;;;;;IAKhD,sCAAiE;;;;;IAKjE,mCAA0B;;;;;IAK1B,kCAAyB;;;;;IAKzB,sCAAgD;;;;;IAKhD,qCAA4B;;;;;IAK5B,mCAA0B;;;;;IAK1B,gCAAoB;;IA0BpB,oCAAiC;;IAEjC,0CAAkC;;;;;IA1BtB,qCAAgC","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  TemplateRef\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'suka-date-picker-input',\n  template: `\n    <div class=\"date-picker-input\"\n      [ngClass]=\"{\n        'date-picker--single' : type === 'single',\n        'date-picker--range' : type === 'range',\n        'skeleton' : skeleton\n      }\">\n      <div class=\"date-picker-input-container\">\n        <label *ngIf=\"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 class=\"date-picker-input__wrapper\">\n          <input\n            *ngIf=\"!skeleton\"\n            autocomplete=\"off\"\n            type=\"text\"\n            class=\"date-picker__input\"\n            [value]=\"value\"\n            [pattern]=\"pattern\"\n            [placeholder]=\"placeholder\"\n            [id]= \"id\"\n            [disabled]=\"disabled\"\n            (change)=\"onChange($event)\"/>\n            <suka-icon\n              icon=\"calendar\"\n              class=\"date-picker__icon\"\n              *ngIf=\"!timePicker\"\n            >\n            </suka-icon>\n            <suka-icon\n              icon=\"clock\"\n              class=\"date-picker__icon\"\n              *ngIf=\"timePicker\"\n            >\n            </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  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: DatePickerInput,\n      multi: true\n    }\n  ]\n})\nexport class DatePickerInput {\n  private static datePickerCount = 0;\n\n  /**\n   * Select a calendar type for the `model`.\n   */\n  @Input() type: 'simple' | 'single' | 'range' = 'simple';\n\n  /**\n   * Sets the id for the `DatePickerInput`.\n   */\n  @Input() id = `datepicker-${DatePickerInput.datePickerCount++}`;\n\n  /**\n   *  Set to `true` to display a calendar icon\n   */\n  @Input() hasIcon = false;\n\n  /**\n   * label content.\n   */\n  @Input() label: string | TemplateRef<any>;\n\n  /**\n   * Sets the input's placeholder.\n   */\n  @Input() placeholder = 'dd/mm/yyyy';\n\n  /**\n   * Sets the pattern to follow.\n   */\n  @Input() pattern = '^\\\\d{1,2}/\\\\d{1,2}/\\\\d{4}$';\n\n  /**\n   * Emits event notifying other classes of a value change.\n   */\n  @Output() valueChange: EventEmitter<string> = new EventEmitter();\n\n  /**\n   * Set to `true` to disable the input\n   */\n  @Input() disabled = false;\n\n  /**\n   * Set to `true` to display invalid state.\n   */\n  @Input() invalid = false;\n\n  /**\n   * Feedback message to display when `DatepickerInput` is invalid.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n\n  /**\n   * Sets a time picker icon for input\n   */\n  @Input() timePicker = false;\n\n  /**\n   * Skeleton state.\n   */\n  @Input() skeleton = false;\n\n  /**\n   * Sets the `DatepickerInput` value.\n   */\n  @Input() value = '';\n\n  constructor(protected elementRef: ElementRef) { }\n\n  /**\n   * Sets the value, marks the input as touched and emits a value change event.\n   */\n  onChange(event) {\n    this.value = event.target.value;\n    this.valueChange.emit(this.value);\n    this.propagateChange(this.value);\n    this.onTouched();\n  }\n\n  public writeValue(value: any) {\n    this.value = value;\n  }\n\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  public registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  onTouched: () => any = () => { };\n\n  propagateChange = (_: any) => { };\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n}\n"]}