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