@snabcentr/client-ui 3.36.2 → 3.36.4

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.
@@ -47,7 +47,7 @@ export class ScHoverImageCarouselComponent {
47
47
  * Обработчик события `mouseleave.silent`.
48
48
  */
49
49
  onLeave() {
50
- if (this.images.length <= 1) {
50
+ if (this.images().length <= 1) {
51
51
  return;
52
52
  }
53
53
  this.currentIndex.set(0);
@@ -73,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
73
73
  '(mouseleave.silent)': 'onLeave()',
74
74
  }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"overflow-hidden rounded-xl\"\n [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n [style.aspect-ratio]=\"'20/19'\"\n>\n @let image = currentImage();\n <picture>\n @if (image.imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"image.imageWebp\"\n />\n }\n\n @if (image.image) {\n <img\n [src]=\"image.image\"\n [alt]=\"image.alt\"\n class=\"size-full rounded-xl object-contain\"\n />\n }\n </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n <div\n (mousemove.silent)=\"$event.stopPropagation()\"\n class=\"flex justify-center\"\n >\n <button\n *tuiRepeatTimes=\"let indexItem of images().length\"\n #element\n tuiButton\n type=\"button\"\n class=\"button button_small\"\n [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n ></button>\n </div>\n}\n", styles: [".button{flex-shrink:0}.button:first-child{margin-inline-start:0}.button:last-child{margin-inline-end:0}.button_small{inline-size:.5rem;block-size:.5rem;font-size:0;padding:0;margin:0}.button_small:not(:first-child){margin-left:.5rem}\n"] }]
