UNPKG

kwikui

Version:

KwikID's UI Component Library in Angular

225 lines 31.7 kB
import { Component, EventEmitter, forwardRef, Input, Output } from "@angular/core"; import { FormControl, FormGroup, NG_VALUE_ACCESSOR } from "@angular/forms"; import { Subscription } from "rxjs"; import { distinctUntilChanged } from "rxjs/operators"; import * as i0 from "@angular/core"; import * as i1 from "@taiga-ui/kit"; import * as i2 from "@taiga-ui/core"; import * as i3 from "./input-otp-multiple/input-otp-multiple.component"; import * as i4 from "@angular/common"; import * as i5 from "@angular/forms"; export class KwikUIInputOtpComponent { constructor() { this.disabled = false; this.focus = false; this.formControl = new FormControl({}); this.formControlName = "form_control_name"; this.id = ""; this.invalid = false; this.label = ""; this.mask = "# # # #"; this.mode = "single"; this.otpLength = 4; this.placeholder = ""; this.postfix = ""; this.prefix = ""; this.properties = { readOnly: false, hidePlaceholder: false }; this.size = "m"; this.validators = { required: true }; this.getKeyValue = new EventEmitter(); this.formGroup = new FormGroup({}); this.otpMultipleConfig = { allowKeyCodes: [], allowNumbersOnly: true, containerClass: "", containerStyles: {}, disableAutoFocus: true, inputClass: "", inputStyles: {}, isPasswordInput: false, length: this.otpLength, placeholder: "", size: this.size }; this.subscriptions = new Subscription(); } ngOnInit() { this.formGroup.addControl(this.formControlName, this.formControl); this.focus = this.focus === undefined ? false : this.focus; this.invalid = this.invalid === undefined ? false : this.invalid && this.focus; this.validators = Object.assign({}, this.validators); this.properties = Object.assign({}, this.properties); this.mode = this.mode !== "single" && this.mode !== "multiple" ? "multiple" : this.mode; this.otpMultipleConfig = Object.assign(Object.assign({}, this.otpMultipleConfig), { length: this.otpLength, placeholder: this.properties.hidePlaceholder ? "" : this.placeholder.length > 0 ? "0" : this.placeholder, size: this.size }); this.setDisabled(); this.subscriptions.add(this.formGroup.controls[this.formControlName].valueChanges .pipe(distinctUntilChanged()) // makes sure the value has actually changed. .subscribe((value) => this.handleInputValueChange(value))); } ngOnChanges(changes) { if (changes.hasOwnProperty("formControl") && !changes.formControl.firstChange) { this.formControl = changes.formControl.currentValue; } if (changes.hasOwnProperty("invalid") && !changes.invalid.firstChange) { this.invalid = Boolean(changes.invalid.currentValue); this.setError(); } if (changes.hasOwnProperty("focus") && !changes.focus.firstChange) { this.focus = Boolean(changes.focus.currentValue); } if (changes.hasOwnProperty("focus") && !changes.focus.firstChange) { this.focus = Boolean(changes.focus.currentValue); } if (changes.hasOwnProperty("size") && !changes.size.firstChange) { this.size = changes.size.currentValue; } if (changes.hasOwnProperty("disabled") && !changes.disabled.firstChange) { this.disabled = Boolean(changes.disabled.currentValue); this.setDisabled(); } } ngOnDestroy() { this.subscriptions.unsubscribe(); // ensure when component is destroyed the subscription is also and not left open. } /** * @description Handles updating the config object with the latest values for multiple mode */ setConfigProperties() { this.otpMultipleConfig = Object.assign(Object.assign({}, this.otpMultipleConfig), { length: this.otpLength, placeholder: this.placeholder.length > 0 ? "0" : this.placeholder, size: this.size }); } /** * @description Handles setting up of error and focus on the input field is it is invalid */ setDisabled() { if (this.formGroup.controls[this.formControlName] !== undefined) { if (this.disabled === true) { this.formGroup.controls[this.formControlName].disable({ emitEvent: false }); } else { this.formGroup.controls[this.formControlName].enable({ emitEvent: false }); } } } /** * @description Handles setting up of error and focus on the input field is it is invalid */ setError() { if (this.formGroup.controls[this.formControlName] !== undefined && this.formGroup.controls[this.formControlName].invalid) { this.invalid = true; this.focus = true; } else { this.invalid = false; this.focus = false; } } /** * @description Handles firing of 2 events on (keyup) event * * @param value */ handleInputValueChange(value) { if (value === this.formControl.value && this.mode === "single") { this.emitEvent(this.getKeyValue, { key: this.formControlName, value: this.formControl.value }); } } handleInputValueChangeMultiple(value) { if (this.mode === "multiple") { this.formControl.patchValue(value); this.formGroup.controls[this.formControlName].patchValue(value); this.emitEvent(this.getKeyValue, { key: this.formControlName, value: this.formControl.value }); } } handleFocusedChange(e) { if (!this.invalid) { this.focus = e; } } emitEvent(event, data) { event.emit(data); } /** Method Implementations for Abstract Control */ writeValue(value) { } registerOnChange(fn) { } registerOnTouched(fn) { } setDisabledState(isDisabled) { } } /** @nocollapse */ KwikUIInputOtpComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputOtpComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikUIInputOtpComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikUIInputOtpComponent, selector: "kwikui-input-otp", inputs: { disabled: "disabled", focus: "focus", formControl: "formControl", formControlName: "formControlName", id: "id", invalid: "invalid", label: "label", mask: "mask", mode: "mode", otpLength: "otpLength", placeholder: "placeholder", postfix: "postfix", prefix: "prefix", properties: "properties", size: "size", validators: "validators" }, outputs: { getKeyValue: "getKeyValue" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => KwikUIInputOtpComponent)), multi: true } ], usesOnChanges: true, ngImport: i0, template: "<div\n [formGroup]=\"formGroup\"\n *ngIf=\"mode === 'single'\"\n id=\"mode-single\"\n>\n <tui-input-phone\n [formControlName]=\"formControlName\"\n [countryCode]=\"''\"\n [phoneMaskAfterCountryCode]=\"mask\"\n [nativeId]=\"id\"\n [pseudoInvalid]=\"invalid === undefined ? null : invalid\"\n [pseudoFocus]=\"focus ?? null\"\n [readOnly]=\"properties?.readOnly ?? false\"\n (focusedChange)=\"handleFocusedChange($event)\"\n >\n {{ label }}\n <span\n class=\"tui-required\"\n *ngIf=\"validators.required\"\n ></span>\n <input\n tuiTextfield\n inputmode=\"numeric\"\n [attr.placeholder]=\"placeholder ?? ''\"\n [attr.required]=\"validators.required\"\n />\n </tui-input-phone>\n</div>\n<div\n [formGroup]=\"formGroup\"\n *ngIf=\"mode === 'multiple'\"\n id=\"mode-multiple\"\n>\n <div\n id=\"mode-multiple-label\"\n *ngIf=\"label !== ''\"\n >\n <span class=\"t-label\">\n <b>\n <p class=\"tui-space_bottom-1 tui-space_left-1 ng-star-inserted\">\n {{ label }}\n <span\n class=\"tui-required\"\n *ngIf=\"validators.required\"\n ></span>\n </p>\n </b>\n </span>\n </div>\n <div id=\"mode-multiple-inputs\">\n <kwikui-input-otp-multiple\n [formCtrl]=\"formControl\"\n [config]=\"otpMultipleConfig\"\n [invalid]=\"invalid === undefined ? null : invalid\"\n [disabled]=\"disabled\"\n [readOnly]=\"properties?.readOnly ?? false\"\n (onInputChange)=\"handleInputValueChangeMultiple($event)\"\n ></kwikui-input-otp-multiple>\n </div>\n</div>\n", styles: ["#mode-multiple{display:flex;flex-direction:column;align-content:center;align-items:stretch}tui-primitive-textfield ::ng-deep .t-input{padding-top:0!important}tui-primitive-textfield{text-align:center}tui-primitive-textfield.size_s{width:var(--tui-height-s)!important}tui-primitive-textfield.size_m{width:var(--tui-height-m)!important}tui-primitive-textfield.size_l{width:var(--tui-height-l)!important}\n"], components: [{ type: i1.TuiInputPhoneComponent, selector: "tui-input-phone", inputs: ["countryCode", "phoneMaskAfterCountryCode", "allowText", "search"], outputs: ["searchChange"] }, { type: i2.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }, { type: i3.KwikUIInputOtpMultipleComponent, selector: "kwikui-input-otp-multiple", inputs: ["config", "disabled", "formCtrl", "invalid", "readOnly"], outputs: ["onInputChange"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.TuiInputPhoneDirective, selector: "tui-input-phone" }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputOtpComponent, decorators: [{ type: Component, args: [{ selector: "kwikui-input-otp", templateUrl: "./input-otp.component.html", styleUrls: ["./input-otp.component.scss"], providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => KwikUIInputOtpComponent)), multi: true } ] }] }], ctorParameters: function () { return []; }, propDecorators: { disabled: [{ type: Input }], focus: [{ type: Input }], formControl: [{ type: Input }], formControlName: [{ type: Input }], id: [{ type: Input }], invalid: [{ type: Input }], label: [{ type: Input }], mask: [{ type: Input }], mode: [{ type: Input }], otpLength: [{ type: Input }], placeholder: [{ type: Input }], postfix: [{ type: Input }], prefix: [{ type: Input }], properties: [{ type: Input }], size: [{ type: Input }], validators: [{ type: Input }], getKeyValue: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-otp.component.js","sourceRoot":"","sources":["../../../../../../../projects/kwikui/src/lib/components/custom/input-otp/input-otp.component.ts","../../../../../../../projects/kwikui/src/lib/components/custom/input-otp/input-otp.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from \"@angular/core\";\nimport {\n  ControlValueAccessor,\n  FormControl,\n  FormGroup,\n  NG_VALUE_ACCESSOR\n} from \"@angular/forms\";\nimport { Subscription } from \"rxjs\";\nimport { distinctUntilChanged } from \"rxjs/operators\";\n\n@Component({\n  selector: \"kwikui-input-otp\",\n  templateUrl: \"./input-otp.component.html\",\n  styleUrls: [\"./input-otp.component.scss\"],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => KwikUIInputOtpComponent),\n      multi: true\n    }\n  ]\n})\nexport class KwikUIInputOtpComponent\n  implements OnInit, OnChanges, ControlValueAccessor {\n  @Input() disabled = false;\n\n  @Input() focus = false;\n\n  @Input() formControl: FormControl = new FormControl({});\n\n  @Input() formControlName = \"form_control_name\";\n\n  @Input() id = \"\";\n\n  @Input() invalid = false;\n\n  @Input() label = \"\";\n\n  @Input() mask = \"# # # #\";\n\n  @Input() mode: \"single\" | \"multiple\" = \"single\";\n\n  @Input() otpLength = 4;\n\n  @Input() placeholder = \"\";\n\n  @Input() postfix = \"\";\n\n  @Input() prefix = \"\";\n\n  @Input() properties = { readOnly: false, hidePlaceholder: false };\n\n  @Input() size: \"s\" | \"m\" | \"l\" = \"m\";\n\n  @Input() validators = { required: true };\n\n  @Output() getKeyValue: EventEmitter<any> = new EventEmitter<any>();\n\n  formGroup: FormGroup = new FormGroup({});\n\n  otpMultipleConfig = {\n    allowKeyCodes: [],\n    allowNumbersOnly: true,\n    containerClass: \"\",\n    containerStyles: {},\n    disableAutoFocus: true,\n    inputClass: \"\",\n    inputStyles: {},\n    isPasswordInput: false,\n    length: this.otpLength,\n    placeholder: \"\",\n    size: this.size\n  };\n\n  subscriptions = new Subscription();\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.formGroup.addControl(this.formControlName, this.formControl);\n    this.focus = this.focus === undefined ? false : this.focus;\n    this.invalid =\n      this.invalid === undefined ? false : this.invalid && this.focus;\n    this.validators = { ...this.validators };\n    this.properties = { ...this.properties };\n    this.mode =\n      this.mode !== \"single\" && this.mode !== \"multiple\"\n        ? \"multiple\"\n        : this.mode;\n    this.otpMultipleConfig = {\n      ...this.otpMultipleConfig,\n      length: this.otpLength,\n      placeholder: this.properties.hidePlaceholder\n        ? \"\"\n        : this.placeholder.length > 0\n          ? \"0\"\n          : this.placeholder,\n      size: this.size\n    };\n    this.setDisabled();\n\n    this.subscriptions.add(\n      this.formGroup.controls[this.formControlName].valueChanges\n        .pipe(distinctUntilChanged()) // makes sure the value has actually changed.\n        .subscribe((value) => this.handleInputValueChange(value))\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (\n      changes.hasOwnProperty(\"formControl\") &&\n      !changes.formControl.firstChange\n    ) {\n      this.formControl = changes.formControl.currentValue;\n    }\n    if (changes.hasOwnProperty(\"invalid\") && !changes.invalid.firstChange) {\n      this.invalid = Boolean(changes.invalid.currentValue);\n      this.setError();\n    }\n    if (changes.hasOwnProperty(\"focus\") && !changes.focus.firstChange) {\n      this.focus = Boolean(changes.focus.currentValue);\n    }\n    if (changes.hasOwnProperty(\"focus\") && !changes.focus.firstChange) {\n      this.focus = Boolean(changes.focus.currentValue);\n    }\n    if (changes.hasOwnProperty(\"size\") && !changes.size.firstChange) {\n      this.size = changes.size.currentValue;\n    }\n    if (changes.hasOwnProperty(\"disabled\") && !changes.disabled.firstChange) {\n      this.disabled = Boolean(changes.disabled.currentValue);\n      this.setDisabled();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n    // ensure when component is destroyed the subscription is also and not left open.\n  }\n\n  /**\n   * @description Handles updating the config object with the latest values for multiple mode\n   */\n  setConfigProperties() {\n    this.otpMultipleConfig = {\n      ...this.otpMultipleConfig,\n      length: this.otpLength,\n      placeholder: this.placeholder.length > 0 ? \"0\" : this.placeholder,\n      size: this.size\n    };\n  }\n\n  /**\n   * @description Handles setting up of error and focus on the input field is it is invalid\n   */\n  setDisabled() {\n    if (this.formGroup.controls[this.formControlName] !== undefined) {\n      if (this.disabled === true) {\n        this.formGroup.controls[this.formControlName].disable({\n          emitEvent: false\n        });\n      } else {\n        this.formGroup.controls[this.formControlName].enable({\n          emitEvent: false\n        });\n      }\n    }\n  }\n\n  /**\n   * @description Handles setting up of error and focus on the input field is it is invalid\n   */\n  setError() {\n    if (\n      this.formGroup.controls[this.formControlName] !== undefined &&\n      this.formGroup.controls[this.formControlName].invalid\n    ) {\n      this.invalid = true;\n      this.focus = true;\n    } else {\n      this.invalid = false;\n      this.focus = false;\n    }\n  }\n\n  /**\n   * @description Handles firing of 2 events on (keyup) event\n   *\n   * @param value\n   */\n  handleInputValueChange(value: any) {\n    if (value === this.formControl.value && this.mode === \"single\") {\n      this.emitEvent(this.getKeyValue, {\n        key: this.formControlName,\n        value: this.formControl.value\n      });\n    }\n  }\n\n  handleInputValueChangeMultiple(value: any) {\n    if (this.mode === \"multiple\") {\n      this.formControl.patchValue(value);\n      this.formGroup.controls[this.formControlName].patchValue(value);\n      this.emitEvent(this.getKeyValue, {\n        key: this.formControlName,\n        value: this.formControl.value\n      });\n    }\n  }\n\n  handleFocusedChange(e: any) {\n    if (!this.invalid) {\n      this.focus = e;\n    }\n  }\n\n  emitEvent(event: any, data: any) {\n    event.emit(data);\n  }\n\n  /** Method Implementations for Abstract Control */\n  writeValue(value: any): void {}\n\n  registerOnChange(fn: any): void {}\n\n  registerOnTouched(fn: any): void {}\n\n  setDisabledState?(isDisabled: boolean): void {}\n}\n","<div\n  [formGroup]=\"formGroup\"\n  *ngIf=\"mode === 'single'\"\n  id=\"mode-single\"\n>\n  <tui-input-phone\n    [formControlName]=\"formControlName\"\n    [countryCode]=\"''\"\n    [phoneMaskAfterCountryCode]=\"mask\"\n    [nativeId]=\"id\"\n    [pseudoInvalid]=\"invalid === undefined ? null : invalid\"\n    [pseudoFocus]=\"focus ?? null\"\n    [readOnly]=\"properties?.readOnly ?? false\"\n    (focusedChange)=\"handleFocusedChange($event)\"\n  >\n    {{ label }}\n    <span\n      class=\"tui-required\"\n      *ngIf=\"validators.required\"\n    ></span>\n    <input\n      tuiTextfield\n      inputmode=\"numeric\"\n      [attr.placeholder]=\"placeholder ?? ''\"\n      [attr.required]=\"validators.required\"\n    />\n  </tui-input-phone>\n</div>\n<div\n  [formGroup]=\"formGroup\"\n  *ngIf=\"mode === 'multiple'\"\n  id=\"mode-multiple\"\n>\n  <div\n    id=\"mode-multiple-label\"\n    *ngIf=\"label !== ''\"\n  >\n    <span class=\"t-label\">\n      <b>\n        <p class=\"tui-space_bottom-1 tui-space_left-1 ng-star-inserted\">\n          {{ label }}\n          <span\n            class=\"tui-required\"\n            *ngIf=\"validators.required\"\n          ></span>\n        </p>\n      </b>\n    </span>\n  </div>\n  <div id=\"mode-multiple-inputs\">\n    <kwikui-input-otp-multiple\n      [formCtrl]=\"formControl\"\n      [config]=\"otpMultipleConfig\"\n      [invalid]=\"invalid === undefined ? null : invalid\"\n      [disabled]=\"disabled\"\n      [readOnly]=\"properties?.readOnly ?? false\"\n      (onInputChange)=\"handleInputValueChangeMultiple($event)\"\n    ></kwikui-input-otp-multiple>\n  </div>\n</div>\n"]}