@taiga-ui/kit 4.47.0 → 4.48.0-canary.0b5890f
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.
- package/components/combo-box/combo-box.directive.d.ts +3 -2
- package/components/index.d.ts +1 -0
- package/components/input-chip/input-chip.directive.d.ts +6 -2
- package/components/input-date/input-date.component.d.ts +2 -1
- package/components/input-date/input-date.directive.d.ts +1 -0
- package/components/input-date-multi/input-date-multi.directive.d.ts +3 -3
- package/components/input-date-time/input-date-time.component.d.ts +2 -1
- package/components/input-month/input-month.component.d.ts +2 -1
- package/components/input-number/step/input-number-step.component.d.ts +5 -2
- package/components/input-phone/index.d.ts +2 -0
- package/components/input-phone/input-phone.directive.d.ts +27 -0
- package/components/input-phone/input-phone.options.d.ts +8 -0
- package/components/input-phone/utils/complete-phone-insertion-preprocessor.d.ts +9 -0
- package/components/input-phone/utils/create-phone-mask-expression.d.ts +7 -0
- package/components/input-time/input-time.component.d.ts +2 -1
- package/components/range/range.component.d.ts +5 -4
- package/directives/copy/copy.component.d.ts +15 -0
- package/directives/copy/copy.d.ts +3 -0
- package/directives/copy/copy.directive.d.ts +3 -3
- package/directives/copy/index.d.ts +2 -0
- package/esm2022/components/combo-box/combo-box.directive.mjs +10 -10
- package/esm2022/components/index.mjs +2 -1
- package/esm2022/components/input-chip/input-chip.directive.mjs +29 -17
- package/esm2022/components/input-date/input-date.component.mjs +5 -5
- package/esm2022/components/input-date/input-date.directive.mjs +10 -3
- package/esm2022/components/input-date-multi/input-date-multi.directive.mjs +7 -13
- package/esm2022/components/input-date-time/input-date-time.component.mjs +5 -4
- package/esm2022/components/input-month/input-month.component.mjs +5 -5
- package/esm2022/components/input-month/input-month.directive.mjs +3 -4
- package/esm2022/components/input-number/step/input-number-step.component.mjs +21 -20
- package/esm2022/components/input-phone/index.mjs +3 -0
- package/esm2022/components/input-phone/input-phone.directive.mjs +137 -0
- package/esm2022/components/input-phone/input-phone.options.mjs +9 -0
- package/esm2022/components/input-phone/taiga-ui-kit-components-input-phone.mjs +5 -0
- package/esm2022/components/input-phone/utils/complete-phone-insertion-preprocessor.mjs +41 -0
- package/esm2022/components/input-phone/utils/create-phone-mask-expression.mjs +17 -0
- package/esm2022/components/input-time/input-time.component.mjs +6 -6
- package/esm2022/components/input-time/input-time.directive.mjs +3 -4
- package/esm2022/components/range/range-change.directive.mjs +22 -20
- package/esm2022/components/range/range.component.mjs +22 -23
- package/esm2022/directives/copy/copy.component.mjs +48 -0
- package/esm2022/directives/copy/copy.directive.mjs +7 -7
- package/esm2022/directives/copy/copy.mjs +4 -0
- package/esm2022/directives/copy/copy.options.mjs +2 -4
- package/esm2022/directives/copy/index.mjs +4 -1
- package/esm2022/directives/fluid-typography/fluid-typography.options.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs +9 -9
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs +28 -17
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs +6 -12
- package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-time.mjs +3 -3
- package/fesm2022/taiga-ui-kit-components-input-date-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date.mjs +11 -5
- package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-month.mjs +4 -6
- package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-number.mjs +20 -19
- package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-phone.mjs +206 -0
- package/fesm2022/taiga-ui-kit-components-input-phone.mjs.map +1 -0
- package/fesm2022/taiga-ui-kit-components-input-time.mjs +5 -6
- package/fesm2022/taiga-ui-kit-components-input-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-range.mjs +42 -41
- package/fesm2022/taiga-ui-kit-components-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components.mjs +1 -0
- package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-directives-copy.mjs +57 -18
- package/fesm2022/taiga-ui-kit-directives-copy.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-directives-fluid-typography.mjs +1 -1
- package/fesm2022/taiga-ui-kit-directives-fluid-typography.mjs.map +1 -1
- package/package.json +20 -14
|
@@ -1,45 +1,43 @@
|
|
|
1
|
-
import { NgIf } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, computed,
|
|
1
|
+
import { DOCUMENT, NgIf } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, inject, Input, signal, ViewEncapsulation, } from '@angular/core';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
-
import { tuiZonefree } from '@taiga-ui/cdk/observables';
|
|
5
4
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
6
5
|
import { tuiClamp } from '@taiga-ui/cdk/utils/math';
|
|
7
6
|
import { TuiButton } from '@taiga-ui/core/components/button';
|
|
8
7
|
import { TUI_TEXTFIELD_OPTIONS, TuiTextfieldContent, } from '@taiga-ui/core/components/textfield';
|
|
9
|
-
import { timer } from 'rxjs';
|
|
8
|
+
import { expand, fromEvent, map, merge, Subject, switchMap, takeUntil, timer } from 'rxjs';
|
|
10
9
|
import { TuiInputNumberDirective } from '../input-number.directive';
|
|
11
10
|
import { TUI_INPUT_NUMBER_OPTIONS } from '../input-number.options';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
12
|
+
const INITIAL_DELAY = 300;
|
|
13
|
+
const DELAY_DECREMENT = 15;
|
|
14
|
+
const MIN_DELAY = 100;
|
|
13
15
|
class TuiInputNumberStep {
|
|
14
16
|
constructor() {
|
|
15
|
-
this.destroyRef = inject(DestroyRef);
|
|
16
|
-
this.zone = inject(NgZone);
|
|
17
17
|
this.el = tuiInjectElement();
|
|
18
18
|
this.appearance = inject(TUI_TEXTFIELD_OPTIONS).appearance;
|
|
19
19
|
this.options = inject(TUI_INPUT_NUMBER_OPTIONS);
|
|
20
20
|
this.input = inject(TuiInputNumberDirective, { self: true });
|
|
21
21
|
this.step = signal(this.options.step);
|
|
22
22
|
this.value = computed(() => this.input.value() ?? NaN);
|
|
23
|
+
this.step$ = new Subject();
|
|
24
|
+
this.doc = inject(DOCUMENT);
|
|
25
|
+
this.stop$ = merge(fromEvent(this.doc, 'pointerup'), fromEvent(this.doc, 'pointerleave'), fromEvent(this.doc, 'pointercancel'));
|
|
26
|
+
this.stepping = this.step$
|
|
27
|
+
.pipe(switchMap((value) => timer(INITIAL_DELAY).pipe(expand((_, index) => timer(getDelay(index))), map(() => value), takeUntil(this.stop$))), takeUntilDestroyed())
|
|
28
|
+
.subscribe((value) => this.onStep(value));
|
|
23
29
|
}
|
|
24
30
|
// TODO(v5): replace with signal input
|
|
25
31
|
set stepSetter(x) {
|
|
26
32
|
this.step.set(x);
|
|
27
33
|
}
|
|
28
34
|
onStep(step) {
|
|
29
|
-
const current =
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
timer(0)
|
|
33
|
-
.pipe(tuiZonefree(this.zone), takeUntilDestroyed(this.destroyRef))
|
|
34
|
-
.subscribe(() => {
|
|
35
|
-
const caretIndex = this.el.value.length - this.input.postfix().length;
|
|
36
|
-
this.el.setSelectionRange(caretIndex, caretIndex);
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
this.input.setValue(value);
|
|
35
|
+
const current = this.input.value() ?? 0;
|
|
36
|
+
this.input.setValue(tuiClamp(current + step, this.input.min(), this.input.max()));
|
|
37
|
+
this.el.setSelectionRange(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);
|
|
40
38
|
}
|
|
41
39
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputNumberStep, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputNumberStep, isStandalone: true, selector: "input[tuiInputNumber][step]", inputs: { stepSetter: ["step", "stepSetter"] }, host: { attributes: { "ngSkipHydration": "true" }, listeners: { "keydown.arrowDown.prevent": "onStep(-step())", "keydown.arrowUp.prevent": "onStep(step())" }, properties: { "class._with-buttons": "step()" } }, ngImport: i0, template: "<ng-container *tuiTextfieldContent>\n <section\n *ngIf=\"step()\"\n class=\"t-input-number-buttons\"\n >\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() >= input.max()\"\n [iconStart]=\"options.icons.increase\"\n (click.prevent)=\"onStep(step())\"\n (
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputNumberStep, isStandalone: true, selector: "input[tuiInputNumber][step]", inputs: { stepSetter: ["step", "stepSetter"] }, host: { attributes: { "ngSkipHydration": "true" }, listeners: { "keydown.arrowDown.prevent": "onStep(-step())", "keydown.arrowUp.prevent": "onStep(step())" }, properties: { "class._with-buttons": "step()" } }, ngImport: i0, template: "<ng-container *tuiTextfieldContent>\n <section\n *ngIf=\"step()\"\n class=\"t-input-number-buttons\"\n >\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() >= input.max()\"\n [iconStart]=\"options.icons.increase\"\n (click.prevent)=\"onStep(step())\"\n (pointerdown.prevent)=\"step$.next(step())\"\n >\n +\n </button>\n\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() <= input.min()\"\n [iconStart]=\"options.icons.decrease\"\n (click.prevent)=\"onStep(-step())\"\n (pointerdown.prevent)=\"step$.next(-step())\"\n >\n -\n </button>\n </section>\n</ng-container>\n", styles: [".t-input-number-buttons.t-input-number-buttons{position:absolute;right:0;display:flex;block-size:var(--t-height);flex-direction:column;gap:.125rem;border-radius:inherit}@supports (inset-inline-end: 0){.t-input-number-buttons.t-input-number-buttons{right:unset;inset-inline-end:0}}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons{flex-direction:row-reverse}.t-input-number-buttons.t-input-number-buttons>*{flex:1 1 0;border-radius:0}.t-input-number-buttons.t-input-number-buttons>*:first-child{border-top-right-radius:inherit}.t-input-number-buttons.t-input-number-buttons>*:last-child{border-bottom-right-radius:inherit}[dir=rtl] .t-input-number-buttons.t-input-number-buttons>*:first-child{border-radius:0;border-top-left-radius:inherit}[dir=rtl] .t-input-number-buttons.t-input-number-buttons>*:last-child{border-radius:0;border-bottom-left-radius:inherit}tui-textfield[data-size=l] .t-input-number-buttons.t-input-number-buttons>*{inline-size:var(--tui-height-m)}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons>*:first-child{border-top-right-radius:inherit;border-bottom-right-radius:inherit}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons>*:last-child{border-radius:0}[tuiInputNumber]._with-buttons{border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] [tuiInputNumber]._with-buttons{border-radius:inherit;border-top-left-radius:0;border-bottom-left-radius:0}tui-textfield[data-size=l]{--t-input-number-offset-end: calc(var(--tui-height-m) + .125rem)}tui-textfield[data-size=m]{--t-input-number-offset-end: calc(var(--tui-height-s) + .125rem)}tui-textfield[data-size=s]{--t-input-number-offset-end: calc(2 * var(--tui-height-s) + .25rem)}[tuiInputNumber]._with-buttons,[tuiInputNumber]._with-buttons~.t-template{inline-size:calc(100% - var(--t-input-number-offset-end));margin-inline-end:var(--t-input-number-offset-end)}[tuiInputNumber]._with-buttons~.t-content{margin-inline-end:var(--t-input-number-offset-end)}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiTextfieldContent, selector: "ng-template[tuiTextfieldContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
43
41
|
}
|
|
44
42
|
export { TuiInputNumberStep };
|
|
45
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputNumberStep, decorators: [{
|
|
@@ -49,9 +47,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
49
47
|
'(keydown.arrowDown.prevent)': 'onStep(-step())',
|
|
50
48
|
'(keydown.arrowUp.prevent)': 'onStep(step())',
|
|
51
49
|
'[class._with-buttons]': 'step()',
|
|
52
|
-
}, template: "<ng-container *tuiTextfieldContent>\n <section\n *ngIf=\"step()\"\n class=\"t-input-number-buttons\"\n >\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() >= input.max()\"\n [iconStart]=\"options.icons.increase\"\n (click.prevent)=\"onStep(step())\"\n (
|
|
50
|
+
}, template: "<ng-container *tuiTextfieldContent>\n <section\n *ngIf=\"step()\"\n class=\"t-input-number-buttons\"\n >\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() >= input.max()\"\n [iconStart]=\"options.icons.increase\"\n (click.prevent)=\"onStep(step())\"\n (pointerdown.prevent)=\"step$.next(step())\"\n >\n +\n </button>\n\n <button\n size=\"s\"\n tabindex=\"-1\"\n tuiIconButton\n type=\"button\"\n class=\"t-button\"\n [appearance]=\"appearance()\"\n [disabled]=\"!input.interactive() || value() <= input.min()\"\n [iconStart]=\"options.icons.decrease\"\n (click.prevent)=\"onStep(-step())\"\n (pointerdown.prevent)=\"step$.next(-step())\"\n >\n -\n </button>\n </section>\n</ng-container>\n", styles: [".t-input-number-buttons.t-input-number-buttons{position:absolute;right:0;display:flex;block-size:var(--t-height);flex-direction:column;gap:.125rem;border-radius:inherit}@supports (inset-inline-end: 0){.t-input-number-buttons.t-input-number-buttons{right:unset;inset-inline-end:0}}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons{flex-direction:row-reverse}.t-input-number-buttons.t-input-number-buttons>*{flex:1 1 0;border-radius:0}.t-input-number-buttons.t-input-number-buttons>*:first-child{border-top-right-radius:inherit}.t-input-number-buttons.t-input-number-buttons>*:last-child{border-bottom-right-radius:inherit}[dir=rtl] .t-input-number-buttons.t-input-number-buttons>*:first-child{border-radius:0;border-top-left-radius:inherit}[dir=rtl] .t-input-number-buttons.t-input-number-buttons>*:last-child{border-radius:0;border-bottom-left-radius:inherit}tui-textfield[data-size=l] .t-input-number-buttons.t-input-number-buttons>*{inline-size:var(--tui-height-m)}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons>*:first-child{border-top-right-radius:inherit;border-bottom-right-radius:inherit}tui-textfield[data-size=s] .t-input-number-buttons.t-input-number-buttons>*:last-child{border-radius:0}[tuiInputNumber]._with-buttons{border-top-right-radius:0;border-bottom-right-radius:0}[dir=rtl] [tuiInputNumber]._with-buttons{border-radius:inherit;border-top-left-radius:0;border-bottom-left-radius:0}tui-textfield[data-size=l]{--t-input-number-offset-end: calc(var(--tui-height-m) + .125rem)}tui-textfield[data-size=m]{--t-input-number-offset-end: calc(var(--tui-height-s) + .125rem)}tui-textfield[data-size=s]{--t-input-number-offset-end: calc(2 * var(--tui-height-s) + .25rem)}[tuiInputNumber]._with-buttons,[tuiInputNumber]._with-buttons~.t-template{inline-size:calc(100% - var(--t-input-number-offset-end));margin-inline-end:var(--t-input-number-offset-end)}[tuiInputNumber]._with-buttons~.t-content{margin-inline-end:var(--t-input-number-offset-end)}\n"] }]
|
|
53
51
|
}], propDecorators: { stepSetter: [{
|
|
54
52
|
type: Input,
|
|
55
53
|
args: ['step']
|
|
56
54
|
}] } });
|
|
57
|
-
|
|
55
|
+
function getDelay(index) {
|
|
56
|
+
return Math.max(INITIAL_DELAY - index * DELAY_DECREMENT, MIN_DELAY);
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number-step.component.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/input-number/step/input-number-step.component.ts","../../../../../../projects/kit/components/input-number/step/input-number-step.template.html"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp} from '@taiga-ui/cdk/utils/math';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {\n    TUI_TEXTFIELD_OPTIONS,\n    TuiTextfieldContent,\n} from '@taiga-ui/core/components/textfield';\nimport {expand, fromEvent, map, merge, Subject, switchMap, takeUntil, timer} from 'rxjs';\n\nimport {TuiInputNumberDirective} from '../input-number.directive';\nimport type {TuiInputNumberOptions} from '../input-number.options';\nimport {TUI_INPUT_NUMBER_OPTIONS} from '../input-number.options';\n\nconst INITIAL_DELAY = 300;\nconst DELAY_DECREMENT = 15;\nconst MIN_DELAY = 100;\n\n@Component({\n    standalone: true,\n    selector: 'input[tuiInputNumber][step]',\n    imports: [NgIf, TuiButton, TuiTextfieldContent],\n    templateUrl: './input-number-step.template.html',\n    styleUrls: ['./input-number-step.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        ngSkipHydration: 'true',\n        '(keydown.arrowDown.prevent)': 'onStep(-step())',\n        '(keydown.arrowUp.prevent)': 'onStep(step())',\n        '[class._with-buttons]': 'step()',\n    },\n})\nexport class TuiInputNumberStep {\n    protected readonly el = tuiInjectElement<HTMLInputElement>();\n    protected readonly appearance = inject(TUI_TEXTFIELD_OPTIONS).appearance;\n    protected readonly options = inject<TuiInputNumberOptions>(TUI_INPUT_NUMBER_OPTIONS);\n    protected readonly input = inject(TuiInputNumberDirective, {self: true});\n    protected readonly step = signal(this.options.step);\n    protected readonly value = computed(() => this.input.value() ?? NaN);\n    protected readonly step$ = new Subject<number>();\n    protected readonly doc = inject(DOCUMENT);\n\n    protected readonly stop$ = merge(\n        fromEvent(this.doc, 'pointerup'),\n        fromEvent(this.doc, 'pointerleave'),\n        fromEvent(this.doc, 'pointercancel'),\n    );\n\n    protected readonly stepping = this.step$\n        .pipe(\n            switchMap((value) =>\n                timer(INITIAL_DELAY).pipe(\n                    expand((_, index) => timer(getDelay(index))),\n                    map(() => value),\n                    takeUntil(this.stop$),\n                ),\n            ),\n            takeUntilDestroyed(),\n        )\n        .subscribe((value) => this.onStep(value));\n\n    // TODO(v5): replace with signal input\n    @Input('step')\n    public set stepSetter(x: number) {\n        this.step.set(x);\n    }\n\n    protected onStep(step: number): void {\n        const current = this.input.value() ?? 0;\n\n        this.input.setValue(tuiClamp(current + step, this.input.min(), this.input.max()));\n        this.el.setSelectionRange(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);\n    }\n}\n\nfunction getDelay(index: number): number {\n    return Math.max(INITIAL_DELAY - index * DELAY_DECREMENT, MIN_DELAY);\n}\n","<ng-container *tuiTextfieldContent>\n    <section\n        *ngIf=\"step()\"\n        class=\"t-input-number-buttons\"\n    >\n        <button\n            size=\"s\"\n            tabindex=\"-1\"\n            tuiIconButton\n            type=\"button\"\n            class=\"t-button\"\n            [appearance]=\"appearance()\"\n            [disabled]=\"!input.interactive() || value() >= input.max()\"\n            [iconStart]=\"options.icons.increase\"\n            (click.prevent)=\"onStep(step())\"\n            (pointerdown.prevent)=\"step$.next(step())\"\n        >\n            +\n        </button>\n\n        <button\n            size=\"s\"\n            tabindex=\"-1\"\n            tuiIconButton\n            type=\"button\"\n            class=\"t-button\"\n            [appearance]=\"appearance()\"\n            [disabled]=\"!input.interactive() || value() <= input.min()\"\n            [iconStart]=\"options.icons.decrease\"\n            (click.prevent)=\"onStep(-step())\"\n            (pointerdown.prevent)=\"step$.next(-step())\"\n        >\n            -\n        </button>\n    </section>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './input-phone.directive';
|
|
2
|
+
export * from './input-phone.options';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1waG9uZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2lucHV0LXBob25lLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXBob25lLm9wdGlvbnMnO1xuIl19
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { computed, Directive, effect, inject, Input, signal, untracked, } from '@angular/core';
|
|
2
|
+
import { MaskitoDirective } from '@maskito/angular';
|
|
3
|
+
import { MASKITO_DEFAULT_OPTIONS, maskitoTransform } from '@maskito/core';
|
|
4
|
+
import { maskitoCaretGuard, maskitoPrefixPostprocessorGenerator } from '@maskito/kit';
|
|
5
|
+
import { tuiAsControl, TuiControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
|
|
6
|
+
import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants';
|
|
7
|
+
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
8
|
+
import { TuiTextfieldComponent, TuiTextfieldDirective, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
9
|
+
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
10
|
+
import { TUI_INPUT_PHONE_OPTIONS } from './input-phone.options';
|
|
11
|
+
import { tuiCreateCompletePhoneInsertionPreprocessor } from './utils/complete-phone-insertion-preprocessor';
|
|
12
|
+
import { tuiCreatePhoneMaskExpression } from './utils/create-phone-mask-expression';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
15
|
+
import * as i2 from "@maskito/angular";
|
|
16
|
+
const MASK_SYMBOLS = /[ \-_()]/g;
|
|
17
|
+
function isText(value) {
|
|
18
|
+
return Number.isNaN(parseInt(value.replaceAll(MASK_SYMBOLS, ''), 10));
|
|
19
|
+
}
|
|
20
|
+
class TuiInputPhone extends TuiControl {
|
|
21
|
+
constructor() {
|
|
22
|
+
super(...arguments);
|
|
23
|
+
this.textfield = inject(TuiTextfieldDirective);
|
|
24
|
+
this.host = inject(TuiTextfieldComponent);
|
|
25
|
+
this.nonRemovablePrefix = computed(() => `${this.countryCode()} `);
|
|
26
|
+
this.inputMode = computed(() => (this.allowText() ? 'text' : 'numeric'));
|
|
27
|
+
this.valueEffect = effect(() => {
|
|
28
|
+
const value = this.value() ?? '';
|
|
29
|
+
if (!value) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
this.textfield.value.set(maskitoTransform(value, this.mask()));
|
|
33
|
+
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
34
|
+
this.blurEffect = effect(() => {
|
|
35
|
+
const incomplete = untracked(() => !this.value());
|
|
36
|
+
if (!this.host.focused() && incomplete) {
|
|
37
|
+
this.textfield.value.set('');
|
|
38
|
+
}
|
|
39
|
+
if (this.host.focused() && incomplete && !this.allowText()) {
|
|
40
|
+
this.textfield.value.set(this.nonRemovablePrefix());
|
|
41
|
+
}
|
|
42
|
+
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
43
|
+
this.options = inject(TUI_INPUT_PHONE_OPTIONS);
|
|
44
|
+
this.el = tuiInjectElement();
|
|
45
|
+
this.mask = computed(() => this.calculateMask(this.countryCode(), this.phoneMask(), this.nonRemovablePrefix(), this.allowText()));
|
|
46
|
+
this.maskito = tuiMaskito(computed(() => this.mask()));
|
|
47
|
+
this.countryCode = signal(extractCountryCode(this.options.mask));
|
|
48
|
+
this.allowText = signal(this.options.allowText);
|
|
49
|
+
this.phoneMask = signal(extractMask(this.options.mask));
|
|
50
|
+
}
|
|
51
|
+
// TODO(v5): replace with signal input
|
|
52
|
+
set allowTextSetter(allow) {
|
|
53
|
+
this.allowText.set(allow);
|
|
54
|
+
}
|
|
55
|
+
// TODO(v5): replace with signal input
|
|
56
|
+
set maskSetter(mask) {
|
|
57
|
+
this.countryCode.set(extractCountryCode(mask));
|
|
58
|
+
this.phoneMask.set(extractMask(mask));
|
|
59
|
+
}
|
|
60
|
+
onInput(value) {
|
|
61
|
+
if (!value && !this.allowText()) {
|
|
62
|
+
this.textfield.value.set(this.nonRemovablePrefix());
|
|
63
|
+
}
|
|
64
|
+
const parsed = isText(value)
|
|
65
|
+
? value
|
|
66
|
+
: value.replaceAll(MASK_SYMBOLS, '').slice(0, this.maxPhoneLength);
|
|
67
|
+
this.onChange(parsed === this.countryCode() || isText(parsed) ? '' : parsed);
|
|
68
|
+
}
|
|
69
|
+
get maxPhoneLength() {
|
|
70
|
+
return (this.countryCode().length + this.phoneMask().replaceAll(/[^#]+/g, '').length);
|
|
71
|
+
}
|
|
72
|
+
calculateMask(countryCode, phoneMaskAfterCountryCode, nonRemovablePrefix, allowText) {
|
|
73
|
+
const mask = tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode);
|
|
74
|
+
const preprocessors = [
|
|
75
|
+
tuiCreateCompletePhoneInsertionPreprocessor(countryCode, phoneMaskAfterCountryCode),
|
|
76
|
+
];
|
|
77
|
+
return allowText
|
|
78
|
+
? {
|
|
79
|
+
mask: ({ value }) => isText(value) && value !== '+'
|
|
80
|
+
? MASKITO_DEFAULT_OPTIONS.mask
|
|
81
|
+
: mask,
|
|
82
|
+
preprocessors,
|
|
83
|
+
}
|
|
84
|
+
: {
|
|
85
|
+
mask,
|
|
86
|
+
preprocessors,
|
|
87
|
+
postprocessors: [
|
|
88
|
+
maskitoPrefixPostprocessorGenerator(nonRemovablePrefix),
|
|
89
|
+
],
|
|
90
|
+
plugins: [
|
|
91
|
+
maskitoCaretGuard((value, [from, to]) => [
|
|
92
|
+
from === to ? nonRemovablePrefix.length : 0,
|
|
93
|
+
value.length,
|
|
94
|
+
]),
|
|
95
|
+
],
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputPhone, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
99
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputPhone, isStandalone: true, selector: "input[tuiInputPhone]", inputs: { allowTextSetter: ["allowText", "allowTextSetter"], maskSetter: ["mask", "maskSetter"] }, host: { attributes: { "type": "tel" }, listeners: { "input": "onInput($event.target.value)" }, properties: { "inputMode": "inputMode()", "disabled": "disabled()" } }, providers: [
|
|
100
|
+
tuiAsControl(TuiInputPhone),
|
|
101
|
+
tuiValueTransformerFrom(TUI_INPUT_PHONE_OPTIONS),
|
|
102
|
+
], usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithTextfield }, { directive: i2.MaskitoDirective }], ngImport: i0 }); }
|
|
103
|
+
}
|
|
104
|
+
export { TuiInputPhone };
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputPhone, decorators: [{
|
|
106
|
+
type: Directive,
|
|
107
|
+
args: [{
|
|
108
|
+
standalone: true,
|
|
109
|
+
selector: 'input[tuiInputPhone]',
|
|
110
|
+
providers: [
|
|
111
|
+
tuiAsControl(TuiInputPhone),
|
|
112
|
+
tuiValueTransformerFrom(TUI_INPUT_PHONE_OPTIONS),
|
|
113
|
+
],
|
|
114
|
+
hostDirectives: [TuiWithTextfield, MaskitoDirective],
|
|
115
|
+
host: {
|
|
116
|
+
type: 'tel',
|
|
117
|
+
'[inputMode]': 'inputMode()',
|
|
118
|
+
'[disabled]': 'disabled()',
|
|
119
|
+
'(input)': 'onInput($event.target.value)',
|
|
120
|
+
},
|
|
121
|
+
}]
|
|
122
|
+
}], propDecorators: { allowTextSetter: [{
|
|
123
|
+
type: Input,
|
|
124
|
+
args: ['allowText']
|
|
125
|
+
}], maskSetter: [{
|
|
126
|
+
type: Input,
|
|
127
|
+
args: ['mask']
|
|
128
|
+
}] } });
|
|
129
|
+
function extractCountryCode(mask) {
|
|
130
|
+
const match = /^(\+\d+)/.exec(mask);
|
|
131
|
+
return match?.[1] || '';
|
|
132
|
+
}
|
|
133
|
+
function extractMask(mask) {
|
|
134
|
+
const match = /^\+\d+(.*)$/.exec(mask);
|
|
135
|
+
return match?.[1]?.trim() || '';
|
|
136
|
+
}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-phone.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-phone/input-phone.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {MaskitoDirective} from '@maskito/angular';\nimport type {MaskitoOptions} from '@maskito/core';\nimport {MASKITO_DEFAULT_OPTIONS, maskitoTransform} from '@maskito/core';\nimport {maskitoCaretGuard, maskitoPrefixPostprocessorGenerator} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_PHONE_OPTIONS} from './input-phone.options';\nimport {tuiCreateCompletePhoneInsertionPreprocessor} from './utils/complete-phone-insertion-preprocessor';\nimport {tuiCreatePhoneMaskExpression} from './utils/create-phone-mask-expression';\n\nconst MASK_SYMBOLS = /[ \\-_()]/g;\n\nfunction isText(value: string): boolean {\n    return Number.isNaN(parseInt(value.replaceAll(MASK_SYMBOLS, ''), 10));\n}\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputPhone]',\n    providers: [\n        tuiAsControl(TuiInputPhone),\n        tuiValueTransformerFrom(TUI_INPUT_PHONE_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective],\n    host: {\n        type: 'tel',\n        '[inputMode]': 'inputMode()',\n        '[disabled]': 'disabled()',\n        '(input)': 'onInput($event.target.value)',\n    },\n})\nexport class TuiInputPhone extends TuiControl<string | null> {\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly host: TuiTextfieldComponent<string> = inject(TuiTextfieldComponent);\n\n    protected readonly nonRemovablePrefix = computed(() => `${this.countryCode()} `);\n    protected inputMode = computed(() => (this.allowText() ? 'text' : 'numeric'));\n\n    protected readonly valueEffect = effect(() => {\n        const value = this.value() ?? '';\n\n        if (!value) {\n            return;\n        }\n\n        this.textfield.value.set(maskitoTransform(value, this.mask()));\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly blurEffect = effect(() => {\n        const incomplete = untracked(() => !this.value());\n\n        if (!this.host.focused() && incomplete) {\n            this.textfield.value.set('');\n        }\n\n        if (this.host.focused() && incomplete && !this.allowText()) {\n            this.textfield.value.set(this.nonRemovablePrefix());\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly options = inject(TUI_INPUT_PHONE_OPTIONS);\n    protected readonly el = tuiInjectElement<HTMLInputElement>();\n\n    protected readonly mask = computed(() =>\n        this.calculateMask(\n            this.countryCode(),\n            this.phoneMask(),\n            this.nonRemovablePrefix(),\n            this.allowText(),\n        ),\n    );\n\n    protected readonly maskito = tuiMaskito(computed(() => this.mask()));\n\n    public readonly countryCode = signal(extractCountryCode(this.options.mask));\n    public readonly allowText = signal(this.options.allowText);\n    public readonly phoneMask = signal(extractMask(this.options.mask));\n\n    // TODO(v5): replace with signal input\n    @Input('allowText')\n    public set allowTextSetter(allow: boolean) {\n        this.allowText.set(allow);\n    }\n\n    // TODO(v5): replace with signal input\n    @Input('mask')\n    public set maskSetter(mask: string) {\n        this.countryCode.set(extractCountryCode(mask));\n        this.phoneMask.set(extractMask(mask));\n    }\n\n    protected onInput(value: string): void {\n        if (!value && !this.allowText()) {\n            this.textfield.value.set(this.nonRemovablePrefix());\n        }\n\n        const parsed = isText(value)\n            ? value\n            : value.replaceAll(MASK_SYMBOLS, '').slice(0, this.maxPhoneLength);\n\n        this.onChange(parsed === this.countryCode() || isText(parsed) ? '' : parsed);\n    }\n\n    private get maxPhoneLength(): number {\n        return (\n            this.countryCode().length + this.phoneMask().replaceAll(/[^#]+/g, '').length\n        );\n    }\n\n    private calculateMask(\n        countryCode: string,\n        phoneMaskAfterCountryCode: string,\n        nonRemovablePrefix: string,\n        allowText: boolean,\n    ): MaskitoOptions {\n        const mask = tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode);\n        const preprocessors = [\n            tuiCreateCompletePhoneInsertionPreprocessor(\n                countryCode,\n                phoneMaskAfterCountryCode,\n            ),\n        ];\n\n        return allowText\n            ? {\n                  mask: ({value}) =>\n                      isText(value) && value !== '+'\n                          ? (MASKITO_DEFAULT_OPTIONS.mask as RegExp)\n                          : mask,\n                  preprocessors,\n              }\n            : {\n                  mask,\n                  preprocessors,\n                  postprocessors: [\n                      maskitoPrefixPostprocessorGenerator(nonRemovablePrefix),\n                  ],\n                  plugins: [\n                      maskitoCaretGuard((value, [from, to]) => [\n                          from === to ? nonRemovablePrefix.length : 0,\n                          value.length,\n                      ]),\n                  ],\n              };\n    }\n}\n\nfunction extractCountryCode(mask: string): string {\n    const match = /^(\\+\\d+)/.exec(mask);\n\n    return match?.[1] || '';\n}\n\nfunction extractMask(mask: string): string {\n    const match = /^\\+\\d+(.*)$/.exec(mask);\n\n    return match?.[1]?.trim() || '';\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TUI_IDENTITY_VALUE_TRANSFORMER } from '@taiga-ui/cdk/classes';
|
|
2
|
+
import { tuiCreateOptions } from '@taiga-ui/cdk/utils/di';
|
|
3
|
+
export const TUI_INPUT_PHONE_DEFAULT_OPTIONS = {
|
|
4
|
+
mask: '+1 ### ###-####',
|
|
5
|
+
allowText: false,
|
|
6
|
+
valueTransformer: TUI_IDENTITY_VALUE_TRANSFORMER,
|
|
7
|
+
};
|
|
8
|
+
export const [TUI_INPUT_PHONE_OPTIONS, tuiInputPhoneOptionsProvider] = tuiCreateOptions(TUI_INPUT_PHONE_DEFAULT_OPTIONS);
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtcGhvbmUub3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lL2lucHV0LXBob25lLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDckUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFReEQsTUFBTSxDQUFDLE1BQU0sK0JBQStCLEdBQXlCO0lBQ2pFLElBQUksRUFBRSxpQkFBaUI7SUFDdkIsU0FBUyxFQUFFLEtBQUs7SUFDaEIsZ0JBQWdCLEVBQUUsOEJBQThCO0NBQ25ELENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxDQUFDLHVCQUF1QixFQUFFLDRCQUE0QixDQUFDLEdBQUcsZ0JBQWdCLENBQ25GLCtCQUErQixDQUNsQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1R1aVZhbHVlVHJhbnNmb3JtZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvY2xhc3Nlcyc7XG5pbXBvcnQge1RVSV9JREVOVElUWV9WQUxVRV9UUkFOU0ZPUk1FUn0gZnJvbSAnQHRhaWdhLXVpL2Nkay9jbGFzc2VzJztcbmltcG9ydCB7dHVpQ3JlYXRlT3B0aW9uc30gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9kaSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpSW5wdXRQaG9uZU9wdGlvbnMge1xuICAgIHJlYWRvbmx5IGFsbG93VGV4dDogYm9vbGVhbjtcbiAgICByZWFkb25seSBtYXNrOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdmFsdWVUcmFuc2Zvcm1lcjogVHVpVmFsdWVUcmFuc2Zvcm1lcjxzdHJpbmcgfCBudWxsLCBhbnk+O1xufVxuXG5leHBvcnQgY29uc3QgVFVJX0lOUFVUX1BIT05FX0RFRkFVTFRfT1BUSU9OUzogVHVpSW5wdXRQaG9uZU9wdGlvbnMgPSB7XG4gICAgbWFzazogJysxICMjIyAjIyMtIyMjIycsXG4gICAgYWxsb3dUZXh0OiBmYWxzZSxcbiAgICB2YWx1ZVRyYW5zZm9ybWVyOiBUVUlfSURFTlRJVFlfVkFMVUVfVFJBTlNGT1JNRVIsXG59O1xuXG5leHBvcnQgY29uc3QgW1RVSV9JTlBVVF9QSE9ORV9PUFRJT05TLCB0dWlJbnB1dFBob25lT3B0aW9uc1Byb3ZpZGVyXSA9IHR1aUNyZWF0ZU9wdGlvbnMoXG4gICAgVFVJX0lOUFVUX1BIT05FX0RFRkFVTFRfT1BUSU9OUyxcbik7XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtaW5wdXQtcGhvbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1waG9uZS90YWlnYS11aS1raXQtY29tcG9uZW50cy1pbnB1dC1waG9uZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
const countDigits = (value) => value.replaceAll(/\D/g, '').length;
|
|
2
|
+
/**
|
|
3
|
+
* `InputPhone` component sets country code as non-removable prefix.
|
|
4
|
+
* This prefix appears on focus and cannot be erased.
|
|
5
|
+
* But users sometimes can copy complete phone number (from any different source)
|
|
6
|
+
* and try to insert the whole string inside our `InputPhone` textfield.
|
|
7
|
+
* This preprocessor helps to avoid country prefix duplication on paste/drop/autofill events.
|
|
8
|
+
*/
|
|
9
|
+
export function tuiCreateCompletePhoneInsertionPreprocessor(countryCode, phoneMaskAfterCountryCode) {
|
|
10
|
+
const completePhoneLength = (countryCode + phoneMaskAfterCountryCode).replaceAll(/[^#\d]+/g, '').length;
|
|
11
|
+
const trimCountryPrefix = (value) => countryCode === '+7'
|
|
12
|
+
? value.replace(/^(\+?\s*7?\s?8?)\s?/, '')
|
|
13
|
+
: value.replace(new RegExp(`^(\\+?\\s*${countryCode.replace('+', '')}?)\\s?`), '');
|
|
14
|
+
return ({ elementState, data }) => {
|
|
15
|
+
const { value, selection } = elementState;
|
|
16
|
+
return {
|
|
17
|
+
elementState: {
|
|
18
|
+
selection,
|
|
19
|
+
value:
|
|
20
|
+
/**
|
|
21
|
+
* The only possible case when `value` includes digits more
|
|
22
|
+
* than mask expression allows – browser autofill.
|
|
23
|
+
* It means that we are inside `input`-event
|
|
24
|
+
* and mask are ready to reject "extra" characters.
|
|
25
|
+
* We should cut leading country prefix to save trailing characters!
|
|
26
|
+
*/
|
|
27
|
+
countDigits(value) > completePhoneLength
|
|
28
|
+
? trimCountryPrefix(value)
|
|
29
|
+
: value,
|
|
30
|
+
},
|
|
31
|
+
data: countDigits(data) >= completePhoneLength || data.startsWith(countryCode)
|
|
32
|
+
? /**
|
|
33
|
+
* User tries to insert/drop the complete phone number (with country prefix).
|
|
34
|
+
* We should drop already existing non-removable prefix.
|
|
35
|
+
*/
|
|
36
|
+
trimCountryPrefix(data)
|
|
37
|
+
: data,
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGxldGUtcGhvbmUtaW5zZXJ0aW9uLXByZXByb2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lL3V0aWxzL2NvbXBsZXRlLXBob25lLWluc2VydGlvbi1wcmVwcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxXQUFXLEdBQUcsQ0FBQyxLQUFhLEVBQVUsRUFBRSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQztBQUVsRjs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsMkNBQTJDLENBQ3ZELFdBQW1CLEVBQ25CLHlCQUFpQztJQUVqQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsV0FBVyxHQUFHLHlCQUF5QixDQUFDLENBQUMsVUFBVSxDQUM1RSxVQUFVLEVBQ1YsRUFBRSxDQUNMLENBQUMsTUFBTSxDQUFDO0lBRVQsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLEtBQWEsRUFBVSxFQUFFLENBQ2hELFdBQVcsS0FBSyxJQUFJO1FBQ2hCLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLHFCQUFxQixFQUFFLEVBQUUsQ0FBQztRQUMxQyxDQUFDLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FDVCxJQUFJLE1BQU0sQ0FBQyxhQUFhLFdBQVcsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFDN0QsRUFBRSxDQUNMLENBQUM7SUFFWixPQUFPLENBQUMsRUFBQyxZQUFZLEVBQUUsSUFBSSxFQUFDLEVBQUUsRUFBRTtRQUM1QixNQUFNLEVBQUMsS0FBSyxFQUFFLFNBQVMsRUFBQyxHQUFHLFlBQVksQ0FBQztRQUV4QyxPQUFPO1lBQ0gsWUFBWSxFQUFFO2dCQUNWLFNBQVM7Z0JBQ1QsS0FBSztnQkFDRDs7Ozs7O21CQU1HO2dCQUNILFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxtQkFBbUI7b0JBQ3BDLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUM7b0JBQzFCLENBQUMsQ0FBQyxLQUFLO2FBQ2xCO1lBQ0QsSUFBSSxFQUNBLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxtQkFBbUIsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQztnQkFDcEUsQ0FBQyxDQUFDOzs7cUJBR0c7b0JBQ0gsaUJBQWlCLENBQUMsSUFBSSxDQUFDO2dCQUN6QixDQUFDLENBQUMsSUFBSTtTQUNqQixDQUFDO0lBQ04sQ0FBQyxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtNYXNraXRvUHJlcHJvY2Vzc29yfSBmcm9tICdAbWFza2l0by9jb3JlJztcblxuY29uc3QgY291bnREaWdpdHMgPSAodmFsdWU6IHN0cmluZyk6IG51bWJlciA9PiB2YWx1ZS5yZXBsYWNlQWxsKC9cXEQvZywgJycpLmxlbmd0aDtcblxuLyoqXG4gKiBgSW5wdXRQaG9uZWAgY29tcG9uZW50IHNldHMgY291bnRyeSBjb2RlIGFzIG5vbi1yZW1vdmFibGUgcHJlZml4LlxuICogVGhpcyBwcmVmaXggYXBwZWFycyBvbiBmb2N1cyBhbmQgY2Fubm90IGJlIGVyYXNlZC5cbiAqIEJ1dCB1c2VycyBzb21ldGltZXMgY2FuIGNvcHkgY29tcGxldGUgcGhvbmUgbnVtYmVyIChmcm9tIGFueSBkaWZmZXJlbnQgc291cmNlKVxuICogYW5kIHRyeSB0byBpbnNlcnQgdGhlIHdob2xlIHN0cmluZyBpbnNpZGUgb3VyIGBJbnB1dFBob25lYCB0ZXh0ZmllbGQuXG4gKiBUaGlzIHByZXByb2Nlc3NvciBoZWxwcyB0byBhdm9pZCBjb3VudHJ5IHByZWZpeCBkdXBsaWNhdGlvbiBvbiBwYXN0ZS9kcm9wL2F1dG9maWxsIGV2ZW50cy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHR1aUNyZWF0ZUNvbXBsZXRlUGhvbmVJbnNlcnRpb25QcmVwcm9jZXNzb3IoXG4gICAgY291bnRyeUNvZGU6IHN0cmluZyxcbiAgICBwaG9uZU1hc2tBZnRlckNvdW50cnlDb2RlOiBzdHJpbmcsXG4pOiBNYXNraXRvUHJlcHJvY2Vzc29yIHtcbiAgICBjb25zdCBjb21wbGV0ZVBob25lTGVuZ3RoID0gKGNvdW50cnlDb2RlICsgcGhvbmVNYXNrQWZ0ZXJDb3VudHJ5Q29kZSkucmVwbGFjZUFsbChcbiAgICAgICAgL1teI1xcZF0rL2csXG4gICAgICAgICcnLFxuICAgICkubGVuZ3RoO1xuXG4gICAgY29uc3QgdHJpbUNvdW50cnlQcmVmaXggPSAodmFsdWU6IHN0cmluZyk6IHN0cmluZyA9PlxuICAgICAgICBjb3VudHJ5Q29kZSA9PT0gJys3J1xuICAgICAgICAgICAgPyB2YWx1ZS5yZXBsYWNlKC9eKFxcKz9cXHMqNz9cXHM/OD8pXFxzPy8sICcnKVxuICAgICAgICAgICAgOiB2YWx1ZS5yZXBsYWNlKFxuICAgICAgICAgICAgICAgICAgbmV3IFJlZ0V4cChgXihcXFxcKz9cXFxccyoke2NvdW50cnlDb2RlLnJlcGxhY2UoJysnLCAnJyl9PylcXFxccz9gKSxcbiAgICAgICAgICAgICAgICAgICcnLFxuICAgICAgICAgICAgICApO1xuXG4gICAgcmV0dXJuICh7ZWxlbWVudFN0YXRlLCBkYXRhfSkgPT4ge1xuICAgICAgICBjb25zdCB7dmFsdWUsIHNlbGVjdGlvbn0gPSBlbGVtZW50U3RhdGU7XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIGVsZW1lbnRTdGF0ZToge1xuICAgICAgICAgICAgICAgIHNlbGVjdGlvbixcbiAgICAgICAgICAgICAgICB2YWx1ZTpcbiAgICAgICAgICAgICAgICAgICAgLyoqXG4gICAgICAgICAgICAgICAgICAgICAqIFRoZSBvbmx5IHBvc3NpYmxlIGNhc2Ugd2hlbiBgdmFsdWVgIGluY2x1ZGVzIGRpZ2l0cyBtb3JlXG4gICAgICAgICAgICAgICAgICAgICAqIHRoYW4gbWFzayBleHByZXNzaW9uIGFsbG93cyDigJMgYnJvd3NlciBhdXRvZmlsbC5cbiAgICAgICAgICAgICAgICAgICAgICogSXQgbWVhbnMgdGhhdCB3ZSBhcmUgaW5zaWRlIGBpbnB1dGAtZXZlbnRcbiAgICAgICAgICAgICAgICAgICAgICogYW5kIG1hc2sgYXJlIHJlYWR5IHRvIHJlamVjdCBcImV4dHJhXCIgY2hhcmFjdGVycy5cbiAgICAgICAgICAgICAgICAgICAgICogV2Ugc2hvdWxkIGN1dCBsZWFkaW5nIGNvdW50cnkgcHJlZml4IHRvIHNhdmUgdHJhaWxpbmcgY2hhcmFjdGVycyFcbiAgICAgICAgICAgICAgICAgICAgICovXG4gICAgICAgICAgICAgICAgICAgIGNvdW50RGlnaXRzKHZhbHVlKSA+IGNvbXBsZXRlUGhvbmVMZW5ndGhcbiAgICAgICAgICAgICAgICAgICAgICAgID8gdHJpbUNvdW50cnlQcmVmaXgodmFsdWUpXG4gICAgICAgICAgICAgICAgICAgICAgICA6IHZhbHVlLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIGRhdGE6XG4gICAgICAgICAgICAgICAgY291bnREaWdpdHMoZGF0YSkgPj0gY29tcGxldGVQaG9uZUxlbmd0aCB8fCBkYXRhLnN0YXJ0c1dpdGgoY291bnRyeUNvZGUpXG4gICAgICAgICAgICAgICAgICAgID8gLyoqXG4gICAgICAgICAgICAgICAgICAgICAgICogVXNlciB0cmllcyB0byBpbnNlcnQvZHJvcCB0aGUgY29tcGxldGUgcGhvbmUgbnVtYmVyICh3aXRoIGNvdW50cnkgcHJlZml4KS5cbiAgICAgICAgICAgICAgICAgICAgICAgKiBXZSBzaG91bGQgZHJvcCBhbHJlYWR5IGV4aXN0aW5nIG5vbi1yZW1vdmFibGUgcHJlZml4LlxuICAgICAgICAgICAgICAgICAgICAgICAqL1xuICAgICAgICAgICAgICAgICAgICAgIHRyaW1Db3VudHJ5UHJlZml4KGRhdGEpXG4gICAgICAgICAgICAgICAgICAgIDogZGF0YSxcbiAgICAgICAgfTtcbiAgICB9O1xufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Create {@link https://maskito.dev/core-concepts/mask-expression pattern mask expression} for phone number
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* tuiCreatePhoneMaskExpression('+1', '(###) ###-####');
|
|
6
|
+
*/
|
|
7
|
+
export function tuiCreatePhoneMaskExpression(countryCode, phoneMaskAfterCountryCode) {
|
|
8
|
+
return [
|
|
9
|
+
...countryCode.split(''),
|
|
10
|
+
' ',
|
|
11
|
+
...phoneMaskAfterCountryCode
|
|
12
|
+
.replaceAll(/[^#\- ()]+/g, '')
|
|
13
|
+
.split('')
|
|
14
|
+
.map((item) => (item === '#' ? /\d/ : item)),
|
|
15
|
+
];
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXBob25lLW1hc2stZXhwcmVzc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lL3V0aWxzL2NyZWF0ZS1waG9uZS1tYXNrLWV4cHJlc3Npb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLFVBQVUsNEJBQTRCLENBQ3hDLFdBQW1CLEVBQ25CLHlCQUFpQztJQUVqQyxPQUFPO1FBQ0gsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUN4QixHQUFHO1FBQ0gsR0FBRyx5QkFBeUI7YUFDdkIsVUFBVSxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7YUFDN0IsS0FBSyxDQUFDLEVBQUUsQ0FBQzthQUNULEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0tBQ25ELENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDcmVhdGUge0BsaW5rIGh0dHBzOi8vbWFza2l0by5kZXYvY29yZS1jb25jZXB0cy9tYXNrLWV4cHJlc3Npb24gcGF0dGVybiBtYXNrIGV4cHJlc3Npb259IGZvciBwaG9uZSBudW1iZXJcbiAqXG4gKiBAZXhhbXBsZVxuICogdHVpQ3JlYXRlUGhvbmVNYXNrRXhwcmVzc2lvbignKzEnLCAnKCMjIykgIyMjLSMjIyMnKTtcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHR1aUNyZWF0ZVBob25lTWFza0V4cHJlc3Npb24oXG4gICAgY291bnRyeUNvZGU6IHN0cmluZyxcbiAgICBwaG9uZU1hc2tBZnRlckNvdW50cnlDb2RlOiBzdHJpbmcsXG4pOiBBcnJheTxSZWdFeHAgfCBzdHJpbmc+IHtcbiAgICByZXR1cm4gW1xuICAgICAgICAuLi5jb3VudHJ5Q29kZS5zcGxpdCgnJyksXG4gICAgICAgICcgJyxcbiAgICAgICAgLi4ucGhvbmVNYXNrQWZ0ZXJDb3VudHJ5Q29kZVxuICAgICAgICAgICAgLnJlcGxhY2VBbGwoL1teI1xcLSAoKV0rL2csICcnKVxuICAgICAgICAgICAgLnNwbGl0KCcnKVxuICAgICAgICAgICAgLm1hcCgoaXRlbSkgPT4gKGl0ZW0gPT09ICcjJyA/IC9cXGQvIDogaXRlbSkpLFxuICAgIF07XG59XG4iXX0=
|
|
@@ -3,9 +3,10 @@ import { ChangeDetectionStrategy, Component, computed, Directive, inject, ViewEn
|
|
|
3
3
|
import { TuiControl } from '@taiga-ui/cdk/classes';
|
|
4
4
|
import { TuiTime } from '@taiga-ui/cdk/date-time';
|
|
5
5
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
6
|
-
import { TuiTextfieldContent, TuiTextfieldDirective, } from '@taiga-ui/core/components/textfield';
|
|
6
|
+
import { TuiTextfieldContent, TuiTextfieldDirective, TuiWithNativePicker, } from '@taiga-ui/core/components/textfield';
|
|
7
7
|
import { TuiInputTimeDirective } from './input-time.directive';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
9
10
|
class TuiNativeTimePicker {
|
|
10
11
|
constructor() {
|
|
11
12
|
this.list = tuiInjectElement().getAttribute('list');
|
|
@@ -29,14 +30,13 @@ class TuiNativeTimePicker {
|
|
|
29
30
|
return dateString + timeString;
|
|
30
31
|
}
|
|
31
32
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNativeTimePicker, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
32
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiNativeTimePicker, host: { properties: { "
|
|
33
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiNativeTimePicker, host: { properties: { "attr.list": "null" } }, ngImport: i0 }); }
|
|
33
34
|
}
|
|
34
35
|
export { TuiNativeTimePicker };
|
|
35
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNativeTimePicker, decorators: [{
|
|
36
37
|
type: Directive,
|
|
37
38
|
args: [{
|
|
38
39
|
host: {
|
|
39
|
-
'[type]': '"text"',
|
|
40
40
|
'[attr.list]': 'null',
|
|
41
41
|
},
|
|
42
42
|
}]
|
|
@@ -54,11 +54,11 @@ class TuiInputTimeComponent extends TuiNativeTimePicker {
|
|
|
54
54
|
this.host.setValue(TuiTime.fromString(value));
|
|
55
55
|
}
|
|
56
56
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
57
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputTimeComponent, isStandalone: true, selector: "input[tuiInputTime][type=\"time\"]", host: { attributes: { "ngSkipHydration": "true" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"time\"\n [attr.list]=\"list\"\n [step]=\"step()\"\n [value]=\"value()\"\n (change)=\"setValue($any($event.target).value)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputTime]~.t-content input[type=time]{position:absolute;right:0;left:auto;inline-size:calc(var(--t-right) + var(--t-padding));opacity:0;margin:0;padding:0}tui-textfield input[tuiInputTime]~.t-content input[type=time]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiTextfieldContent, selector: "ng-template[tuiTextfieldContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
57
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputTimeComponent, isStandalone: true, selector: "input[tuiInputTime][type=\"time\"]", host: { attributes: { "ngSkipHydration": "true" } }, usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithNativePicker }], ngImport: i0, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"time\"\n [attr.list]=\"list\"\n [step]=\"step()\"\n [value]=\"value()\"\n (change)=\"setValue($any($event.target).value)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputTime]~.t-content input[type=time]{position:absolute;right:0;left:auto;inline-size:calc(var(--t-right) + var(--t-padding));opacity:0;margin:0;padding:0}tui-textfield input[tuiInputTime]~.t-content input[type=time]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiTextfieldContent, selector: "ng-template[tuiTextfieldContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
58
58
|
}
|
|
59
59
|
export { TuiInputTimeComponent };
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputTimeComponent, decorators: [{
|
|
61
61
|
type: Component,
|
|
62
|
-
args: [{ standalone: true, selector: 'input[tuiInputTime][type="time"]', imports: [NgIf, TuiTextfieldContent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: { ngSkipHydration: 'true' }, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"time\"\n [attr.list]=\"list\"\n [step]=\"step()\"\n [value]=\"value()\"\n (change)=\"setValue($any($event.target).value)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputTime]~.t-content input[type=time]{position:absolute;right:0;left:auto;inline-size:calc(var(--t-right) + var(--t-padding));opacity:0;margin:0;padding:0}tui-textfield input[tuiInputTime]~.t-content input[type=time]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"] }]
|
|
62
|
+
args: [{ standalone: true, selector: 'input[tuiInputTime][type="time"]', imports: [NgIf, TuiTextfieldContent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [TuiWithNativePicker], host: { ngSkipHydration: 'true' }, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"time\"\n [attr.list]=\"list\"\n [step]=\"step()\"\n [value]=\"value()\"\n (change)=\"setValue($any($event.target).value)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputTime]~.t-content input[type=time]{position:absolute;right:0;left:auto;inline-size:calc(var(--t-right) + var(--t-padding));opacity:0;margin:0;padding:0}tui-textfield input[tuiInputTime]~.t-content input[type=time]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"] }]
|
|
63
63
|
}] });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGltZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC10aW1lL2lucHV0LXRpbWUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtdGltZS9pbnB1dC10aW1lLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3JDLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFFBQVEsRUFDUixTQUFTLEVBQ1QsTUFBTSxFQUNOLGlCQUFpQixHQUNwQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ2hELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFDSCxtQkFBbUIsRUFDbkIscUJBQXFCLEVBQ3JCLG1CQUFtQixHQUN0QixNQUFNLHFDQUFxQyxDQUFDO0FBRTdDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHdCQUF3QixDQUFDOzs7QUFFN0QsTUFLc0IsbUJBQW1CO0lBTHpDO1FBTXVCLFNBQUksR0FBRyxnQkFBZ0IsRUFBRSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsQ0FBQztLQXdCckU7SUF0QmEsT0FBTyxDQUFDLFFBQXlCO1FBQ3ZDLFFBQVEsUUFBUSxFQUFFO1lBQ2QsS0FBSyxVQUFVLENBQUM7WUFDaEIsS0FBSyxhQUFhO2dCQUNkLE9BQU8sQ0FBQyxDQUFDO1lBQ2IsS0FBSyxjQUFjLENBQUM7WUFDcEIsS0FBSyxpQkFBaUI7Z0JBQ2xCLE9BQU8sS0FBSyxDQUFDO1lBQ2pCO2dCQUNJLE9BQU8sRUFBRSxDQUFDO1NBQ2pCO0lBQ0wsQ0FBQztJQUVTLFdBQVcsQ0FDakIsS0FBeUQ7UUFFekQsTUFBTSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sVUFBVSxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDL0QsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFFN0QsT0FBTyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQ25DLENBQUM7K0dBeEJpQixtQkFBbUI7bUdBQW5CLG1CQUFtQjs7U0FBbkIsbUJBQW1COzRGQUFuQixtQkFBbUI7a0JBTHhDLFNBQVM7bUJBQUM7b0JBQ1AsSUFBSSxFQUFFO3dCQUNGLGFBQWEsRUFBRSxNQUFNO3FCQUN4QjtpQkFDSjs7QUE0QkQsTUFXYSxxQkFBc0IsU0FBUSxtQkFBbUI7SUFYOUQ7O1FBWXFCLFlBQU8sR0FBK0IsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRXZELFNBQUksR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUVyQyxjQUFTLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFDMUMsVUFBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRS9ELFNBQUksR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQztLQUtoRjtJQUhhLFFBQVEsQ0FBQyxLQUFhO1FBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNsRCxDQUFDOytHQVpRLHFCQUFxQjttR0FBckIscUJBQXFCLG1PQ2pFbEMsa1JBVUEsZ1pEK0NjLElBQUksNkZBQUUsbUJBQW1COztTQVExQixxQkFBcUI7NEZBQXJCLHFCQUFxQjtrQkFYakMsU0FBUztpQ0FDTSxJQUFJLFlBQ04sa0NBQWtDLFdBQ25DLENBQUMsSUFBSSxFQUFFLG1CQUFtQixDQUFDLGlCQUdyQixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLGtCQUMvQixDQUFDLG1CQUFtQixDQUFDLFFBQy9CLEVBQUMsZUFBZSxFQUFFLE1BQU0sRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdJZn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIGNvbXB1dGVkLFxuICAgIERpcmVjdGl2ZSxcbiAgICBpbmplY3QsXG4gICAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge01hc2tpdG9UaW1lTW9kZX0gZnJvbSAnQG1hc2tpdG8va2l0JztcbmltcG9ydCB7VHVpQ29udHJvbH0gZnJvbSAnQHRhaWdhLXVpL2Nkay9jbGFzc2VzJztcbmltcG9ydCB0eXBlIHtUdWlEYXl9IGZyb20gJ0B0YWlnYS11aS9jZGsvZGF0ZS10aW1lJztcbmltcG9ydCB7VHVpVGltZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay9kYXRlLXRpbWUnO1xuaW1wb3J0IHt0dWlJbmplY3RFbGVtZW50fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2RvbSc7XG5pbXBvcnQge1xuICAgIFR1aVRleHRmaWVsZENvbnRlbnQsXG4gICAgVHVpVGV4dGZpZWxkRGlyZWN0aXZlLFxuICAgIFR1aVdpdGhOYXRpdmVQaWNrZXIsXG59IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvdGV4dGZpZWxkJztcblxuaW1wb3J0IHtUdWlJbnB1dFRpbWVEaXJlY3RpdmV9IGZyb20gJy4vaW5wdXQtdGltZS5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5saXN0XSc6ICdudWxsJyxcbiAgICB9LFxufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBUdWlOYXRpdmVUaW1lUGlja2VyIHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgbGlzdCA9IHR1aUluamVjdEVsZW1lbnQoKS5nZXRBdHRyaWJ1dGUoJ2xpc3QnKTtcblxuICAgIHByb3RlY3RlZCBnZXRTdGVwKHRpbWVNb2RlOiBNYXNraXRvVGltZU1vZGUpOiBudW1iZXIge1xuICAgICAgICBzd2l0Y2ggKHRpbWVNb2RlKSB7XG4gICAgICAgICAgICBjYXNlICdISDpNTTpTUyc6XG4gICAgICAgICAgICBjYXNlICdISDpNTTpTUyBBQSc6XG4gICAgICAgICAgICAgICAgcmV0dXJuIDE7XG4gICAgICAgICAgICBjYXNlICdISDpNTTpTUy5NU1MnOlxuICAgICAgICAgICAgY2FzZSAnSEg6TU06U1MuTVNTIEFBJzpcbiAgICAgICAgICAgICAgICByZXR1cm4gMC4wMDE7XG4gICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgIHJldHVybiA2MDtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByb3RlY3RlZCB0b0lTT1N0cmluZyhcbiAgICAgICAgdmFsdWU6IFR1aVRpbWUgfCByZWFkb25seSBbVHVpRGF5LCBUdWlUaW1lIHwgbnVsbF0gfCBudWxsLFxuICAgICk6IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IFtkYXksIHRpbWVdID0gQXJyYXkuaXNBcnJheSh2YWx1ZSkgPyB2YWx1ZSA6IFtudWxsLCB2YWx1ZV07XG4gICAgICAgIGNvbnN0IGRhdGVTdHJpbmcgPSBkYXkgPyBkYXkudG9KU09OKCkgKyAodGltZSA/ICdUJyA6ICcnKSA6ICcnO1xuICAgICAgICBjb25zdCB0aW1lU3RyaW5nID0gdGltZSA/IHRpbWUudG9TdHJpbmcoJ0hIOk1NOlNTLk1TUycpIDogJyc7XG5cbiAgICAgICAgcmV0dXJuIGRhdGVTdHJpbmcgKyB0aW1lU3RyaW5nO1xuICAgIH1cbn1cblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2lucHV0W3R1aUlucHV0VGltZV1bdHlwZT1cInRpbWVcIl0nLFxuICAgIGltcG9ydHM6IFtOZ0lmLCBUdWlUZXh0ZmllbGRDb250ZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vaW5wdXQtdGltZS50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9pbnB1dC10aW1lLnN0eWxlLmxlc3MnXSxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpV2l0aE5hdGl2ZVBpY2tlcl0sXG4gICAgaG9zdDoge25nU2tpcEh5ZHJhdGlvbjogJ3RydWUnfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpSW5wdXRUaW1lQ29tcG9uZW50IGV4dGVuZHMgVHVpTmF0aXZlVGltZVBpY2tlciB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjb250cm9sOiBUdWlDb250cm9sPFR1aVRpbWUgfCBudWxsPiA9IGluamVjdChUdWlDb250cm9sKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBob3N0ID0gaW5qZWN0KFR1aUlucHV0VGltZURpcmVjdGl2ZSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgdGV4dGZpZWxkID0gaW5qZWN0KFR1aVRleHRmaWVsZERpcmVjdGl2ZSk7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHZhbHVlID0gY29tcHV0ZWQoKCkgPT4gdGhpcy50b0lTT1N0cmluZyh0aGlzLmNvbnRyb2wudmFsdWUoKSkpO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHN0ZXAgPSBjb21wdXRlZCgoKSA9PiB0aGlzLmdldFN0ZXAodGhpcy5ob3N0LnRpbWVNb2RlKCkpKTtcblxuICAgIHByb3RlY3RlZCBzZXRWYWx1ZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaG9zdC5zZXRWYWx1ZShUdWlUaW1lLmZyb21TdHJpbmcodmFsdWUpKTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwiaG9zdC5uYXRpdmVcIj5cbiAgICA8aW5wdXRcbiAgICAgICAgKnR1aVRleHRmaWVsZENvbnRlbnRcbiAgICAgICAgdHlwZT1cInRpbWVcIlxuICAgICAgICBbYXR0ci5saXN0XT1cImxpc3RcIlxuICAgICAgICBbc3RlcF09XCJzdGVwKClcIlxuICAgICAgICBbdmFsdWVdPVwidmFsdWUoKVwiXG4gICAgICAgIChjaGFuZ2UpPVwic2V0VmFsdWUoJGFueSgkZXZlbnQudGFyZ2V0KS52YWx1ZSlcIlxuICAgIC8+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -5,10 +5,9 @@ import { maskitoAddOnFocusPlugin, maskitoCaretGuard, maskitoRemoveOnBlurPlugin,
|
|
|
5
5
|
import { tuiAsControl, TuiControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
|
|
6
6
|
import { TuiTime } from '@taiga-ui/cdk/date-time';
|
|
7
7
|
import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
|
|
8
|
-
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
9
8
|
import { tuiDirectiveBinding } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
10
9
|
import { tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
|
|
11
|
-
import { tuiAsTextfieldAccessor, TuiTextfieldComponent, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
10
|
+
import { tuiAsTextfieldAccessor, TuiTextfieldComponent, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithNativePicker, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
12
11
|
import { TuiDropdownDirective, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown';
|
|
13
12
|
import { tuiAsAuxiliary } from '@taiga-ui/core/tokens';
|
|
14
13
|
import { TuiSelectOption } from '@taiga-ui/kit/components/select';
|
|
@@ -39,7 +38,7 @@ class TuiInputTimeDirective extends TuiControl {
|
|
|
39
38
|
postfix: this.postfix(),
|
|
40
39
|
})));
|
|
41
40
|
this.accept = [];
|
|
42
|
-
this.native =
|
|
41
|
+
this.native = !!inject(TuiWithNativePicker, { optional: true }) && inject(TUI_IS_MOBILE);
|
|
43
42
|
this.timeMode = signal(this.options.mode);
|
|
44
43
|
}
|
|
45
44
|
// TODO(v5): use signal inputs
|
|
@@ -153,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
153
152
|
type: Input,
|
|
154
153
|
args: ['postfix']
|
|
155
154
|
}] } });
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-time.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-time/input-time.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, inject, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport type {MaskitoOptions} from '@maskito/core';\nimport type {MaskitoTimeMode, MaskitoTimeParams} from '@maskito/kit';\nimport {\n    maskitoAddOnFocusPlugin,\n    maskitoCaretGuard,\n    maskitoRemoveOnBlurPlugin,\n    maskitoSelectionChangeHandler,\n    maskitoTimeOptionsGenerator,\n} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TuiTime} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    tuiTextfieldIconBinding,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_TIME_OPTIONS} from './input-time.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputTime]',\n    providers: [\n        tuiAsControl(TuiInputTimeDirective),\n        tuiAsTextfieldAccessor(TuiInputTimeDirective),\n        tuiAsAuxiliary(TuiInputTimeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_TIME_OPTIONS),\n        tuiAsOptionContent(TuiSelectOption),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective],\n    host: {\n        inputmode: 'numeric',\n        '[disabled]': 'disabled()',\n        '(click)': 'toggle()',\n        '(input)': 'onInput($event.target.value)',\n    },\n})\nexport class TuiInputTimeDirective\n    extends TuiControl<TuiTime | null>\n    implements TuiTextfieldAccessor<TuiTime | null>\n{\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly dropdown = inject(TuiDropdownDirective);\n    private readonly open = tuiDropdownOpen();\n    private readonly options = inject(TUI_INPUT_TIME_OPTIONS);\n    private readonly fillers = toSignal(inject(TUI_TIME_TEXTS));\n    private readonly prefix = signal('');\n    private readonly postfix = signal('');\n\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_TIME_OPTIONS);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(\n        computed(() => !this.native && this.interactive()),\n    );\n\n    protected readonly filler = tuiDirectiveBinding(\n        TuiTextfieldComponent,\n        'fillerSetter',\n        computed((filler = this.fillers()?.[this.timeMode()] ?? '') =>\n            this.postfix() ? '' : this.prefix() + filler,\n        ),\n        {},\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            this.computeMask({\n                ...this.options,\n                mode: this.timeMode(),\n                step: this.interactive() && !this.dropdown._content() ? 1 : 0,\n                prefix: this.prefix(),\n                postfix: this.postfix(),\n            }),\n        ),\n    );\n\n    @Input()\n    public accept: readonly TuiTime[] = [];\n\n    public readonly native =\n        tuiInjectElement<HTMLInputElement>().type === 'time' && inject(TUI_IS_MOBILE);\n\n    public readonly timeMode = signal(this.options.mode);\n\n    // TODO(v5): use signal inputs\n    @Input('mode')\n    public set modeSetter(x: MaskitoTimeMode) {\n        this.timeMode.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('prefix')\n    public set prefixSetter(x: string) {\n        this.prefix.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('postfix')\n    public set postfixSetter(x: string) {\n        this.postfix.set(x);\n    }\n\n    public setValue(value: TuiTime | null): void {\n        this.onChange(value);\n\n        if (value) {\n            this.textfield.value.set(this.stringify(value));\n        } else {\n            this.textfield.setValue(value);\n        }\n\n        if (!value && this.dropdownEnabled()) {\n            this.open.set(true);\n        }\n    }\n\n    public override writeValue(value: TuiTime | null): void {\n        super.writeValue(value);\n        this.textfield.value.set(this.stringify(this.value()));\n    }\n\n    protected onInput(valueWithAffixes: string): void {\n        const value = valueWithAffixes\n            .replace(this.prefix(), '')\n            .replace(this.postfix(), '');\n        const time =\n            value.length === this.timeMode().length ? TuiTime.fromString(value) : null;\n        const newValue =\n            this.accept.length && time ? this.findNearestTime(time, this.accept) : time;\n\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(newValue);\n\n        if (newValue && newValue !== time) {\n            this.textfield.value.set(this.stringify(newValue));\n        }\n    }\n\n    protected toggle(): void {\n        this.open.update((x) => !x);\n    }\n\n    private computeMask(params: Required<MaskitoTimeParams>): MaskitoOptions {\n        const options = maskitoTimeOptionsGenerator(params);\n        const {mode, prefix, postfix} = params;\n        const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {\n            element.inputMode =\n                element.selectionStart! >= mode.indexOf(' AA') ? 'text' : 'numeric';\n        });\n        const caretGuardPlugin = maskitoCaretGuard((value) => [\n            prefix.length,\n            value.length - postfix.length,\n        ]);\n\n        return {\n            ...options,\n            plugins: options.plugins.concat(\n                caretGuardPlugin,\n                maskitoAddOnFocusPlugin(prefix + postfix),\n                maskitoRemoveOnBlurPlugin(prefix + postfix),\n                mode.includes('AA') ? inputModeSwitchPlugin : [],\n            ),\n        };\n    }\n\n    private findNearestTime(value: TuiTime, items: readonly TuiTime[]): TuiTime | null {\n        // eslint-disable-next-line no-restricted-syntax\n        return items.reduce((previous, current) =>\n            Math.abs(current.valueOf() - value.valueOf()) <\n            Math.abs(previous.valueOf() - value.valueOf())\n                ? current\n                : previous,\n        );\n    }\n\n    private stringify(time: TuiTime | null): string {\n        return this.prefix() + (time?.toString(this.timeMode()) || '') + this.postfix();\n    }\n}\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-time.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-time/input-time.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, inject, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport type {MaskitoOptions} from '@maskito/core';\nimport type {MaskitoTimeMode, MaskitoTimeParams} from '@maskito/kit';\nimport {\n    maskitoAddOnFocusPlugin,\n    maskitoCaretGuard,\n    maskitoRemoveOnBlurPlugin,\n    maskitoSelectionChangeHandler,\n    maskitoTimeOptionsGenerator,\n} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TuiTime} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    tuiTextfieldIconBinding,\n    TuiWithNativePicker,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_TIME_OPTIONS} from './input-time.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputTime]',\n    providers: [\n        tuiAsControl(TuiInputTimeDirective),\n        tuiAsTextfieldAccessor(TuiInputTimeDirective),\n        tuiAsAuxiliary(TuiInputTimeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_TIME_OPTIONS),\n        tuiAsOptionContent(TuiSelectOption),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective],\n    host: {\n        inputmode: 'numeric',\n        '[disabled]': 'disabled()',\n        '(click)': 'toggle()',\n        '(input)': 'onInput($event.target.value)',\n    },\n})\nexport class TuiInputTimeDirective\n    extends TuiControl<TuiTime | null>\n    implements TuiTextfieldAccessor<TuiTime | null>\n{\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly dropdown = inject(TuiDropdownDirective);\n    private readonly open = tuiDropdownOpen();\n    private readonly options = inject(TUI_INPUT_TIME_OPTIONS);\n    private readonly fillers = toSignal(inject(TUI_TIME_TEXTS));\n    private readonly prefix = signal('');\n    private readonly postfix = signal('');\n\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_TIME_OPTIONS);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(\n        computed(() => !this.native && this.interactive()),\n    );\n\n    protected readonly filler = tuiDirectiveBinding(\n        TuiTextfieldComponent,\n        'fillerSetter',\n        computed((filler = this.fillers()?.[this.timeMode()] ?? '') =>\n            this.postfix() ? '' : this.prefix() + filler,\n        ),\n        {},\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            this.computeMask({\n                ...this.options,\n                mode: this.timeMode(),\n                step: this.interactive() && !this.dropdown._content() ? 1 : 0,\n                prefix: this.prefix(),\n                postfix: this.postfix(),\n            }),\n        ),\n    );\n\n    @Input()\n    public accept: readonly TuiTime[] = [];\n\n    public readonly native =\n        !!inject(TuiWithNativePicker, {optional: true}) && inject(TUI_IS_MOBILE);\n\n    public readonly timeMode = signal(this.options.mode);\n\n    // TODO(v5): use signal inputs\n    @Input('mode')\n    public set modeSetter(x: MaskitoTimeMode) {\n        this.timeMode.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('prefix')\n    public set prefixSetter(x: string) {\n        this.prefix.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('postfix')\n    public set postfixSetter(x: string) {\n        this.postfix.set(x);\n    }\n\n    public setValue(value: TuiTime | null): void {\n        this.onChange(value);\n\n        if (value) {\n            this.textfield.value.set(this.stringify(value));\n        } else {\n            this.textfield.setValue(value);\n        }\n\n        if (!value && this.dropdownEnabled()) {\n            this.open.set(true);\n        }\n    }\n\n    public override writeValue(value: TuiTime | null): void {\n        super.writeValue(value);\n        this.textfield.value.set(this.stringify(this.value()));\n    }\n\n    protected onInput(valueWithAffixes: string): void {\n        const value = valueWithAffixes\n            .replace(this.prefix(), '')\n            .replace(this.postfix(), '');\n        const time =\n            value.length === this.timeMode().length ? TuiTime.fromString(value) : null;\n        const newValue =\n            this.accept.length && time ? this.findNearestTime(time, this.accept) : time;\n\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(newValue);\n\n        if (newValue && newValue !== time) {\n            this.textfield.value.set(this.stringify(newValue));\n        }\n    }\n\n    protected toggle(): void {\n        this.open.update((x) => !x);\n    }\n\n    private computeMask(params: Required<MaskitoTimeParams>): MaskitoOptions {\n        const options = maskitoTimeOptionsGenerator(params);\n        const {mode, prefix, postfix} = params;\n        const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {\n            element.inputMode =\n                element.selectionStart! >= mode.indexOf(' AA') ? 'text' : 'numeric';\n        });\n        const caretGuardPlugin = maskitoCaretGuard((value) => [\n            prefix.length,\n            value.length - postfix.length,\n        ]);\n\n        return {\n            ...options,\n            plugins: options.plugins.concat(\n                caretGuardPlugin,\n                maskitoAddOnFocusPlugin(prefix + postfix),\n                maskitoRemoveOnBlurPlugin(prefix + postfix),\n                mode.includes('AA') ? inputModeSwitchPlugin : [],\n            ),\n        };\n    }\n\n    private findNearestTime(value: TuiTime, items: readonly TuiTime[]): TuiTime | null {\n        // eslint-disable-next-line no-restricted-syntax\n        return items.reduce((previous, current) =>\n            Math.abs(current.valueOf() - value.valueOf()) <\n            Math.abs(previous.valueOf() - value.valueOf())\n                ? current\n                : previous,\n        );\n    }\n\n    private stringify(time: TuiTime | null): string {\n        return this.prefix() + (time?.toString(this.timeMode()) || '') + this.postfix();\n    }\n}\n"]}
|