75
75
  }] });
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-hover-image-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.ts","../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAuB,MAAM,EAAkB,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;AAE3C;;GAEG;AAaH,MAAM,OAAO,6BAA6B;IAZ1C;QAaI;;WAEG;QACa,WAAM,GAA4B,KAAK,CAAC,QAAQ,EAAc,CAAC;QAE/E;;WAEG;QACa,kBAAa,GAAyB,KAAK,CAAU,IAAI,CAAC,CAAC;QAE3E;;WAEG;QACa,iBAAY,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACa,iBAAY,GAAqB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAEpG;;WAEG;QACa,gBAAW,GAAoC,KAAK,EAAsB,CAAC;KA2C9F;IAzCG;;;;;OAKG;IACK,OAAO,CAAC,OAAe,EAAE,MAAmB;QAChD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,YAAY,EAAE,CAAC,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAExG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACK,OAAO;QACX,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC1B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACO,YAAY,CAAC,OAAgB,EAAE,KAAa;QAClD,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC;+GAlEQ,6BAA6B;mGAA7B,6BAA6B,4mBCpB1C,koCAuCA,qSD5Bc,cAAc,6GAAE,SAAS,oIAAE,UAAU;;4FAStC,6BAA6B;kBAZzC,SAAS;iCACM,IAAI,YACN,yBAAyB,WAC1B,CAAC,cAAc,EAAE,SAAS,EAAE,UAAU,CAAC,QAG1C;wBACF,oBAAoB,EAAE,wCAAwC;wBAC9D,qBAAqB,EAAE,WAAW;qBACrC,mBACgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, InputSignal, Signal, signal, WritableSignal } from '@angular/core';\nimport { ScIImage } from '@snabcentr/client-core';\nimport { TuiHovered, TuiRepeatTimes } from '@taiga-ui/cdk';\nimport { TuiButton } from '@taiga-ui/core';\n\n/**\n * Компонент просмотра изображений через событие наведения.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-hover-image-carousel',\n    imports: [TuiRepeatTimes, TuiButton, TuiHovered],\n    templateUrl: './sc-hover-image-carousel.component.html',\n    styleUrl: './sc-hover-image-carousel.component.scss',\n    host: {\n        '(mousemove.silent)': 'onHover($event.offsetX, $event.target)',\n        '(mouseleave.silent)': 'onLeave()',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScHoverImageCarouselComponent {\n    /**\n     * Массив изображений.\n     */\n    public readonly images: InputSignal<ScIImage[]> = input.required<ScIImage[]>();\n\n    /**\n     * Признак что необходимо отобразить элементы управления.\n     */\n    public readonly isShowActions: InputSignal<boolean> = input<boolean>(true);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentIndex: WritableSignal<number> = signal(0);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentImage: Signal<ScIImage> = computed(() => this.images()[this.currentIndex()]);\n\n    /**\n     * Название товара.\n     */\n    public readonly productName: InputSignal<string | undefined> = input<string | undefined>();\n\n    /**\n     * Обработчик события `mousemove.silent`.\n     *\n     * @param offsetX Отступ курсора мыши по оси X от края {@link HTMLElement}.\n     * @param target Объект {@link HTMLElement} в котором лежат изображения\n     */\n    private onHover(offsetX: number, target: HTMLElement): void {\n        if (this.images().length <= 1 || offsetX < 0) {\n            return;\n        }\n\n        const elementWidth = target.offsetWidth;\n        const hoverPercentage = Math.min(offsetX / elementWidth, 1);\n\n        const newIndex = Math.min(Math.floor(hoverPercentage * this.images().length), this.images().length - 1);\n\n        this.currentIndex.set(newIndex);\n    }\n\n    /**\n     * Обработчик события `mouseleave.silent`.\n     */\n    private onLeave(): void {\n        if (this.images.length <= 1) {\n            return;\n        }\n\n        this.currentIndex.set(0);\n    }\n\n    /**\n     * Обработчик события наведения указателя мыши на точку.\n     *\n     * @param hovered Признак что указатель мыши наведен на точку.\n     * @param index Индекс изображения, который соответствует точке.\n     */\n    protected onDotHovered(hovered: boolean, index: number): void {\n        if (hovered) {\n            this.currentIndex.set(index);\n        }\n    }\n}\n","<div\n    class=\"overflow-hidden rounded-xl\"\n    [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n    [style.aspect-ratio]=\"'20/19'\"\n>\n    @let image = currentImage();\n    <picture>\n        @if (image.imageWebp) {\n            <source\n                type=\"image/webp\"\n                [srcset]=\"image.imageWebp\"\n            />\n        }\n\n        @if (image.image) {\n            <img\n                [src]=\"image.image\"\n                [alt]=\"image.alt\"\n                class=\"size-full rounded-xl object-contain\"\n            />\n        }\n    </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n    <div\n        (mousemove.silent)=\"$event.stopPropagation()\"\n        class=\"flex justify-center\"\n    >\n        <button\n            *tuiRepeatTimes=\"let indexItem of images().length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"button button_small\"\n            [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n            (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n        ></button>\n    </div>\n}\n"]}
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-hover-image-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.ts","../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAuB,MAAM,EAAkB,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;AAE3C;;GAEG;AAaH,MAAM,OAAO,6BAA6B;IAZ1C;QAaI;;WAEG;QACa,WAAM,GAA4B,KAAK,CAAC,QAAQ,EAAc,CAAC;QAE/E;;WAEG;QACa,kBAAa,GAAyB,KAAK,CAAU,IAAI,CAAC,CAAC;QAE3E;;WAEG;QACa,iBAAY,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACa,iBAAY,GAAqB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAEpG;;WAEG;QACa,gBAAW,GAAoC,KAAK,EAAsB,CAAC;KA2C9F;IAzCG;;;;;OAKG;IACK,OAAO,CAAC,OAAe,EAAE,MAAmB;QAChD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,YAAY,EAAE,CAAC,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAExG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACK,OAAO;QACX,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACO,YAAY,CAAC,OAAgB,EAAE,KAAa;QAClD,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC;+GAlEQ,6BAA6B;mGAA7B,6BAA6B,4mBCpB1C,koCAuCA,qSD5Bc,cAAc,6GAAE,SAAS,oIAAE,UAAU;;4FAStC,6BAA6B;kBAZzC,SAAS;iCACM,IAAI,YACN,yBAAyB,WAC1B,CAAC,cAAc,EAAE,SAAS,EAAE,UAAU,CAAC,QAG1C;wBACF,oBAAoB,EAAE,wCAAwC;wBAC9D,qBAAqB,EAAE,WAAW;qBACrC,mBACgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, InputSignal, Signal, signal, WritableSignal } from '@angular/core';\nimport { ScIImage } from '@snabcentr/client-core';\nimport { TuiHovered, TuiRepeatTimes } from '@taiga-ui/cdk';\nimport { TuiButton } from '@taiga-ui/core';\n\n/**\n * Компонент просмотра изображений через событие наведения.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-hover-image-carousel',\n    imports: [TuiRepeatTimes, TuiButton, TuiHovered],\n    templateUrl: './sc-hover-image-carousel.component.html',\n    styleUrl: './sc-hover-image-carousel.component.scss',\n    host: {\n        '(mousemove.silent)': 'onHover($event.offsetX, $event.target)',\n        '(mouseleave.silent)': 'onLeave()',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScHoverImageCarouselComponent {\n    /**\n     * Массив изображений.\n     */\n    public readonly images: InputSignal<ScIImage[]> = input.required<ScIImage[]>();\n\n    /**\n     * Признак что необходимо отобразить элементы управления.\n     */\n    public readonly isShowActions: InputSignal<boolean> = input<boolean>(true);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentIndex: WritableSignal<number> = signal(0);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentImage: Signal<ScIImage> = computed(() => this.images()[this.currentIndex()]);\n\n    /**\n     * Название товара.\n     */\n    public readonly productName: InputSignal<string | undefined> = input<string | undefined>();\n\n    /**\n     * Обработчик события `mousemove.silent`.\n     *\n     * @param offsetX Отступ курсора мыши по оси X от края {@link HTMLElement}.\n     * @param target Объект {@link HTMLElement} в котором лежат изображения\n     */\n    private onHover(offsetX: number, target: HTMLElement): void {\n        if (this.images().length <= 1 || offsetX < 0) {\n            return;\n        }\n\n        const elementWidth = target.offsetWidth;\n        const hoverPercentage = Math.min(offsetX / elementWidth, 1);\n\n        const newIndex = Math.min(Math.floor(hoverPercentage * this.images().length), this.images().length - 1);\n\n        this.currentIndex.set(newIndex);\n    }\n\n    /**\n     * Обработчик события `mouseleave.silent`.\n     */\n    private onLeave(): void {\n        if (this.images().length <= 1) {\n            return;\n        }\n\n        this.currentIndex.set(0);\n    }\n\n    /**\n     * Обработчик события наведения указателя мыши на точку.\n     *\n     * @param hovered Признак что указатель мыши наведен на точку.\n     * @param index Индекс изображения, который соответствует точке.\n     */\n    protected onDotHovered(hovered: boolean, index: number): void {\n        if (hovered) {\n            this.currentIndex.set(index);\n        }\n    }\n}\n","<div\n    class=\"overflow-hidden rounded-xl\"\n    [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n    [style.aspect-ratio]=\"'20/19'\"\n>\n    @let image = currentImage();\n    <picture>\n        @if (image.imageWebp) {\n            <source\n                type=\"image/webp\"\n                [srcset]=\"image.imageWebp\"\n            />\n        }\n\n        @if (image.image) {\n            <img\n                [src]=\"image.image\"\n                [alt]=\"image.alt\"\n                class=\"size-full rounded-xl object-contain\"\n            />\n        }\n    </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n    <div\n        (mousemove.silent)=\"$event.stopPropagation()\"\n        class=\"flex justify-center\"\n    >\n        <button\n            *tuiRepeatTimes=\"let indexItem of images().length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"button button_small\"\n            [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n            (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n        ></button>\n    </div>\n}\n"]}
@@ -185,7 +185,7 @@ export class ScVerificationPhoneCheckFormComponent {
185
185
  }), switchMap((value) => {
186
186
  if (this.phoneControl.valid && !!value) {
187
187
  return this.verificationService.getPhoneCheck$(value).pipe(map((result) => {
188
- if (this.shouldBeBusy() === undefined && this.shouldBeConfirmed() !== undefined) {
188
+ if (this.shouldBeBusy() === undefined && isNil(this.shouldBeConfirmed())) {
189
189
  this.isBusyChange.emit(result.isBusy);
190
190
  if (!isNil(result.isConfirmed)) {
191
191
  this.isConfirmedChange.emit(result.isConfirmed);
@@ -254,4 +254,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
254
254
  }], propDecorators: { showCodeFields: [{
255
255
  type: Input
256
256
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-verification-phone-check-form.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/verification/verification-phone-check-form/sc-verification-phone-check-form.component.ts","../../../../../projects/client-ui/verification/verification-phone-check-form/sc-verification-phone-check-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle,lodash/prefer-constant */\n\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, inject, Input, input, InputSignal, model, ModelSignal, OnInit, output, OutputEmitterRef, Signal } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroup, FormGroupDirective } from '@angular/forms';\nimport { MaskitoOptions } from '@maskito/core';\nimport { ScIOrgContact, ScVerificationService } from '@snabcentr/client-core';\nimport { tuiControlValue } from '@taiga-ui/cdk';\nimport type { TuiCountryIsoCode } from '@taiga-ui/i18n';\nimport { getCountries } from 'libphonenumber-js';\nimport { isNil } from 'lodash-es';\nimport {\n    catchError,\n    distinctUntilChanged,\n    endWith,\n    filter,\n    finalize,\n    map,\n    Observable,\n    of,\n    scan,\n    share,\n    shareReplay,\n    startWith,\n    Subject,\n    switchMap,\n    takeWhile,\n    tap,\n    timer,\n} from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { SC_SHOW_HELP_NOTIFICATION_IN_PHONE_INPUT } from '../../contacts/tokens/sc-show-help-notification-in-phone-input.token';\nimport { scPhoneVerificationCodeMask } from '../../masks';\nimport { SC_VERIFICATION_CODE_TIMEOUT } from '../../providers/sc-verification-code-timeout';\nimport { ScHelpNotificationService } from '../../services';\n\n/**\n * Компонент формы проверки телефона и получения кода подтверждения.\n */\n@Component({\n    selector: 'sc-verification-phone-check-form',\n    templateUrl: './sc-verification-phone-check-form.component.html',\n    host: { ngSkipHydration: 'true' },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScVerificationPhoneCheckFormComponent implements OnInit {\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    @Input()\n    public set showCodeFields(showCodeFields: boolean) {\n        this._showCodeFields = showCodeFields;\n        this.form.controls.verificationCode[showCodeFields ? 'enable' : 'disable']();\n    }\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    public get showCodeFields(): boolean {\n        return this._showCodeFields;\n    }\n\n    /**\n     * Сервис верификации.\n     */\n    protected readonly verificationService = inject(ScVerificationService);\n\n    /**\n     * Директива c `FormGroup` из DOM.\n     */\n    protected readonly formGroupDirective = inject(FormGroupDirective, { optional: true });\n\n    /**\n     * HTTP-клиент.\n     */\n    protected readonly http = inject(HttpClient);\n\n    /**\n     * Признак, что поле ввода телефона только для чтения.\n     */\n    public readonly readOnly: InputSignal<boolean> = input(false);\n\n    /**\n     * Признак, что поле ввода телефона псевдо-невалидное.\n     */\n    public readonly pseudoInvalid: InputSignal<boolean> = input(false);\n\n    /**\n     * Признак, что поле ввода телефона и кода подтверждения обязательные.\n     */\n    public readonly required: InputSignal<boolean> = input(false);\n\n    /**\n     * Текст подсказки.\n     */\n    public readonly subtitle: InputSignal<string> = input('');\n\n    /**\n     * Признак, следует ли телефону быть в системе. От этого признака зависит, в каких случаях выдавать ошибку при проверке занятости телефона.\n     */\n    public readonly shouldBeBusy: InputSignal<boolean | undefined> = input<boolean | undefined>();\n\n    /**\n     * Признак, следует ли проверять, подтверждён ли телефон в системе. При `true` будет вызывать ошибку при наличии телефона в системе без подтверждения.\n     */\n    public readonly shouldBeConfirmed: InputSignal<boolean | undefined> = input<boolean | undefined>();\n\n    /**\n     * Список стран.\n     */\n    protected readonly countries: readonly TuiCountryIsoCode[] = getCountries();\n\n    /**\n     * Сервис для отображения Push-уведомлений с контактами для помощи клиенту.\n     */\n    protected readonly helpNotificationService: ScHelpNotificationService = inject(ScHelpNotificationService);\n\n    /**\n     * Список контактов для отправки push-уведомлений.\n     */\n    protected readonly pushContacts: Signal<ScIOrgContact[] | undefined> = toSignal(this.helpNotificationService.getContactsShow$());\n\n    /**\n     * Наличие кода подтверждения у пользователя.\n     */\n    public readonly haveCode: ModelSignal<boolean> = model(false);\n\n    /**\n     * {@link Observable} запроса проверки номера телефона.\n     */\n    public phoneCheck$?: Observable<boolean | null>;\n\n    /**\n     * {@link OutputEmitter} события изменения признака занятости телефона.\n     */\n    public readonly isBusyChange: OutputEmitterRef<boolean | null> = output<boolean | null>();\n\n    /**\n     * {@link OutputEmitter} события изменения признака подтверждения телефона.\n     */\n    public readonly isConfirmedChange: OutputEmitterRef<boolean | null> = output<boolean | null>();\n\n    /**\n     * {@link Subject} события отправки кода подтверждения.\n     */\n    protected readonly onSendCode: Subject<void> = new Subject<void>();\n\n    /**\n     * Таймаут отправки кода подтверждения.\n     */\n    protected readonly codeTimeout: number = inject(SC_VERIFICATION_CODE_TIMEOUT);\n\n    /**\n     * {@link Observable} запроса данных получения кода подтверждения.\n     */\n    protected readonly loadingApproveCode$: Observable<boolean> = this.onSendCode.pipe(\n        map(() => this.phoneControl.value),\n        filter((value): value is string => this.phoneControl.valid),\n        switchMap((value) =>\n            this.verificationService.sendPhoneApproveCode(value).pipe(\n                tap(() => {\n                    this.reloadTimer$.next(this.codeTimeout);\n                }),\n                map(() => false),\n                catchError((error: unknown) => {\n                    if (error instanceof HttpErrorResponse) {\n                        const errorResponse = error.error as ApiErrorResponse;\n\n                        const regex = /(\\d{2}):\\d{2}/;\n                        const match = regex.exec(errorResponse.message);\n\n                        if (match && match.length > 1) {\n                            const timeParts = match[0].split(':');\n                            const seconds = Number.parseInt(timeParts[1], 10);\n\n                            this.reloadTimer$.next(seconds);\n                        } else {\n                            this.phoneControl.setErrors({ serverResponse: errorResponse.errors?.['phone'] ?? [errorResponse.message] });\n                        }\n                    }\n\n                    return of(false);\n                }),\n                finalize(() => {\n                    this.setHaveCode(true);\n                }),\n                startWith(true),\n                shareReplay({ refCount: true, bufferSize: 1 })\n            )\n        ),\n        startWith(false),\n        share()\n    );\n\n    /**\n     * Маска поля ввода кода для подтверждения.\n     */\n    protected readonly verificationCodeMask: MaskitoOptions = scPhoneVerificationCodeMask;\n\n    /**\n     * {@link Subject} события запуска/остановки таймера.\n     */\n    protected readonly reloadTimer$: Subject<number> = new Subject<number>();\n\n    /**\n     * {@link Observable} Таймера.\n     *\n     * TODO: Вынести таймер в отдельную директиву TASK:[#9260].\n     */\n    protected readonly timer$: Observable<string | null> = this.reloadTimer$.pipe(\n        switchMap((sec) =>\n            timer(0, 1000).pipe(\n                scan((total) => -1 + total, sec),\n                takeWhile((total) => total >= 0),\n                map((total) => {\n                    const minutes = Math.floor(total / 60);\n                    const seconds = total % 60;\n\n                    return `${Math.round(minutes).toString().padStart(2, '0')}:${Math.round(seconds).toString().padStart(2, '0')}`;\n                }),\n                endWith(null),\n                startWith(null),\n                distinctUntilChanged()\n            )\n        )\n    );\n\n    /**\n     * Токен показа уведомления помощи.\n     */\n    protected readonly showHelpNotification = inject(SC_SHOW_HELP_NOTIFICATION_IN_PHONE_INPUT);\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    private _showCodeFields: boolean = true;\n\n    /**\n     * Группа полей ввода для формы «Вход на сайт».\n     */\n    public get form(): FormGroup<{\n        phone: FormControl<string | null>;\n        verificationCode: FormControl<string | null>;\n    }> {\n        return this.formGroupDirective?.form as FormGroup<{\n            phone: FormControl<string | null>;\n            verificationCode: FormControl<string | null>;\n        }>;\n    }\n\n    /**\n     * Поле ввода 'Номер телефона'.\n     */\n    public get phoneControl(): FormControl<string | null> {\n        return this.form.controls.phone;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.phoneCheck$ = tuiControlValue<string | null>(this.phoneControl).pipe(\n            tap(() => {\n                this.reloadTimer$.next(0);\n                this.isBusyChange.emit(null);\n                this.isConfirmedChange.emit(null);\n                this.helpNotificationService.closeAllHelpNotification();\n\n                if (this.form.controls.verificationCode.value) {\n                    this.form.controls.verificationCode.setValue(null);\n                }\n            }),\n            switchMap((value) => {\n                if (this.phoneControl.valid && !!value) {\n                    return this.verificationService.getPhoneCheck$(value).pipe(\n                        map((result) => {\n                            if (this.shouldBeBusy() === undefined && this.shouldBeConfirmed() !== undefined) {\n                                this.isBusyChange.emit(result.isBusy);\n\n                                if (!isNil(result.isConfirmed)) {\n                                    this.isConfirmedChange.emit(result.isConfirmed);\n\n                                    return this.shouldBeConfirmed() === result.isConfirmed;\n                                }\n\n                                return true;\n                            }\n\n                            if (this.shouldBeBusy() !== undefined && this.shouldBeBusy() !== result.isBusy) {\n                                this.phoneControl.setErrors({\n                                    serverResponse: [\n                                        result.isBusy ? 'Пользователь с таким номером телефона уже существует' : 'Пользователя с таким номером телефона не существует',\n                                    ],\n                                });\n                                this.phoneControl.markAsTouched();\n\n                                return false;\n                            }\n\n                            if (this.shouldBeConfirmed() !== undefined && this.shouldBeConfirmed() !== result.isConfirmed) {\n                                this.phoneControl.setErrors({\n                                    serverResponse: [\n                                        result.isConfirmed\n                                            ? 'Телефон уже подтверждён'\n                                            : 'Номер телефона не подтверждён или вход по нему невозможен. Обратитесь к вашему персональному менеджеру или войдите с использованием e-mail и пароля.',\n                                    ],\n                                });\n                                this.phoneControl.markAsTouched();\n\n                                return false;\n                            }\n\n                            return true;\n                        }),\n                        catchError((error: unknown) => {\n                            if (error instanceof HttpErrorResponse) {\n                                const errorResponse = error.error as ApiErrorResponse;\n                                this.phoneControl.setErrors({ serverResponse: errorResponse.errors?.['phone'] ?? [errorResponse.message] });\n                            }\n\n                            return of(false);\n                        }),\n                        tap((check) => {\n                            if (!check) {\n                                this.helpNotificationService.helpNotificationByPhone(value);\n                            }\n                        }),\n                        startWith(null)\n                    );\n                }\n\n                this.setHaveCode(false);\n\n                return of(false);\n            }),\n            share()\n        );\n\n        this.setHaveCode(false);\n    }\n\n    /**\n     * Устанавливает состояние наличия кода подтверждения у пользователя.\n     *\n     * @param haveCode Признак того есть ли код подтверждения или нет.\n     */\n    protected setHaveCode(haveCode: boolean): void {\n        this.haveCode.set(haveCode);\n    }\n\n    /**\n     * Закрытие уведомления.\n     */\n    protected closeNotification(): void {\n        this.helpNotificationService.closeAllHelpNotification();\n    }\n}\n","@let phoneCheck = phoneCheck$ | async;\n\n<form\n    [formGroup]=\"form\"\n    *tuiLet=\"loadingApproveCode$ | async as loadingApproveCode\"\n    class=\"flex flex-col gap-3\"\n>\n    <label tuiLabel>\n        Номер телефона\n        <tui-textfield>\n            <input\n                formControlName=\"phone\"\n                tuiInputPhoneInternational\n                [invalid]=\"pseudoInvalid() || null\"\n                [countrySearch]=\"true\"\n                [countries]=\"(countries | tuiSortCountries | async) || []\"\n                autocomplete=\"phone\"\n            />\n        </tui-textfield>\n        <p\n            *ngIf=\"subtitle()\"\n            class=\"text-body-s text-tui-text-tertiary\"\n        >\n            {{ subtitle() }}\n        </p>\n        <tui-error\n            formControlName=\"phone\"\n            [error]=\"[] | tuiFieldError | async\"\n        />\n        @if (showHelpNotification && pushContacts()) {\n            @for (manager of pushContacts(); track manager.id) {\n                <tui-push\n                    type=\"Свяжитесь с нами для решения возникших вопросов\"\n                    (close)=\"closeNotification()\"\n                    class=\"!w-auto\"\n                >\n                    <tui-icon icon=\"@tui.message-square\" />\n                    <sc-manager-card [manager]=\"manager\" />\n                </tui-push>\n            }\n        }\n    </label>\n\n    <ng-container *ngIf=\"showCodeFields && form.enabled && phoneCheck\">\n        <label\n            *ngIf=\"!loadingApproveCode && haveCode()\"\n            tuiLabel\n        >\n            Код из СМС\n            <tui-input\n                formControlName=\"verificationCode\"\n                [required]=\"required() || showCodeFields\"\n            >\n                Код из СМС\n                <input\n                    tuiAutoFocus\n                    tuiTextfieldLegacy\n                    [maskito]=\"verificationCodeMask\"\n                    autocomplete=\"new-password\"\n                />\n            </tui-input>\n            <tui-error\n                formControlName=\"verificationCode\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        <div\n            *tuiLet=\"!!loadingApproveCode as loadingApproveCode\"\n            class=\"flex justify-center gap-4\"\n        >\n            <button\n                *ngIf=\"!haveCode()\"\n                tuiButton\n                (click)=\"onSendCode.next()\"\n                [disabled]=\"loadingApproveCode || !phoneCheck || phoneControl.invalid\"\n                [loading]=\"loadingApproveCode\"\n                iconStart=\"@tui.sc.send\"\n            >\n                Получить код\n            </button>\n            <button\n                *ngIf=\"!loadingApproveCode && !haveCode()\"\n                tuiLink\n                [pseudo]=\"true\"\n                [disabled]=\"!phoneCheck || phoneControl.invalid\"\n                (click)=\"setHaveCode(true)\"\n            >\n                У меня есть код\n            </button>\n\n            <ng-container *tuiLet=\"timer$ | async as timer\">\n                <tui-loader\n                    *ngIf=\"haveCode()\"\n                    [showLoader]=\"loadingApproveCode\"\n                >\n                    <button\n                        tuiLink\n                        [pseudo]=\"true\"\n                        [disabled]=\"loadingApproveCode || timer\"\n                        (click)=\"onSendCode.next()\"\n                    >\n                        Повторно отправить код\n                        <ng-container\n                            *ngIf=\"timer\"\n                            class=\"!text-tui-base-08\"\n                        >\n                            (через {{ timer }})\n                        </ng-container>\n                    </button>\n                </tui-loader>\n            </ng-container>\n        </div>\n    </ng-container>\n</form>\n\n<ng-template #checkingPhone>\n    <tui-loader\n        *ngIf=\"!phoneCheck && phoneControl.valid\"\n        class=\"size-4\"\n    />\n</ng-template>\n"]}
257
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-verification-phone-check-form.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/verification/verification-phone-check-form/sc-verification-phone-check-form.component.ts","../../../../../projects/client-ui/verification/verification-phone-check-form/sc-verification-phone-check-form.component.html"],"names":[],"mappings":"AAAA,gEAAgE;AAEhE,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAe,KAAK,EAAuB,MAAM,EAA4B,MAAM,eAAe,CAAC;AACpK,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAA0B,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAE5E,OAAO,EAAiB,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAClC,OAAO,EACH,UAAU,EACV,oBAAoB,EACpB,OAAO,EACP,MAAM,EACN,QAAQ,EACR,GAAG,EAEH,EAAE,EACF,IAAI,EACJ,KAAK,EACL,WAAW,EACX,SAAS,EACT,OAAO,EACP,SAAS,EACT,SAAS,EACT,GAAG,EACH,KAAK,GACR,MAAM,MAAM,CAAC;AAGd,OAAO,EAAE,wCAAwC,EAAE,MAAM,sEAAsE,CAAC;AAChI,OAAO,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAC;AAC1D,OAAO,EAAE,4BAA4B,EAAE,MAAM,8CAA8C,CAAC;AAC5F,OAAO,EAAE,yBAAyB,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAE3D;;GAEG;AAOH,MAAM,OAAO,qCAAqC;IANlD;QAuBI;;WAEG;QACgB,wBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAEvE;;WAEG;QACgB,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAEvF;;WAEG;QACgB,SAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAE7C;;WAEG;QACa,aAAQ,GAAyB,KAAK,CAAC,KAAK,CAAC,CAAC;QAE9D;;WAEG;QACa,kBAAa,GAAyB,KAAK,CAAC,KAAK,CAAC,CAAC;QAEnE;;WAEG;QACa,aAAQ,GAAyB,KAAK,CAAC,KAAK,CAAC,CAAC;QAE9D;;WAEG;QACa,aAAQ,GAAwB,KAAK,CAAC,EAAE,CAAC,CAAC;QAE1D;;WAEG;QACa,iBAAY,GAAqC,KAAK,EAAuB,CAAC;QAE9F;;WAEG;QACa,sBAAiB,GAAqC,KAAK,EAAuB,CAAC;QAEnG;;WAEG;QACgB,cAAS,GAAiC,YAAY,EAAE,CAAC;QAE5E;;WAEG;QACgB,4BAAuB,GAA8B,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAE1G;;WAEG;QACgB,iBAAY,GAAwC,QAAQ,CAAC,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAEjI;;WAEG;QACa,aAAQ,GAAyB,KAAK,CAAC,KAAK,CAAC,CAAC;QAO9D;;WAEG;QACa,iBAAY,GAAqC,MAAM,EAAkB,CAAC;QAE1F;;WAEG;QACa,sBAAiB,GAAqC,MAAM,EAAkB,CAAC;QAE/F;;WAEG;QACgB,eAAU,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAEnE;;WAEG;QACgB,gBAAW,GAAW,MAAM,CAAC,4BAA4B,CAAC,CAAC;QAE9E;;WAEG;QACgB,wBAAmB,GAAwB,IAAI,CAAC,UAAU,CAAC,IAAI,CAC9E,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAClC,MAAM,CAAC,CAAC,KAAK,EAAmB,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAC3D,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAChB,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,IAAI,CACrD,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,EAChB,UAAU,CAAC,CAAC,KAAc,EAAE,EAAE;YAC1B,IAAI,KAAK,YAAY,iBAAiB,EAAE,CAAC;gBACrC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAyB,CAAC;gBAEtD,MAAM,KAAK,GAAG,eAAe,CAAC;gBAC9B,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAEhD,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC5B,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACtC,MAAM,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;oBAElD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACpC,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,cAAc,EAAE,aAAa,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBAChH,CAAC;YACL,CAAC;YAED,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE;YACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,EACf,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CACjD,CACJ,EACD,SAAS,CAAC,KAAK,CAAC,EAChB,KAAK,EAAE,CACV,CAAC;QAEF;;WAEG;QACgB,yBAAoB,GAAmB,2BAA2B,CAAC;QAEtF;;WAEG;QACgB,iBAAY,GAAoB,IAAI,OAAO,EAAU,CAAC;QAEzE;;;;WAIG;QACgB,WAAM,GAA8B,IAAI,CAAC,YAAY,CAAC,IAAI,CACzE,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE,CACd,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CACf,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,EAChC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,EAChC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACV,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;YACvC,MAAM,OAAO,GAAG,KAAK,GAAG,EAAE,CAAC;YAE3B,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;QACnH,CAAC,CAAC,EACF,OAAO,CAAC,IAAI,CAAC,EACb,SAAS,CAAC,IAAI,CAAC,EACf,oBAAoB,EAAE,CACzB,CACJ,CACJ,CAAC;QAEF;;WAEG;QACgB,yBAAoB,GAAG,MAAM,CAAC,wCAAwC,CAAC,CAAC;QAE3F;;WAEG;QACK,oBAAe,GAAY,IAAI,CAAC;KAuH3C;IApTG;;OAEG;IACH,IACW,cAAc,CAAC,cAAuB;QAC7C,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;QACtC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC;IACjF,CAAC;IAED;;OAEG;IACH,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAiLD;;OAEG;IACH,IAAW,IAAI;QAIX,OAAO,IAAI,CAAC,kBAAkB,EAAE,IAG9B,CAAC;IACP,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;IACpC,CAAC;IAED,kBAAkB;IACX,QAAQ;QACX,IAAI,CAAC,WAAW,GAAG,eAAe,CAAgB,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CACrE,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,uBAAuB,CAAC,wBAAwB,EAAE,CAAC;YAExD,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;gBAC5C,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACvD,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAChB,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACrC,OAAO,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,IAAI,CACtD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;oBACX,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,SAAS,IAAI,KAAK,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,EAAE,CAAC;wBACvE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;wBAEtC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;4BAC7B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;4BAEhD,OAAO,IAAI,CAAC,iBAAiB,EAAE,KAAK,MAAM,CAAC,WAAW,CAAC;wBAC3D,CAAC;wBAED,OAAO,IAAI,CAAC;oBAChB,CAAC;oBAED,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,SAAS,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,MAAM,CAAC,MAAM,EAAE,CAAC;wBAC7E,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;4BACxB,cAAc,EAAE;gCACZ,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,sDAAsD,CAAC,CAAC,CAAC,qDAAqD;6BACjI;yBACJ,CAAC,CAAC;wBACH,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;wBAElC,OAAO,KAAK,CAAC;oBACjB,CAAC;oBAED,IAAI,IAAI,CAAC,iBAAiB,EAAE,KAAK,SAAS,IAAI,IAAI,CAAC,iBAAiB,EAAE,KAAK,MAAM,CAAC,WAAW,EAAE,CAAC;wBAC5F,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;4BACxB,cAAc,EAAE;gCACZ,MAAM,CAAC,WAAW;oCACd,CAAC,CAAC,yBAAyB;oCAC3B,CAAC,CAAC,sJAAsJ;6BAC/J;yBACJ,CAAC,CAAC;wBACH,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;wBAElC,OAAO,KAAK,CAAC;oBACjB,CAAC;oBAED,OAAO,IAAI,CAAC;gBAChB,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAc,EAAE,EAAE;oBAC1B,IAAI,KAAK,YAAY,iBAAiB,EAAE,CAAC;wBACrC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAyB,CAAC;wBACtD,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,cAAc,EAAE,aAAa,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;oBAChH,CAAC;oBAED,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;gBACrB,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;oBACV,IAAI,CAAC,KAAK,EAAE,CAAC;wBACT,IAAI,CAAC,uBAAuB,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;oBAChE,CAAC;gBACL,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,CAClB,CAAC;YACN,CAAC;YAED,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAExB,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC,CAAC,EACF,KAAK,EAAE,CACV,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACO,WAAW,CAAC,QAAiB;QACnC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACO,iBAAiB;QACvB,IAAI,CAAC,uBAAuB,CAAC,wBAAwB,EAAE,CAAC;IAC5D,CAAC;+GApTQ,qCAAqC;mGAArC,qCAAqC,y0CC/ClD,4oJA0HA;;4FD3Ea,qCAAqC;kBANjD,SAAS;+BACI,kCAAkC,QAEtC,EAAE,eAAe,EAAE,MAAM,EAAE,mBAChB,uBAAuB,CAAC,MAAM;8BAOpC,cAAc;sBADxB,KAAK","sourcesContent":["/* eslint-disable no-underscore-dangle,lodash/prefer-constant */\n\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, inject, Input, input, InputSignal, model, ModelSignal, OnInit, output, OutputEmitterRef, Signal } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroup, FormGroupDirective } from '@angular/forms';\nimport { MaskitoOptions } from '@maskito/core';\nimport { ScIOrgContact, ScVerificationService } from '@snabcentr/client-core';\nimport { tuiControlValue } from '@taiga-ui/cdk';\nimport type { TuiCountryIsoCode } from '@taiga-ui/i18n';\nimport { getCountries } from 'libphonenumber-js';\nimport { isNil } from 'lodash-es';\nimport {\n    catchError,\n    distinctUntilChanged,\n    endWith,\n    filter,\n    finalize,\n    map,\n    Observable,\n    of,\n    scan,\n    share,\n    shareReplay,\n    startWith,\n    Subject,\n    switchMap,\n    takeWhile,\n    tap,\n    timer,\n} from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { SC_SHOW_HELP_NOTIFICATION_IN_PHONE_INPUT } from '../../contacts/tokens/sc-show-help-notification-in-phone-input.token';\nimport { scPhoneVerificationCodeMask } from '../../masks';\nimport { SC_VERIFICATION_CODE_TIMEOUT } from '../../providers/sc-verification-code-timeout';\nimport { ScHelpNotificationService } from '../../services';\n\n/**\n * Компонент формы проверки телефона и получения кода подтверждения.\n */\n@Component({\n    selector: 'sc-verification-phone-check-form',\n    templateUrl: './sc-verification-phone-check-form.component.html',\n    host: { ngSkipHydration: 'true' },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScVerificationPhoneCheckFormComponent implements OnInit {\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    @Input()\n    public set showCodeFields(showCodeFields: boolean) {\n        this._showCodeFields = showCodeFields;\n        this.form.controls.verificationCode[showCodeFields ? 'enable' : 'disable']();\n    }\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    public get showCodeFields(): boolean {\n        return this._showCodeFields;\n    }\n\n    /**\n     * Сервис верификации.\n     */\n    protected readonly verificationService = inject(ScVerificationService);\n\n    /**\n     * Директива c `FormGroup` из DOM.\n     */\n    protected readonly formGroupDirective = inject(FormGroupDirective, { optional: true });\n\n    /**\n     * HTTP-клиент.\n     */\n    protected readonly http = inject(HttpClient);\n\n    /**\n     * Признак, что поле ввода телефона только для чтения.\n     */\n    public readonly readOnly: InputSignal<boolean> = input(false);\n\n    /**\n     * Признак, что поле ввода телефона псевдо-невалидное.\n     */\n    public readonly pseudoInvalid: InputSignal<boolean> = input(false);\n\n    /**\n     * Признак, что поле ввода телефона и кода подтверждения обязательные.\n     */\n    public readonly required: InputSignal<boolean> = input(false);\n\n    /**\n     * Текст подсказки.\n     */\n    public readonly subtitle: InputSignal<string> = input('');\n\n    /**\n     * Признак, следует ли телефону быть в системе. От этого признака зависит, в каких случаях выдавать ошибку при проверке занятости телефона.\n     */\n    public readonly shouldBeBusy: InputSignal<boolean | undefined> = input<boolean | undefined>();\n\n    /**\n     * Признак, следует ли проверять, подтверждён ли телефон в системе. При `true` будет вызывать ошибку при наличии телефона в системе без подтверждения.\n     */\n    public readonly shouldBeConfirmed: InputSignal<boolean | undefined> = input<boolean | undefined>();\n\n    /**\n     * Список стран.\n     */\n    protected readonly countries: readonly TuiCountryIsoCode[] = getCountries();\n\n    /**\n     * Сервис для отображения Push-уведомлений с контактами для помощи клиенту.\n     */\n    protected readonly helpNotificationService: ScHelpNotificationService = inject(ScHelpNotificationService);\n\n    /**\n     * Список контактов для отправки push-уведомлений.\n     */\n    protected readonly pushContacts: Signal<ScIOrgContact[] | undefined> = toSignal(this.helpNotificationService.getContactsShow$());\n\n    /**\n     * Наличие кода подтверждения у пользователя.\n     */\n    public readonly haveCode: ModelSignal<boolean> = model(false);\n\n    /**\n     * {@link Observable} запроса проверки номера телефона.\n     */\n    public phoneCheck$?: Observable<boolean | null>;\n\n    /**\n     * {@link OutputEmitter} события изменения признака занятости телефона.\n     */\n    public readonly isBusyChange: OutputEmitterRef<boolean | null> = output<boolean | null>();\n\n    /**\n     * {@link OutputEmitter} события изменения признака подтверждения телефона.\n     */\n    public readonly isConfirmedChange: OutputEmitterRef<boolean | null> = output<boolean | null>();\n\n    /**\n     * {@link Subject} события отправки кода подтверждения.\n     */\n    protected readonly onSendCode: Subject<void> = new Subject<void>();\n\n    /**\n     * Таймаут отправки кода подтверждения.\n     */\n    protected readonly codeTimeout: number = inject(SC_VERIFICATION_CODE_TIMEOUT);\n\n    /**\n     * {@link Observable} запроса данных получения кода подтверждения.\n     */\n    protected readonly loadingApproveCode$: Observable<boolean> = this.onSendCode.pipe(\n        map(() => this.phoneControl.value),\n        filter((value): value is string => this.phoneControl.valid),\n        switchMap((value) =>\n            this.verificationService.sendPhoneApproveCode(value).pipe(\n                tap(() => {\n                    this.reloadTimer$.next(this.codeTimeout);\n                }),\n                map(() => false),\n                catchError((error: unknown) => {\n                    if (error instanceof HttpErrorResponse) {\n                        const errorResponse = error.error as ApiErrorResponse;\n\n                        const regex = /(\\d{2}):\\d{2}/;\n                        const match = regex.exec(errorResponse.message);\n\n                        if (match && match.length > 1) {\n                            const timeParts = match[0].split(':');\n                            const seconds = Number.parseInt(timeParts[1], 10);\n\n                            this.reloadTimer$.next(seconds);\n                        } else {\n                            this.phoneControl.setErrors({ serverResponse: errorResponse.errors?.['phone'] ?? [errorResponse.message] });\n                        }\n                    }\n\n                    return of(false);\n                }),\n                finalize(() => {\n                    this.setHaveCode(true);\n                }),\n                startWith(true),\n                shareReplay({ refCount: true, bufferSize: 1 })\n            )\n        ),\n        startWith(false),\n        share()\n    );\n\n    /**\n     * Маска поля ввода кода для подтверждения.\n     */\n    protected readonly verificationCodeMask: MaskitoOptions = scPhoneVerificationCodeMask;\n\n    /**\n     * {@link Subject} события запуска/остановки таймера.\n     */\n    protected readonly reloadTimer$: Subject<number> = new Subject<number>();\n\n    /**\n     * {@link Observable} Таймера.\n     *\n     * TODO: Вынести таймер в отдельную директиву TASK:[#9260].\n     */\n    protected readonly timer$: Observable<string | null> = this.reloadTimer$.pipe(\n        switchMap((sec) =>\n            timer(0, 1000).pipe(\n                scan((total) => -1 + total, sec),\n                takeWhile((total) => total >= 0),\n                map((total) => {\n                    const minutes = Math.floor(total / 60);\n                    const seconds = total % 60;\n\n                    return `${Math.round(minutes).toString().padStart(2, '0')}:${Math.round(seconds).toString().padStart(2, '0')}`;\n                }),\n                endWith(null),\n                startWith(null),\n                distinctUntilChanged()\n            )\n        )\n    );\n\n    /**\n     * Токен показа уведомления помощи.\n     */\n    protected readonly showHelpNotification = inject(SC_SHOW_HELP_NOTIFICATION_IN_PHONE_INPUT);\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    private _showCodeFields: boolean = true;\n\n    /**\n     * Группа полей ввода для формы «Вход на сайт».\n     */\n    public get form(): FormGroup<{\n        phone: FormControl<string | null>;\n        verificationCode: FormControl<string | null>;\n    }> {\n        return this.formGroupDirective?.form as FormGroup<{\n            phone: FormControl<string | null>;\n            verificationCode: FormControl<string | null>;\n        }>;\n    }\n\n    /**\n     * Поле ввода 'Номер телефона'.\n     */\n    public get phoneControl(): FormControl<string | null> {\n        return this.form.controls.phone;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.phoneCheck$ = tuiControlValue<string | null>(this.phoneControl).pipe(\n            tap(() => {\n                this.reloadTimer$.next(0);\n                this.isBusyChange.emit(null);\n                this.isConfirmedChange.emit(null);\n                this.helpNotificationService.closeAllHelpNotification();\n\n                if (this.form.controls.verificationCode.value) {\n                    this.form.controls.verificationCode.setValue(null);\n                }\n            }),\n            switchMap((value) => {\n                if (this.phoneControl.valid && !!value) {\n                    return this.verificationService.getPhoneCheck$(value).pipe(\n                        map((result) => {\n                            if (this.shouldBeBusy() === undefined && isNil(this.shouldBeConfirmed())) {\n                                this.isBusyChange.emit(result.isBusy);\n\n                                if (!isNil(result.isConfirmed)) {\n                                    this.isConfirmedChange.emit(result.isConfirmed);\n\n                                    return this.shouldBeConfirmed() === result.isConfirmed;\n                                }\n\n                                return true;\n                            }\n\n                            if (this.shouldBeBusy() !== undefined && this.shouldBeBusy() !== result.isBusy) {\n                                this.phoneControl.setErrors({\n                                    serverResponse: [\n                                        result.isBusy ? 'Пользователь с таким номером телефона уже существует' : 'Пользователя с таким номером телефона не существует',\n                                    ],\n                                });\n                                this.phoneControl.markAsTouched();\n\n                                return false;\n                            }\n\n                            if (this.shouldBeConfirmed() !== undefined && this.shouldBeConfirmed() !== result.isConfirmed) {\n                                this.phoneControl.setErrors({\n                                    serverResponse: [\n                                        result.isConfirmed\n                                            ? 'Телефон уже подтверждён'\n                                            : 'Номер телефона не подтверждён или вход по нему невозможен. Обратитесь к вашему персональному менеджеру или войдите с использованием e-mail и пароля.',\n                                    ],\n                                });\n                                this.phoneControl.markAsTouched();\n\n                                return false;\n                            }\n\n                            return true;\n                        }),\n                        catchError((error: unknown) => {\n                            if (error instanceof HttpErrorResponse) {\n                                const errorResponse = error.error as ApiErrorResponse;\n                                this.phoneControl.setErrors({ serverResponse: errorResponse.errors?.['phone'] ?? [errorResponse.message] });\n                            }\n\n                            return of(false);\n                        }),\n                        tap((check) => {\n                            if (!check) {\n                                this.helpNotificationService.helpNotificationByPhone(value);\n                            }\n                        }),\n                        startWith(null)\n                    );\n                }\n\n                this.setHaveCode(false);\n\n                return of(false);\n            }),\n            share()\n        );\n\n        this.setHaveCode(false);\n    }\n\n    /**\n     * Устанавливает состояние наличия кода подтверждения у пользователя.\n     *\n     * @param haveCode Признак того есть ли код подтверждения или нет.\n     */\n    protected setHaveCode(haveCode: boolean): void {\n        this.haveCode.set(haveCode);\n    }\n\n    /**\n     * Закрытие уведомления.\n     */\n    protected closeNotification(): void {\n        this.helpNotificationService.closeAllHelpNotification();\n    }\n}\n","@let phoneCheck = phoneCheck$ | async;\n\n<form\n    [formGroup]=\"form\"\n    *tuiLet=\"loadingApproveCode$ | async as loadingApproveCode\"\n    class=\"flex flex-col gap-3\"\n>\n    <label tuiLabel>\n        Номер телефона\n        <tui-textfield>\n            <input\n                formControlName=\"phone\"\n                tuiInputPhoneInternational\n                [invalid]=\"pseudoInvalid() || null\"\n                [countrySearch]=\"true\"\n                [countries]=\"(countries | tuiSortCountries | async) || []\"\n                autocomplete=\"phone\"\n            />\n        </tui-textfield>\n        <p\n            *ngIf=\"subtitle()\"\n            class=\"text-body-s text-tui-text-tertiary\"\n        >\n            {{ subtitle() }}\n        </p>\n        <tui-error\n            formControlName=\"phone\"\n            [error]=\"[] | tuiFieldError | async\"\n        />\n        @if (showHelpNotification && pushContacts()) {\n            @for (manager of pushContacts(); track manager.id) {\n                <tui-push\n                    type=\"Свяжитесь с нами для решения возникших вопросов\"\n                    (close)=\"closeNotification()\"\n                    class=\"!w-auto\"\n                >\n                    <tui-icon icon=\"@tui.message-square\" />\n                    <sc-manager-card [manager]=\"manager\" />\n                </tui-push>\n            }\n        }\n    </label>\n\n    <ng-container *ngIf=\"showCodeFields && form.enabled && phoneCheck\">\n        <label\n            *ngIf=\"!loadingApproveCode && haveCode()\"\n            tuiLabel\n        >\n            Код из СМС\n            <tui-input\n                formControlName=\"verificationCode\"\n                [required]=\"required() || showCodeFields\"\n            >\n                Код из СМС\n                <input\n                    tuiAutoFocus\n                    tuiTextfieldLegacy\n                    [maskito]=\"verificationCodeMask\"\n                    autocomplete=\"new-password\"\n                />\n            </tui-input>\n            <tui-error\n                formControlName=\"verificationCode\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        <div\n            *tuiLet=\"!!loadingApproveCode as loadingApproveCode\"\n            class=\"flex justify-center gap-4\"\n        >\n            <button\n                *ngIf=\"!haveCode()\"\n                tuiButton\n                (click)=\"onSendCode.next()\"\n                [disabled]=\"loadingApproveCode || !phoneCheck || phoneControl.invalid\"\n                [loading]=\"loadingApproveCode\"\n                iconStart=\"@tui.sc.send\"\n            >\n                Получить код\n            </button>\n            <button\n                *ngIf=\"!loadingApproveCode && !haveCode()\"\n                tuiLink\n                [pseudo]=\"true\"\n                [disabled]=\"!phoneCheck || phoneControl.invalid\"\n                (click)=\"setHaveCode(true)\"\n            >\n                У меня есть код\n            </button>\n\n            <ng-container *tuiLet=\"timer$ | async as timer\">\n                <tui-loader\n                    *ngIf=\"haveCode()\"\n                    [showLoader]=\"loadingApproveCode\"\n                >\n                    <button\n                        tuiLink\n                        [pseudo]=\"true\"\n                        [disabled]=\"loadingApproveCode || timer\"\n                        (click)=\"onSendCode.next()\"\n                    >\n                        Повторно отправить код\n                        <ng-container\n                            *ngIf=\"timer\"\n                            class=\"!text-tui-base-08\"\n                        >\n                            (через {{ timer }})\n                        </ng-container>\n                    </button>\n                </tui-loader>\n            </ng-container>\n        </div>\n    </ng-container>\n</form>\n\n<ng-template #checkingPhone>\n    <tui-loader\n        *ngIf=\"!phoneCheck && phoneControl.valid\"\n        class=\"size-4\"\n    />\n</ng-template>\n"]}
@@ -1091,7 +1091,7 @@ class ScVerificationPhoneCheckFormComponent {
1091
1091
  }), switchMap((value) => {
1092
1092
  if (this.phoneControl.valid && !!value) {
1093
1093
  return this.verificationService.getPhoneCheck$(value).pipe(map((result) => {
1094
- if (this.shouldBeBusy() === undefined && this.shouldBeConfirmed() !== undefined) {
1094
+ if (this.shouldBeBusy() === undefined && isNil(this.shouldBeConfirmed())) {
1095
1095
  this.isBusyChange.emit(result.isBusy);
1096
1096
  if (!isNil(result.isConfirmed)) {
1097
1097
  this.isConfirmedChange.emit(result.isConfirmed);
@@ -3921,7 +3921,7 @@ class ScHoverImageCarouselComponent {
3921
3921
  * Обработчик события `mouseleave.silent`.
3922
3922
  */
3923
3923
  onLeave() {
3924
- if (this.images.length <= 1) {
3924
+ if (this.images().length <= 1) {
3925
3925
  return;
3926
3926
  }
3927
3927
  this.currentIndex.set(0);