ng-zenduit 2.0.10 → 2.0.11

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.
@@ -105,7 +105,7 @@ export class ZenduInputComponent {
105
105
  /**
106
106
  * Phone input maximum length
107
107
  */
108
- this.phoneMaxLength = 12;
108
+ this.phoneMaxLength = 13;
109
109
  /**
110
110
  * Phone number value (for tel type)
111
111
  */
@@ -355,7 +355,7 @@ export class ZenduInputComponent {
355
355
  // Phone input methods
356
356
  parsePhoneNumber() {
357
357
  try {
358
- this.phoneText = this.phone;
358
+ this.phoneText = this.phone || '';
359
359
  if (this.phone) {
360
360
  const countryFromList = this.countryList.find(country => this.phone.startsWith(country.countryCallingCode) ||
361
361
  `+${this.phone}`.startsWith(country.countryCallingCode));
@@ -554,4 +554,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
554
554
  type: HostBinding,
555
555
  args: ['class.zen-input-wrapper']
556
556
  }] } });
557
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-input.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/input/zendu-input.component.ts","../../../../../projects/ng-zenduit/src/lib/input/zendu-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { \n    Component, \n    Input, \n    Output, \n    EventEmitter, \n    forwardRef,\n    ViewChild,\n    ElementRef,\n    OnInit,\n    OnChanges,\n    SimpleChanges,\n    HostBinding\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PhoneNumberUtil } from 'google-libphonenumber';\n\nexport interface DropdownOption {\n    label: string;\n    value: string | number;\n    icon?: string;\n}\n\n@Component({\n    selector: 'zen-input',\n    templateUrl: './zendu-input.component.html',\n    styleUrls: ['./zendu-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => ZenduInputComponent),\n            multi: true\n        }\n    ]\n})\nexport class ZenduInputComponent implements ControlValueAccessor, OnInit, OnChanges {\n    \n    @ViewChild('inputElement') inputElement: ElementRef<HTMLInputElement>;\n    \n    /**\n     * Input type attribute\n     */\n    @Input() type: 'text' | 'email' | 'password' | 'tel' | 'number' | 'url' | 'search' = 'text';\n    \n    /**\n     * Input variant type\n     */\n    @Input() variant: 'default' | 'input-field' | 'payment' | 'leading-dropdown' | 'leading-text' | 'trailing-dropdown' = 'default';\n    \n    /**\n     * Placeholder text\n     */\n    @Input() placeholder = '';\n    \n    /**\n     * Label text (shown above input)\n     */\n    @Input() label = '';\n    \n    /**\n     * Hint text (shown below input)\n     */\n    @Input() hintText = '';\n    \n    /**\n     * Leading icon name (Material Icons)\n     */\n    @Input() leadingIcon = '';\n    \n    /**\n     * Show help icon with tooltip\n     */\n    @Input() helpIcon = false;\n    \n    /**\n     * Tooltip text for help icon\n     */\n    @Input() helpTooltip = 'This is a tooltip';\n    \n    /**\n     * Error/destructive state\n     */\n    @Input() destructive = false;\n    \n    /**\n     * Error message to display\n     */\n    @Input() errorMessage = '';\n    \n    /**\n     * Disabled state\n     */\n    @Input() disabled = false;\n    \n    /**\n     * Required field\n     */\n    @Input() required = false;\n    \n    /**\n     * Maximum character length\n     */\n    @Input() maxLength: number;\n    \n    /**\n     * Minimum character length\n     */\n    @Input() minLength: number;\n    \n    /**\n     * Pattern for validation\n     */\n    @Input() pattern: string;\n    \n    /**\n     * Autocomplete attribute\n     */\n    @Input() autocomplete = 'off';\n    \n    /**\n     * Name attribute\n     */\n    @Input() name = '';\n    \n    /**\n     * ID attribute\n     */\n    @Input() id = '';\n    \n    /**\n     * Leading dropdown options\n     */\n    @Input() leadingDropdownOptions: DropdownOption[] = [];\n    \n    /**\n     * Selected leading dropdown value\n     */\n    @Input() leadingDropdownValue: string | number = '';\n    \n    /**\n     * Leading dropdown placeholder\n     */\n    @Input() leadingDropdownPlaceholder = 'Select';\n    \n    /**\n     * Trailing dropdown options\n     */\n    @Input() trailingDropdownOptions: DropdownOption[] = [];\n    \n    /**\n     * Selected trailing dropdown value\n     */\n    @Input() trailingDropdownValue: string | number = '';\n    \n    /**\n     * Trailing dropdown placeholder\n     */\n    @Input() trailingDropdownPlaceholder = 'Select';\n    \n    /**\n     * Leading static text\n     */\n    @Input() leadingText = '';\n    \n    /**\n     * Input size\n     */\n    @Input() size: 'sm' | 'md' = 'md';\n    \n    /**\n     * Show character counter\n     */\n    @Input() showCharacterCount = false;\n    \n    /**\n     * Phone input maximum length\n     */\n    @Input() phoneMaxLength: number = 12;\n    \n    /**\n     * Phone number value (for tel type)\n     */\n    @Input() phone: string = '';\n    \n    /**\n     * Width for phone input\n     */\n    @Input() width: string;\n    \n    /**\n     * Value change event\n     */\n    @Output() valueChange = new EventEmitter<string>();\n    \n    /**\n     * Focus event\n     */\n    @Output() inputFocus = new EventEmitter<FocusEvent>();\n    \n    /**\n     * Blur event\n     */\n    @Output() inputBlur = new EventEmitter<FocusEvent>();\n    \n    /**\n     * Keydown event\n     */\n    @Output() inputKeydown = new EventEmitter<KeyboardEvent>();\n    \n    /**\n     * Keyup event\n     */\n    @Output() inputKeyup = new EventEmitter<KeyboardEvent>();\n    \n    /**\n     * Leading dropdown change event\n     */\n    @Output() leadingDropdownChange = new EventEmitter<string | number>();\n    \n    /**\n     * Leading dropdown value change event (for two-way binding)\n     */\n    @Output() leadingDropdownValueChange = new EventEmitter<string | number>();\n    \n    /**\n     * Trailing dropdown change event\n     */\n    @Output() trailingDropdownChange = new EventEmitter<string | number>();\n    \n    /**\n     * Trailing dropdown value change event (for two-way binding)\n     */\n    @Output() trailingDropdownValueChange = new EventEmitter<string | number>();\n    \n    /**\n     * Help icon click event\n     */\n    @Output() helpIconClick = new EventEmitter<MouseEvent>();\n    \n    /**\n     * Phone change event\n     */\n    @Output() phoneChange = new EventEmitter<string>();\n    \n    /**\n     * Phone valid change event\n     */\n    @Output() validChange = new EventEmitter<boolean>();\n    \n    /**\n     * Leading icon click event\n     */\n    @Output() leadingIconClick = new EventEmitter<MouseEvent>();\n    \n    // Internal properties\n    public value = '';\n    public isFocused = false;\n    public showHelpTooltip = false;\n    public leadingDropdownOpen = false;\n    public trailingDropdownOpen = false;\n    \n    // Phone input properties\n    public phoneText = '';\n    public countryList: { countryCode: string, countryName: string, countryCallingCode: string, flag: string }[] = [\n        {\n            countryCode: \"US\",\n            countryName: \"America\",\n            countryCallingCode: \"+1\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/USA.svg\"\n        },\n        {\n            countryCode: \"CA\",\n            countryName: \"Canada\",\n            countryCallingCode: \"+1\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Canada.svg\"\n        },\n        {\n            countryCode: \"MX\",\n            countryName: \"Mexico\",\n            countryCallingCode: \"+52\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Mexico.svg\"\n        }\n    ];\n    \n    public customCountry = {\n        countryCode: \"\",\n        countryName: \"Custom\",\n        countryCallingCode: \"\",\n        flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Custom.svg\"\n    };\n    \n    public selectedCountry: { countryCode: string, countryName: string, countryCallingCode: string, flag: string };\n    public isPhoneDropdownExpanded = false;\n    \n    // ControlValueAccessor implementation\n    private onChange: (value: string) => void = () => {};\n    private onTouched: () => void = () => {};\n    \n    @HostBinding('class.zen-input-wrapper')\n    get hostClass(): boolean {\n        return true;\n    }\n    \n    ngOnInit(): void {\n        // Set default ID if not provided\n        if (!this.id) {\n            this.id = `zen-input-${Math.random().toString(36).substr(2, 9)}`;\n        }\n        \n        // Initialize phone input if type is tel\n        if (this.type === 'tel') {\n            this.selectedCountry = this.countryList[1]; // Default to Canada\n            this.parsePhoneNumber();\n        }\n    }\n    \n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes[\"phone\"] && this.type === 'tel' && (!this.selectedCountry || !this.selectedCountry.countryCode)) {\n            this.parsePhoneNumber();\n        }\n    }\n    \n    // ControlValueAccessor methods\n    writeValue(value: string): void {\n        this.value = value || '';\n    }\n    \n    registerOnChange(fn: (value: string) => void): void {\n        this.onChange = fn;\n    }\n    \n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n    \n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n    \n    // Event handlers\n    onInputChange(event: Event): void {\n        const target = event.target as HTMLInputElement;\n        \n        if (this.type === 'tel') {\n            // Handle phone input\n            this.phoneText = target.value;\n            this.onPhoneChanged(target);\n        } else {\n            // Handle regular input\n            this.value = target.value;\n            this.onChange(this.value);\n            this.valueChange.emit(this.value);\n        }\n    }\n    \n    onInputFocus(event: FocusEvent): void {\n        this.isFocused = true;\n        this.onTouched();\n        this.inputFocus.emit(event);\n    }\n    \n    onInputBlur(event: FocusEvent): void {\n        this.isFocused = false;\n        this.inputBlur.emit(event);\n    }\n    \n    onKeydown(event: KeyboardEvent): void {\n        this.inputKeydown.emit(event);\n    }\n    \n    onKeyup(event: KeyboardEvent): void {\n        this.inputKeyup.emit(event);\n    }\n    \n    onLeadingDropdownChange(value: string | number): void {\n        this.leadingDropdownValue = value;\n        this.leadingDropdownChange.emit(value);\n        this.leadingDropdownValueChange.emit(value);\n        this.leadingDropdownOpen = false;\n    }\n    \n    onTrailingDropdownChange(value: string | number): void {\n        this.trailingDropdownValue = value;\n        this.trailingDropdownChange.emit(value);\n        this.trailingDropdownValueChange.emit(value);\n        this.trailingDropdownOpen = false;\n    }\n    \n    toggleLeadingDropdown(): void {\n        if (!this.disabled) {\n            this.leadingDropdownOpen = !this.leadingDropdownOpen;\n            this.trailingDropdownOpen = false;\n        }\n    }\n    \n    toggleTrailingDropdown(): void {\n        if (!this.disabled) {\n            this.trailingDropdownOpen = !this.trailingDropdownOpen;\n            this.leadingDropdownOpen = false;\n        }\n    }\n    \n    onHelpIconClick(event: MouseEvent): void {\n        this.showHelpTooltip = !this.showHelpTooltip;\n        this.helpIconClick.emit(event);\n    }\n    \n    closeDropdowns(): void {\n        this.leadingDropdownOpen = false;\n        this.trailingDropdownOpen = false;\n    }\n    \n    get hasValue(): boolean {\n        return this.value !== '' && this.value !== null && this.value !== undefined;\n    }\n    \n    get showLabel(): boolean {\n        return !!this.label;\n    }\n    \n    get showHintText(): boolean {\n        return !!this.hintText || (this.destructive && !!this.errorMessage);\n    }\n    \n    get displayHintText(): string {\n        if (this.destructive && this.errorMessage) {\n            return this.errorMessage;\n        }\n        return this.hintText;\n    }\n    \n    get characterCount(): string {\n        const currentLength = this.value ? this.value.length : 0;\n        if (this.maxLength) {\n            return `${currentLength}/${this.maxLength}`;\n        }\n        return `${currentLength}`;\n    }\n    \n    get inputClasses(): string {\n        const classes = ['zen-input-container'];\n        \n        if (this.isFocused) {\n            classes.push('focused');\n        }\n        \n        if (this.hasValue) {\n            classes.push('filled');\n        }\n        \n        if (this.disabled) {\n            classes.push('disabled');\n        }\n        \n        if (this.destructive) {\n            classes.push('destructive');\n        }\n        \n        if (this.size) {\n            classes.push(`size-${this.size}`);\n        }\n        \n        if (this.variant) {\n            classes.push(`variant-${this.variant}`);\n        }\n        \n        return classes.join(' ');\n    }\n    \n    getLeadingDropdownLabel(): string {\n        const selected = this.leadingDropdownOptions.find(opt => opt.value === this.leadingDropdownValue);\n        return selected ? selected.label : this.leadingDropdownPlaceholder;\n    }\n    \n    getTrailingDropdownLabel(): string {\n        const selected = this.trailingDropdownOptions.find(opt => opt.value === this.trailingDropdownValue);\n        return selected ? selected.label : this.trailingDropdownPlaceholder;\n    }\n    \n    focusInput(): void {\n        if (this.inputElement) {\n            this.inputElement.nativeElement.focus();\n        }\n    }\n    \n    // Phone input methods\n    parsePhoneNumber(): void {\n        try {\n            this.phoneText = this.phone;\n\n            if (this.phone) {\n                const countryFromList = this.countryList.find(country => \n                    this.phone.startsWith(country.countryCallingCode) || \n                    `+${this.phone}`.startsWith(country.countryCallingCode)\n                );\n                if (countryFromList) {\n                    this.selectedCountry = countryFromList || this.customCountry;\n                    const phoneNumberUtil = PhoneNumberUtil.getInstance();\n                    const parsedPhone = phoneNumberUtil.parse(this.phone || \"\", 'US');\n                    setTimeout(() => {\n                        if (this.phoneText.startsWith('+')) {\n                            this.phoneText = this.phoneText.replace(`+${parsedPhone.getCountryCode()}`, \"\");\n                        } else if (this.phoneText.startsWith(parsedPhone.getCountryCode())) {\n                            this.phoneText = this.phoneText.replace(parsedPhone.getCountryCode(), \"\");\n                        }\n                        this.onPhoneChanged();\n                    });\n                } else {\n                    this.selectedCountry = this.customCountry;  \n                }\n            } else {\n                this.selectedCountry = this.customCountry;\n            }\n        } catch (err) {\n            console.warn(`Can't parse phone: ${this.phone}`, err);\n            this.selectedCountry = this.customCountry;\n        }\n    }\n    \n    onCountryChanged(country): void {\n        this.isPhoneDropdownExpanded = false;\n        this.selectedCountry = country;\n        this.onPhoneChanged();\n    }\n    \n    onPhoneChanged(input?: HTMLInputElement): void {\n        // allow + in custom country\n        let custom = false;\n        if (this.selectedCountry === this.customCountry && this.phoneText.includes('+')) {\n            custom = true;\n        }\n        \n        const phoneText = (this.phoneText || '').replace(/\\D/g, '');\n        this.phoneText = custom ? `+${phoneText}` : phoneText;\n        if (input && input.value !== this.phoneText) {\n            input.value = this.phoneText;\n        }\n        const fullNumber = `${this.selectedCountry.countryCallingCode}${this.phoneText}`;\n        if (this.phone !== fullNumber) {\n            this.phoneChange.emit(fullNumber);\n            // Also update the main value for form integration\n            this.value = fullNumber;\n            this.onChange(this.value);\n            this.valueChange.emit(this.value);\n        }\n        const phoneNumberUtil = PhoneNumberUtil.getInstance();\n        if (this.selectedCountry === this.customCountry) {\n            this.validChange.emit(true);\n        } else {\n            try {\n                this.validChange.emit(phoneNumberUtil.isValidNumber(phoneNumberUtil.parseAndKeepRawInput(fullNumber)));\n            } catch {\n                this.validChange.emit(false);\n            }\n        }\n    }\n    \n    hidePhoneDropdown(): void {\n        this.isPhoneDropdownExpanded = false;\n    }\n    \n    togglePhoneDropdown(): void {\n        if (this.disabled) {\n            return;\n        }\n        this.isPhoneDropdownExpanded = !this.isPhoneDropdownExpanded;\n    }\n    \n    onPhoneInputChange(event: Event): void {\n        const target = event.target as HTMLInputElement;\n        this.phoneText = target.value;\n        this.onPhoneChanged(target);\n    }\n    \n    onLeadingIconClick(event: MouseEvent): void {\n        event.stopPropagation();\n        this.leadingIconClick.emit(event);\n        \n        // Focus the input when leading icon is clicked\n        this.focusInput();\n    }\n}","<div class=\"zen-input-container\" [ngClass]=\"inputClasses\">\n    <!-- Label -->\n    <label *ngIf=\"showLabel\" \n           [for]=\"id\" \n           class=\"zen-input-label text text-sm text-weight-medium\"\n           [ngClass]=\"{'required': required, 'disabled': disabled, 'destructive': destructive}\">\n        {{ label | translate }}\n        <span *ngIf=\"required\" class=\"required-indicator\">*</span>\n    </label>\n    \n    <!-- Input wrapper -->\n    <div class=\"zen-input-field-wrapper\" (click)=\"focusInput()\">\n        \n        <!-- Leading icon -->\n        <i *ngIf=\"leadingIcon && variant === 'default'\" \n           class=\"material-icons zen-input-leading-icon\"\n           (click)=\"onLeadingIconClick($event)\">\n            {{ leadingIcon }}\n        </i>\n        \n        <!-- Leading dropdown -->\n        <div *ngIf=\"variant === 'leading-dropdown'\" \n             class=\"zen-input-leading-dropdown\">\n            <button type=\"button\"\n                    class=\"zen-dropdown-trigger\"\n                    [disabled]=\"disabled\"\n                    (click)=\"toggleLeadingDropdown(); $event.stopPropagation()\">\n                <span class=\"dropdown-label\">{{ getLeadingDropdownLabel() }}</span>\n                <i class=\"material-icons dropdown-icon\">expand_more</i>\n            </button>\n            \n            <div class=\"zen-dropdown-menu\" \n                 *ngIf=\"leadingDropdownOpen\"\n                 [ngClass]=\"{'open': leadingDropdownOpen}\">\n                <button *ngFor=\"let option of leadingDropdownOptions\"\n                        type=\"button\"\n                        class=\"zen-dropdown-option\"\n                        [ngClass]=\"{'selected': option.value === leadingDropdownValue}\"\n                        (click)=\"onLeadingDropdownChange(option.value); $event.stopPropagation()\">\n                    <i *ngIf=\"option.icon\" class=\"material-icons option-icon\">{{ option.icon }}</i>\n                    {{ option.label | translate }}\n                </button>\n            </div>\n        </div>\n        \n        <!-- Leading text -->\n        <span *ngIf=\"variant === 'leading-text'\" \n              class=\"zen-input-leading-text text text-md text-weight-regular\">\n            {{ leadingText }}\n        </span>\n        \n        <!-- Payment card icon -->\n        <div *ngIf=\"variant === 'payment'\" \n             class=\"zen-payment-card-icon\">\n            <i class=\"material-icons card-icon\">payment</i>\n        </div>\n        \n        <!-- Input content based on type -->\n        <ng-container *ngIf=\"type === 'tel'; else defaultInputTemplate\">\n            <ng-container *ngTemplateOutlet=\"phoneInputTemplate\"></ng-container>\n        </ng-container>\n        \n        <!-- Default input template -->\n        <ng-template #defaultInputTemplate>\n            <input #inputElement\n                   [type]=\"type\"\n                   [id]=\"id\"\n                   [name]=\"name\"\n                   [placeholder]=\"placeholder\"\n                   [value]=\"value\"\n                   [disabled]=\"disabled\"\n                   [required]=\"required\"\n                   [attr.maxlength]=\"maxLength\"\n                   [attr.minlength]=\"minLength\"\n                   [pattern]=\"pattern\"\n                   [autocomplete]=\"autocomplete\"\n                   class=\"zen-input-field text text-md text-weight-regular\"\n                   [ngClass]=\"{'zen-payment-field': variant === 'payment'}\"\n                   (input)=\"onInputChange($event)\"\n                   (focus)=\"onInputFocus($event)\"\n                   (blur)=\"onInputBlur($event)\"\n                   (keydown)=\"onKeydown($event)\"\n                   (keyup)=\"onKeyup($event)\" />\n        </ng-template>\n        \n        <!-- Trailing elements container -->\n        <div class=\"zen-input-trailing-container\">\n            <!-- Character counter -->\n            <span *ngIf=\"showCharacterCount && !helpIcon && variant === 'default'\" \n                  class=\"zen-character-count text text-sm text-weight-regular\">\n                {{ characterCount }}\n            </span>\n            \n            <!-- Help icon -->\n            <button *ngIf=\"helpIcon && variant !== 'trailing-dropdown'\" \n                    type=\"button\"\n                    class=\"zen-help-icon\"\n                    [disabled]=\"disabled\"\n                    (click)=\"onHelpIconClick($event); $event.stopPropagation()\">\n                <i class=\"material-icons-outlined\">help_outline</i>\n                \n                <!-- Help tooltip -->\n                <div class=\"zen-help-tooltip\" \n                     *ngIf=\"showHelpTooltip\"\n                     (click)=\"$event.stopPropagation()\">\n                    <div class=\"tooltip-content\">\n                        {{ helpTooltip | translate }}\n                    </div>\n                    <div class=\"tooltip-arrow\"></div>\n                </div>\n            </button>\n            \n            <!-- Trailing dropdown -->\n            <div *ngIf=\"variant === 'trailing-dropdown'\" \n                 class=\"zen-input-trailing-dropdown\">\n                <button type=\"button\"\n                        class=\"zen-dropdown-trigger\"\n                        [disabled]=\"disabled\"\n                        (click)=\"toggleTrailingDropdown(); $event.stopPropagation()\">\n                    <span class=\"dropdown-label\">{{ getTrailingDropdownLabel() }}</span>\n                    <i class=\"material-icons dropdown-icon\">expand_more</i>\n                </button>\n                \n                <div class=\"zen-dropdown-menu dropdown-menu-right\" \n                     *ngIf=\"trailingDropdownOpen\"\n                     [ngClass]=\"{'open': trailingDropdownOpen}\">\n                    <button *ngFor=\"let option of trailingDropdownOptions\"\n                            type=\"button\"\n                            class=\"zen-dropdown-option\"\n                            [ngClass]=\"{'selected': option.value === trailingDropdownValue}\"\n                            (click)=\"onTrailingDropdownChange(option.value); $event.stopPropagation()\">\n                        <i *ngIf=\"option.icon\" class=\"material-icons option-icon\">{{ option.icon }}</i>\n                        {{ option.label | translate }}\n                    </button>\n                </div>\n            </div>\n        </div>\n    </div>\n    \n    <!-- Hint text / Error message -->\n    <div *ngIf=\"showHintText\" \n         class=\"zen-input-hint text text-sm text-weight-regular\"\n         [ngClass]=\"{'destructive': destructive}\">\n        <i *ngIf=\"destructive\" class=\"material-icons-outlined hint-icon\">error_outline</i>\n        {{ displayHintText | translate }}\n    </div>\n    \n    <!-- Phone Country Dropdown (for tel type) -->\n    <div *ngIf=\"type === 'tel' && isPhoneDropdownExpanded\" \n         class=\"zen-phone-dropdown-menu\">\n        <div class=\"zen-phone-dropdown-list\">\n            <!-- Countries List -->\n            <button type=\"button\"\n                    class=\"zen-phone-dropdown-item\"\n                    *ngFor=\"let country of countryList\"\n                    [ngClass]=\"{'active': selectedCountry.countryName === country.countryName}\"\n                    (click)=\"onCountryChanged(country)\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"country.flag\"\n                     [alt]=\"country.countryName\">\n                <span class=\"zen-phone-country-name\">{{ country.countryName | translate }}</span>\n                <span class=\"zen-phone-country-code\">{{ country.countryCallingCode }}</span>\n            </button>\n\n            <!-- Custom Country -->\n            <button type=\"button\"\n                    class=\"zen-phone-dropdown-item\"\n                    [ngClass]=\"{'active': selectedCountry.countryName === customCountry.countryName}\"\n                    (click)=\"onCountryChanged(customCountry)\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"customCountry.flag\"\n                     [alt]=\"customCountry.countryName\">\n                <span class=\"zen-phone-country-name\">{{ customCountry.countryName | translate }}</span>\n                <span class=\"zen-phone-country-code\">{{ customCountry.countryCallingCode }}</span>\n            </button>\n        </div>\n    </div>\n</div>\n\n<!-- Phone Input Template -->\n<ng-template #phoneInputTemplate>\n    <!-- Phone country selector -->\n    <div class=\"zen-phone-country-select\">\n        <img class=\"zen-phone-country-flag\"\n             [src]=\"selectedCountry.flag\"\n             [alt]=\"selectedCountry.countryName\">\n        <span class=\"zen-phone-code\">{{ selectedCountry.countryCallingCode }}</span>\n        <button type=\"button\"\n                class=\"zen-phone-dropdown-btn\"\n                [disabled]=\"disabled\"\n                (click)=\"togglePhoneDropdown(); $event.stopPropagation()\">\n            <i class=\"material-icons zen-phone-expand-icon\"\n               [ngClass]=\"{'active': isPhoneDropdownExpanded}\">expand_more</i>\n        </button>\n    </div>\n    \n    <!-- Phone input field -->\n    <input #inputElement\n           type=\"text\"\n           [id]=\"id\"\n           [name]=\"name\"\n           [placeholder]=\"placeholder\"\n           [value]=\"phoneText\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [attr.maxlength]=\"phoneMaxLength\"\n           [attr.minlength]=\"minLength\"\n           [autocomplete]=\"autocomplete\"\n           class=\"zen-input-field text text-md text-weight-regular\"\n           (input)=\"onInputChange($event)\"\n           (focus)=\"onInputFocus($event)\"\n           (blur)=\"onInputBlur($event)\"\n           (keydown)=\"onKeydown($event)\"\n           (keyup)=\"onKeyup($event)\" />\n</ng-template>\n\n<!-- Click outside handler for dropdowns -->\n<div *ngIf=\"leadingDropdownOpen || trailingDropdownOpen || isPhoneDropdownExpanded\" \n     class=\"zen-dropdown-backdrop\" \n     (click)=\"closeDropdowns(); hidePhoneDropdown()\"></div>"]}
557
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-input.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/input/zendu-input.component.ts","../../../../../projects/ng-zenduit/src/lib/input/zendu-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { \n    Component, \n    Input, \n    Output, \n    EventEmitter, \n    forwardRef,\n    ViewChild,\n    ElementRef,\n    OnInit,\n    OnChanges,\n    SimpleChanges,\n    HostBinding\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PhoneNumberUtil } from 'google-libphonenumber';\n\nexport interface DropdownOption {\n    label: string;\n    value: string | number;\n    icon?: string;\n}\n\n@Component({\n    selector: 'zen-input',\n    templateUrl: './zendu-input.component.html',\n    styleUrls: ['./zendu-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => ZenduInputComponent),\n            multi: true\n        }\n    ]\n})\nexport class ZenduInputComponent implements ControlValueAccessor, OnInit, OnChanges {\n    \n    @ViewChild('inputElement') inputElement: ElementRef<HTMLInputElement>;\n    \n    /**\n     * Input type attribute\n     */\n    @Input() type: 'text' | 'email' | 'password' | 'tel' | 'number' | 'url' | 'search' = 'text';\n    \n    /**\n     * Input variant type\n     */\n    @Input() variant: 'default' | 'input-field' | 'payment' | 'leading-dropdown' | 'leading-text' | 'trailing-dropdown' = 'default';\n    \n    /**\n     * Placeholder text\n     */\n    @Input() placeholder = '';\n    \n    /**\n     * Label text (shown above input)\n     */\n    @Input() label = '';\n    \n    /**\n     * Hint text (shown below input)\n     */\n    @Input() hintText = '';\n    \n    /**\n     * Leading icon name (Material Icons)\n     */\n    @Input() leadingIcon = '';\n    \n    /**\n     * Show help icon with tooltip\n     */\n    @Input() helpIcon = false;\n    \n    /**\n     * Tooltip text for help icon\n     */\n    @Input() helpTooltip = 'This is a tooltip';\n    \n    /**\n     * Error/destructive state\n     */\n    @Input() destructive = false;\n    \n    /**\n     * Error message to display\n     */\n    @Input() errorMessage = '';\n    \n    /**\n     * Disabled state\n     */\n    @Input() disabled = false;\n    \n    /**\n     * Required field\n     */\n    @Input() required = false;\n    \n    /**\n     * Maximum character length\n     */\n    @Input() maxLength: number;\n    \n    /**\n     * Minimum character length\n     */\n    @Input() minLength: number;\n    \n    /**\n     * Pattern for validation\n     */\n    @Input() pattern: string;\n    \n    /**\n     * Autocomplete attribute\n     */\n    @Input() autocomplete = 'off';\n    \n    /**\n     * Name attribute\n     */\n    @Input() name = '';\n    \n    /**\n     * ID attribute\n     */\n    @Input() id = '';\n    \n    /**\n     * Leading dropdown options\n     */\n    @Input() leadingDropdownOptions: DropdownOption[] = [];\n    \n    /**\n     * Selected leading dropdown value\n     */\n    @Input() leadingDropdownValue: string | number = '';\n    \n    /**\n     * Leading dropdown placeholder\n     */\n    @Input() leadingDropdownPlaceholder = 'Select';\n    \n    /**\n     * Trailing dropdown options\n     */\n    @Input() trailingDropdownOptions: DropdownOption[] = [];\n    \n    /**\n     * Selected trailing dropdown value\n     */\n    @Input() trailingDropdownValue: string | number = '';\n    \n    /**\n     * Trailing dropdown placeholder\n     */\n    @Input() trailingDropdownPlaceholder = 'Select';\n    \n    /**\n     * Leading static text\n     */\n    @Input() leadingText = '';\n    \n    /**\n     * Input size\n     */\n    @Input() size: 'sm' | 'md' = 'md';\n    \n    /**\n     * Show character counter\n     */\n    @Input() showCharacterCount = false;\n    \n    /**\n     * Phone input maximum length\n     */\n    @Input() phoneMaxLength: number = 13;\n    \n    /**\n     * Phone number value (for tel type)\n     */\n    @Input() phone: string = '';\n    \n    /**\n     * Width for phone input\n     */\n    @Input() width: string;\n    \n    /**\n     * Value change event\n     */\n    @Output() valueChange = new EventEmitter<string>();\n    \n    /**\n     * Focus event\n     */\n    @Output() inputFocus = new EventEmitter<FocusEvent>();\n    \n    /**\n     * Blur event\n     */\n    @Output() inputBlur = new EventEmitter<FocusEvent>();\n    \n    /**\n     * Keydown event\n     */\n    @Output() inputKeydown = new EventEmitter<KeyboardEvent>();\n    \n    /**\n     * Keyup event\n     */\n    @Output() inputKeyup = new EventEmitter<KeyboardEvent>();\n    \n    /**\n     * Leading dropdown change event\n     */\n    @Output() leadingDropdownChange = new EventEmitter<string | number>();\n    \n    /**\n     * Leading dropdown value change event (for two-way binding)\n     */\n    @Output() leadingDropdownValueChange = new EventEmitter<string | number>();\n    \n    /**\n     * Trailing dropdown change event\n     */\n    @Output() trailingDropdownChange = new EventEmitter<string | number>();\n    \n    /**\n     * Trailing dropdown value change event (for two-way binding)\n     */\n    @Output() trailingDropdownValueChange = new EventEmitter<string | number>();\n    \n    /**\n     * Help icon click event\n     */\n    @Output() helpIconClick = new EventEmitter<MouseEvent>();\n    \n    /**\n     * Phone change event\n     */\n    @Output() phoneChange = new EventEmitter<string>();\n    \n    /**\n     * Phone valid change event\n     */\n    @Output() validChange = new EventEmitter<boolean>();\n    \n    /**\n     * Leading icon click event\n     */\n    @Output() leadingIconClick = new EventEmitter<MouseEvent>();\n    \n    // Internal properties\n    public value = '';\n    public isFocused = false;\n    public showHelpTooltip = false;\n    public leadingDropdownOpen = false;\n    public trailingDropdownOpen = false;\n    \n    // Phone input properties\n    public phoneText = '';\n    public countryList: { countryCode: string, countryName: string, countryCallingCode: string, flag: string }[] = [\n        {\n            countryCode: \"US\",\n            countryName: \"America\",\n            countryCallingCode: \"+1\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/USA.svg\"\n        },\n        {\n            countryCode: \"CA\",\n            countryName: \"Canada\",\n            countryCallingCode: \"+1\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Canada.svg\"\n        },\n        {\n            countryCode: \"MX\",\n            countryName: \"Mexico\",\n            countryCallingCode: \"+52\",\n            flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Mexico.svg\"\n        }\n    ];\n    \n    public customCountry = {\n        countryCode: \"\",\n        countryName: \"Custom\",\n        countryCallingCode: \"\",\n        flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Custom.svg\"\n    };\n    \n    public selectedCountry: { countryCode: string, countryName: string, countryCallingCode: string, flag: string };\n    public isPhoneDropdownExpanded = false;\n    \n    // ControlValueAccessor implementation\n    private onChange: (value: string) => void = () => {};\n    private onTouched: () => void = () => {};\n    \n    @HostBinding('class.zen-input-wrapper')\n    get hostClass(): boolean {\n        return true;\n    }\n    \n    ngOnInit(): void {\n        // Set default ID if not provided\n        if (!this.id) {\n            this.id = `zen-input-${Math.random().toString(36).substr(2, 9)}`;\n        }\n        \n        // Initialize phone input if type is tel\n        if (this.type === 'tel') {\n            this.selectedCountry = this.countryList[1]; // Default to Canada\n            this.parsePhoneNumber();\n        }\n    }\n    \n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes[\"phone\"] && this.type === 'tel' && (!this.selectedCountry || !this.selectedCountry.countryCode)) {\n            this.parsePhoneNumber();\n        }\n    }\n    \n    // ControlValueAccessor methods\n    writeValue(value: string): void {\n        this.value = value || '';\n    }\n    \n    registerOnChange(fn: (value: string) => void): void {\n        this.onChange = fn;\n    }\n    \n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n    \n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n    \n    // Event handlers\n    onInputChange(event: Event): void {\n        const target = event.target as HTMLInputElement;\n        \n        if (this.type === 'tel') {\n            // Handle phone input\n            this.phoneText = target.value;\n            this.onPhoneChanged(target);\n        } else {\n            // Handle regular input\n            this.value = target.value;\n            this.onChange(this.value);\n            this.valueChange.emit(this.value);\n        }\n    }\n    \n    onInputFocus(event: FocusEvent): void {\n        this.isFocused = true;\n        this.onTouched();\n        this.inputFocus.emit(event);\n    }\n    \n    onInputBlur(event: FocusEvent): void {\n        this.isFocused = false;\n        this.inputBlur.emit(event);\n    }\n    \n    onKeydown(event: KeyboardEvent): void {\n        this.inputKeydown.emit(event);\n    }\n    \n    onKeyup(event: KeyboardEvent): void {\n        this.inputKeyup.emit(event);\n    }\n    \n    onLeadingDropdownChange(value: string | number): void {\n        this.leadingDropdownValue = value;\n        this.leadingDropdownChange.emit(value);\n        this.leadingDropdownValueChange.emit(value);\n        this.leadingDropdownOpen = false;\n    }\n    \n    onTrailingDropdownChange(value: string | number): void {\n        this.trailingDropdownValue = value;\n        this.trailingDropdownChange.emit(value);\n        this.trailingDropdownValueChange.emit(value);\n        this.trailingDropdownOpen = false;\n    }\n    \n    toggleLeadingDropdown(): void {\n        if (!this.disabled) {\n            this.leadingDropdownOpen = !this.leadingDropdownOpen;\n            this.trailingDropdownOpen = false;\n        }\n    }\n    \n    toggleTrailingDropdown(): void {\n        if (!this.disabled) {\n            this.trailingDropdownOpen = !this.trailingDropdownOpen;\n            this.leadingDropdownOpen = false;\n        }\n    }\n    \n    onHelpIconClick(event: MouseEvent): void {\n        this.showHelpTooltip = !this.showHelpTooltip;\n        this.helpIconClick.emit(event);\n    }\n    \n    closeDropdowns(): void {\n        this.leadingDropdownOpen = false;\n        this.trailingDropdownOpen = false;\n    }\n    \n    get hasValue(): boolean {\n        return this.value !== '' && this.value !== null && this.value !== undefined;\n    }\n    \n    get showLabel(): boolean {\n        return !!this.label;\n    }\n    \n    get showHintText(): boolean {\n        return !!this.hintText || (this.destructive && !!this.errorMessage);\n    }\n    \n    get displayHintText(): string {\n        if (this.destructive && this.errorMessage) {\n            return this.errorMessage;\n        }\n        return this.hintText;\n    }\n    \n    get characterCount(): string {\n        const currentLength = this.value ? this.value.length : 0;\n        if (this.maxLength) {\n            return `${currentLength}/${this.maxLength}`;\n        }\n        return `${currentLength}`;\n    }\n    \n    get inputClasses(): string {\n        const classes = ['zen-input-container'];\n        \n        if (this.isFocused) {\n            classes.push('focused');\n        }\n        \n        if (this.hasValue) {\n            classes.push('filled');\n        }\n        \n        if (this.disabled) {\n            classes.push('disabled');\n        }\n        \n        if (this.destructive) {\n            classes.push('destructive');\n        }\n        \n        if (this.size) {\n            classes.push(`size-${this.size}`);\n        }\n        \n        if (this.variant) {\n            classes.push(`variant-${this.variant}`);\n        }\n        \n        return classes.join(' ');\n    }\n    \n    getLeadingDropdownLabel(): string {\n        const selected = this.leadingDropdownOptions.find(opt => opt.value === this.leadingDropdownValue);\n        return selected ? selected.label : this.leadingDropdownPlaceholder;\n    }\n    \n    getTrailingDropdownLabel(): string {\n        const selected = this.trailingDropdownOptions.find(opt => opt.value === this.trailingDropdownValue);\n        return selected ? selected.label : this.trailingDropdownPlaceholder;\n    }\n    \n    focusInput(): void {\n        if (this.inputElement) {\n            this.inputElement.nativeElement.focus();\n        }\n    }\n    \n    // Phone input methods\n    parsePhoneNumber(): void {\n        try {\n            this.phoneText = this.phone || '';\n\n            if (this.phone) {\n                const countryFromList = this.countryList.find(country => \n                    this.phone.startsWith(country.countryCallingCode) || \n                    `+${this.phone}`.startsWith(country.countryCallingCode)\n                );\n                if (countryFromList) {\n                    this.selectedCountry = countryFromList || this.customCountry;\n                    const phoneNumberUtil = PhoneNumberUtil.getInstance();\n                    const parsedPhone = phoneNumberUtil.parse(this.phone || \"\", 'US');\n                    setTimeout(() => {\n                        if (this.phoneText.startsWith('+')) {\n                            this.phoneText = this.phoneText.replace(`+${parsedPhone.getCountryCode()}`, \"\");\n                        } else if (this.phoneText.startsWith(parsedPhone.getCountryCode())) {\n                            this.phoneText = this.phoneText.replace(parsedPhone.getCountryCode(), \"\");\n                        }\n                        this.onPhoneChanged();\n                    });\n                } else {\n                    this.selectedCountry = this.customCountry;  \n                }\n            } else {\n                this.selectedCountry = this.customCountry;\n            }\n        } catch (err) {\n            console.warn(`Can't parse phone: ${this.phone}`, err);\n            this.selectedCountry = this.customCountry;\n        }\n    }\n    \n    onCountryChanged(country): void {\n        this.isPhoneDropdownExpanded = false;\n        this.selectedCountry = country;\n        this.onPhoneChanged();\n    }\n    \n    onPhoneChanged(input?: HTMLInputElement): void {\n        // allow + in custom country\n        let custom = false;\n        if (this.selectedCountry === this.customCountry && this.phoneText.includes('+')) {\n            custom = true;\n        }\n        \n        const phoneText = (this.phoneText || '').replace(/\\D/g, '');\n        this.phoneText = custom ? `+${phoneText}` : phoneText;\n        if (input && input.value !== this.phoneText) {\n            input.value = this.phoneText;\n        }\n        const fullNumber = `${this.selectedCountry.countryCallingCode}${this.phoneText}`;\n        if (this.phone !== fullNumber) {\n            this.phoneChange.emit(fullNumber);\n            // Also update the main value for form integration\n            this.value = fullNumber;\n            this.onChange(this.value);\n            this.valueChange.emit(this.value);\n        }\n        const phoneNumberUtil = PhoneNumberUtil.getInstance();\n        if (this.selectedCountry === this.customCountry) {\n            this.validChange.emit(true);\n        } else {\n            try {\n                this.validChange.emit(phoneNumberUtil.isValidNumber(phoneNumberUtil.parseAndKeepRawInput(fullNumber)));\n            } catch {\n                this.validChange.emit(false);\n            }\n        }\n    }\n    \n    hidePhoneDropdown(): void {\n        this.isPhoneDropdownExpanded = false;\n    }\n    \n    togglePhoneDropdown(): void {\n        if (this.disabled) {\n            return;\n        }\n        this.isPhoneDropdownExpanded = !this.isPhoneDropdownExpanded;\n    }\n    \n    onPhoneInputChange(event: Event): void {\n        const target = event.target as HTMLInputElement;\n        this.phoneText = target.value;\n        this.onPhoneChanged(target);\n    }\n    \n    onLeadingIconClick(event: MouseEvent): void {\n        event.stopPropagation();\n        this.leadingIconClick.emit(event);\n        \n        // Focus the input when leading icon is clicked\n        this.focusInput();\n    }\n}","<div class=\"zen-input-container\" [ngClass]=\"inputClasses\">\n    <!-- Label -->\n    <label *ngIf=\"showLabel\" \n           [for]=\"id\" \n           class=\"zen-input-label text text-sm text-weight-medium\"\n           [ngClass]=\"{'required': required, 'disabled': disabled, 'destructive': destructive}\">\n        {{ label | translate }}\n        <span *ngIf=\"required\" class=\"required-indicator\">*</span>\n    </label>\n    \n    <!-- Input wrapper -->\n    <div class=\"zen-input-field-wrapper\" (click)=\"focusInput()\">\n        \n        <!-- Leading icon -->\n        <i *ngIf=\"leadingIcon && variant === 'default'\" \n           class=\"material-icons zen-input-leading-icon\"\n           (click)=\"onLeadingIconClick($event)\">\n            {{ leadingIcon }}\n        </i>\n        \n        <!-- Leading dropdown -->\n        <div *ngIf=\"variant === 'leading-dropdown'\" \n             class=\"zen-input-leading-dropdown\">\n            <button type=\"button\"\n                    class=\"zen-dropdown-trigger\"\n                    [disabled]=\"disabled\"\n                    (click)=\"toggleLeadingDropdown(); $event.stopPropagation()\">\n                <span class=\"dropdown-label\">{{ getLeadingDropdownLabel() }}</span>\n                <i class=\"material-icons dropdown-icon\">expand_more</i>\n            </button>\n            \n            <div class=\"zen-dropdown-menu\" \n                 *ngIf=\"leadingDropdownOpen\"\n                 [ngClass]=\"{'open': leadingDropdownOpen}\">\n                <button *ngFor=\"let option of leadingDropdownOptions\"\n                        type=\"button\"\n                        class=\"zen-dropdown-option\"\n                        [ngClass]=\"{'selected': option.value === leadingDropdownValue}\"\n                        (click)=\"onLeadingDropdownChange(option.value); $event.stopPropagation()\">\n                    <i *ngIf=\"option.icon\" class=\"material-icons option-icon\">{{ option.icon }}</i>\n                    {{ option.label | translate }}\n                </button>\n            </div>\n        </div>\n        \n        <!-- Leading text -->\n        <span *ngIf=\"variant === 'leading-text'\" \n              class=\"zen-input-leading-text text text-md text-weight-regular\">\n            {{ leadingText }}\n        </span>\n        \n        <!-- Payment card icon -->\n        <div *ngIf=\"variant === 'payment'\" \n             class=\"zen-payment-card-icon\">\n            <i class=\"material-icons card-icon\">payment</i>\n        </div>\n        \n        <!-- Input content based on type -->\n        <ng-container *ngIf=\"type === 'tel'; else defaultInputTemplate\">\n            <ng-container *ngTemplateOutlet=\"phoneInputTemplate\"></ng-container>\n        </ng-container>\n        \n        <!-- Default input template -->\n        <ng-template #defaultInputTemplate>\n            <input #inputElement\n                   [type]=\"type\"\n                   [id]=\"id\"\n                   [name]=\"name\"\n                   [placeholder]=\"placeholder\"\n                   [value]=\"value\"\n                   [disabled]=\"disabled\"\n                   [required]=\"required\"\n                   [attr.maxlength]=\"maxLength\"\n                   [attr.minlength]=\"minLength\"\n                   [pattern]=\"pattern\"\n                   [autocomplete]=\"autocomplete\"\n                   class=\"zen-input-field text text-md text-weight-regular\"\n                   [ngClass]=\"{'zen-payment-field': variant === 'payment'}\"\n                   (input)=\"onInputChange($event)\"\n                   (focus)=\"onInputFocus($event)\"\n                   (blur)=\"onInputBlur($event)\"\n                   (keydown)=\"onKeydown($event)\"\n                   (keyup)=\"onKeyup($event)\" />\n        </ng-template>\n        \n        <!-- Trailing elements container -->\n        <div class=\"zen-input-trailing-container\">\n            <!-- Character counter -->\n            <span *ngIf=\"showCharacterCount && !helpIcon && variant === 'default'\" \n                  class=\"zen-character-count text text-sm text-weight-regular\">\n                {{ characterCount }}\n            </span>\n            \n            <!-- Help icon -->\n            <button *ngIf=\"helpIcon && variant !== 'trailing-dropdown'\" \n                    type=\"button\"\n                    class=\"zen-help-icon\"\n                    [disabled]=\"disabled\"\n                    (click)=\"onHelpIconClick($event); $event.stopPropagation()\">\n                <i class=\"material-icons-outlined\">help_outline</i>\n                \n                <!-- Help tooltip -->\n                <div class=\"zen-help-tooltip\" \n                     *ngIf=\"showHelpTooltip\"\n                     (click)=\"$event.stopPropagation()\">\n                    <div class=\"tooltip-content\">\n                        {{ helpTooltip | translate }}\n                    </div>\n                    <div class=\"tooltip-arrow\"></div>\n                </div>\n            </button>\n            \n            <!-- Trailing dropdown -->\n            <div *ngIf=\"variant === 'trailing-dropdown'\" \n                 class=\"zen-input-trailing-dropdown\">\n                <button type=\"button\"\n                        class=\"zen-dropdown-trigger\"\n                        [disabled]=\"disabled\"\n                        (click)=\"toggleTrailingDropdown(); $event.stopPropagation()\">\n                    <span class=\"dropdown-label\">{{ getTrailingDropdownLabel() }}</span>\n                    <i class=\"material-icons dropdown-icon\">expand_more</i>\n                </button>\n                \n                <div class=\"zen-dropdown-menu dropdown-menu-right\" \n                     *ngIf=\"trailingDropdownOpen\"\n                     [ngClass]=\"{'open': trailingDropdownOpen}\">\n                    <button *ngFor=\"let option of trailingDropdownOptions\"\n                            type=\"button\"\n                            class=\"zen-dropdown-option\"\n                            [ngClass]=\"{'selected': option.value === trailingDropdownValue}\"\n                            (click)=\"onTrailingDropdownChange(option.value); $event.stopPropagation()\">\n                        <i *ngIf=\"option.icon\" class=\"material-icons option-icon\">{{ option.icon }}</i>\n                        {{ option.label | translate }}\n                    </button>\n                </div>\n            </div>\n        </div>\n    </div>\n    \n    <!-- Hint text / Error message -->\n    <div *ngIf=\"showHintText\" \n         class=\"zen-input-hint text text-sm text-weight-regular\"\n         [ngClass]=\"{'destructive': destructive}\">\n        <i *ngIf=\"destructive\" class=\"material-icons-outlined hint-icon\">error_outline</i>\n        {{ displayHintText | translate }}\n    </div>\n    \n    <!-- Phone Country Dropdown (for tel type) -->\n    <div *ngIf=\"type === 'tel' && isPhoneDropdownExpanded\" \n         class=\"zen-phone-dropdown-menu\">\n        <div class=\"zen-phone-dropdown-list\">\n            <!-- Countries List -->\n            <button type=\"button\"\n                    class=\"zen-phone-dropdown-item\"\n                    *ngFor=\"let country of countryList\"\n                    [ngClass]=\"{'active': selectedCountry.countryName === country.countryName}\"\n                    (click)=\"onCountryChanged(country)\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"country.flag\"\n                     [alt]=\"country.countryName\">\n                <span class=\"zen-phone-country-name\">{{ country.countryName | translate }}</span>\n                <span class=\"zen-phone-country-code\">{{ country.countryCallingCode }}</span>\n            </button>\n\n            <!-- Custom Country -->\n            <button type=\"button\"\n                    class=\"zen-phone-dropdown-item\"\n                    [ngClass]=\"{'active': selectedCountry.countryName === customCountry.countryName}\"\n                    (click)=\"onCountryChanged(customCountry)\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"customCountry.flag\"\n                     [alt]=\"customCountry.countryName\">\n                <span class=\"zen-phone-country-name\">{{ customCountry.countryName | translate }}</span>\n                <span class=\"zen-phone-country-code\">{{ customCountry.countryCallingCode }}</span>\n            </button>\n        </div>\n    </div>\n</div>\n\n<!-- Phone Input Template -->\n<ng-template #phoneInputTemplate>\n    <!-- Phone country selector -->\n    <div class=\"zen-phone-country-select\">\n        <img class=\"zen-phone-country-flag\"\n             [src]=\"selectedCountry.flag\"\n             [alt]=\"selectedCountry.countryName\">\n        <span class=\"zen-phone-code\">{{ selectedCountry.countryCallingCode }}</span>\n        <button type=\"button\"\n                class=\"zen-phone-dropdown-btn\"\n                [disabled]=\"disabled\"\n                (click)=\"togglePhoneDropdown(); $event.stopPropagation()\">\n            <i class=\"material-icons zen-phone-expand-icon\"\n               [ngClass]=\"{'active': isPhoneDropdownExpanded}\">expand_more</i>\n        </button>\n    </div>\n    \n    <!-- Phone input field -->\n    <input #inputElement\n           type=\"text\"\n           [id]=\"id\"\n           [name]=\"name\"\n           [placeholder]=\"placeholder\"\n           [value]=\"phoneText\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [attr.maxlength]=\"phoneMaxLength\"\n           [attr.minlength]=\"minLength\"\n           [autocomplete]=\"autocomplete\"\n           class=\"zen-input-field text text-md text-weight-regular\"\n           (input)=\"onInputChange($event)\"\n           (focus)=\"onInputFocus($event)\"\n           (blur)=\"onInputBlur($event)\"\n           (keydown)=\"onKeydown($event)\"\n           (keyup)=\"onKeyup($event)\" />\n</ng-template>\n\n<!-- Click outside handler for dropdowns -->\n<div *ngIf=\"leadingDropdownOpen || trailingDropdownOpen || isPhoneDropdownExpanded\" \n     class=\"zen-dropdown-backdrop\" \n     (click)=\"closeDropdowns(); hidePhoneDropdown()\"></div>"]}
@@ -15,7 +15,7 @@ const MODULE_LABELS = {
15
15
  more: 'More',
16
16
  };
17
17
  const MODULE_ICONS = {
18
- fleet: 'map',
18
+ fleet: 'truck',
19
19
  safety: 'shield',
20
20
  operations: 'briefcase',
21
21
  reports: 'bar-chart-2',
@@ -75,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
75
75
  type: HostListener,
76
76
  args: ['document:mousedown', ['$event']]
77
77
  }] } });
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemVuLW1vZHVsZS1wb3B1cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy16ZW5kdWl0L3NyYy9saWIvbW9kdWxlLXBvcHVwL3plbi1tb2R1bGUtcG9wdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctemVuZHVpdC9zcmMvbGliL21vZHVsZS1wb3B1cC96ZW4tbW9kdWxlLXBvcHVwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFjLE1BQU0sZUFBZSxDQUFDOzs7O0FBWWpHLE1BQU0sYUFBYSxHQUF5QztJQUMxRCxLQUFLLEVBQUUsT0FBTztJQUNkLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFVBQVUsRUFBRSxTQUFTO0lBQ3JCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsSUFBSSxFQUFFLE1BQU07SUFDWixRQUFRLEVBQUUsVUFBVTtJQUNwQixVQUFVLEVBQUUsWUFBWTtJQUN4QixTQUFTLEVBQUUsV0FBVztJQUN0QixJQUFJLEVBQUUsTUFBTTtDQUNiLENBQUM7QUFFRixNQUFNLFlBQVksR0FBeUM7SUFDekQsS0FBSyxFQUFFLEtBQUs7SUFDWixNQUFNLEVBQUUsUUFBUTtJQUNoQixVQUFVLEVBQUUsV0FBVztJQUN2QixPQUFPLEVBQUUsYUFBYTtJQUN0QixHQUFHLEVBQUUsS0FBSztJQUNWLElBQUksRUFBRSxTQUFTO0lBQ2YsUUFBUSxFQUFFLE1BQU07SUFDaEIsVUFBVSxFQUFFLGFBQWE7SUFDekIsU0FBUyxFQUFFLFNBQVM7SUFDcEIsSUFBSSxFQUFFLGVBQWU7Q0FDdEIsQ0FBQztBQU9GLE1BQU0sT0FBTyx1QkFBdUI7SUFTbEMsWUFBb0IsV0FBdUI7UUFBdkIsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFQbEMsV0FBTSxHQUF5QixPQUFPLENBQUM7UUFDdkMsVUFBSyxHQUF5QixFQUFFLENBQUM7UUFDakMsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUVkLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUNuRCxVQUFLLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUVHLENBQUM7SUFFL0MsSUFBSSxXQUFXO1FBQ2IsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDbkQsQ0FBQztJQUVELElBQUksVUFBVTtRQUNaLE9BQU8sWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxRQUFRLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE1BQU0sT0FBTyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUNyQyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssTUFBTTtZQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUNuRSxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELFdBQVcsQ0FBQyxJQUF3QjtRQUNsQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBR0QsZUFBZSxDQUFDLEtBQWlCO1FBQy9CLElBQUksSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDekUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNuQjtJQUNILENBQUM7O3FIQWxDVSx1QkFBdUI7eUdBQXZCLHVCQUF1Qix1UEMzQ3BDLGdvQkFvQkE7NEZEdUJhLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0I7aUdBTW5CLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUVJLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNO2dCQXVCUCxlQUFlO3NCQURkLFlBQVk7dUJBQUMsb0JBQW9CLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCB0eXBlIFplbk1vZHVsZVBvcHVwTW9kdWxlID1cbiAgfCAnZmxlZXQnIHwgJ3NhZmV0eScgfCAnb3BlcmF0aW9ucycgfCAncmVwb3J0cydcbiAgfCAnYnVzJyB8ICdmdWVsJyB8ICdtYWludGFpbicgfCAnZWZmaWNpZW5jeScgfCAnaW52ZW50b3J5JyB8ICdtb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBaZW5Nb2R1bGVQb3B1cEl0ZW0ge1xuICBsYWJlbDogc3RyaW5nO1xuICByb3V0ZT86IHN0cmluZztcbiAgdGFnPzogdW5rbm93bjtcbn1cblxuY29uc3QgTU9EVUxFX0xBQkVMUzogUmVjb3JkPFplbk1vZHVsZVBvcHVwTW9kdWxlLCBzdHJpbmc+ID0ge1xuICBmbGVldDogJ0ZsZWV0JyxcbiAgc2FmZXR5OiAnU2FmZXR5JyxcbiAgb3BlcmF0aW9uczogJ09wZXJhdGUnLFxuICByZXBvcnRzOiAnUmVwb3J0cycsXG4gIGJ1czogJ0J1cycsXG4gIGZ1ZWw6ICdGdWVsJyxcbiAgbWFpbnRhaW46ICdNYWludGFpbicsXG4gIGVmZmljaWVuY3k6ICdFZmZpY2llbmN5JyxcbiAgaW52ZW50b3J5OiAnSW52ZW50b3J5JyxcbiAgbW9yZTogJ01vcmUnLFxufTtcblxuY29uc3QgTU9EVUxFX0lDT05TOiBSZWNvcmQ8WmVuTW9kdWxlUG9wdXBNb2R1bGUsIHN0cmluZz4gPSB7XG4gIGZsZWV0OiAnbWFwJyxcbiAgc2FmZXR5OiAnc2hpZWxkJyxcbiAgb3BlcmF0aW9uczogJ2JyaWVmY2FzZScsXG4gIHJlcG9ydHM6ICdiYXItY2hhcnQtMicsXG4gIGJ1czogJ2J1cycsXG4gIGZ1ZWw6ICdkcm9wbGV0JyxcbiAgbWFpbnRhaW46ICd0b29sJyxcbiAgZWZmaWNpZW5jeTogJ3RyZW5kaW5nLXVwJyxcbiAgaW52ZW50b3J5OiAncGFja2FnZScsXG4gIG1vcmU6ICdtb3JlLXZlcnRpY2FsJyxcbn07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3plbi1tb2R1bGUtcG9wdXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vemVuLW1vZHVsZS1wb3B1cC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3plbi1tb2R1bGUtcG9wdXAuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBaZW5Nb2R1bGVQb3B1cENvbXBvbmVudCB7XG5cbiAgQElucHV0KCkgbW9kdWxlOiBaZW5Nb2R1bGVQb3B1cE1vZHVsZSA9ICdmbGVldCc7XG4gIEBJbnB1dCgpIGl0ZW1zOiBaZW5Nb2R1bGVQb3B1cEl0ZW1bXSA9IFtdO1xuICBASW5wdXQoKSBpc09wZW4gPSBmYWxzZTtcblxuICBAT3V0cHV0KCkgaXRlbUNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxaZW5Nb2R1bGVQb3B1cEl0ZW0+KCk7XG4gIEBPdXRwdXQoKSBjbG9zZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7fVxuXG4gIGdldCBtb2R1bGVMYWJlbCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBNT0RVTEVfTEFCRUxTW3RoaXMubW9kdWxlXSB8fCB0aGlzLm1vZHVsZTtcbiAgfVxuXG4gIGdldCBtb2R1bGVJY29uKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIE1PRFVMRV9JQ09OU1t0aGlzLm1vZHVsZV0gfHwgJ2NpcmNsZSc7XG4gIH1cblxuICBnZXQgaG9zdENsYXNzZXMoKTogc3RyaW5nIHtcbiAgICBjb25zdCBjbGFzc2VzID0gWyd6ZW4tbW9kdWxlLXBvcHVwJ107XG4gICAgaWYgKHRoaXMubW9kdWxlID09PSAnbW9yZScpIGNsYXNzZXMucHVzaCgnemVuLW1vZHVsZS1wb3B1cC0tbW9yZScpO1xuICAgIHJldHVybiBjbGFzc2VzLmpvaW4oJyAnKTtcbiAgfVxuXG4gIG9uSXRlbUNsaWNrKGl0ZW06IFplbk1vZHVsZVBvcHVwSXRlbSk6IHZvaWQge1xuICAgIHRoaXMuaXRlbUNsaWNrLmVtaXQoaXRlbSk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDptb3VzZWRvd24nLCBbJyRldmVudCddKVxuICBvbkRvY3VtZW50Q2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5pc09wZW4gJiYgIXRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5jb250YWlucyhldmVudC50YXJnZXQpKSB7XG4gICAgICB0aGlzLmNsb3NlLmVtaXQoKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgKm5nSWY9XCJpc09wZW5cIiBbY2xhc3NdPVwiaG9zdENsYXNzZXNcIj5cbiAgPCEtLSBIZWFkZXIgLS0+XG4gIDxkaXYgY2xhc3M9XCJ6ZW4tbW9kdWxlLXBvcHVwX19oZWFkZXJcIj5cbiAgICA8emVuLWljb24gY2xhc3M9XCJ6ZW4tbW9kdWxlLXBvcHVwX19oZWFkZXItaWNvblwiXG4gICAgICAgICAgICAgIFtuYW1lXT1cIm1vZHVsZUljb25cIlxuICAgICAgICAgICAgICBbY3VzdG9tQ29sb3JdPVwiJyM5OEEyQjMnXCI+PC96ZW4taWNvbj5cbiAgICA8c3BhbiBjbGFzcz1cInplbi1tb2R1bGUtcG9wdXBfX2hlYWRlci1sYWJlbFwiPnt7IG1vZHVsZUxhYmVsIH19PC9zcGFuPlxuICA8L2Rpdj5cblxuICA8ZGl2IGNsYXNzPVwiemVuLW1vZHVsZS1wb3B1cF9fZGl2aWRlclwiPjwvZGl2PlxuXG4gIDwhLS0gSXRlbXMgLS0+XG4gIDxkaXYgY2xhc3M9XCJ6ZW4tbW9kdWxlLXBvcHVwX19pdGVtc1wiPlxuICAgIDxkaXYgKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXNcIlxuICAgICAgICAgY2xhc3M9XCJ6ZW4tbW9kdWxlLXBvcHVwX19pdGVtXCJcbiAgICAgICAgIChjbGljayk9XCJvbkl0ZW1DbGljayhpdGVtKVwiPlxuICAgICAge3sgaXRlbS5sYWJlbCB9fVxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemVuLW1vZHVsZS1wb3B1cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy16ZW5kdWl0L3NyYy9saWIvbW9kdWxlLXBvcHVwL3plbi1tb2R1bGUtcG9wdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctemVuZHVpdC9zcmMvbGliL21vZHVsZS1wb3B1cC96ZW4tbW9kdWxlLXBvcHVwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFjLE1BQU0sZUFBZSxDQUFDOzs7O0FBWWpHLE1BQU0sYUFBYSxHQUF5QztJQUMxRCxLQUFLLEVBQUUsT0FBTztJQUNkLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFVBQVUsRUFBRSxTQUFTO0lBQ3JCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsSUFBSSxFQUFFLE1BQU07SUFDWixRQUFRLEVBQUUsVUFBVTtJQUNwQixVQUFVLEVBQUUsWUFBWTtJQUN4QixTQUFTLEVBQUUsV0FBVztJQUN0QixJQUFJLEVBQUUsTUFBTTtDQUNiLENBQUM7QUFFRixNQUFNLFlBQVksR0FBeUM7SUFDekQsS0FBSyxFQUFFLE9BQU87SUFDZCxNQUFNLEVBQUUsUUFBUTtJQUNoQixVQUFVLEVBQUUsV0FBVztJQUN2QixPQUFPLEVBQUUsYUFBYTtJQUN0QixHQUFHLEVBQUUsS0FBSztJQUNWLElBQUksRUFBRSxTQUFTO0lBQ2YsUUFBUSxFQUFFLE1BQU07SUFDaEIsVUFBVSxFQUFFLGFBQWE7SUFDekIsU0FBUyxFQUFFLFNBQVM7SUFDcEIsSUFBSSxFQUFFLGVBQWU7Q0FDdEIsQ0FBQztBQU9GLE1BQU0sT0FBTyx1QkFBdUI7SUFTbEMsWUFBb0IsV0FBdUI7UUFBdkIsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFQbEMsV0FBTSxHQUF5QixPQUFPLENBQUM7UUFDdkMsVUFBSyxHQUF5QixFQUFFLENBQUM7UUFDakMsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUVkLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBc0IsQ0FBQztRQUNuRCxVQUFLLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUVHLENBQUM7SUFFL0MsSUFBSSxXQUFXO1FBQ2IsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDbkQsQ0FBQztJQUVELElBQUksVUFBVTtRQUNaLE9BQU8sWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxRQUFRLENBQUM7SUFDL0MsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE1BQU0sT0FBTyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUNyQyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssTUFBTTtZQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUNuRSxPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELFdBQVcsQ0FBQyxJQUF3QjtRQUNsQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBR0QsZUFBZSxDQUFDLEtBQWlCO1FBQy9CLElBQUksSUFBSSxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDekUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNuQjtJQUNILENBQUM7O3FIQWxDVSx1QkFBdUI7eUdBQXZCLHVCQUF1Qix1UEMzQ3BDLGdvQkFvQkE7NEZEdUJhLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0I7aUdBTW5CLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUVJLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNO2dCQXVCUCxlQUFlO3NCQURkLFlBQVk7dUJBQUMsb0JBQW9CLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCB0eXBlIFplbk1vZHVsZVBvcHVwTW9kdWxlID1cbiAgfCAnZmxlZXQnIHwgJ3NhZmV0eScgfCAnb3BlcmF0aW9ucycgfCAncmVwb3J0cydcbiAgfCAnYnVzJyB8ICdmdWVsJyB8ICdtYWludGFpbicgfCAnZWZmaWNpZW5jeScgfCAnaW52ZW50b3J5JyB8ICdtb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBaZW5Nb2R1bGVQb3B1cEl0ZW0ge1xuICBsYWJlbDogc3RyaW5nO1xuICByb3V0ZT86IHN0cmluZztcbiAgdGFnPzogdW5rbm93bjtcbn1cblxuY29uc3QgTU9EVUxFX0xBQkVMUzogUmVjb3JkPFplbk1vZHVsZVBvcHVwTW9kdWxlLCBzdHJpbmc+ID0ge1xuICBmbGVldDogJ0ZsZWV0JyxcbiAgc2FmZXR5OiAnU2FmZXR5JyxcbiAgb3BlcmF0aW9uczogJ09wZXJhdGUnLFxuICByZXBvcnRzOiAnUmVwb3J0cycsXG4gIGJ1czogJ0J1cycsXG4gIGZ1ZWw6ICdGdWVsJyxcbiAgbWFpbnRhaW46ICdNYWludGFpbicsXG4gIGVmZmljaWVuY3k6ICdFZmZpY2llbmN5JyxcbiAgaW52ZW50b3J5OiAnSW52ZW50b3J5JyxcbiAgbW9yZTogJ01vcmUnLFxufTtcblxuY29uc3QgTU9EVUxFX0lDT05TOiBSZWNvcmQ8WmVuTW9kdWxlUG9wdXBNb2R1bGUsIHN0cmluZz4gPSB7XG4gIGZsZWV0OiAndHJ1Y2snLFxuICBzYWZldHk6ICdzaGllbGQnLFxuICBvcGVyYXRpb25zOiAnYnJpZWZjYXNlJyxcbiAgcmVwb3J0czogJ2Jhci1jaGFydC0yJyxcbiAgYnVzOiAnYnVzJyxcbiAgZnVlbDogJ2Ryb3BsZXQnLFxuICBtYWludGFpbjogJ3Rvb2wnLFxuICBlZmZpY2llbmN5OiAndHJlbmRpbmctdXAnLFxuICBpbnZlbnRvcnk6ICdwYWNrYWdlJyxcbiAgbW9yZTogJ21vcmUtdmVydGljYWwnLFxufTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnemVuLW1vZHVsZS1wb3B1cCcsXG4gIHRlbXBsYXRlVXJsOiAnLi96ZW4tbW9kdWxlLXBvcHVwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vemVuLW1vZHVsZS1wb3B1cC5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFplbk1vZHVsZVBvcHVwQ29tcG9uZW50IHtcblxuICBASW5wdXQoKSBtb2R1bGU6IFplbk1vZHVsZVBvcHVwTW9kdWxlID0gJ2ZsZWV0JztcbiAgQElucHV0KCkgaXRlbXM6IFplbk1vZHVsZVBvcHVwSXRlbVtdID0gW107XG4gIEBJbnB1dCgpIGlzT3BlbiA9IGZhbHNlO1xuXG4gIEBPdXRwdXQoKSBpdGVtQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPFplbk1vZHVsZVBvcHVwSXRlbT4oKTtcbiAgQE91dHB1dCgpIGNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgX2VsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgZ2V0IG1vZHVsZUxhYmVsKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIE1PRFVMRV9MQUJFTFNbdGhpcy5tb2R1bGVdIHx8IHRoaXMubW9kdWxlO1xuICB9XG5cbiAgZ2V0IG1vZHVsZUljb24oKTogc3RyaW5nIHtcbiAgICByZXR1cm4gTU9EVUxFX0lDT05TW3RoaXMubW9kdWxlXSB8fCAnY2lyY2xlJztcbiAgfVxuXG4gIGdldCBob3N0Q2xhc3NlcygpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNsYXNzZXMgPSBbJ3plbi1tb2R1bGUtcG9wdXAnXTtcbiAgICBpZiAodGhpcy5tb2R1bGUgPT09ICdtb3JlJykgY2xhc3Nlcy5wdXNoKCd6ZW4tbW9kdWxlLXBvcHVwLS1tb3JlJyk7XG4gICAgcmV0dXJuIGNsYXNzZXMuam9pbignICcpO1xuICB9XG5cbiAgb25JdGVtQ2xpY2soaXRlbTogWmVuTW9kdWxlUG9wdXBJdGVtKTogdm9pZCB7XG4gICAgdGhpcy5pdGVtQ2xpY2suZW1pdChpdGVtKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50Om1vdXNlZG93bicsIFsnJGV2ZW50J10pXG4gIG9uRG9jdW1lbnRDbGljayhldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmlzT3BlbiAmJiAhdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCkpIHtcbiAgICAgIHRoaXMuY2xvc2UuZW1pdCgpO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiAqbmdJZj1cImlzT3BlblwiIFtjbGFzc109XCJob3N0Q2xhc3Nlc1wiPlxuICA8IS0tIEhlYWRlciAtLT5cbiAgPGRpdiBjbGFzcz1cInplbi1tb2R1bGUtcG9wdXBfX2hlYWRlclwiPlxuICAgIDx6ZW4taWNvbiBjbGFzcz1cInplbi1tb2R1bGUtcG9wdXBfX2hlYWRlci1pY29uXCJcbiAgICAgICAgICAgICAgW25hbWVdPVwibW9kdWxlSWNvblwiXG4gICAgICAgICAgICAgIFtjdXN0b21Db2xvcl09XCInIzk4QTJCMydcIj48L3plbi1pY29uPlxuICAgIDxzcGFuIGNsYXNzPVwiemVuLW1vZHVsZS1wb3B1cF9faGVhZGVyLWxhYmVsXCI+e3sgbW9kdWxlTGFiZWwgfX08L3NwYW4+XG4gIDwvZGl2PlxuXG4gIDxkaXYgY2xhc3M9XCJ6ZW4tbW9kdWxlLXBvcHVwX19kaXZpZGVyXCI+PC9kaXY+XG5cbiAgPCEtLSBJdGVtcyAtLT5cbiAgPGRpdiBjbGFzcz1cInplbi1tb2R1bGUtcG9wdXBfX2l0ZW1zXCI+XG4gICAgPGRpdiAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtc1wiXG4gICAgICAgICBjbGFzcz1cInplbi1tb2R1bGUtcG9wdXBfX2l0ZW1cIlxuICAgICAgICAgKGNsaWNrKT1cIm9uSXRlbUNsaWNrKGl0ZW0pXCI+XG4gICAgICB7eyBpdGVtLmxhYmVsIH19XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -5,9 +5,10 @@ import * as i2 from "../side-nav-item/zen-side-nav-item.component";
5
5
  import * as i3 from "../module-popup/zen-module-popup.component";
