@tolle_/tolle-ui 18.2.15 → 18.2.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, forwardRef, inject, Input, Output, ChangeDetectorRef } from '@angular/core';
1
+ import { Component, EventEmitter, forwardRef, inject, Input, Output, ChangeDetectorRef, } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
4
4
  import { CountrySelectorComponent } from './country-selector.component';
@@ -6,7 +6,8 @@ import { MaskedInputComponent } from './masked-input.component';
6
6
  import parsePhoneNumber from 'libphonenumber-js';
7
7
  import { cn } from './utils/cn';
8
8
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/forms";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "@angular/forms";
10
11
  export class PhoneNumberInputComponent {
11
12
  cdr = inject(ChangeDetectorRef);
12
13
  id = `phone-input-${Math.random().toString(36).substr(2, 9)}`;
@@ -28,12 +29,48 @@ export class PhoneNumberInputComponent {
28
29
  displayValue = '';
29
30
  selectedIso = '';
30
31
  rawValue = '';
32
+ isFocused = false;
31
33
  cn = cn;
32
34
  onChange = () => { };
33
35
  onTouched = () => { };
34
36
  constructor() {
35
37
  this.selectedIso = this.defaultCountryCode;
36
38
  }
39
+ get computedLabelClass() {
40
+ return cn('text-sm font-medium text-foreground leading-none transition-opacity duration-200', this.disabled && 'opacity-50');
41
+ }
42
+ get computedMergedClass() {
43
+ return cn('flex rounded-md border transition-all duration-200', 'bg-background shadow-sm', this.size === 'xs' && 'h-8', this.size === 'sm' && 'h-9', this.size === 'default' && 'h-10', this.size === 'lg' && 'h-11',
44
+ // Focus state
45
+ !this.disabled &&
46
+ !this.readonly &&
47
+ this.isFocused && [
48
+ 'ring-4',
49
+ 'ring-ring/30',
50
+ 'ring-offset-0',
51
+ 'shadow-none',
52
+ this.error ? 'border-destructive/80' : 'border-primary/80',
53
+ ],
54
+ // Error state
55
+ this.error && ['border-destructive', this.isFocused && 'ring-destructive/30'],
56
+ // Disabled state
57
+ this.disabled && ['cursor-not-allowed opacity-50', 'border-opacity-50'],
58
+ // Readonly state
59
+ this.readonly && [
60
+ 'cursor-default',
61
+ 'border-dashed',
62
+ !this.disabled && !this.isFocused && 'ring-0',
63
+ ], this.class);
64
+ }
65
+ onFocusIn() {
66
+ this.isFocused = true;
67
+ this.cdr.markForCheck();
68
+ }
69
+ onFocusOut() {
70
+ this.isFocused = false;
71
+ this.onTouched();
72
+ this.cdr.markForCheck();
73
+ }
37
74
  writeValue(value) {
38
75
  if (value) {
39
76
  if (typeof value === 'object' && value.number) {
@@ -107,75 +144,103 @@ export class PhoneNumberInputComponent {
107
144
  {
108
145
  provide: NG_VALUE_ACCESSOR,
109
146
  useExisting: forwardRef(() => PhoneNumberInputComponent),
110
- multi: true
111
- }
147
+ multi: true,
148
+ },
112
149
  ], ngImport: i0, template: `
113
- <tolle-masked-input
114
- [id]="id"
115
- [label]="label"
116
- [hint]="hint"
117
- [error]="error"
118
- [errorMessage]="errorMessage"
119
- [hideHintOnFocus]="hideHintOnFocus"
120
- [mask]="mask"
121
- [size]="size"
122
- [disabled]="disabled"
123
- [readonly]="readonly"
124
- [placeholder]="placeholder"
125
- [(ngModel)]="displayValue"
126
- (ngModelChange)="onMaskInputChange($event)"
127
- [containerClass]="cn('pl-0', class)"
128
- >
129
- <tolle-country-selector
130
- prefix
131
- class="country-selector-override"
132
- [showName]="false"
133
- [size]="size"
134
- [disabled]="disabled || !enableCountrySelector"
135
- [readonly]="readonly"
136
- [(ngModel)]="selectedIso"
137
- (ngModelChange)="onCountryChange($event)"
138
- ></tolle-country-selector>
139
- </tolle-masked-input>
140
- `, isInline: true, styles: [":host{display:block;width:100%}::ng-deep .country-selector-override{display:flex;align-items:center;border-right:1px solid var(--border, #e5e7eb)}::ng-deep .country-selector-override button{border:none!important;border-radius:0!important;border-top-left-radius:calc(var(--radius, .5rem) - 1px)!important;border-bottom-left-radius:calc(var(--radius, .5rem) - 1px)!important;background:transparent!important;box-shadow:none!important;padding-left:.75rem!important;padding-right:.5rem!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:.25rem!important}::ng-deep .country-selector-override button .flex{gap:.25rem!important}::ng-deep .country-selector-override button i{margin-left:0!important;line-height:1!important;display:flex!important;align-items:center!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CountrySelectorComponent, selector: "tolle-country-selector", inputs: ["id", "label", "hint", "errorMessage", "error", "hideHintOnFocus", "placeholder", "class", "disabled", "readonly", "size", "defaultCountryCode", "returnValue", "showName"], outputs: ["onSelect"] }, { kind: "component", type: MaskedInputComponent, selector: "tolle-masked-input", inputs: ["id", "label", "hint", "errorMessage", "mask", "placeholder", "type", "disabled", "readonly", "class", "containerClass", "error", "size", "returnRaw", "hideHintOnFocus"] }] });
150
+ <div class="flex w-full flex-col gap-1.5">
151
+ <label *ngIf="label" [for]="id" [class]="computedLabelClass">
152
+ {{ label }}
153
+ </label>
154
+
155
+ <div [class]="computedMergedClass" (focusin)="onFocusIn()" (focusout)="onFocusOut()">
156
+ <tolle-country-selector
157
+ [showName]="false"
158
+ [size]="size"
159
+ [disabled]="disabled || !enableCountrySelector"
160
+ [readonly]="readonly"
161
+ [mergedPosition]="'left'"
162
+ [(ngModel)]="selectedIso"
163
+ (ngModelChange)="onCountryChange($event)"></tolle-country-selector>
164
+
165
+ <tolle-masked-input
166
+ [id]="id"
167
+ [mask]="mask"
168
+ [size]="size"
169
+ [disabled]="disabled"
170
+ [readonly]="readonly"
171
+ [placeholder]="placeholder"
172
+ [error]="error"
173
+ [externalFocused]="isFocused"
174
+ [mergedPosition]="'right'"
175
+ [(ngModel)]="displayValue"
176
+ (ngModelChange)="onMaskInputChange($event)"></tolle-masked-input>
177
+ </div>
178
+
179
+ <ng-container *ngIf="!disabled">
180
+ <p
181
+ *ngIf="hint && !error"
182
+ class="px-1 text-xs text-muted-foreground transition-opacity duration-200"
183
+ [class.opacity-0]="isFocused && hideHintOnFocus">
184
+ {{ hint }}
185
+ </p>
186
+ <p *ngIf="error && errorMessage" [id]="id + '-error'" class="px-1 text-xs text-destructive">
187
+ {{ errorMessage }}
188
+ </p>
189
+ </ng-container>
190
+ </div>
191
+ `, isInline: true, styles: [":host{display:block;width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CountrySelectorComponent, selector: "tolle-country-selector", inputs: ["id", "label", "hint", "errorMessage", "error", "hideHintOnFocus", "placeholder", "class", "disabled", "readonly", "size", "defaultCountryCode", "returnValue", "showName", "mergedPosition"], outputs: ["onSelect", "onFocusChange", "onBlurChange"] }, { kind: "component", type: MaskedInputComponent, selector: "tolle-masked-input", inputs: ["id", "label", "hint", "errorMessage", "mask", "placeholder", "type", "disabled", "readonly", "class", "containerClass", "error", "size", "returnRaw", "hideHintOnFocus", "externalFocused", "mergedPosition"] }] });
141
192
  }
142
193
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PhoneNumberInputComponent, decorators: [{
143
194
  type: Component,
144
195
  args: [{ selector: 'tolle-phone-number-input', standalone: true, imports: [CommonModule, FormsModule, CountrySelectorComponent, MaskedInputComponent], template: `
145
- <tolle-masked-input
146
- [id]="id"
147
- [label]="label"
148
- [hint]="hint"
149
- [error]="error"
150
- [errorMessage]="errorMessage"
151
- [hideHintOnFocus]="hideHintOnFocus"
152
- [mask]="mask"
153
- [size]="size"
154
- [disabled]="disabled"
155
- [readonly]="readonly"
156
- [placeholder]="placeholder"
157
- [(ngModel)]="displayValue"
158
- (ngModelChange)="onMaskInputChange($event)"
159
- [containerClass]="cn('pl-0', class)"
160
- >
161
- <tolle-country-selector
162
- prefix
163
- class="country-selector-override"
164
- [showName]="false"
165
- [size]="size"
166
- [disabled]="disabled || !enableCountrySelector"
167
- [readonly]="readonly"
168
- [(ngModel)]="selectedIso"
169
- (ngModelChange)="onCountryChange($event)"
170
- ></tolle-country-selector>
171
- </tolle-masked-input>
196
+ <div class="flex w-full flex-col gap-1.5">
197
+ <label *ngIf="label" [for]="id" [class]="computedLabelClass">
198
+ {{ label }}
199
+ </label>
200
+
201
+ <div [class]="computedMergedClass" (focusin)="onFocusIn()" (focusout)="onFocusOut()">
202
+ <tolle-country-selector
203
+ [showName]="false"
204
+ [size]="size"
205
+ [disabled]="disabled || !enableCountrySelector"
206
+ [readonly]="readonly"
207
+ [mergedPosition]="'left'"
208
+ [(ngModel)]="selectedIso"
209
+ (ngModelChange)="onCountryChange($event)"></tolle-country-selector>
210
+
211
+ <tolle-masked-input
212
+ [id]="id"
213
+ [mask]="mask"
214
+ [size]="size"
215
+ [disabled]="disabled"
216
+ [readonly]="readonly"
217
+ [placeholder]="placeholder"
218
+ [error]="error"
219
+ [externalFocused]="isFocused"
220
+ [mergedPosition]="'right'"
221
+ [(ngModel)]="displayValue"
222
+ (ngModelChange)="onMaskInputChange($event)"></tolle-masked-input>
223
+ </div>
224
+
225
+ <ng-container *ngIf="!disabled">
226
+ <p
227
+ *ngIf="hint && !error"
228
+ class="px-1 text-xs text-muted-foreground transition-opacity duration-200"
229
+ [class.opacity-0]="isFocused && hideHintOnFocus">
230
+ {{ hint }}
231
+ </p>
232
+ <p *ngIf="error && errorMessage" [id]="id + '-error'" class="px-1 text-xs text-destructive">
233
+ {{ errorMessage }}
234
+ </p>
235
+ </ng-container>
236
+ </div>
172
237
  `, providers: [
173
238
  {
174
239
  provide: NG_VALUE_ACCESSOR,
175
240
  useExisting: forwardRef(() => PhoneNumberInputComponent),
176
- multi: true
177
- }
178
- ], styles: [":host{display:block;width:100%}::ng-deep .country-selector-override{display:flex;align-items:center;border-right:1px solid var(--border, #e5e7eb)}::ng-deep .country-selector-override button{border:none!important;border-radius:0!important;border-top-left-radius:calc(var(--radius, .5rem) - 1px)!important;border-bottom-left-radius:calc(var(--radius, .5rem) - 1px)!important;background:transparent!important;box-shadow:none!important;padding-left:.75rem!important;padding-right:.5rem!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:.25rem!important}::ng-deep .country-selector-override button .flex{gap:.25rem!important}::ng-deep .country-selector-override button i{margin-left:0!important;line-height:1!important;display:flex!important;align-items:center!important}\n"] }]
241
+ multi: true,
242
+ },
243
+ ], styles: [":host{display:block;width:100%}\n"] }]
179
244
  }], ctorParameters: () => [], propDecorators: { id: [{
180
245
  type: Input
181
246
  }], label: [{
@@ -209,4 +274,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
209
274
  }], onSelect: [{
210
275
  type: Output
211
276
  }] } });
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-number-input.component.js","sourceRoot":"","sources":["../../../../projects/tolle/src/lib/phone-number-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    Output,\n    ViewChild,\n    ChangeDetectorRef\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport { CountrySelectorComponent } from './country-selector.component';\nimport { MaskedInputComponent } from './masked-input.component';\nimport parsePhoneNumber from 'libphonenumber-js';\nimport { cn } from './utils/cn';\n\n@Component({\n    selector: 'tolle-phone-number-input',\n    standalone: true,\n    imports: [CommonModule, FormsModule, CountrySelectorComponent, MaskedInputComponent],\n    template: `\n    <tolle-masked-input\n      [id]=\"id\"\n      [label]=\"label\"\n      [hint]=\"hint\"\n      [error]=\"error\"\n      [errorMessage]=\"errorMessage\"\n      [hideHintOnFocus]=\"hideHintOnFocus\"\n      [mask]=\"mask\"\n      [size]=\"size\"\n      [disabled]=\"disabled\"\n      [readonly]=\"readonly\"\n      [placeholder]=\"placeholder\"\n      [(ngModel)]=\"displayValue\"\n      (ngModelChange)=\"onMaskInputChange($event)\"\n      [containerClass]=\"cn('pl-0', class)\"\n    >\n      <tolle-country-selector\n        prefix\n        class=\"country-selector-override\"\n        [showName]=\"false\"\n        [size]=\"size\"\n        [disabled]=\"disabled || !enableCountrySelector\"\n        [readonly]=\"readonly\"\n        [(ngModel)]=\"selectedIso\"\n        (ngModelChange)=\"onCountryChange($event)\"\n      ></tolle-country-selector>\n    </tolle-masked-input>\n  `,\n    styles: [`\n    :host {\n      display: block;\n      width: 100%;\n    }\n    ::ng-deep .country-selector-override {\n       display: flex;\n       align-items: center;\n       border-right: 1px solid var(--border, #e5e7eb);\n    }\n    ::ng-deep .country-selector-override button {\n      border: none !important;\n      border-radius: 0 !important;\n      border-top-left-radius: calc(var(--radius, 0.5rem) - 1px) !important;\n      border-bottom-left-radius: calc(var(--radius, 0.5rem) - 1px) !important;\n      background: transparent !important;\n      box-shadow: none !important;\n      padding-left: 0.75rem !important;\n      padding-right: 0.5rem !important;\n      display: flex !important;\n      align-items: center !important;\n      justify-content: center !important;\n      gap: 0.25rem !important;\n    }\n    ::ng-deep .country-selector-override button .flex {\n      gap: 0.25rem !important;\n    }\n    ::ng-deep .country-selector-override button i {\n      margin-left: 0 !important;\n      line-height: 1 !important;\n      display: flex !important;\n      align-items: center !important;\n    }\n  `],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => PhoneNumberInputComponent),\n            multi: true\n        }\n    ]\n})\nexport class PhoneNumberInputComponent implements ControlValueAccessor {\n    private cdr = inject(ChangeDetectorRef);\n\n    @Input() id = `phone-input-${Math.random().toString(36).substr(2, 9)}`;\n    @Input() label = '';\n    @Input() hint = '';\n    @Input() errorMessage = '';\n    @Input() error = false;\n    @Input() hideHintOnFocus = true;\n    @Input() placeholder = 'Phone number';\n    @Input() size: 'xs' | 'sm' | 'default' | 'lg' = 'default';\n    @Input() disabled = false;\n    @Input() readonly = false;\n    @Input() defaultCountryCode = 'GH';\n    @Input() dataType: 'NumberOnly' | 'FullObject' = 'FullObject';\n    @Input() mask = '(000) 000-0000';\n    @Input() class = '';\n    @Input() enableCountrySelector = true;\n\n    @Output() onSelect = new EventEmitter<any>();\n\n    displayValue = '';\n    selectedIso = '';\n    private rawValue = '';\n\n    protected cn = cn;\n\n    onChange: any = () => { };\n    onTouched: any = () => { };\n\n    constructor() {\n        this.selectedIso = this.defaultCountryCode;\n    }\n\n    writeValue(value: any): void {\n        if (value) {\n            if (typeof value === 'object' && value.number) {\n                this.selectedIso = value.country || this.defaultCountryCode;\n                this.displayValue = value.number;\n                this.rawValue = value.number.replace(/\\D/g, '');\n            } else {\n                this.displayValue = value;\n                this.rawValue = value.toString().replace(/\\D/g, '');\n                try {\n                    const parsed = parsePhoneNumber(value);\n                    if (parsed) {\n                        this.selectedIso = parsed.country || this.defaultCountryCode;\n                    }\n                } catch (e) { }\n            }\n        } else {\n            this.displayValue = '';\n            this.rawValue = '';\n        }\n        this.cdr.markForCheck();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    onCountryChange(iso: string) {\n        this.selectedIso = iso;\n        this.updateModel();\n    }\n\n    onMaskInputChange(value: string) {\n        this.displayValue = value;\n        this.rawValue = value.replace(/\\D/g, '');\n        this.updateModel();\n    }\n\n    private updateModel() {\n        if (!this.rawValue) {\n            this.onChange(null);\n            return;\n        }\n\n        try {\n            const parsed = parsePhoneNumber(this.rawValue, this.selectedIso as any);\n            if (parsed) {\n                if (this.dataType === 'FullObject') {\n                    this.onChange(parsed);\n                } else {\n                    this.onChange(parsed.number);\n                }\n                this.onSelect.emit(parsed);\n            } else {\n                this.onChange(this.rawValue);\n            }\n        } catch (e) {\n            this.onChange(this.rawValue);\n        }\n    }\n}\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-number-input.component.js","sourceRoot":"","sources":["../../../../projects/tolle/src/lib/phone-number-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  Output,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport { CountrySelectorComponent } from './country-selector.component';\nimport { MaskedInputComponent } from './masked-input.component';\nimport parsePhoneNumber from 'libphonenumber-js';\nimport { cn } from './utils/cn';\n\n@Component({\n  selector: 'tolle-phone-number-input',\n  standalone: true,\n  imports: [CommonModule, FormsModule, CountrySelectorComponent, MaskedInputComponent],\n  template: `\n    <div class=\"flex w-full flex-col gap-1.5\">\n      <label *ngIf=\"label\" [for]=\"id\" [class]=\"computedLabelClass\">\n        {{ label }}\n      </label>\n\n      <div [class]=\"computedMergedClass\" (focusin)=\"onFocusIn()\" (focusout)=\"onFocusOut()\">\n        <tolle-country-selector\n          [showName]=\"false\"\n          [size]=\"size\"\n          [disabled]=\"disabled || !enableCountrySelector\"\n          [readonly]=\"readonly\"\n          [mergedPosition]=\"'left'\"\n          [(ngModel)]=\"selectedIso\"\n          (ngModelChange)=\"onCountryChange($event)\"></tolle-country-selector>\n\n        <tolle-masked-input\n          [id]=\"id\"\n          [mask]=\"mask\"\n          [size]=\"size\"\n          [disabled]=\"disabled\"\n          [readonly]=\"readonly\"\n          [placeholder]=\"placeholder\"\n          [error]=\"error\"\n          [externalFocused]=\"isFocused\"\n          [mergedPosition]=\"'right'\"\n          [(ngModel)]=\"displayValue\"\n          (ngModelChange)=\"onMaskInputChange($event)\"></tolle-masked-input>\n      </div>\n\n      <ng-container *ngIf=\"!disabled\">\n        <p\n          *ngIf=\"hint && !error\"\n          class=\"px-1 text-xs text-muted-foreground transition-opacity duration-200\"\n          [class.opacity-0]=\"isFocused && hideHintOnFocus\">\n          {{ hint }}\n        </p>\n        <p *ngIf=\"error && errorMessage\" [id]=\"id + '-error'\" class=\"px-1 text-xs text-destructive\">\n          {{ errorMessage }}\n        </p>\n      </ng-container>\n    </div>\n  `,\n  styles: [\n    `\n      :host {\n        display: block;\n        width: 100%;\n      }\n    `,\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PhoneNumberInputComponent),\n      multi: true,\n    },\n  ],\n})\nexport class PhoneNumberInputComponent implements ControlValueAccessor {\n  private cdr = inject(ChangeDetectorRef);\n\n  @Input() id = `phone-input-${Math.random().toString(36).substr(2, 9)}`;\n  @Input() label = '';\n  @Input() hint = '';\n  @Input() errorMessage = '';\n  @Input() error = false;\n  @Input() hideHintOnFocus = true;\n  @Input() placeholder = 'Phone number';\n  @Input() size: 'xs' | 'sm' | 'default' | 'lg' = 'default';\n  @Input() disabled = false;\n  @Input() readonly = false;\n  @Input() defaultCountryCode = 'GH';\n  @Input() dataType: 'NumberOnly' | 'FullObject' = 'FullObject';\n  @Input() mask = '(000) 000-0000';\n  @Input() class = '';\n  @Input() enableCountrySelector = true;\n\n  @Output() onSelect = new EventEmitter<any>();\n\n  displayValue = '';\n  selectedIso = '';\n  private rawValue = '';\n  isFocused = false;\n\n  protected cn = cn;\n\n  onChange: any = () => {};\n  onTouched: any = () => {};\n\n  constructor() {\n    this.selectedIso = this.defaultCountryCode;\n  }\n\n  get computedLabelClass() {\n    return cn(\n      'text-sm font-medium text-foreground leading-none transition-opacity duration-200',\n      this.disabled && 'opacity-50'\n    );\n  }\n\n  get computedMergedClass() {\n    return cn(\n      'flex rounded-md border transition-all duration-200',\n      'bg-background shadow-sm',\n      this.size === 'xs' && 'h-8',\n      this.size === 'sm' && 'h-9',\n      this.size === 'default' && 'h-10',\n      this.size === 'lg' && 'h-11',\n      // Focus state\n      !this.disabled &&\n        !this.readonly &&\n        this.isFocused && [\n          'ring-4',\n          'ring-ring/30',\n          'ring-offset-0',\n          'shadow-none',\n          this.error ? 'border-destructive/80' : 'border-primary/80',\n        ],\n      // Error state\n      this.error && ['border-destructive', this.isFocused && 'ring-destructive/30'],\n      // Disabled state\n      this.disabled && ['cursor-not-allowed opacity-50', 'border-opacity-50'],\n      // Readonly state\n      this.readonly && [\n        'cursor-default',\n        'border-dashed',\n        !this.disabled && !this.isFocused && 'ring-0',\n      ],\n      this.class\n    );\n  }\n\n  onFocusIn(): void {\n    this.isFocused = true;\n    this.cdr.markForCheck();\n  }\n\n  onFocusOut(): void {\n    this.isFocused = false;\n    this.onTouched();\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: any): void {\n    if (value) {\n      if (typeof value === 'object' && value.number) {\n        this.selectedIso = value.country || this.defaultCountryCode;\n        this.displayValue = value.number;\n        this.rawValue = value.number.replace(/\\D/g, '');\n      } else {\n        this.displayValue = value;\n        this.rawValue = value.toString().replace(/\\D/g, '');\n        try {\n          const parsed = parsePhoneNumber(value);\n          if (parsed) {\n            this.selectedIso = parsed.country || this.defaultCountryCode;\n          }\n        } catch (e) {}\n      }\n    } else {\n      this.displayValue = '';\n      this.rawValue = '';\n    }\n    this.cdr.markForCheck();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  onCountryChange(iso: string) {\n    this.selectedIso = iso;\n    this.updateModel();\n  }\n\n  onMaskInputChange(value: string) {\n    this.displayValue = value;\n    this.rawValue = value.replace(/\\D/g, '');\n    this.updateModel();\n  }\n\n  private updateModel() {\n    if (!this.rawValue) {\n      this.onChange(null);\n      return;\n    }\n\n    try {\n      const parsed = parsePhoneNumber(this.rawValue, this.selectedIso as any);\n      if (parsed) {\n        if (this.dataType === 'FullObject') {\n          this.onChange(parsed);\n        } else {\n          this.onChange(parsed.number);\n        }\n        this.onSelect.emit(parsed);\n      } else {\n        this.onChange(this.rawValue);\n      }\n    } catch (e) {\n      this.onChange(this.rawValue);\n    }\n  }\n}\n"]}