@taiga-ui/kit
Version:
Taiga UI Angular main components kit
294 lines • 37.9 kB
JavaScript
import { __decorate, __extends, __param, __read, __spread } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, forwardRef, Inject, Input, Optional, Output, Self, TemplateRef, ViewChild, } from '@angular/core';
import { NgControl } from '@angular/forms';
import { AbstractTuiControl, getClipboardDataText, isNativeFocused, setNativeFocused, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, tuiRequiredSetter, } from '@taiga-ui/cdk';
import { formatPhone, TUI_DATA_LIST_HOST, TuiDataListDirective, TuiHostedDropdownComponent, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
import { Observable } from 'rxjs';
import { INPUT_PHONE_PROVIDERS, SELECTION_STREAM } from './input-phone.providers';
var NON_PLUS_AND_DIGITS_REGEX = /[ \-_\(\)]/g;
// @dynamic
var TuiInputPhoneComponent = /** @class */ (function (_super) {
__extends(TuiInputPhoneComponent, _super);
function TuiInputPhoneComponent(control, changeDetectorRef, selection$) {
var _this = _super.call(this, control, changeDetectorRef) || this;
_this.phoneMaskAfterCountryCode = '(###) ###-##-##';
_this.allowText = false;
_this.search = '';
_this.searchChange = new EventEmitter();
_this.textMaskOptions = {
mask: function (value) {
return _this.allowText && !_this.value && isText(value) && value !== '+'
? false
: __spread(_this.countryCode.split(''), [
' '
], _this.phoneMaskAfterCountryCode
.replace(/[^#\- \(\)]+/g, '')
.split('')
.map(function (item) { return (item === '#' ? /\d/ : item); }));
},
pipe: function (value) {
if (_this.allowText) {
return value;
}
return value === '' && _this.focused && !_this.readOnly
? _this.countryCode + " "
: value.replace(/-$/, '');
},
guide: false,
};
_this.countryCode = '+7';
_this.open = false;
selection$.subscribe(function () {
_this.setCaretPosition();
});
return _this;
}
TuiInputPhoneComponent_1 = TuiInputPhoneComponent;
Object.defineProperty(TuiInputPhoneComponent.prototype, "countryCodeSetter", {
set: function (countryCode) {
this.updateValueWithNewContryCode(countryCode);
this.countryCode = countryCode;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "nativeFocusableElement", {
get: function () {
return !this.textfield || this.computedDisabled
? null
: this.textfield.nativeFocusableElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "focused", {
get: function () {
return (isNativeFocused(this.nativeFocusableElement) ||
(!!this.dropdown && this.dropdown.focused));
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "nativeValue", {
get: function () {
return this.value
? formatPhone(this.value, this.countryCode, this.phoneMaskAfterCountryCode)
: this.search || '';
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "inputMode", {
get: function () {
return this.allowText ? "text" /* Text */ : "numeric" /* Numeric */;
},
enumerable: true,
configurable: true
});
TuiInputPhoneComponent.prototype.onHovered = function (hovered) {
this.updateHovered(hovered);
};
TuiInputPhoneComponent.prototype.onDrop = function (event) {
if (!event.dataTransfer) {
return;
}
this.setValueWithoutPrefix(event.dataTransfer.getData('text'));
event.preventDefault();
};
TuiInputPhoneComponent.prototype.onPaste = function (event) {
this.setValueWithoutPrefix(getClipboardDataText(event));
};
TuiInputPhoneComponent.prototype.onActiveZone = function (active) {
this.updateFocused(active);
if (active && !this.nativeValue && !this.readOnly && !this.allowText) {
this.updateSearch(this.countryCode);
return;
}
if (this.nativeValue === this.countryCode ||
(this.search !== null &&
isNaN(parseInt(this.search.replace(NON_PLUS_AND_DIGITS_REGEX, ''), 10)))) {
this.updateSearch('');
}
};
TuiInputPhoneComponent.prototype.onBackspace = function (event) {
if ((event.target.selectionStart || 0) <= this.nonRemovableLength &&
event.target.selectionStart === event.target.selectionEnd) {
event.preventDefault();
}
};
TuiInputPhoneComponent.prototype.onValueChange = function (value) {
var parsed = isText(value)
? value
: value.replace(NON_PLUS_AND_DIGITS_REGEX, '');
this.updateSearch(parsed);
this.updateValue(parsed === this.countryCode || isText(parsed) ? '' : parsed);
this.open = true;
};
TuiInputPhoneComponent.prototype.handleOption = function (item) {
this.focusInput();
this.updateValue(item);
this.updateSearch('');
this.open = false;
};
TuiInputPhoneComponent.prototype.setDisabledState = function () {
_super.prototype.setDisabledState.call(this);
this.open = false;
};
TuiInputPhoneComponent.prototype.writeValue = function (value) {
_super.prototype.writeValue.call(this, value);
this.updateSearch('');
};
TuiInputPhoneComponent.prototype.getFallbackValue = function () {
return '';
};
Object.defineProperty(TuiInputPhoneComponent.prototype, "caretIsInForbiddenArea", {
get: function () {
var nativeFocusableElement = this.nativeFocusableElement;
if (!nativeFocusableElement) {
return false;
}
var selectionStart = nativeFocusableElement.selectionStart, selectionEnd = nativeFocusableElement.selectionEnd;
return (isNativeFocused(nativeFocusableElement) &&
selectionStart !== null &&
selectionStart < this.nonRemovableLength &&
selectionStart === selectionEnd);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "nonRemovableLength", {
get: function () {
return this.isTextValue ? 0 : this.countryCode.length + 1;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "maxPhoneLength", {
get: function () {
return (this.countryCode.length +
this.phoneMaskAfterCountryCode.replace(/[^#]+/g, '').length);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TuiInputPhoneComponent.prototype, "isTextValue", {
get: function () {
return !!this.search && isText(this.search);
},
enumerable: true,
configurable: true
});
TuiInputPhoneComponent.prototype.setCaretPosition = function () {
if (this.caretIsInForbiddenArea && !!this.nativeFocusableElement) {
this.nativeFocusableElement.setSelectionRange(this.nonRemovableLength, this.nonRemovableLength);
}
};
TuiInputPhoneComponent.prototype.setValueWithoutPrefix = function (value) {
if (this.readOnly) {
return;
}
this.open = true;
this.updateValue(this.cleanValue(value));
this.updateSearch(this.allowText && isText(value)
? value
: value.replace(NON_PLUS_AND_DIGITS_REGEX, ''));
};
TuiInputPhoneComponent.prototype.cleanValue = function (value) {
var reg = this.countryCode === '+7'
? /^7|^8/
: new RegExp(this.countryCode.substring(1));
var oldValueExist = this.value.length > this.countryCode.length &&
this.value.length < this.maxPhoneLength;
var newValueLength = value.replace(NON_PLUS_AND_DIGITS_REGEX, '').length;
var cleanNewValue = value.replace(/[^0-9]+/g, '');
var selectionLength = getSelection().toString().length;
if (oldValueExist && selectionLength === 0) {
return ("" + this.value + cleanNewValue).slice(0, this.maxPhoneLength);
}
if (newValueLength < this.maxPhoneLength - 1) {
return ("" + this.countryCode + cleanNewValue).slice(0, this.maxPhoneLength);
}
return ("" + this.countryCode + cleanNewValue.replace(reg, '')).slice(0, this.maxPhoneLength);
};
TuiInputPhoneComponent.prototype.focusInput = function () {
if (this.nativeFocusableElement) {
setNativeFocused(this.nativeFocusableElement, true, true);
}
};
TuiInputPhoneComponent.prototype.updateSearch = function (search) {
if (this.search === search) {
return;
}
this.search = search;
this.searchChange.emit(search);
};
TuiInputPhoneComponent.prototype.updateValueWithNewContryCode = function (newCountryCode) {
if (!this.isTextValue) {
this.updateValue(this.value.replace(this.countryCode, newCountryCode));
}
};
var TuiInputPhoneComponent_1;
TuiInputPhoneComponent.ctorParameters = function () { return [
{ type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] },
{ type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] },
{ type: Observable, decorators: [{ type: Inject, args: [SELECTION_STREAM,] }] }
]; };
__decorate([
Input('countryCode'),
tuiRequiredSetter()
], TuiInputPhoneComponent.prototype, "countryCodeSetter", null);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputPhoneComponent.prototype, "phoneMaskAfterCountryCode", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputPhoneComponent.prototype, "allowText", void 0);
__decorate([
Input(),
tuiDefaultProp()
], TuiInputPhoneComponent.prototype, "search", void 0);
__decorate([
Output()
], TuiInputPhoneComponent.prototype, "searchChange", void 0);
__decorate([
ContentChild(TuiDataListDirective, { read: TemplateRef })
], TuiInputPhoneComponent.prototype, "datalist", void 0);
__decorate([
ViewChild(TuiHostedDropdownComponent)
], TuiInputPhoneComponent.prototype, "dropdown", void 0);
__decorate([
ViewChild(TuiPrimitiveTextfieldComponent)
], TuiInputPhoneComponent.prototype, "textfield", void 0);
TuiInputPhoneComponent = TuiInputPhoneComponent_1 = __decorate([
Component({
selector: 'tui-input-phone',
template: "<tui-hosted-dropdown\n class=\"hosted\"\n [content]=\"datalist || ''\"\n [(open)]=\"open\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n class=\"textfield\"\n tuiValueAccessor\n tuiTextfieldType=\"tel\"\n [tuiTextfieldInputMode]=\"inputMode\"\n [pseudoHovered]=\"pseudoHovered\"\n [pseudoFocused]=\"computedFocused\"\n [invalid]=\"computedInvalid\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"focusable\"\n [textMask]=\"textMaskOptions\"\n [value]=\"nativeValue\"\n (valueChange)=\"onValueChange($event)\"\n (hoveredChange)=\"onHovered($event)\"\n (drop)=\"onDrop($event)\"\n (keydown.backspace)=\"onBackspace($event)\"\n (paste.prevent)=\"onPaste($event)\"\n >\n <ng-content></ng-content>\n </tui-primitive-textfield>\n</tui-hosted-dropdown>\n",
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [
{
provide: TUI_FOCUSABLE_ITEM_ACCESSOR,
useExisting: forwardRef(function () { return TuiInputPhoneComponent_1; }),
},
{
provide: TUI_DATA_LIST_HOST,
useExisting: forwardRef(function () { return TuiInputPhoneComponent_1; }),
},
INPUT_PHONE_PROVIDERS,
],
styles: [":host{display:block;border-radius:var(--tui-radius-m)}:host._disabled{pointer-events:none}.hosted{display:block;border-radius:inherit}.textfield{border-radius:inherit}"]
}),
__param(0, Optional()),
__param(0, Self()),
__param(0, Inject(NgControl)),
__param(1, Inject(ChangeDetectorRef)),
__param(2, Inject(SELECTION_STREAM))
], TuiInputPhoneComponent);
return TuiInputPhoneComponent;
}(AbstractTuiControl));
export { TuiInputPhoneComponent };
function isText(value) {
return isNaN(parseInt(value.replace(NON_PLUS_AND_DIGITS_REGEX, ''), 10));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-phone/","sources":["input-phone.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    getClipboardDataText,\n    isNativeFocused,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiActiveZoneDirective,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiInputMode,\n    tuiRequiredSetter,\n} from '@taiga-ui/cdk';\nimport {\n    formatPhone,\n    TUI_DATA_LIST_HOST,\n    TuiDataListDirective,\n    TuiDataListHost,\n    TuiHostedDropdownComponent,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextMaskOptions,\n} from '@taiga-ui/core';\nimport {Observable} from 'rxjs';\nimport {INPUT_PHONE_PROVIDERS, SELECTION_STREAM} from './input-phone.providers';\n\nconst NON_PLUS_AND_DIGITS_REGEX = /[ \\-_\\(\\)]/g;\n\n// @dynamic\n@Component({\n    selector: 'tui-input-phone',\n    templateUrl: './input-phone.template.html',\n    styleUrls: ['./input-phone.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputPhoneComponent),\n        },\n        {\n            provide: TUI_DATA_LIST_HOST,\n            useExisting: forwardRef(() => TuiInputPhoneComponent),\n        },\n        INPUT_PHONE_PROVIDERS,\n    ],\n})\nexport class TuiInputPhoneComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor, TuiDataListHost<string> {\n    @Input('countryCode')\n    @tuiRequiredSetter()\n    set countryCodeSetter(countryCode: string) {\n        this.updateValueWithNewContryCode(countryCode);\n        this.countryCode = countryCode;\n    }\n\n    @Input()\n    @tuiDefaultProp()\n    phoneMaskAfterCountryCode = '(###) ###-##-##';\n\n    @Input()\n    @tuiDefaultProp()\n    allowText = false;\n\n    @Input()\n    @tuiDefaultProp()\n    search = '';\n\n    @Output()\n    readonly searchChange = new EventEmitter<string>();\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: value =>\n            this.allowText && !this.value && isText(value) && value !== '+'\n                ? false\n                : [\n                      ...this.countryCode.split(''),\n                      ' ',\n                      ...this.phoneMaskAfterCountryCode\n                          .replace(/[^#\\- \\(\\)]+/g, '')\n                          .split('')\n                          .map(item => (item === '#' ? /\\d/ : item)),\n                  ],\n        pipe: value => {\n            if (this.allowText) {\n                return value;\n            }\n\n            return value === '' && this.focused && !this.readOnly\n                ? `${this.countryCode} `\n                : value.replace(/-$/, '');\n        },\n        guide: false,\n    };\n\n    countryCode = '+7';\n\n    open = false;\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist?: TemplateRef<TuiContextWithImplicit<TuiActiveZoneDirective>>;\n\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly dropdown?: TuiHostedDropdownComponent;\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(SELECTION_STREAM)\n        selection$: Observable<unknown>,\n    ) {\n        super(control, changeDetectorRef);\n\n        selection$.subscribe(() => {\n            this.setCaretPosition();\n        });\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return !this.textfield || this.computedDisabled\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return (\n            isNativeFocused(this.nativeFocusableElement) ||\n            (!!this.dropdown && this.dropdown.focused)\n        );\n    }\n\n    get nativeValue(): string {\n        return this.value\n            ? formatPhone(this.value, this.countryCode, this.phoneMaskAfterCountryCode)\n            : this.search || '';\n    }\n\n    get inputMode(): TuiInputMode {\n        return this.allowText ? TuiInputMode.Text : TuiInputMode.Numeric;\n    }\n\n    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onDrop(event: DragEvent) {\n        if (!event.dataTransfer) {\n            return;\n        }\n\n        this.setValueWithoutPrefix(event.dataTransfer.getData('text'));\n        event.preventDefault();\n    }\n\n    onPaste(event: ClipboardEvent) {\n        this.setValueWithoutPrefix(getClipboardDataText(event));\n    }\n\n    onActiveZone(active: boolean) {\n        this.updateFocused(active);\n\n        if (active && !this.nativeValue && !this.readOnly && !this.allowText) {\n            this.updateSearch(this.countryCode);\n\n            return;\n        }\n\n        if (\n            this.nativeValue === this.countryCode ||\n            (this.search !== null &&\n                isNaN(parseInt(this.search.replace(NON_PLUS_AND_DIGITS_REGEX, ''), 10)))\n        ) {\n            this.updateSearch('');\n        }\n    }\n\n    onBackspace(event: Event & {target: HTMLInputElement}) {\n        if (\n            (event.target.selectionStart || 0) <= this.nonRemovableLength &&\n            event.target.selectionStart === event.target.selectionEnd\n        ) {\n            event.preventDefault();\n        }\n    }\n\n    onValueChange(value: string) {\n        const parsed = isText(value)\n            ? value\n            : value.replace(NON_PLUS_AND_DIGITS_REGEX, '');\n\n        this.updateSearch(parsed);\n        this.updateValue(parsed === this.countryCode || isText(parsed) ? '' : parsed);\n        this.open = true;\n    }\n\n    handleOption(item: string) {\n        this.focusInput();\n        this.updateValue(item);\n        this.updateSearch('');\n        this.open = false;\n    }\n\n    setDisabledState() {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    writeValue(value: string | null) {\n        super.writeValue(value);\n        this.updateSearch('');\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    private get caretIsInForbiddenArea(): boolean {\n        const {nativeFocusableElement} = this;\n\n        if (!nativeFocusableElement) {\n            return false;\n        }\n\n        const {selectionStart, selectionEnd} = nativeFocusableElement;\n\n        return (\n            isNativeFocused(nativeFocusableElement) &&\n            selectionStart !== null &&\n            selectionStart < this.nonRemovableLength &&\n            selectionStart === selectionEnd\n        );\n    }\n\n    private get nonRemovableLength(): number {\n        return this.isTextValue ? 0 : this.countryCode.length + 1;\n    }\n\n    private get maxPhoneLength(): number {\n        return (\n            this.countryCode.length +\n            this.phoneMaskAfterCountryCode.replace(/[^#]+/g, '').length\n        );\n    }\n\n    private get isTextValue(): boolean {\n        return !!this.search && isText(this.search);\n    }\n\n    private setCaretPosition() {\n        if (this.caretIsInForbiddenArea && !!this.nativeFocusableElement) {\n            this.nativeFocusableElement.setSelectionRange(\n                this.nonRemovableLength,\n                this.nonRemovableLength,\n            );\n        }\n    }\n\n    private setValueWithoutPrefix(value: string) {\n        if (this.readOnly) {\n            return;\n        }\n\n        this.open = true;\n        this.updateValue(this.cleanValue(value));\n        this.updateSearch(\n            this.allowText && isText(value)\n                ? value\n                : value.replace(NON_PLUS_AND_DIGITS_REGEX, ''),\n        );\n    }\n\n    private cleanValue(value: string): string {\n        const reg: RegExp =\n            this.countryCode === '+7'\n                ? /^7|^8/\n                : new RegExp(this.countryCode.substring(1));\n        const oldValueExist =\n            this.value.length > this.countryCode.length &&\n            this.value.length < this.maxPhoneLength;\n        const newValueLength = value.replace(NON_PLUS_AND_DIGITS_REGEX, '').length;\n        const cleanNewValue = value.replace(/[^0-9]+/g, '');\n        const selectionLength = getSelection()!.toString().length;\n\n        if (oldValueExist && selectionLength === 0) {\n            return `${this.value}${cleanNewValue}`.slice(0, this.maxPhoneLength);\n        }\n\n        if (newValueLength < this.maxPhoneLength - 1) {\n            return `${this.countryCode}${cleanNewValue}`.slice(0, this.maxPhoneLength);\n        }\n\n        return `${this.countryCode}${cleanNewValue.replace(reg, '')}`.slice(\n            0,\n            this.maxPhoneLength,\n        );\n    }\n\n    private focusInput() {\n        if (this.nativeFocusableElement) {\n            setNativeFocused(this.nativeFocusableElement, true, true);\n        }\n    }\n\n    private updateSearch(search: string) {\n        if (this.search === search) {\n            return;\n        }\n\n        this.search = search;\n        this.searchChange.emit(search);\n    }\n\n    private updateValueWithNewContryCode(newCountryCode: string) {\n        if (!this.isTextValue) {\n            this.updateValue(this.value.replace(this.countryCode, newCountryCode));\n        }\n    }\n}\n\nfunction isText(value: string): boolean {\n    return isNaN(parseInt(value.replace(NON_PLUS_AND_DIGITS_REGEX, ''), 10));\n}\n"]}