6
6
  const MODULE_CONFIG = {
7
7
  dashboard: { icon: 'home', label: 'Dashboard' },
8
- fleet: { icon: 'map', label: 'Fleet' },
8
+ today: { icon: 'sun', label: 'Today' },
9
+ fleet: { icon: 'truck', label: 'Fleet' },
9
10
  safety: { icon: 'shield', label: 'Safety' },
10
- operations: { icon: 'briefcase', label: 'Operations' },
11
+ operations: { icon: 'briefcase', label: 'Operate' },
11
12
  reports: { icon: 'bar-chart-2', label: 'Reports' },
12
13
  bus: { icon: 'bus', label: 'Bus' },
13
14
  fuel: { icon: 'droplet', label: 'Fuel' },
@@ -16,10 +17,12 @@ const MODULE_CONFIG = {
16
17
  vehicles: { icon: 'truck', label: 'Vehicles' },
17
18
  drivers: { icon: 'users', label: 'Drivers' },
18
19
  admin: { icon: 'settings', label: 'Admin' },
19
- notification: { icon: 'bell', label: 'Notification' },
20
- message: { icon: 'message-square', label: 'Message' },
20
+ notification: { icon: 'bell', label: 'Alerts' },
21
+ message: { icon: 'message-square', label: 'Chat' },
21
22
  manage: { icon: 'sliders', label: 'Manage' },
22
23
  help: { icon: 'help-circle', label: 'Help' },
24
+ efficiency: { icon: 'trending-up', label: 'Efficiency' },
25
+ inventory: { icon: 'package', label: 'Inventory' },
23
26
  };
24
27
  const MODULE_TO_POPUP = {
25
28
  fleet: 'fleet',
@@ -30,6 +33,8 @@ const MODULE_TO_POPUP = {
30
33
  fuel: 'fuel',
31
34
  more: 'more',
32
35
  maintain: 'maintain',
36
+ efficiency: 'efficiency',
37
+ inventory: 'inventory',
33
38
  };
34
39
  export class ZenNavItemComponent {
35
40
  constructor() {
@@ -96,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
96
101
  }], expandedChange: [{
97
102
  type: Output
98
103
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zen-nav-item.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/nav-item/zen-nav-item.component.ts","../../../../../projects/ng-zenduit/src/lib/nav-item/zen-nav-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { ZenSideNavItemType, ZenSideNavItemState, ZenSideNavSubItem } from '../side-nav-item/zen-side-nav-item.component';\nimport { ZenModulePopupModule, ZenModulePopupItem } from '../module-popup/zen-module-popup.component';\n\nexport type ZenNavModule =\n  | 'dashboard' | 'fleet' | 'safety' | 'operations' | 'reports'\n  | 'bus' | 'fuel' | 'more' | 'maintain' | 'vehicles'\n  | 'drivers' | 'admin' | 'notification' | 'message'\n  | 'manage' | 'help';\n\ninterface ModuleConfig {\n  icon: string;\n  label: string;\n}\n\nconst MODULE_CONFIG: Record<ZenNavModule, ModuleConfig> = {\n  dashboard: { icon: 'home', label: 'Dashboard' },\n  fleet: { icon: 'map', label: 'Fleet' },\n  safety: { icon: 'shield', label: 'Safety' },\n  operations: { icon: 'briefcase', label: 'Operations' },\n  reports: { icon: 'bar-chart-2', label: 'Reports' },\n  bus: { icon: 'bus', label: 'Bus' },\n  fuel: { icon: 'droplet', label: 'Fuel' },\n  more: { icon: 'more-vertical', label: 'More' },\n  maintain: { icon: 'tool', label: 'Maintain' },\n  vehicles: { icon: 'truck', label: 'Vehicles' },\n  drivers: { icon: 'users', label: 'Drivers' },\n  admin: { icon: 'settings', label: 'Admin' },\n  notification: { icon: 'bell', label: 'Notification' },\n  message: { icon: 'message-square', label: 'Message' },\n  manage: { icon: 'sliders', label: 'Manage' },\n  help: { icon: 'help-circle', label: 'Help' },\n};\n\nconst MODULE_TO_POPUP: Record<string, ZenModulePopupModule> = {\n  fleet: 'fleet',\n  safety: 'safety',\n  operations: 'operations',\n  reports: 'reports',\n  bus: 'bus',\n  fuel: 'fuel',\n  more: 'more',\n  maintain: 'maintain',\n};\n\n@Component({\n  selector: 'zen-nav-item',\n  templateUrl: './zen-nav-item.component.html',\n  styleUrls: ['./zen-nav-item.component.scss']\n})\nexport class ZenNavItemComponent {\n\n  @Input() module: ZenNavModule = 'dashboard';\n  @Input() type: ZenSideNavItemType = 'collapsed';\n  @Input() state: ZenSideNavItemState = 'default';\n  @Input() hasSubmodule = false;\n  @Input() subItems: ZenSideNavSubItem[] = [];\n  @Input() expanded = false;\n\n  @Output() activate = new EventEmitter<void>();\n  @Output() subItemActivate = new EventEmitter<ZenSideNavSubItem>();\n  @Output() expandedChange = new EventEmitter<boolean>();\n\n  popupOpen = false;\n\n  get moduleConfig(): ModuleConfig {\n    return MODULE_CONFIG[this.module] || MODULE_CONFIG.dashboard;\n  }\n\n  get popupModule(): ZenModulePopupModule | null {\n    return MODULE_TO_POPUP[this.module] || null;\n  }\n\n  get popupItems(): ZenModulePopupItem[] {\n    return this.subItems.map(s => ({ label: s.label, route: s.route, tag: s.tag }));\n  }\n\n  get showPopupOnHover(): boolean {\n    return this.type === 'collapsed' && this.hasSubmodule && this.subItems.length > 0;\n  }\n\n  onMouseEnter(): void {\n    if (this.showPopupOnHover) {\n      this.popupOpen = true;\n    }\n  }\n\n  onMouseLeave(): void {\n    this.popupOpen = false;\n  }\n\n  onPopupItemClick(item: ZenModulePopupItem): void {\n    const subItem = this.subItems.find(s => s.label === item.label);\n    if (subItem) {\n      this.subItemActivate.emit(subItem);\n    }\n    this.popupOpen = false;\n  }\n}\n","<div class=\"zen-nav-item\"\n     (mouseenter)=\"onMouseEnter()\"\n     (mouseleave)=\"onMouseLeave()\">\n  <zen-side-nav-item\n    [type]=\"type\"\n    [state]=\"state\"\n    [icon]=\"moduleConfig.icon\"\n    [label]=\"moduleConfig.label\"\n    [hasSubmodule]=\"hasSubmodule\"\n    [subItems]=\"subItems\"\n    [expanded]=\"expanded\"\n    (activate)=\"activate.emit()\"\n    (subItemActivate)=\"subItemActivate.emit($event)\"\n    (expandedChange)=\"expandedChange.emit($event)\">\n  </zen-side-nav-item>\n\n  <!-- Collapsed hover popup -->\n  <zen-module-popup *ngIf=\"popupOpen && popupModule\"\n                    class=\"zen-nav-item__popup\"\n                    [module]=\"popupModule\"\n                    [items]=\"popupItems\"\n                    [isOpen]=\"true\"\n                    (itemClick)=\"onPopupItemClick($event)\">\n  </zen-module-popup>\n</div>\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zen-nav-item.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/nav-item/zen-nav-item.component.ts","../../../../../projects/ng-zenduit/src/lib/nav-item/zen-nav-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { ZenSideNavItemType, ZenSideNavItemState, ZenSideNavSubItem } from '../side-nav-item/zen-side-nav-item.component';\nimport { ZenModulePopupModule, ZenModulePopupItem } from '../module-popup/zen-module-popup.component';\n\nexport type ZenNavModule =\n  | 'dashboard' | 'today' | 'fleet' | 'safety' | 'operations' | 'reports'\n  | 'bus' | 'fuel' | 'more' | 'maintain' | 'vehicles'\n  | 'drivers' | 'admin' | 'notification' | 'message'\n  | 'manage' | 'help' | 'efficiency' | 'inventory';\n\ninterface ModuleConfig {\n  icon: string;\n  label: string;\n}\n\nconst MODULE_CONFIG: Record<ZenNavModule, ModuleConfig> = {\n  dashboard: { icon: 'home', label: 'Dashboard' },\n  today: { icon: 'sun', label: 'Today' },\n  fleet: { icon: 'truck', label: 'Fleet' },\n  safety: { icon: 'shield', label: 'Safety' },\n  operations: { icon: 'briefcase', label: 'Operate' },\n  reports: { icon: 'bar-chart-2', label: 'Reports' },\n  bus: { icon: 'bus', label: 'Bus' },\n  fuel: { icon: 'droplet', label: 'Fuel' },\n  more: { icon: 'more-vertical', label: 'More' },\n  maintain: { icon: 'tool', label: 'Maintain' },\n  vehicles: { icon: 'truck', label: 'Vehicles' },\n  drivers: { icon: 'users', label: 'Drivers' },\n  admin: { icon: 'settings', label: 'Admin' },\n  notification: { icon: 'bell', label: 'Alerts' },\n  message: { icon: 'message-square', label: 'Chat' },\n  manage: { icon: 'sliders', label: 'Manage' },\n  help: { icon: 'help-circle', label: 'Help' },\n  efficiency: { icon: 'trending-up', label: 'Efficiency' },\n  inventory: { icon: 'package', label: 'Inventory' },\n};\n\nconst MODULE_TO_POPUP: Record<string, ZenModulePopupModule> = {\n  fleet: 'fleet',\n  safety: 'safety',\n  operations: 'operations',\n  reports: 'reports',\n  bus: 'bus',\n  fuel: 'fuel',\n  more: 'more',\n  maintain: 'maintain',\n  efficiency: 'efficiency',\n  inventory: 'inventory',\n};\n\n@Component({\n  selector: 'zen-nav-item',\n  templateUrl: './zen-nav-item.component.html',\n  styleUrls: ['./zen-nav-item.component.scss']\n})\nexport class ZenNavItemComponent {\n\n  @Input() module: ZenNavModule = 'dashboard';\n  @Input() type: ZenSideNavItemType = 'collapsed';\n  @Input() state: ZenSideNavItemState = 'default';\n  @Input() hasSubmodule = false;\n  @Input() subItems: ZenSideNavSubItem[] = [];\n  @Input() expanded = false;\n\n  @Output() activate = new EventEmitter<void>();\n  @Output() subItemActivate = new EventEmitter<ZenSideNavSubItem>();\n  @Output() expandedChange = new EventEmitter<boolean>();\n\n  popupOpen = false;\n\n  get moduleConfig(): ModuleConfig {\n    return MODULE_CONFIG[this.module] || MODULE_CONFIG.dashboard;\n  }\n\n  get popupModule(): ZenModulePopupModule | null {\n    return MODULE_TO_POPUP[this.module] || null;\n  }\n\n  get popupItems(): ZenModulePopupItem[] {\n    return this.subItems.map(s => ({ label: s.label, route: s.route, tag: s.tag }));\n  }\n\n  get showPopupOnHover(): boolean {\n    return this.type === 'collapsed' && this.hasSubmodule && this.subItems.length > 0;\n  }\n\n  onMouseEnter(): void {\n    if (this.showPopupOnHover) {\n      this.popupOpen = true;\n    }\n  }\n\n  onMouseLeave(): void {\n    this.popupOpen = false;\n  }\n\n  onPopupItemClick(item: ZenModulePopupItem): void {\n    const subItem = this.subItems.find(s => s.label === item.label);\n    if (subItem) {\n      this.subItemActivate.emit(subItem);\n    }\n    this.popupOpen = false;\n  }\n}\n","<div class=\"zen-nav-item\"\n     (mouseenter)=\"onMouseEnter()\"\n     (mouseleave)=\"onMouseLeave()\">\n  <zen-side-nav-item\n    [type]=\"type\"\n    [state]=\"state\"\n    [icon]=\"moduleConfig.icon\"\n    [label]=\"moduleConfig.label\"\n    [hasSubmodule]=\"hasSubmodule\"\n    [subItems]=\"subItems\"\n    [expanded]=\"expanded\"\n    (activate)=\"activate.emit()\"\n    (subItemActivate)=\"subItemActivate.emit($event)\"\n    (expandedChange)=\"expandedChange.emit($event)\">\n  </zen-side-nav-item>\n\n  <!-- Collapsed hover popup -->\n  <zen-module-popup *ngIf=\"popupOpen && popupModule\"\n                    class=\"zen-nav-item__popup\"\n                    [module]=\"popupModule\"\n                    [items]=\"popupItems\"\n                    [isOpen]=\"true\"\n                    (itemClick)=\"onPopupItemClick($event)\">\n  </zen-module-popup>\n</div>\n"]}
@@ -60,7 +60,7 @@ export class ZenduPaginationBarComponent {
60
60
  }
61
61
  }
62
62
  ZenduPaginationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
63
- ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "label", "supportingText", "placeholder", "leadingType", "leadingIcon", "leadingAvatar", "leadingDotColor", "displayProp", "idProp", "hasSearch", "isMultiselect", "multiselect", "hideSelectAll", "hideTreeSearch", "disabled", "error", "errorMessage", "size", "returnOption", "isTruncate", "enableAddNewOption", "showDefaultAddOption", "newOptionText", "enableRemoveOption", "removeOptionText", "isLazyLoading", "lazyLoader"], outputs: ["selectModelChange", "addNewOption", "removeOption", "closed"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
63
+ ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "label", "supportingText", "hintText", "placeholder", "leadingType", "leadingIcon", "leadingAvatar", "leadingDotColor", "displayProp", "idProp", "hasSearch", "isMultiselect", "multiselect", "hideSelectAll", "hideTreeSearch", "disabled", "error", "errorMessage", "destructive", "size", "returnOption", "isTruncate", "enableAddNewOption", "showDefaultAddOption", "newOptionText", "enableRemoveOption", "removeOptionText", "isLazyLoading", "lazyLoader", "preferredOpenDirection"], outputs: ["selectModelChange", "addNewOption", "removeOption", "closed"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
64
64
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, decorators: [{
65
65
  type: Component,
66
66
  args: [{ selector: 'zen-pagination-bar', template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"] }]
@@ -49,7 +49,7 @@ export class ZenduPhoneInputComponent {
49
49
  }
50
50
  parseNumber() {
51
51
  try {
52
- this.phoneText = this.phone;
52
+ this.phoneText = this.phone || '';
53
53
  if (this.phone) {
54
54
  const countryFromList = this.countryList.find(country => this.phone.startsWith(country.countryCallingCode) || `+${this.phone}`.startsWith(country.countryCallingCode));
55
55
  if (countryFromList) {
@@ -148,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
148
148
  }], width: [{
149
149
  type: Input
150
150
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/phone-input/zendu-phone-input.component.ts","../../../../../projects/ng-zenduit/src/lib/phone-input/zendu-phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { PhoneNumberUtil } from 'google-libphonenumber';\n\n@Component({\n  selector: 'zen-phone-input',\n  templateUrl: './zendu-phone-input.component.html',\n  styleUrls: ['./zendu-phone-input.component.scss']\n})\nexport class ZenduPhoneInputComponent implements OnInit, OnChanges {\n\n  @ViewChild('input') inputElement: ElementRef<HTMLInputElement>;\n\n  @Input() phone: string;\n\n  @Input() maxLength: number = 12;\n\n  @Output() phoneChange = new EventEmitter<string>();\n\n  @Output() validChange = new EventEmitter<boolean>();\n\n  @Input() disabled = false;\n\n  @Input() width: string;\n\n  public phoneText = \"\";\n\n  public countryList: { countryCode: string, countryName: string, countryCallingCode: string, flag: string }[] = [\n    {\n      countryCode: \"US\",\n      countryName: \"America\",\n      countryCallingCode: \"+1\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/USA.svg\"\n    },\n    {\n      countryCode: \"CA\",\n      countryName: \"Canada\",\n      countryCallingCode: \"+1\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Canada.svg\"\n    },\n    {\n      countryCode: \"MX\",\n      countryName: \"Mexico\",\n      countryCallingCode: \"+52\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Mexico.svg\"\n    }\n  ];\n\n  public customCountry = {\n    countryCode: \"\",\n    countryName: \"Custom\",\n    countryCallingCode: \"\",\n    flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Custom.svg\"\n  };\n\n  public selectedCountry: { countryCode: string, countryName: string, countryCallingCode: string, flag: string };\n\n  public isExpanded = false;\n\n  public constructor() {\n    this.selectedCountry = this.countryList[1];\n  }\n\n  public ngOnInit(): void {\n    this.parseNumber();\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"phone\"] && (!this.selectedCountry || !this.selectedCountry.countryCode)) {\n      this.parseNumber();\n    }\n  }\n\n  public parseNumber(): void {\n    try {\n      this.phoneText = this.phone;\n\n      if (this.phone) {\n        const countryFromList = this.countryList.find(country => this.phone.startsWith(country.countryCallingCode) || `+${this.phone}`.startsWith(country.countryCallingCode));\n        if (countryFromList) {\n          this.selectedCountry = countryFromList || this.customCountry;\n          const phoneNumberUtil = PhoneNumberUtil.getInstance();\n          const parsedPhone = phoneNumberUtil.parse(this.phone || \"\", 'US');\n          setTimeout(() => {\n            if (this.phoneText.startsWith('+')) {\n              this.phoneText = this.phoneText.replace(`+${parsedPhone.getCountryCode()}`, \"\");\n            } else if (this.phoneText.startsWith(parsedPhone.getCountryCode())) {\n              this.phoneText = this.phoneText.replace(parsedPhone.getCountryCode(), \"\");\n            }\n            this.phoneChanged();\n          });\n        } else {\n          this.selectedCountry = this.customCountry;  \n        }\n      } else {\n        this.selectedCountry = this.customCountry;\n      }\n    } catch (err) {\n      console.warn(`Can't parse phone: ${this.phone}`, err);\n      this.selectedCountry = this.customCountry;\n    }\n  }\n\n  public countryChanged(country): void {\n    this.isExpanded = false;\n    this.selectedCountry = country;\n    this.phoneChanged();\n  }\n\n  public phoneChanged(input?: HTMLInputElement): void {\n    \n    // allow + in custom country\n    let custom = false;\n    if (this.selectedCountry === this.customCountry && this.phoneText.includes('+')) {\n      custom = true;\n    }\n    \n    const phoneText = (this.phoneText || '').replace(/\\D/g, '');\n    this.phoneText = custom ? `+${phoneText}`: phoneText\n    if (input && input.value !== this.phoneText) {\n      input.value = this.phoneText;\n    }\n    const fullNumber = `${this.selectedCountry.countryCallingCode}${this.phoneText}`;\n    if (this.phone !== fullNumber) {\n      this.phoneChange.emit(fullNumber);\n    }\n    const phoneNumberUtil = PhoneNumberUtil.getInstance();\n    if (this.selectedCountry === this.customCountry) {\n      this.validChange.emit(true);\n    } else {\n      try {\n        this.validChange.emit(phoneNumberUtil.isValidNumber(phoneNumberUtil.parseAndKeepRawInput(fullNumber)));\n      } catch {\n        this.validChange.emit(false);\n      }\n    }\n  }\n\n  public hideDropDown(): void {\n    this.isExpanded = false;\n  }\n\n  public toggle() {\n    if (this.disabled) {\n      return;\n    }\n    this.isExpanded = !this.isExpanded;\n  }\n\n  public focusInput(): void {\n    if (this.inputElement) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n}\n","<div class=\"zen-input-container\" [style.width]=\"width\">\n    <!-- Input wrapper -->\n    <div class=\"zen-input-field-wrapper\" (click)=\"focusInput()\">\n\n        <!-- Leading dropdown: Country selector -->\n        <div class=\"zen-input-leading-dropdown\">\n            <button type=\"button\"\n                    class=\"zen-dropdown-trigger\"\n                    [disabled]=\"disabled\"\n                    (click)=\"toggle(); $event.stopPropagation()\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"selectedCountry.flag\"\n                     [alt]=\"selectedCountry.countryName\">\n                <span class=\"dropdown-label\">{{ selectedCountry.countryCallingCode }}</span>\n                <i class=\"material-icons dropdown-icon\"\n                   [ngClass]=\"{'active': isExpanded}\">expand_more</i>\n            </button>\n        </div>\n\n        <!-- Phone input field -->\n        <input #input\n               class=\"zen-input-field text text-md text-weight-regular\"\n               type=\"text\"\n               [(ngModel)]=\"phoneText\"\n               (ngModelChange)=\"phoneChanged(input)\"\n               (click)=\"isExpanded = false\"\n               [disabled]=\"disabled\"\n               country-code=\"selectedCountry.countryCode\"\n               [maxlength]=\"maxLength\">\n    </div>\n\n    <!-- Country dropdown menu -->\n    <div class=\"zen-dropdown-menu\"\n         *ngIf=\"isExpanded\"\n         [ngClass]=\"{'open': isExpanded}\">\n        <!-- Countries List -->\n        <button type=\"button\"\n                class=\"zen-dropdown-option\"\n                *ngFor=\"let country of countryList\"\n                [ngClass]=\"{'selected': selectedCountry.countryName === country.countryName}\"\n                (click)=\"countryChanged(country)\">\n            <img class=\"zen-phone-country-flag\"\n                 [src]=\"country.flag\"\n                 [alt]=\"country.countryName\">\n            <span class=\"zen-phone-country-name\">{{ country.countryName }}</span>\n            <span class=\"zen-phone-country-code\">{{ country.countryCallingCode }}</span>\n        </button>\n\n        <!-- Custom Country -->\n        <button type=\"button\"\n                class=\"zen-dropdown-option\"\n                [ngClass]=\"{'selected': selectedCountry.countryName === customCountry.countryName}\"\n                (click)=\"countryChanged(customCountry)\">\n            <img class=\"zen-phone-country-flag\"\n                 [src]=\"customCountry.flag\"\n                 [alt]=\"customCountry.countryName\">\n            <span class=\"zen-phone-country-name\">{{ customCountry.countryName }}</span>\n            <span class=\"zen-phone-country-code\">{{ customCountry.countryCallingCode }}</span>\n        </button>\n    </div>\n</div>\n\n<!-- Click outside handler for dropdown -->\n<div *ngIf=\"isExpanded\"\n     class=\"zen-dropdown-backdrop\"\n     (click)=\"hideDropDown()\"></div>\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/phone-input/zendu-phone-input.component.ts","../../../../../projects/ng-zenduit/src/lib/phone-input/zendu-phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { PhoneNumberUtil } from 'google-libphonenumber';\n\n@Component({\n  selector: 'zen-phone-input',\n  templateUrl: './zendu-phone-input.component.html',\n  styleUrls: ['./zendu-phone-input.component.scss']\n})\nexport class ZenduPhoneInputComponent implements OnInit, OnChanges {\n\n  @ViewChild('input') inputElement: ElementRef<HTMLInputElement>;\n\n  @Input() phone: string;\n\n  @Input() maxLength: number = 12;\n\n  @Output() phoneChange = new EventEmitter<string>();\n\n  @Output() validChange = new EventEmitter<boolean>();\n\n  @Input() disabled = false;\n\n  @Input() width: string;\n\n  public phoneText = \"\";\n\n  public countryList: { countryCode: string, countryName: string, countryCallingCode: string, flag: string }[] = [\n    {\n      countryCode: \"US\",\n      countryName: \"America\",\n      countryCallingCode: \"+1\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/USA.svg\"\n    },\n    {\n      countryCode: \"CA\",\n      countryName: \"Canada\",\n      countryCallingCode: \"+1\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Canada.svg\"\n    },\n    {\n      countryCode: \"MX\",\n      countryName: \"Mexico\",\n      countryCallingCode: \"+52\",\n      flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Mexico.svg\"\n    }\n  ];\n\n  public customCountry = {\n    countryCode: \"\",\n    countryName: \"Custom\",\n    countryCallingCode: \"\",\n    flag: \"https://storage.googleapis.com/zenduit-icons/Flags/Custom.svg\"\n  };\n\n  public selectedCountry: { countryCode: string, countryName: string, countryCallingCode: string, flag: string };\n\n  public isExpanded = false;\n\n  public constructor() {\n    this.selectedCountry = this.countryList[1];\n  }\n\n  public ngOnInit(): void {\n    this.parseNumber();\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"phone\"] && (!this.selectedCountry || !this.selectedCountry.countryCode)) {\n      this.parseNumber();\n    }\n  }\n\n  public parseNumber(): void {\n    try {\n      this.phoneText = this.phone || '';\n\n      if (this.phone) {\n        const countryFromList = this.countryList.find(country => this.phone.startsWith(country.countryCallingCode) || `+${this.phone}`.startsWith(country.countryCallingCode));\n        if (countryFromList) {\n          this.selectedCountry = countryFromList || this.customCountry;\n          const phoneNumberUtil = PhoneNumberUtil.getInstance();\n          const parsedPhone = phoneNumberUtil.parse(this.phone || \"\", 'US');\n          setTimeout(() => {\n            if (this.phoneText.startsWith('+')) {\n              this.phoneText = this.phoneText.replace(`+${parsedPhone.getCountryCode()}`, \"\");\n            } else if (this.phoneText.startsWith(parsedPhone.getCountryCode())) {\n              this.phoneText = this.phoneText.replace(parsedPhone.getCountryCode(), \"\");\n            }\n            this.phoneChanged();\n          });\n        } else {\n          this.selectedCountry = this.customCountry;  \n        }\n      } else {\n        this.selectedCountry = this.customCountry;\n      }\n    } catch (err) {\n      console.warn(`Can't parse phone: ${this.phone}`, err);\n      this.selectedCountry = this.customCountry;\n    }\n  }\n\n  public countryChanged(country): void {\n    this.isExpanded = false;\n    this.selectedCountry = country;\n    this.phoneChanged();\n  }\n\n  public phoneChanged(input?: HTMLInputElement): void {\n    \n    // allow + in custom country\n    let custom = false;\n    if (this.selectedCountry === this.customCountry && this.phoneText.includes('+')) {\n      custom = true;\n    }\n    \n    const phoneText = (this.phoneText || '').replace(/\\D/g, '');\n    this.phoneText = custom ? `+${phoneText}`: phoneText\n    if (input && input.value !== this.phoneText) {\n      input.value = this.phoneText;\n    }\n    const fullNumber = `${this.selectedCountry.countryCallingCode}${this.phoneText}`;\n    if (this.phone !== fullNumber) {\n      this.phoneChange.emit(fullNumber);\n    }\n    const phoneNumberUtil = PhoneNumberUtil.getInstance();\n    if (this.selectedCountry === this.customCountry) {\n      this.validChange.emit(true);\n    } else {\n      try {\n        this.validChange.emit(phoneNumberUtil.isValidNumber(phoneNumberUtil.parseAndKeepRawInput(fullNumber)));\n      } catch {\n        this.validChange.emit(false);\n      }\n    }\n  }\n\n  public hideDropDown(): void {\n    this.isExpanded = false;\n  }\n\n  public toggle() {\n    if (this.disabled) {\n      return;\n    }\n    this.isExpanded = !this.isExpanded;\n  }\n\n  public focusInput(): void {\n    if (this.inputElement) {\n      this.inputElement.nativeElement.focus();\n    }\n  }\n}\n","<div class=\"zen-input-container\" [style.width]=\"width\">\n    <!-- Input wrapper -->\n    <div class=\"zen-input-field-wrapper\" (click)=\"focusInput()\">\n\n        <!-- Leading dropdown: Country selector -->\n        <div class=\"zen-input-leading-dropdown\">\n            <button type=\"button\"\n                    class=\"zen-dropdown-trigger\"\n                    [disabled]=\"disabled\"\n                    (click)=\"toggle(); $event.stopPropagation()\">\n                <img class=\"zen-phone-country-flag\"\n                     [src]=\"selectedCountry.flag\"\n                     [alt]=\"selectedCountry.countryName\">\n                <span class=\"dropdown-label\">{{ selectedCountry.countryCallingCode }}</span>\n                <i class=\"material-icons dropdown-icon\"\n                   [ngClass]=\"{'active': isExpanded}\">expand_more</i>\n            </button>\n        </div>\n\n        <!-- Phone input field -->\n        <input #input\n               class=\"zen-input-field text text-md text-weight-regular\"\n               type=\"text\"\n               [(ngModel)]=\"phoneText\"\n               (ngModelChange)=\"phoneChanged(input)\"\n               (click)=\"isExpanded = false\"\n               [disabled]=\"disabled\"\n               country-code=\"selectedCountry.countryCode\"\n               [maxlength]=\"maxLength\">\n    </div>\n\n    <!-- Country dropdown menu -->\n    <div class=\"zen-dropdown-menu\"\n         *ngIf=\"isExpanded\"\n         [ngClass]=\"{'open': isExpanded}\">\n        <!-- Countries List -->\n        <button type=\"button\"\n                class=\"zen-dropdown-option\"\n                *ngFor=\"let country of countryList\"\n                [ngClass]=\"{'selected': selectedCountry.countryName === country.countryName}\"\n                (click)=\"countryChanged(country)\">\n            <img class=\"zen-phone-country-flag\"\n                 [src]=\"country.flag\"\n                 [alt]=\"country.countryName\">\n            <span class=\"zen-phone-country-name\">{{ country.countryName }}</span>\n            <span class=\"zen-phone-country-code\">{{ country.countryCallingCode }}</span>\n        </button>\n\n        <!-- Custom Country -->\n        <button type=\"button\"\n                class=\"zen-dropdown-option\"\n                [ngClass]=\"{'selected': selectedCountry.countryName === customCountry.countryName}\"\n                (click)=\"countryChanged(customCountry)\">\n            <img class=\"zen-phone-country-flag\"\n                 [src]=\"customCountry.flag\"\n                 [alt]=\"customCountry.countryName\">\n            <span class=\"zen-phone-country-name\">{{ customCountry.countryName }}</span>\n            <span class=\"zen-phone-country-code\">{{ customCountry.countryCallingCode }}</span>\n        </button>\n    </div>\n</div>\n\n<!-- Click outside handler for dropdown -->\n<div *ngIf=\"isExpanded\"\n     class=\"zen-dropdown-backdrop\"\n     (click)=\"hideDropDown()\"></div>\n"]}