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>

264 lines 15.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'; export class DatePickerInput { /** * @param {?} elementRef */ constructor(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 {?} */ () => { }); this.propagateChange = (/** * @param {?} _ * @return {?} */ (_) => { }); } /** * Sets the value, marks the input as touched and emits a value change event. * @param {?} event * @return {?} */ onChange(event) { this.value = event.target.value; this.valueChange.emit(this.value); this.propagateChange(this.value); this.onTouched(); } /** * @param {?} value * @return {?} */ writeValue(value) { this.value = value; } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.propagateChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} value * @return {?} */ isTemplate(value) { return value instanceof TemplateRef; } } DatePickerInput.datePickerCount = 0; DatePickerInput.decorators = [ { type: Component, args: [{ selector: 'suka-date-picker-input', template: ` <div class="date-picker-input" [ngClass]="{ 'date-picker--single' : type === 'single', 'date-picker--range' : type === 'range', 'skeleton' : skeleton }"> <div class="date-picker-input-container"> <label *ngIf="label" [for]="id" class="label"> <ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container> <ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template> </label> <div class="date-picker-input__wrapper"> <input *ngIf="!skeleton" autocomplete="off" type="text" class="date-picker__input" [value]="value" [pattern]="pattern" [placeholder]="placeholder" [id]= "id" [disabled]="disabled" (change)="onChange($event)"/> <suka-icon icon="calendar" class="date-picker__icon" *ngIf="!timePicker" > </suka-icon> <suka-icon icon="clock" class="date-picker__icon" *ngIf="timePicker" > </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: DatePickerInput, multi: true } ] }] } ]; /** @nocollapse */ DatePickerInput.ctorParameters = () => [ { 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 }] }; 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;AAwDnD,MAAM,OAAO,eAAe;;;;IAoE1B,YAAsB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;;;;QA9DnC,SAAI,GAAkC,QAAQ,CAAC;;;;QAK/C,OAAE,GAAG,cAAc,eAAe,CAAC,eAAe,EAAE,EAAE,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,GAAG,EAAE,GAAG,CAAC,EAAC;QAEjC,oBAAe;;;;QAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,EAAC;IA1Bc,CAAC;;;;;;IAKjD,QAAQ,CAAC,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,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;;;;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;;;;;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IAMM,UAAU,CAAC,KAAK;QACrB,OAAO,KAAK,YAAY,WAAW,CAAC;IACtC,CAAC;;AAjGc,+BAAe,GAAG,CAAC,CAAC;;YAvDpC,SAAS,SAAC;gBACT,QAAQ,EAAE,wBAAwB;gBAClC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CT;gBACD,SAAS,EAAE;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,eAAe;wBAC5B,KAAK,EAAE,IAAI;qBACZ;iBACF;aACF;;;;YA1DC,UAAU;;;mBAiET,KAAK;iBAKL,KAAK;sBAKL,KAAK;oBAKL,KAAK;0BAKL,KAAK;sBAKL,KAAK;0BAKL,MAAM;uBAKN,KAAK;sBAKL,KAAK;0BAKL,KAAK;yBAKL,KAAK;uBAKL,KAAK;oBAKL,KAAK;;;;;;;IAjEN,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"]}