@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
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';
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"]}