kwikui
Version:
KwikID's UI Component Library in Angular
196 lines • 27.2 kB
JavaScript
import { Component, EventEmitter, forwardRef, Input, Output } from "@angular/core";
import { FormControl, FormGroup, NG_VALUE_ACCESSOR } from "@angular/forms";
import { Subscription } from "rxjs";
import { isNotEmptyValue } from "kwikid-toolkit";
import { throwErrorMessage } from "../../../helpers/kwikui.common.helpers";
import { DEFAULT_VALUES, VALIDATE_KEY_VALUES } from "./input-currency.constants";
import { isValidKeyValue } from "./input-currency.validation";
import { formatCurrency } from "./input-currency.helpers";
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-currency.directive";
import * as i4 from "@angular/forms";
import * as i5 from "@angular/common";
export class KwikUIInputCurrencyComponent {
constructor() {
this.currencyType = DEFAULT_VALUES.currencyType;
this.disabled = DEFAULT_VALUES.disabled;
this.focus = DEFAULT_VALUES.focus;
this.formControl = new FormControl({});
this.formControlName = DEFAULT_VALUES.formControlName;
this.hintContent = DEFAULT_VALUES.hintContent;
this.icon = DEFAULT_VALUES.icon;
this.id = DEFAULT_VALUES.id;
this.invalid = DEFAULT_VALUES.invalid;
this.label = DEFAULT_VALUES.label;
this.placeholder = DEFAULT_VALUES.placeholder;
this.postfix = DEFAULT_VALUES.postfix;
this.prefix = DEFAULT_VALUES.prefix;
this.properties = { readOnly: false };
this.size = DEFAULT_VALUES.size;
this.validators = { required: true };
this.value = DEFAULT_VALUES.value;
this.getKeyValue = new EventEmitter();
this.currentValue = "";
this.formGroup = new FormGroup({});
this.subscriptions = new Subscription();
}
ngOnInit() {
this.formControlName = this.id;
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.setDisabled();
if (isNotEmptyValue(this.value)) {
this.formatValue(this.value);
}
}
ngOnChanges(changes) {
const verifyChange = (key) => {
return changes.hasOwnProperty(key) && !changes[key].firstChange;
};
for (const change of Object.entries(changes)) {
const key = change[0];
const value = change[1].currentValue;
this.validateInputProperty(key, value);
}
if (verifyChange("formControl")) {
this.formControl = changes.formControl.currentValue;
}
if (verifyChange("invalid")) {
this.invalid = Boolean(changes.invalid.currentValue);
this.setError();
}
if (verifyChange("focus")) {
this.focus = Boolean(changes.focus.currentValue);
}
if (verifyChange("disabled")) {
this.disabled = Boolean(changes.disabled.currentValue);
this.setDisabled();
}
}
ngOnDestroy() {
this.subscriptions.unsubscribe();
}
validateInputProperty(key, value) {
if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) {
this[key] = DEFAULT_VALUES[key];
throwErrorMessage("kwikui-input-currency", this.id, key, value, DEFAULT_VALUES[key]);
}
}
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
});
}
}
}
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;
}
}
handleInputValueChange(value) {
this.formatValue(value);
// Emit the raw value without separators if needed
this.emitEvent(this.getKeyValue, {
key: this.formControlName,
value: Number(this.formControl.value)
});
this.value = this.formControl.value;
}
handleFocusedChange(e) {
if (!this.invalid) {
this.focus = e;
}
}
emitEvent(event, data) {
event.emit(data);
}
formatValue(value) {
const numericValue = String(value).replace(/[^0-9.-]/g, "");
this.currentValue = formatCurrency(this.currencyType, numericValue);
this.formControl.setValue(numericValue, { emitEvent: true });
}
writeValue(value) { }
registerOnChange(fn) { }
registerOnTouched(fn) { }
setDisabledState(isDisabled) { }
}
/** @nocollapse */ KwikUIInputCurrencyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputCurrencyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ KwikUIInputCurrencyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikUIInputCurrencyComponent, selector: "kwikui-input-currency", inputs: { currencyType: "currencyType", disabled: "disabled", focus: "focus", formControl: "formControl", formControlName: "formControlName", hintContent: "hintContent", icon: "icon", id: "id", invalid: "invalid", label: "label", placeholder: "placeholder", postfix: "postfix", prefix: "prefix", properties: "properties", size: "size", validators: "validators", value: "value" }, outputs: { getKeyValue: "getKeyValue" }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((() => KwikUIInputCurrencyComponent)),
multi: true
}
], usesOnChanges: true, ngImport: i0, template: "<div>\n <tui-input\n [currencyType]=\"currencyType\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"currentValue\"\n [nativeId]=\"id\"\n [pseudoFocus]=\"focus ?? null\"\n [pseudoInvalid]=\"invalid === undefined ? null : invalid\"\n [readOnly]=\"properties?.readOnly ?? false\"\n [tuiHintContent]=\"hintContent\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiTextfieldIconLeft]=\"icon\"\n [tuiTextfieldPostfix]=\"postfix\"\n [tuiTextfieldPrefix]=\"prefix\"\n [tuiTextfieldSize]=\"size\"\n (focusedChange)=\"handleFocusedChange($event)\"\n (input)=\"handleInputValueChange($event.target.value)\"\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>\n</div>\n", styles: [""], components: [{ type: i1.TuiInputComponent, selector: "tui-input" }, { type: i2.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }], directives: [{ type: i1.TuiInputDirective, selector: "tui-input" }, { type: i3.NumericCurrencyTypeDirective, selector: "[currencyType]", inputs: ["currencyType"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i2.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i2.TuiTextfieldIconLeftDirective, selector: "[tuiTextfieldIconLeft]", inputs: ["tuiTextfieldIconLeft"] }, { type: i2.TuiTextfieldPostfixDirective, selector: "[tuiTextfieldPostfix]", inputs: ["tuiTextfieldPostfix"] }, { type: i2.TuiTextfieldPrefixDirective, selector: "[tuiTextfieldPrefix]", inputs: ["tuiTextfieldPrefix"] }, { type: i2.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputCurrencyComponent, decorators: [{
type: Component,
args: [{
selector: "kwikui-input-currency",
templateUrl: "./input-currency.component.html",
styleUrls: ["./input-currency.component.scss"],
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((() => KwikUIInputCurrencyComponent)),
multi: true
}
]
}]
}], ctorParameters: function () { return []; }, propDecorators: { currencyType: [{
type: Input
}], disabled: [{
type: Input
}], focus: [{
type: Input
}], formControl: [{
type: Input
}], formControlName: [{
type: Input
}], hintContent: [{
type: Input
}], icon: [{
type: Input
}], id: [{
type: Input
}], invalid: [{
type: Input
}], label: [{
type: Input
}], placeholder: [{
type: Input
}], postfix: [{
type: Input
}], prefix: [{
type: Input
}], properties: [{
type: Input
}], size: [{
type: Input
}], validators: [{
type: Input
}], value: [{
type: Input
}], getKeyValue: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-currency.component.js","sourceRoot":"","sources":["../../../../../../../projects/kwikui/src/lib/components/custom/input-currency/input-currency.component.ts","../../../../../../../projects/kwikui/src/lib/components/custom/input-currency/input-currency.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 { isNotEmptyValue } from \"kwikid-toolkit\";\nimport { throwErrorMessage } from \"../../../helpers/kwikui.common.helpers\";\nimport {\n  DEFAULT_VALUES,\n  VALIDATE_KEY_VALUES\n} from \"./input-currency.constants\";\nimport {\n  TKwikUIInputCurrencyType,\n  TKwikUIInputCurrencySize\n} from \"./input-currency.definitions\";\nimport { isValidKeyValue } from \"./input-currency.validation\";\nimport { formatCurrency } from \"./input-currency.helpers\";\n\n@Component({\n  selector: \"kwikui-input-currency\",\n  templateUrl: \"./input-currency.component.html\",\n  styleUrls: [\"./input-currency.component.scss\"],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => KwikUIInputCurrencyComponent),\n      multi: true\n    }\n  ]\n})\nexport class KwikUIInputCurrencyComponent\n  implements OnInit, OnChanges, ControlValueAccessor {\n  @Input() currencyType: TKwikUIInputCurrencyType = DEFAULT_VALUES.currencyType;\n\n  @Input() disabled: boolean = DEFAULT_VALUES.disabled;\n\n  @Input() focus: boolean = DEFAULT_VALUES.focus;\n\n  @Input() formControl: FormControl = new FormControl({});\n\n  @Input() formControlName: string = DEFAULT_VALUES.formControlName;\n\n  @Input() hintContent: string = DEFAULT_VALUES.hintContent;\n\n  @Input() icon: string = DEFAULT_VALUES.icon;\n\n  @Input() id: string = DEFAULT_VALUES.id;\n\n  @Input() invalid: boolean = DEFAULT_VALUES.invalid;\n\n  @Input() label: string = DEFAULT_VALUES.label;\n\n  @Input() placeholder: string = DEFAULT_VALUES.placeholder;\n\n  @Input() postfix: string = DEFAULT_VALUES.postfix;\n\n  @Input() prefix: string = DEFAULT_VALUES.prefix;\n\n  @Input() properties = { readOnly: false };\n\n  @Input() size: TKwikUIInputCurrencySize = DEFAULT_VALUES.size;\n\n  @Input() validators = { required: true };\n\n  @Input() value: string | number = DEFAULT_VALUES.value;\n\n  @Output() getKeyValue: EventEmitter<any> = new EventEmitter<any>();\n\n  currentValue = \"\";\n\n  formGroup: FormGroup = new FormGroup({});\n\n  subscriptions = new Subscription();\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.formControlName = this.id;\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.setDisabled();\n\n    if (isNotEmptyValue(this.value)) {\n      this.formatValue(this.value);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const verifyChange = (key: string) => {\n      return changes.hasOwnProperty(key) && !changes[key].firstChange;\n    };\n\n    for (const change of Object.entries(changes)) {\n      const key: string = change[0];\n      const value: any = change[1].currentValue;\n      this.validateInputProperty(key, value);\n    }\n\n    if (verifyChange(\"formControl\")) {\n      this.formControl = changes.formControl.currentValue;\n    }\n    if (verifyChange(\"invalid\")) {\n      this.invalid = Boolean(changes.invalid.currentValue);\n      this.setError();\n    }\n    if (verifyChange(\"focus\")) {\n      this.focus = Boolean(changes.focus.currentValue);\n    }\n    if (verifyChange(\"disabled\")) {\n      this.disabled = Boolean(changes.disabled.currentValue);\n      this.setDisabled();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n  private validateInputProperty(key: string, value: any): void {\n    if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) {\n      this[key] = DEFAULT_VALUES[key];\n      throwErrorMessage(\n        \"kwikui-input-currency\",\n        this.id,\n        key,\n        value,\n        DEFAULT_VALUES[key]\n      );\n    }\n  }\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  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  handleInputValueChange(value: any) {\n    this.formatValue(value);\n\n    // Emit the raw value without separators if needed\n    this.emitEvent(this.getKeyValue, {\n      key: this.formControlName,\n      value: Number(this.formControl.value)\n    });\n\n    this.value = this.formControl.value;\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  formatValue(value) {\n    const numericValue = String(value).replace(/[^0-9.-]/g, \"\");\n\n    this.currentValue = formatCurrency(this.currencyType, numericValue);\n    this.formControl.setValue(numericValue, { emitEvent: true });\n  }\n\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  <tui-input\n    [currencyType]=\"currencyType\"\n    [disabled]=\"disabled\"\n    [(ngModel)]=\"currentValue\"\n    [nativeId]=\"id\"\n    [pseudoFocus]=\"focus ?? null\"\n    [pseudoInvalid]=\"invalid === undefined ? null : invalid\"\n    [readOnly]=\"properties?.readOnly ?? false\"\n    [tuiHintContent]=\"hintContent\"\n    [tuiTextfieldCleaner]=\"true\"\n    [tuiTextfieldIconLeft]=\"icon\"\n    [tuiTextfieldPostfix]=\"postfix\"\n    [tuiTextfieldPrefix]=\"prefix\"\n    [tuiTextfieldSize]=\"size\"\n    (focusedChange)=\"handleFocusedChange($event)\"\n    (input)=\"handleInputValueChange($event.target.value)\"\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>\n</div>\n"]}