import { ChangeDetectionStrategy, Component, HostListener, Input, Optional, forwardRef, inject, } from '@angular/core'; import { AsyncPipe, DecimalPipe, NgClass } from '@angular/common'; import { InputComponent } from '../input/input.component'; import { provideControlContainer, provideValueAccessor } from '../utils/form.util'; import { integerValidator } from '../utils/validators.util'; import { LabelComponent } from '../label/label.component'; import { IconComponent } from '../../components/atoms/icon/icon.component'; import { FormErrorComponent } from '../error/error.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; export class InputNumberComponent extends InputComponent { constructor(formGroupDirective) { super(formGroupDirective); this.formGroupDirective = formGroupDirective; this.decimalPipe = inject(DecimalPipe); this.validate = 'integer'; } onFocusOut() { this.formatNumber(); this.triggerTouched(); } onFocusIn() { this.reverseFormatNumber(); } ngOnInit() { if (this.formControl && this.validate === 'integer') this.formControl.addValidators(integerValidator()); } ngAfterViewInit() { this.formatNumber(); this.triggerChangeDetection(); } formatNumber() { try { this.value = this.decimalPipe.transform(this.value, '1.0-2') || ''; } catch (_error) { return; } } reverseFormatNumber() { this.value = !isNaN(parseFloat(this.value.replace(/[^0-9.-]/g, ''))) ? parseFloat(this.value.replace(/[^0-9.-]/g, '')) : ''; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: InputNumberComponent, deps: [{ token: i1.FormGroupDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: InputNumberComponent, isStandalone: true, selector: "ct-input-number", inputs: { validate: "validate" }, host: { listeners: { "focusout": "onFocusOut()", "focusin": "onFocusIn()" } }, providers: [provideValueAccessor(forwardRef(() => InputNumberComponent)), DecimalPipe], usesInheritance: true, ngImport: i0, template: "\n @if (label) {\n \n }\n \n \n @if (icon) {\n \n }\n @if (symbol) {\n {{ symbol }}\n }\n @if (showDelete$ | async) {\n \n }\n \n @if (formControl) {\n \n }\n\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: LabelComponent, selector: "ct-form-label", inputs: ["text", "type", "formControlName", "hasError", "showError"] }, { kind: "component", type: IconComponent, selector: "ct-icon", inputs: ["icon", "fill", "strokeWidth", "strokeColor", "size", "variant"] }, { kind: "component", type: FormErrorComponent, selector: "ct-form-alert", inputs: ["errors", "size", "hasErrors", "fullSize", "helper", "errorMessages"] }], viewProviders: [provideControlContainer()], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: InputNumberComponent, decorators: [{ type: Component, args: [{ selector: 'ct-input-number', standalone: true, imports: [NgClass, AsyncPipe, LabelComponent, IconComponent, FormErrorComponent], providers: [provideValueAccessor(forwardRef(() => InputNumberComponent)), DecimalPipe], viewProviders: [provideControlContainer()], changeDetection: ChangeDetectionStrategy.OnPush, template: "\n @if (label) {\n \n }\n \n \n @if (icon) {\n \n }\n @if (symbol) {\n {{ symbol }}\n }\n @if (showDelete$ | async) {\n \n }\n \n @if (formControl) {\n \n }\n\n" }] }], ctorParameters: () => [{ type: i1.FormGroupDirective, decorators: [{ type: Optional }] }], propDecorators: { validate: [{ type: Input }], onFocusOut: [{ type: HostListener, args: ['focusout'] }], onFocusIn: [{ type: HostListener, args: ['focusin'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../../projects/circletone/src/lib/forms/input-number/input-number.component.ts","../../../../../../projects/circletone/src/lib/forms/input/input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,QAAQ,EACR,UAAU,EACV,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAElE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AACnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,4CAA4C,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;;;AAW9D,MAAM,OAAO,oBAAqB,SAAQ,cAAc;IAKtD,YAA2C,kBAAsC;QAC/E,KAAK,CAAC,kBAAkB,CAAC,CAAC;QADe,uBAAkB,GAAlB,kBAAkB,CAAoB;QAJhE,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAE1C,aAAQ,GAA8B,SAAS,CAAC;IAIzD,CAAC;IAGQ,UAAU;QACjB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAGD,SAAS;QACP,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS;YAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC1G,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,YAAY;QACV,IAAI,CAAC;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;QACrE,CAAC;QAAC,OAAO,MAAM,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;IACH,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;YACjD,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;8GAzCU,oBAAoB;kGAApB,oBAAoB,+KAJpB,CAAC,oBAAoB,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC,CAAC,EAAE,WAAW,CAAC,iDCzBxF,gpEA0DA,4CDnCY,OAAO,+EAAE,SAAS,8CAAE,cAAc,gIAAE,aAAa,+HAAE,kBAAkB,+HAGhE,CAAC,uBAAuB,EAAE,CAAC;;2FAG/B,oBAAoB;kBAThC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP,CAAC,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAAE,kBAAkB,CAAC,aAErE,CAAC,oBAAoB,CAAC,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC,CAAC,EAAE,WAAW,CAAC,iBACvE,CAAC,uBAAuB,EAAE,CAAC,mBACzB,uBAAuB,CAAC,MAAM;;0BAOlC,QAAQ;yCAFZ,QAAQ;sBAAhB,KAAK;gBAOG,UAAU;sBADlB,YAAY;uBAAC,UAAU;gBAOxB,SAAS;sBADR,YAAY;uBAAC,SAAS","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  HostListener,\n  Input,\n  OnInit,\n  Optional,\n  forwardRef,\n  inject,\n} from '@angular/core';\nimport { AsyncPipe, DecimalPipe, NgClass } from '@angular/common';\nimport { FormGroupDirective } from '@angular/forms';\nimport { InputComponent } from '../input/input.component';\nimport { provideControlContainer, provideValueAccessor } from '../utils/form.util';\nimport { integerValidator } from '../utils/validators.util';\nimport { LabelComponent } from '../label/label.component';\nimport { IconComponent } from '../../components/atoms/icon/icon.component';\nimport { FormErrorComponent } from '../error/error.component';\n\n@Component({\n  selector: 'ct-input-number',\n  standalone: true,\n  imports: [NgClass, AsyncPipe, LabelComponent, IconComponent, FormErrorComponent],\n  templateUrl: '../input/input.component.html',\n  providers: [provideValueAccessor(forwardRef(() => InputNumberComponent)), DecimalPipe],\n  viewProviders: [provideControlContainer()],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class InputNumberComponent extends InputComponent implements OnInit, AfterViewInit {\n  private readonly decimalPipe = inject(DecimalPipe);\n  private rawValue!: number;\n  @Input() validate: 'integer' | 'credit-card' = 'integer';\n\n  constructor(@Optional() protected override formGroupDirective: FormGroupDirective) {\n    super(formGroupDirective);\n  }\n\n  @HostListener('focusout')\n  override onFocusOut() {\n    this.formatNumber();\n    this.triggerTouched();\n  }\n\n  @HostListener('focusin')\n  onFocusIn() {\n    this.reverseFormatNumber();\n  }\n\n  ngOnInit(): void {\n    if (this.formControl && this.validate === 'integer') this.formControl.addValidators(integerValidator());\n  }\n\n  ngAfterViewInit(): void {\n    this.formatNumber();\n    this.triggerChangeDetection();\n  }\n\n  formatNumber() {\n    try {\n      this.value = this.decimalPipe.transform(this.value, '1.0-2') || '';\n    } catch (_error) {\n      return;\n    }\n  }\n\n  reverseFormatNumber(): void {\n    this.value = !isNaN(parseFloat(this.value.replace(/[^0-9.-]/g, '')))\n      ? parseFloat(this.value.replace(/[^0-9.-]/g, ''))\n      : '';\n  }\n}\n","<div\n  class=\"flex\"\n  [class.w-fit]=\"!fullSize\"\n  [class.w-full]=\"fullSize\"\n  [ngClass]=\"{\n    'items-center gap-4': disposition === 'horizontal',\n    'flex-col gap-0.5 items-start': disposition === 'vertical'\n  }\">\n  @if (label) {\n    <ct-form-label [text]=\"label\" [hasError]=\"hasErrors(formControl)\" [showError]=\"showError\" />\n  }\n  <div\n    class=\"relative inline-block rounded-md text-on-surface dark:text-on-surface-dark\"\n    [class.w-fit]=\"!fullSize\"\n    [class.w-full]=\"fullSize\">\n    <input\n      tabindex=\"0\"\n      [type]=\"type\"\n      [min]=\"min\"\n      [max]=\"max\"\n      class=\"h-9 rounded-md border bg-primary-50 font-primary text-sm outline-primary hover:border-neutral-600 dark:bg-primary-950 dark:outline-primary-dark focus:dark:border-primary-dark\"\n      [class.px-4]=\"!icon || !symbol\"\n      [ngClass]=\"{\n        'px-4': !icon,\n        'pr-4 pl-10': icon && iconPosition === 'left',\n        'pl-4 pr-10': (icon && iconPosition === 'right') || symbol || canDelete\n      }\"\n      [class.w-fit]=\"!fullSize\"\n      [class.w-full]=\"fullSize\"\n      [class.border-neutral-300]=\"!hasErrors(formControl) || !showError\"\n      [class.border-error]=\"hasErrors(formControl) && showError\"\n      [class.border-success]=\"formControl && formControl.valid && showError\"\n      [value]=\"value\"\n      [placeholder]=\"placeholder\"\n      (input)=\"input($event)\" />\n    @if (icon) {\n      <ct-icon\n        class=\"absolute top-2\"\n        [class.left-3]=\"iconPosition === 'left'\"\n        [class.right-3]=\"iconPosition === 'right'\"\n        [icon]=\"icon\" />\n    }\n    @if (symbol) {\n      <span class=\"absolute right-3 top-2.5 text-xs text-neutral-600 dark:text-neutral-300\">{{ symbol }}</span>\n    }\n    @if (showDelete$ | async) {\n      <ct-icon class=\"absolute right-3 top-2.5 cursor-pointer\" icon=\"x-mark\" size=\"sm\" (click)=\"clearValue()\" />\n    }\n  </div>\n  @if (formControl) {\n    <ct-form-alert\n      [fullSize]=\"fullSize\"\n      [hasErrors]=\"hasErrors(formControl)\"\n      [helper]=\"helper\"\n      [errors]=\"formControl.errors ?? {}\"\n      size=\"xs\" />\n  }\n</div>\n"]}