import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Optional, Output, forwardRef, } from '@angular/core';
import { AsyncPipe, NgClass } from '@angular/common';
import { provideControlContainer, provideValueAccessor } from '../utils/form.util';
import { FormGenericComponent } from '../../services/form-generic.abstract';
import { FormErrorComponent } from '../error/error.component';
import { LabelComponent } from '../label/label.component';
import { IconComponent } from '../../components/atoms/icon/icon.component';
import { BehaviorSubject } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
export class InputComponent extends FormGenericComponent {
onFocusOut() {
this.triggerTouched();
}
constructor(formGroupDirective) {
super(formGroupDirective);
this.formGroupDirective = formGroupDirective;
this.key = '';
this.type = 'text';
this.value = '';
this.label = '';
this.icon = '';
this.helper = '';
this.placeholder = '';
this.symbol = '';
this.canDelete = false;
this.fullSize = true;
this.showError = false;
this.iconPosition = 'left';
this.disposition = 'vertical';
this.typed = new EventEmitter();
this.showDelete$ = new BehaviorSubject(false);
}
input(event) {
const value = event.target.value;
if (this.canDelete) {
this.showDelete$.next(!!value);
}
this.setValue(value);
}
clearValue() {
this.showDelete$.next(false);
this.triggerTouched();
this.setValue(null);
}
setValue(value, propagate = true) {
this.value = value;
if (propagate) {
this.triggerChange(value);
this.typed.emit(value);
}
}
writeValue(value) {
if (value && this.canDelete)
this.showDelete$.next(true);
this.triggerMarkCheck();
this.setValue(value, false);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: InputComponent, deps: [{ token: i1.FormGroupDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: InputComponent, isStandalone: true, selector: "ct-input", inputs: { formControlName: "formControlName", key: "key", type: "type", value: "value", label: "label", icon: "icon", helper: "helper", placeholder: "placeholder", symbol: "symbol", canDelete: "canDelete", fullSize: "fullSize", showError: "showError", min: "min", max: "max", iconPosition: "iconPosition", disposition: "disposition" }, outputs: { typed: "typed" }, host: { listeners: { "focusout": "onFocusOut()" } }, providers: [provideValueAccessor(forwardRef(() => InputComponent))], 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: InputComponent, decorators: [{
type: Component,
args: [{ selector: 'ct-input', standalone: true, imports: [NgClass, AsyncPipe, LabelComponent, IconComponent, FormErrorComponent], providers: [provideValueAccessor(forwardRef(() => InputComponent))], 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: { formControlName: [{
type: Input
}], key: [{
type: Input
}], type: [{
type: Input
}], value: [{
type: Input
}], label: [{
type: Input
}], icon: [{
type: Input
}], helper: [{
type: Input
}], placeholder: [{
type: Input
}], symbol: [{
type: Input
}], canDelete: [{
type: Input
}], fullSize: [{
type: Input
}], showError: [{
type: Input
}], min: [{
type: Input
}], max: [{
type: Input
}], iconPosition: [{
type: Input
}], disposition: [{
type: Input
}], typed: [{
type: Output
}], onFocusOut: [{
type: HostListener,
args: ['focusout']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/circletone/src/lib/forms/input/input.component.ts","../../../../../../projects/circletone/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  Optional,\n  Output,\n  forwardRef,\n} from '@angular/core';\nimport { FormGroupDirective } from '@angular/forms';\nimport { AsyncPipe, NgClass } from '@angular/common';\nimport { provideControlContainer, provideValueAccessor } from '../utils/form.util';\nimport { FormGenericComponent } from '../../services/form-generic.abstract';\nimport { FormErrorComponent } from '../error/error.component';\nimport { LabelComponent } from '../label/label.component';\nimport { ComponentPosition } from '../../model/components/component-position.type';\nimport { IconComponent } from '../../components/atoms/icon/icon.component';\nimport { ComponentDisposition } from '../../model/components/component-disposition.enum';\nimport { BehaviorSubject } from 'rxjs';\n\n@Component({\n  selector: 'ct-input',\n  standalone: true,\n  imports: [NgClass, AsyncPipe, LabelComponent, IconComponent, FormErrorComponent],\n  templateUrl: './input.component.html',\n  providers: [provideValueAccessor(forwardRef(() => InputComponent))],\n  viewProviders: [provideControlContainer()],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class InputComponent extends FormGenericComponent {\n  @Input() formControlName!: string;\n  @Input() key = '';\n  @Input() type: 'password' | 'text' | 'number' = 'text';\n  @Input() value: any = '';\n\n  @Input() label = '';\n  @Input() icon = '';\n  @Input() helper = '';\n  @Input() placeholder = '';\n  @Input() symbol = '';\n  @Input() canDelete = false;\n  @Input() fullSize = true;\n  @Input() showError = false;\n  @Input() min!: number;\n  @Input() max!: number;\n  @Input() iconPosition: ComponentPosition = 'left';\n  @Input() disposition: ComponentDisposition = 'vertical';\n\n  @Output() typed = new EventEmitter<string>();\n\n  showDelete$ = new BehaviorSubject<boolean>(false);\n\n  @HostListener('focusout')\n  onFocusOut() {\n    this.triggerTouched();\n  }\n\n  constructor(@Optional() protected override formGroupDirective: FormGroupDirective) {\n    super(formGroupDirective);\n  }\n\n  input(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n    if (this.canDelete) {\n      this.showDelete$.next(!!value);\n    }\n    this.setValue(value);\n  }\n\n  clearValue() {\n    this.showDelete$.next(false);\n    this.triggerTouched();\n    this.setValue(null);\n  }\n\n  setValue(value: any, propagate = true) {\n    this.value = value;\n    if (propagate) {\n      this.triggerChange(value);\n      this.typed.emit(value);\n    }\n  }\n\n  writeValue(value: any) {\n    if (value && this.canDelete) this.showDelete$.next(true);\n    this.triggerMarkCheck();\n    this.setValue(value, false);\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"]}