@snabcentr/client-ui 0.27.0 → 0.28.3
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.
Potentially problematic release.
This version of @snabcentr/client-ui might be problematic. Click here for more details.
- package/auth/sc-auth.module.d.ts +1 -2
- package/cart/cart-item-mobile/sc-cart-item-mobile.component.d.ts +15 -15
- package/catalog/price-card/sc-price-card.component.d.ts +11 -105
- package/contragents/sc-contragents.module.d.ts +1 -2
- package/directives/abstract-price-card/abstract-sc-price-card.directive.d.ts +107 -0
- package/directives/index.d.ts +1 -2
- package/esm2020/auth/sc-auth.module.mjs +3 -7
- package/esm2020/cart/cart-item-mobile/sc-cart-item-mobile.component.mjs +9 -8
- package/esm2020/catalog/price-card/sc-price-card.component.mjs +31 -142
- package/esm2020/catalog/price-list-pagination/sc-price-list-pagination.component.mjs +3 -3
- package/esm2020/contragents/sc-contragents.module.mjs +38 -20
- package/esm2020/directives/abstract-price-card/abstract-sc-price-card.directive.mjs +131 -0
- package/esm2020/directives/index.mjs +2 -3
- package/esm2020/helpers/sc-units-helper.mjs +11 -10
- package/esm2020/order/order-item-mobile/order-item-mobile.component.mjs +3 -3
- package/fesm2015/snabcentr-client-ui.mjs +301 -321
- package/fesm2015/snabcentr-client-ui.mjs.map +1 -1
- package/fesm2020/snabcentr-client-ui.mjs +299 -316
- package/fesm2020/snabcentr-client-ui.mjs.map +1 -1
- package/helpers/sc-units-helper.d.ts +6 -6
- package/order/order-item-mobile/order-item-mobile.component.d.ts +3 -3
- package/package.json +1 -1
- package/styles/tailwind/tailwind.scss +26 -37
- package/directives/carousel-item-hidden/sc-carousel-item-hidden.directive.d.ts +0 -24
- package/directives/carousel-item-hidden/sc-carousel-item-hidden.module.d.ts +0 -11
- package/esm2020/directives/carousel-item-hidden/sc-carousel-item-hidden.directive.mjs +0 -40
- package/esm2020/directives/carousel-item-hidden/sc-carousel-item-hidden.module.mjs +0 -21
| @@ -1,8 +1,8 @@ | |
| 1 1 | 
             
            import * as i0 from '@angular/core';
         | 
| 2 | 
            -
            import { EventEmitter, Component, ChangeDetectionStrategy, Inject, Input, Output, SkipSelf, Directive, HostBinding, ContentChild, ViewChild, NgModule, Optional,  | 
| 2 | 
            +
            import { EventEmitter, Component, ChangeDetectionStrategy, Inject, Input, Output, SkipSelf, Directive, HostBinding, ContentChild, ViewChild, NgModule, Optional, Injectable, ElementRef, ContentChildren, HostListener, ChangeDetectorRef, Self, inject, InjectionToken, forwardRef } from '@angular/core';
         | 
| 3 3 | 
             
            import * as i1 from '@snabcentr/client-core';
         | 
| 4 | 
            -
            import { ScUserMetrikaGoalsEnum, ScISuggestionType, ScOpfList, SC_URLS, SC_PATH_IMAGE_NOT_FOUND, SEARCH_TERM, SEARCH_TERM_PROVIDERS, ScCatalogService, ScCartService,  | 
| 5 | 
            -
            import * as  | 
| 4 | 
            +
            import { ScUserMetrikaGoalsEnum, ScISuggestionType, ScOpfList, SC_URLS, SC_PATH_IMAGE_NOT_FOUND, ScWarehouseService, ScAuthService, SEARCH_TERM, ScImageHelper, SEARCH_TERM_PROVIDERS, ScCatalogService, ScCartService, ScIconTypesEnum, ScUserService } from '@snabcentr/client-core';
         | 
| 5 | 
            +
            import * as i5 from 'rxjs';
         | 
| 6 6 | 
             
            import { Subject, map, filter, switchMap, tap, catchError, of, finalize, startWith, share, timer, scan, takeWhile, endWith, distinctUntilChanged, combineLatest, debounceTime, throwError, shareReplay, interval, takeUntil, skip, merge } from 'rxjs';
         | 
| 7 7 | 
             
            import * as i2 from '@angular/common';
         | 
| 8 8 | 
             
            import { CommonModule } from '@angular/common';
         | 
| @@ -12,9 +12,9 @@ import { HttpErrorResponse } from '@angular/common/http'; | |
| 12 12 | 
             
            import * as i3 from '@angular/forms';
         | 
| 13 13 | 
             
            import { FormGroupDirective, FormGroup, FormControl, Validators, NgControl, FormArray, FormsModule, ReactiveFormsModule } from '@angular/forms';
         | 
| 14 14 | 
             
            import * as i6 from '@taiga-ui/cdk';
         | 
| 15 | 
            -
            import { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate, TuiLetModule,  | 
| 15 | 
            +
            import { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate, TuiLetModule, tuiCreateToken, AbstractTuiNullableControl, TUI_IS_MOBILE, tuiPure, AbstractTuiControl, TuiDay, TuiDayRange, TuiMonth, TuiDestroyService, TuiRepeatTimesModule, ALWAYS_TRUE_HANDLER } from '@taiga-ui/cdk';
         | 
| 16 16 | 
             
            import * as i4$1 from '@taiga-ui/kit';
         | 
| 17 | 
            -
            import { TuiAccordionItemComponent, TuiAccordionModule, TuiElasticContainerModule, TuiInputModule, TuiFieldErrorPipeModule, TuiComboBoxModule, TuiDataListWrapperModule, TuiFilterByInputPipeModule, TuiStringifyContentPipeModule, TuiInputPhoneModule, TuiSelectModule,  | 
| 17 | 
            +
            import { TuiAccordionItemComponent, TuiAccordionModule, TuiElasticContainerModule, TuiInputModule, TuiFieldErrorPipeModule, TuiComboBoxModule, TuiDataListWrapperModule, TuiFilterByInputPipeModule, TuiStringifyContentPipeModule, TuiInputPhoneModule, TuiSelectModule, TuiCarouselModule, TuiInputPasswordModule, TuiCheckboxModule, TuiCheckboxLabeledModule, TUI_NUMBER_VALUE_TRANSFORMER, TuiInputNumberComponent, TuiIslandModule, TuiInputNumberModule, TuiHighlightModule, TuiTreeService, TuiTreeItemContentComponent, TUI_TREE_START, TUI_TREE_CONTENT, TUI_TREE_LOADING, TUI_TREE_LOADER, TuiTreeModule } from '@taiga-ui/kit';
         | 
| 18 18 | 
             
            import * as i6$1 from '@maskito/angular';
         | 
| 19 19 | 
             
            import { MaskitoModule } from '@maskito/angular';
         | 
| 20 20 | 
             
            import { __decorate } from 'tslib';
         | 
| @@ -1590,132 +1590,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 1590 1590 | 
             
                            }]
         | 
| 1591 1591 | 
             
                    }] });
         | 
| 1592 1592 |  | 
| 1593 | 
            -
            /**
         | 
| 1594 | 
            -
             * Компонент контрагента пользователя.
         | 
| 1595 | 
            -
             */
         | 
| 1596 | 
            -
            class ScContragentsAccordionItemComponent {
         | 
| 1597 | 
            -
                /**
         | 
| 1598 | 
            -
                 * Инициализирует экземпляр класса {@link ScContragentsAccordionItemComponent}.
         | 
| 1599 | 
            -
                 *
         | 
| 1600 | 
            -
                 * @param contragentService Сервис работы с контрагентами.
         | 
| 1601 | 
            -
                 */
         | 
| 1602 | 
            -
                constructor(contragentService) {
         | 
| 1603 | 
            -
                    this.contragentService = contragentService;
         | 
| 1604 | 
            -
                    /**
         | 
| 1605 | 
            -
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1606 | 
            -
                     */
         | 
| 1607 | 
            -
                    this.deleteContragentClick = new EventEmitter();
         | 
| 1608 | 
            -
                    /**
         | 
| 1609 | 
            -
                     * Событие нажатия на кнопку добавления банковского счёта контрагенту.
         | 
| 1610 | 
            -
                     */
         | 
| 1611 | 
            -
                    this.addContragentBankAccountClick = new EventEmitter();
         | 
| 1612 | 
            -
                    /**
         | 
| 1613 | 
            -
                     * Событие нажатия на кнопку удаления банковского счёта контрагента.
         | 
| 1614 | 
            -
                     */
         | 
| 1615 | 
            -
                    this.deleteContragentBankAccountClick = new EventEmitter();
         | 
| 1616 | 
            -
                    /**
         | 
| 1617 | 
            -
                     * Событие нажатия на кнопку добавления контактного лица контрагенту.
         | 
| 1618 | 
            -
                     */
         | 
| 1619 | 
            -
                    this.addContragentContactClick = new EventEmitter();
         | 
| 1620 | 
            -
                    /**
         | 
| 1621 | 
            -
                     * Событие нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 1622 | 
            -
                     */
         | 
| 1623 | 
            -
                    this.deleteContragentContactClick = new EventEmitter();
         | 
| 1624 | 
            -
                }
         | 
| 1625 | 
            -
                /** @inheritDoc */
         | 
| 1626 | 
            -
                ngOnInit() {
         | 
| 1627 | 
            -
                    this.bankAccounts$ = this.contragentService.getContragentBankAccounts$(this.contragent.id);
         | 
| 1628 | 
            -
                    this.contacts$ = this.contragentService.getContragentContacts$(this.contragent.id);
         | 
| 1629 | 
            -
                }
         | 
| 1630 | 
            -
                /**
         | 
| 1631 | 
            -
                 * Обработчик нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 1632 | 
            -
                 *
         | 
| 1633 | 
            -
                 * @param contact Контактное лицо.
         | 
| 1634 | 
            -
                 * @param contragent Контрагент.
         | 
| 1635 | 
            -
                 */
         | 
| 1636 | 
            -
                onDeleteContragentContactClick(contact, contragent) {
         | 
| 1637 | 
            -
                    this.deleteContragentContactClick.emit({ contact: contact, contragent: contragent });
         | 
| 1638 | 
            -
                }
         | 
| 1639 | 
            -
            }
         | 
| 1640 | 
            -
            ScContragentsAccordionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, deps: [{ token: i1.ScContragentService }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 1641 | 
            -
            ScContragentsAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: { contragent: "contragent" }, outputs: { deleteContragentClick: "deleteContragentClick", addContragentBankAccountClick: "addContragentBankAccountClick", deleteContragentBankAccountClick: "deleteContragentBankAccountClick", addContragentContactClick: "addContragentContactClick", deleteContragentContactClick: "deleteContragentContactClick" }, ngImport: i0, template: "<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n                </div>\n                <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n                <!-- <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n                ></button>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconTrash2Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n                ></button> -->\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n                \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n                                        <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n                                        <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n                                        <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n                                        ></button>\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n                                        ></button>\n                                    </div> -->\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion\n                *ngIf=\"contacts$\"\n                [contacts$]=\"contacts$\"\n                (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n                (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n            ></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i4.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i4.TuiNotificationComponent, selector: "tui-notification,a[tuiNotification],button[tuiNotification]", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: ScContactsAccordionComponent, selector: "sc-contacts-accordion", inputs: ["contacts$"], outputs: ["addContactClick", "deleteButtonClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 1642 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, decorators: [{
         | 
| 1643 | 
            -
                        type: Component,
         | 
| 1644 | 
            -
                        args: [{ selector: 'sc-contragents-accordion-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n                </div>\n                <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n                <!-- <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n                ></button>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconTrash2Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n                ></button> -->\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n                \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n                                        <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n                                        <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n                                        <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n                                        ></button>\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n                                        ></button>\n                                    </div> -->\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion\n                *ngIf=\"contacts$\"\n                [contacts$]=\"contacts$\"\n                (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n                (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n            ></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n" }]
         | 
| 1645 | 
            -
                    }], ctorParameters: function () { return [{ type: i1.ScContragentService }]; }, propDecorators: { contragent: [{
         | 
| 1646 | 
            -
                            type: Input
         | 
| 1647 | 
            -
                        }], deleteContragentClick: [{
         | 
| 1648 | 
            -
                            type: Output
         | 
| 1649 | 
            -
                        }], addContragentBankAccountClick: [{
         | 
| 1650 | 
            -
                            type: Output
         | 
| 1651 | 
            -
                        }], deleteContragentBankAccountClick: [{
         | 
| 1652 | 
            -
                            type: Output
         | 
| 1653 | 
            -
                        }], addContragentContactClick: [{
         | 
| 1654 | 
            -
                            type: Output
         | 
| 1655 | 
            -
                        }], deleteContragentContactClick: [{
         | 
| 1656 | 
            -
                            type: Output
         | 
| 1657 | 
            -
                        }] } });
         | 
| 1658 | 
            -
             | 
| 1659 | 
            -
            /**
         | 
| 1660 | 
            -
             * Компонент контрагента пользователя.
         | 
| 1661 | 
            -
             */
         | 
| 1662 | 
            -
            class ScContragentsAccordionComponent {
         | 
| 1663 | 
            -
                /**
         | 
| 1664 | 
            -
                 * Инициализирует экземпляр класса {@link ScContragentsAccordionComponent}.
         | 
| 1665 | 
            -
                 *
         | 
| 1666 | 
            -
                 * @param contragentService Сервис работы с контрагентами.
         | 
| 1667 | 
            -
                 */
         | 
| 1668 | 
            -
                constructor(contragentService) {
         | 
| 1669 | 
            -
                    this.contragentService = contragentService;
         | 
| 1670 | 
            -
                    /**
         | 
| 1671 | 
            -
                     * {@link Observable} данных о контрагентах пользователя.
         | 
| 1672 | 
            -
                     */
         | 
| 1673 | 
            -
                    this.contragents$ = this.contragentService.contragents$;
         | 
| 1674 | 
            -
                    /**
         | 
| 1675 | 
            -
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1676 | 
            -
                     */
         | 
| 1677 | 
            -
                    this.addContragentClick = new EventEmitter();
         | 
| 1678 | 
            -
                    /**
         | 
| 1679 | 
            -
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1680 | 
            -
                     */
         | 
| 1681 | 
            -
                    this.deleteContragentClick = new EventEmitter();
         | 
| 1682 | 
            -
                    /**
         | 
| 1683 | 
            -
                     * Событие нажатия на кнопку добавления банковского счёта контрагенту.
         | 
| 1684 | 
            -
                     */
         | 
| 1685 | 
            -
                    this.addContragentBankAccountClick = new EventEmitter();
         | 
| 1686 | 
            -
                    /**
         | 
| 1687 | 
            -
                     * Событие нажатия на кнопку удаления банковского счёта контрагента.
         | 
| 1688 | 
            -
                     */
         | 
| 1689 | 
            -
                    this.deleteContragentBankAccountClick = new EventEmitter();
         | 
| 1690 | 
            -
                    /**
         | 
| 1691 | 
            -
                     * Событие нажатия на кнопку добавления контактного лица контрагенту.
         | 
| 1692 | 
            -
                     */
         | 
| 1693 | 
            -
                    this.addContragentContactClick = new EventEmitter();
         | 
| 1694 | 
            -
                    /**
         | 
| 1695 | 
            -
                     * Событие нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 1696 | 
            -
                     */
         | 
| 1697 | 
            -
                    this.deleteContragentContactClick = new EventEmitter();
         | 
| 1698 | 
            -
                }
         | 
| 1699 | 
            -
            }
         | 
| 1700 | 
            -
            ScContragentsAccordionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionComponent, deps: [{ token: i1.ScContragentService }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 1701 | 
            -
            ScContragentsAccordionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionComponent, selector: "sc-contragents-accordion", outputs: { addContragentClick: "addContragentClick", deleteContragentClick: "deleteContragentClick", addContragentBankAccountClick: "addContragentBankAccountClick", deleteContragentBankAccountClick: "deleteContragentBankAccountClick", addContragentContactClick: "addContragentContactClick", deleteContragentContactClick: "deleteContragentContactClick" }, ngImport: i0, template: "<sc-accordion (addButtonClick)=\"addContragentClick.emit()\">\n    \u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B\n    <ng-template scAccordionContent>\n        <tui-loader *tuiLet=\"contragents$ | async as contragents\" [overlay]=\"true\" [showLoader]=\"contragents === null\">\n            <div class=\"flex flex-col gap-2\">\n                <ng-container *ngIf=\"!contragents || contragents.length; else contragentsNotExist\">\n                    <sc-contragents-accordion-item\n                        *ngFor=\"let contragent of contragents\"\n                        [contragent]=\"contragent\"\n                        (deleteContragentClick)=\"deleteContragentClick.emit($event)\"\n                        (addContragentBankAccountClick)=\"addContragentBankAccountClick.emit($event)\"\n                        (deleteContragentBankAccountClick)=\"deleteContragentBankAccountClick.emit($event)\"\n                        (addContragentContactClick)=\"addContragentContactClick.emit($event)\"\n                        (deleteContragentContactClick)=\"deleteContragentContactClick.emit($event)\"\n                    ></sc-contragents-accordion-item>\n                </ng-container>\n\n                <ng-template #contragentsNotExist>\n                    <tui-notification size=\"l\">\n                        <div class=\"flex flex-wrap gap-2 font-medium\">\u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B.</div>\n                    </tui-notification>\n                </ng-template>\n            </div>\n        </tui-loader>\n    </ng-template>\n</sc-accordion>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i4.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i4.TuiNotificationComponent, selector: "tui-notification,a[tuiNotification],button[tuiNotification]", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: ["contragent"], outputs: ["deleteContragentClick", "addContragentBankAccountClick", "deleteContragentBankAccountClick", "addContragentContactClick", "deleteContragentContactClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 1702 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionComponent, decorators: [{
         | 
| 1703 | 
            -
                        type: Component,
         | 
| 1704 | 
            -
                        args: [{ selector: 'sc-contragents-accordion', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion (addButtonClick)=\"addContragentClick.emit()\">\n    \u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B\n    <ng-template scAccordionContent>\n        <tui-loader *tuiLet=\"contragents$ | async as contragents\" [overlay]=\"true\" [showLoader]=\"contragents === null\">\n            <div class=\"flex flex-col gap-2\">\n                <ng-container *ngIf=\"!contragents || contragents.length; else contragentsNotExist\">\n                    <sc-contragents-accordion-item\n                        *ngFor=\"let contragent of contragents\"\n                        [contragent]=\"contragent\"\n                        (deleteContragentClick)=\"deleteContragentClick.emit($event)\"\n                        (addContragentBankAccountClick)=\"addContragentBankAccountClick.emit($event)\"\n                        (deleteContragentBankAccountClick)=\"deleteContragentBankAccountClick.emit($event)\"\n                        (addContragentContactClick)=\"addContragentContactClick.emit($event)\"\n                        (deleteContragentContactClick)=\"deleteContragentContactClick.emit($event)\"\n                    ></sc-contragents-accordion-item>\n                </ng-container>\n\n                <ng-template #contragentsNotExist>\n                    <tui-notification size=\"l\">\n                        <div class=\"flex flex-wrap gap-2 font-medium\">\u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B.</div>\n                    </tui-notification>\n                </ng-template>\n            </div>\n        </tui-loader>\n    </ng-template>\n</sc-accordion>\n" }]
         | 
| 1705 | 
            -
                    }], ctorParameters: function () { return [{ type: i1.ScContragentService }]; }, propDecorators: { addContragentClick: [{
         | 
| 1706 | 
            -
                            type: Output
         | 
| 1707 | 
            -
                        }], deleteContragentClick: [{
         | 
| 1708 | 
            -
                            type: Output
         | 
| 1709 | 
            -
                        }], addContragentBankAccountClick: [{
         | 
| 1710 | 
            -
                            type: Output
         | 
| 1711 | 
            -
                        }], deleteContragentBankAccountClick: [{
         | 
| 1712 | 
            -
                            type: Output
         | 
| 1713 | 
            -
                        }], addContragentContactClick: [{
         | 
| 1714 | 
            -
                            type: Output
         | 
| 1715 | 
            -
                        }], deleteContragentContactClick: [{
         | 
| 1716 | 
            -
                            type: Output
         | 
| 1717 | 
            -
                        }] } });
         | 
| 1718 | 
            -
             | 
| 1719 1593 | 
             
            /* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */
         | 
| 1720 1594 | 
             
            /**
         | 
| 1721 1595 | 
             
             * Компонент формы создания нового банковского счета контрагента.
         | 
| @@ -2022,118 +1896,143 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 2022 1896 | 
             
                            }] }]; } });
         | 
| 2023 1897 |  | 
| 2024 1898 | 
             
            /**
         | 
| 2025 | 
            -
             *  | 
| 1899 | 
            +
             * Компонент контрагента пользователя.
         | 
| 2026 1900 | 
             
             */
         | 
| 2027 | 
            -
            class  | 
| 1901 | 
            +
            class ScContragentsAccordionItemComponent {
         | 
| 2028 1902 | 
             
                /**
         | 
| 2029 | 
            -
                 * Инициализирует экземпляр класса {@link  | 
| 1903 | 
            +
                 * Инициализирует экземпляр класса {@link ScContragentsAccordionItemComponent}.
         | 
| 2030 1904 | 
             
                 *
         | 
| 2031 | 
            -
                 * @param  | 
| 1905 | 
            +
                 * @param contragentService Сервис работы с контрагентами.
         | 
| 2032 1906 | 
             
                 */
         | 
| 2033 | 
            -
                constructor( | 
| 2034 | 
            -
                    this. | 
| 1907 | 
            +
                constructor(contragentService) {
         | 
| 1908 | 
            +
                    this.contragentService = contragentService;
         | 
| 1909 | 
            +
                    /**
         | 
| 1910 | 
            +
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1911 | 
            +
                     */
         | 
| 1912 | 
            +
                    this.deleteContragentClick = new EventEmitter();
         | 
| 1913 | 
            +
                    /**
         | 
| 1914 | 
            +
                     * Событие нажатия на кнопку добавления банковского счёта контрагенту.
         | 
| 1915 | 
            +
                     */
         | 
| 1916 | 
            +
                    this.addContragentBankAccountClick = new EventEmitter();
         | 
| 1917 | 
            +
                    /**
         | 
| 1918 | 
            +
                     * Событие нажатия на кнопку удаления банковского счёта контрагента.
         | 
| 1919 | 
            +
                     */
         | 
| 1920 | 
            +
                    this.deleteContragentBankAccountClick = new EventEmitter();
         | 
| 1921 | 
            +
                    /**
         | 
| 1922 | 
            +
                     * Событие нажатия на кнопку добавления контактного лица контрагенту.
         | 
| 1923 | 
            +
                     */
         | 
| 1924 | 
            +
                    this.addContragentContactClick = new EventEmitter();
         | 
| 1925 | 
            +
                    /**
         | 
| 1926 | 
            +
                     * Событие нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 1927 | 
            +
                     */
         | 
| 1928 | 
            +
                    this.deleteContragentContactClick = new EventEmitter();
         | 
| 1929 | 
            +
                }
         | 
| 1930 | 
            +
                /** @inheritDoc */
         | 
| 1931 | 
            +
                ngOnInit() {
         | 
| 1932 | 
            +
                    this.bankAccounts$ = this.contragentService.getContragentBankAccounts$(this.contragent.id);
         | 
| 1933 | 
            +
                    this.contacts$ = this.contragentService.getContragentContacts$(this.contragent.id);
         | 
| 2035 1934 | 
             
                }
         | 
| 2036 1935 | 
             
                /**
         | 
| 2037 | 
            -
                 *  | 
| 1936 | 
            +
                 * Обработчик нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 1937 | 
            +
                 *
         | 
| 1938 | 
            +
                 * @param contact Контактное лицо.
         | 
| 1939 | 
            +
                 * @param contragent Контрагент.
         | 
| 2038 1940 | 
             
                 */
         | 
| 2039 | 
            -
                 | 
| 2040 | 
            -
                     | 
| 1941 | 
            +
                onDeleteContragentContactClick(contact, contragent) {
         | 
| 1942 | 
            +
                    this.deleteContragentContactClick.emit({ contact: contact, contragent: contragent });
         | 
| 2041 1943 | 
             
                }
         | 
| 2042 1944 | 
             
            }
         | 
| 2043 | 
            -
             | 
| 2044 | 
            -
             | 
| 2045 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type:  | 
| 2046 | 
            -
                        type:  | 
| 2047 | 
            -
                        args: [{
         | 
| 2048 | 
            -
             | 
| 2049 | 
            -
                            }]
         | 
| 2050 | 
            -
                    }], ctorParameters: function () { return [{ type: i4$1.TuiCarouselComponent, decorators: [{
         | 
| 2051 | 
            -
                                type: Inject,
         | 
| 2052 | 
            -
                                args: [TuiCarouselComponent]
         | 
| 2053 | 
            -
                            }] }]; }, propDecorators: { index: [{
         | 
| 1945 | 
            +
            ScContragentsAccordionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, deps: [{ token: i1.ScContragentService }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 1946 | 
            +
            ScContragentsAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: { contragent: "contragent" }, outputs: { deleteContragentClick: "deleteContragentClick", addContragentBankAccountClick: "addContragentBankAccountClick", deleteContragentBankAccountClick: "deleteContragentBankAccountClick", addContragentContactClick: "addContragentContactClick", deleteContragentContactClick: "deleteContragentContactClick" }, ngImport: i0, template: "<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n                </div>\n                <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n                <!-- <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n                ></button>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconTrash2Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n                ></button> -->\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n                \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n                                        <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n                                        <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n                                        <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n                                        ></button>\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n                                        ></button>\n                                    </div> -->\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion\n                *ngIf=\"contacts$\"\n                [contacts$]=\"contacts$\"\n                (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n                (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n            ></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i4.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i4.TuiNotificationComponent, selector: "tui-notification,a[tuiNotification],button[tuiNotification]", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: ScContactsAccordionComponent, selector: "sc-contacts-accordion", inputs: ["contacts$"], outputs: ["addContactClick", "deleteButtonClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 1947 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, decorators: [{
         | 
| 1948 | 
            +
                        type: Component,
         | 
| 1949 | 
            +
                        args: [{ selector: 'sc-contragents-accordion-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n                </div>\n                <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n                <!-- <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n                ></button>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconTrash2Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n                ></button> -->\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n                \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n                                        <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n                                        <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n                                        <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n                                        ></button>\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n                                        ></button>\n                                    </div> -->\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion\n                *ngIf=\"contacts$\"\n                [contacts$]=\"contacts$\"\n                (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n                (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n            ></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n" }]
         | 
| 1950 | 
            +
                    }], ctorParameters: function () { return [{ type: i1.ScContragentService }]; }, propDecorators: { contragent: [{
         | 
| 2054 1951 | 
             
                            type: Input
         | 
| 2055 | 
            -
                        }],  | 
| 2056 | 
            -
                            type:  | 
| 2057 | 
            -
             | 
| 1952 | 
            +
                        }], deleteContragentClick: [{
         | 
| 1953 | 
            +
                            type: Output
         | 
| 1954 | 
            +
                        }], addContragentBankAccountClick: [{
         | 
| 1955 | 
            +
                            type: Output
         | 
| 1956 | 
            +
                        }], deleteContragentBankAccountClick: [{
         | 
| 1957 | 
            +
                            type: Output
         | 
| 1958 | 
            +
                        }], addContragentContactClick: [{
         | 
| 1959 | 
            +
                            type: Output
         | 
| 1960 | 
            +
                        }], deleteContragentContactClick: [{
         | 
| 1961 | 
            +
                            type: Output
         | 
| 2058 1962 | 
             
                        }] } });
         | 
| 2059 1963 |  | 
| 2060 1964 | 
             
            /**
         | 
| 2061 | 
            -
             *  | 
| 2062 | 
            -
             */
         | 
| 2063 | 
            -
            class ScCarouselItemHiddenModule {
         | 
| 2064 | 
            -
            }
         | 
| 2065 | 
            -
            ScCarouselItemHiddenModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCarouselItemHiddenModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
         | 
| 2066 | 
            -
            ScCarouselItemHiddenModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ScCarouselItemHiddenModule, declarations: [ScCarouselItemHiddenDirective], imports: [TuiCarouselModule], exports: [ScCarouselItemHiddenDirective] });
         | 
| 2067 | 
            -
            ScCarouselItemHiddenModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCarouselItemHiddenModule, imports: [TuiCarouselModule] });
         | 
| 2068 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCarouselItemHiddenModule, decorators: [{
         | 
| 2069 | 
            -
                        type: NgModule,
         | 
| 2070 | 
            -
                        args: [{
         | 
| 2071 | 
            -
                                imports: [TuiCarouselModule],
         | 
| 2072 | 
            -
                                declarations: [ScCarouselItemHiddenDirective],
         | 
| 2073 | 
            -
                                exports: [ScCarouselItemHiddenDirective],
         | 
| 2074 | 
            -
                            }]
         | 
| 2075 | 
            -
                    }] });
         | 
| 2076 | 
            -
             | 
| 2077 | 
            -
            /* eslint-disable lodash/prefer-lodash-method */
         | 
| 2078 | 
            -
            /**
         | 
| 2079 | 
            -
             * Директива для перехода по нажатию клавиши enter на следующее поле ввода формы.
         | 
| 1965 | 
            +
             * Компонент контрагента пользователя.
         | 
| 2080 1966 | 
             
             */
         | 
| 2081 | 
            -
            class  | 
| 1967 | 
            +
            class ScContragentsAccordionComponent {
         | 
| 2082 1968 | 
             
                /**
         | 
| 2083 | 
            -
                 *  | 
| 1969 | 
            +
                 * Инициализирует экземпляр класса {@link ScContragentsAccordionComponent}.
         | 
| 2084 1970 | 
             
                 *
         | 
| 2085 | 
            -
                 * @param  | 
| 1971 | 
            +
                 * @param contragentService Сервис работы с контрагентами.
         | 
| 2086 1972 | 
             
                 */
         | 
| 2087 | 
            -
                 | 
| 2088 | 
            -
                     | 
| 2089 | 
            -
                     | 
| 2090 | 
            -
             | 
| 2091 | 
            -
             | 
| 2092 | 
            -
             | 
| 2093 | 
            -
             | 
| 2094 | 
            -
             | 
| 2095 | 
            -
             | 
| 2096 | 
            -
                     | 
| 1973 | 
            +
                constructor(contragentService) {
         | 
| 1974 | 
            +
                    this.contragentService = contragentService;
         | 
| 1975 | 
            +
                    /**
         | 
| 1976 | 
            +
                     * {@link Observable} данных о контрагентах пользователя.
         | 
| 1977 | 
            +
                     */
         | 
| 1978 | 
            +
                    this.contragents$ = this.contragentService.contragents$;
         | 
| 1979 | 
            +
                    /**
         | 
| 1980 | 
            +
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1981 | 
            +
                     */
         | 
| 1982 | 
            +
                    this.addContragentClick = new EventEmitter();
         | 
| 1983 | 
            +
                    /**
         | 
| 1984 | 
            +
                     * Событие нажатия на кнопку удаления контрагента.
         | 
| 1985 | 
            +
                     */
         | 
| 1986 | 
            +
                    this.deleteContragentClick = new EventEmitter();
         | 
| 1987 | 
            +
                    /**
         | 
| 1988 | 
            +
                     * Событие нажатия на кнопку добавления банковского счёта контрагенту.
         | 
| 1989 | 
            +
                     */
         | 
| 1990 | 
            +
                    this.addContragentBankAccountClick = new EventEmitter();
         | 
| 1991 | 
            +
                    /**
         | 
| 1992 | 
            +
                     * Событие нажатия на кнопку удаления банковского счёта контрагента.
         | 
| 1993 | 
            +
                     */
         | 
| 1994 | 
            +
                    this.deleteContragentBankAccountClick = new EventEmitter();
         | 
| 1995 | 
            +
                    /**
         | 
| 1996 | 
            +
                     * Событие нажатия на кнопку добавления контактного лица контрагенту.
         | 
| 1997 | 
            +
                     */
         | 
| 1998 | 
            +
                    this.addContragentContactClick = new EventEmitter();
         | 
| 1999 | 
            +
                    /**
         | 
| 2000 | 
            +
                     * Событие нажатия на кнопку удаления контактного лица у контрагента.
         | 
| 2001 | 
            +
                     */
         | 
| 2002 | 
            +
                    this.deleteContragentContactClick = new EventEmitter();
         | 
| 2097 2003 | 
             
                }
         | 
| 2098 2004 | 
             
            }
         | 
| 2099 | 
            -
             | 
| 2100 | 
            -
             | 
| 2101 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type:  | 
| 2102 | 
            -
                        type:  | 
| 2103 | 
            -
                        args: [{
         | 
| 2104 | 
            -
             | 
| 2105 | 
            -
                             | 
| 2106 | 
            -
             | 
| 2107 | 
            -
                            type:  | 
| 2108 | 
            -
             | 
| 2109 | 
            -
             | 
| 2110 | 
            -
             | 
| 2111 | 
            -
                             | 
| 2005 | 
            +
            ScContragentsAccordionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionComponent, deps: [{ token: i1.ScContragentService }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 2006 | 
            +
            ScContragentsAccordionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionComponent, selector: "sc-contragents-accordion", outputs: { addContragentClick: "addContragentClick", deleteContragentClick: "deleteContragentClick", addContragentBankAccountClick: "addContragentBankAccountClick", deleteContragentBankAccountClick: "deleteContragentBankAccountClick", addContragentContactClick: "addContragentContactClick", deleteContragentContactClick: "deleteContragentContactClick" }, ngImport: i0, template: "<sc-accordion (addButtonClick)=\"addContragentClick.emit()\">\n    \u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B\n    <ng-template scAccordionContent>\n        <tui-loader *tuiLet=\"contragents$ | async as contragents\" [overlay]=\"true\" [showLoader]=\"contragents === null\">\n            <div class=\"flex flex-col gap-2\">\n                <ng-container *ngIf=\"!contragents || contragents.length; else contragentsNotExist\">\n                    <sc-contragents-accordion-item\n                        *ngFor=\"let contragent of contragents\"\n                        [contragent]=\"contragent\"\n                        (deleteContragentClick)=\"deleteContragentClick.emit($event)\"\n                        (addContragentBankAccountClick)=\"addContragentBankAccountClick.emit($event)\"\n                        (deleteContragentBankAccountClick)=\"deleteContragentBankAccountClick.emit($event)\"\n                        (addContragentContactClick)=\"addContragentContactClick.emit($event)\"\n                        (deleteContragentContactClick)=\"deleteContragentContactClick.emit($event)\"\n                    ></sc-contragents-accordion-item>\n                </ng-container>\n\n                <ng-template #contragentsNotExist>\n                    <tui-notification size=\"l\">\n                        <div class=\"flex flex-wrap gap-2 font-medium\">\u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B.</div>\n                    </tui-notification>\n                </ng-template>\n            </div>\n        </tui-loader>\n    </ng-template>\n</sc-accordion>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i4.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i4.TuiNotificationComponent, selector: "tui-notification,a[tuiNotification],button[tuiNotification]", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: ["contragent"], outputs: ["deleteContragentClick", "addContragentBankAccountClick", "deleteContragentBankAccountClick", "addContragentContactClick", "deleteContragentContactClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 2007 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionComponent, decorators: [{
         | 
| 2008 | 
            +
                        type: Component,
         | 
| 2009 | 
            +
                        args: [{ selector: 'sc-contragents-accordion', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion (addButtonClick)=\"addContragentClick.emit()\">\n    \u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B\n    <ng-template scAccordionContent>\n        <tui-loader *tuiLet=\"contragents$ | async as contragents\" [overlay]=\"true\" [showLoader]=\"contragents === null\">\n            <div class=\"flex flex-col gap-2\">\n                <ng-container *ngIf=\"!contragents || contragents.length; else contragentsNotExist\">\n                    <sc-contragents-accordion-item\n                        *ngFor=\"let contragent of contragents\"\n                        [contragent]=\"contragent\"\n                        (deleteContragentClick)=\"deleteContragentClick.emit($event)\"\n                        (addContragentBankAccountClick)=\"addContragentBankAccountClick.emit($event)\"\n                        (deleteContragentBankAccountClick)=\"deleteContragentBankAccountClick.emit($event)\"\n                        (addContragentContactClick)=\"addContragentContactClick.emit($event)\"\n                        (deleteContragentContactClick)=\"deleteContragentContactClick.emit($event)\"\n                    ></sc-contragents-accordion-item>\n                </ng-container>\n\n                <ng-template #contragentsNotExist>\n                    <tui-notification size=\"l\">\n                        <div class=\"flex flex-wrap gap-2 font-medium\">\u041A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u044B \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B.</div>\n                    </tui-notification>\n                </ng-template>\n            </div>\n        </tui-loader>\n    </ng-template>\n</sc-accordion>\n" }]
         | 
| 2010 | 
            +
                    }], ctorParameters: function () { return [{ type: i1.ScContragentService }]; }, propDecorators: { addContragentClick: [{
         | 
| 2011 | 
            +
                            type: Output
         | 
| 2012 | 
            +
                        }], deleteContragentClick: [{
         | 
| 2013 | 
            +
                            type: Output
         | 
| 2014 | 
            +
                        }], addContragentBankAccountClick: [{
         | 
| 2015 | 
            +
                            type: Output
         | 
| 2016 | 
            +
                        }], deleteContragentBankAccountClick: [{
         | 
| 2017 | 
            +
                            type: Output
         | 
| 2018 | 
            +
                        }], addContragentContactClick: [{
         | 
| 2019 | 
            +
                            type: Output
         | 
| 2020 | 
            +
                        }], deleteContragentContactClick: [{
         | 
| 2021 | 
            +
                            type: Output
         | 
| 2112 2022 | 
             
                        }] } });
         | 
| 2113 2023 |  | 
| 2114 | 
            -
            /**
         | 
| 2115 | 
            -
             * Модуль директивы для перехода по нажатию клавиши enter на следующее поле ввода формы.
         | 
| 2116 | 
            -
             */
         | 
| 2117 | 
            -
            class ScNextInputFocusModule {
         | 
| 2118 | 
            -
            }
         | 
| 2119 | 
            -
            ScNextInputFocusModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
         | 
| 2120 | 
            -
            ScNextInputFocusModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, declarations: [ScNextInputFocusDirective], exports: [ScNextInputFocusDirective] });
         | 
| 2121 | 
            -
            ScNextInputFocusModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule });
         | 
| 2122 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, decorators: [{
         | 
| 2123 | 
            -
                        type: NgModule,
         | 
| 2124 | 
            -
                        args: [{
         | 
| 2125 | 
            -
                                declarations: [ScNextInputFocusDirective],
         | 
| 2126 | 
            -
                                exports: [ScNextInputFocusDirective],
         | 
| 2127 | 
            -
                            }]
         | 
| 2128 | 
            -
                    }] });
         | 
| 2129 | 
            -
             | 
| 2130 2024 | 
             
            /**
         | 
| 2131 2025 | 
             
             * Модуль для отображение контента разделами, с возможностью скрывать и отображать содержимое.
         | 
| 2132 2026 | 
             
             */
         | 
| 2133 2027 | 
             
            class ScContragentsModule {
         | 
| 2134 2028 | 
             
            }
         | 
| 2135 2029 | 
             
            ScContragentsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
         | 
| 2136 | 
            -
            ScContragentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsModule, declarations: [ScContragentsAccordionComponent, | 
| 2030 | 
            +
            ScContragentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsModule, declarations: [ScContragentsAccordionComponent,
         | 
| 2031 | 
            +
                    ScContragentsAccordionItemComponent,
         | 
| 2032 | 
            +
                    ScNewContragentBankAccountsFormComponent,
         | 
| 2033 | 
            +
                    ScAddContragentBankAccountsDialogComponent,
         | 
| 2034 | 
            +
                    ScAddContragentDialogComponent,
         | 
| 2035 | 
            +
                    ScNewContragentFormComponent], imports: [FormsModule,
         | 
| 2137 2036 | 
             
                    ReactiveFormsModule,
         | 
| 2138 2037 | 
             
                    CommonModule,
         | 
| 2139 2038 | 
             
                    ScAccordionModule,
         | 
| @@ -2154,8 +2053,11 @@ ScContragentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", ver | |
| 2154 2053 | 
             
                    MaskitoModule,
         | 
| 2155 2054 | 
             
                    ScFormFieldsModule,
         | 
| 2156 2055 | 
             
                    TuiElasticContainerModule,
         | 
| 2157 | 
            -
                    TuiCarouselModule,
         | 
| 2158 | 
            -
                     | 
| 2056 | 
            +
                    TuiCarouselModule], exports: [ScContragentsAccordionComponent,
         | 
| 2057 | 
            +
                    ScNewContragentBankAccountsFormComponent,
         | 
| 2058 | 
            +
                    ScAddContragentBankAccountsDialogComponent,
         | 
| 2059 | 
            +
                    ScAddContragentDialogComponent,
         | 
| 2060 | 
            +
                    ScNewContragentFormComponent] });
         | 
| 2159 2061 | 
             
            ScContragentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsModule, imports: [FormsModule,
         | 
| 2160 2062 | 
             
                    ReactiveFormsModule,
         | 
| 2161 2063 | 
             
                    CommonModule,
         | 
| @@ -2177,12 +2079,18 @@ ScContragentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver | |
| 2177 2079 | 
             
                    MaskitoModule,
         | 
| 2178 2080 | 
             
                    ScFormFieldsModule,
         | 
| 2179 2081 | 
             
                    TuiElasticContainerModule,
         | 
| 2180 | 
            -
                    TuiCarouselModule | 
| 2181 | 
            -
                    ScCarouselItemHiddenModule] });
         | 
| 2082 | 
            +
                    TuiCarouselModule] });
         | 
| 2182 2083 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsModule, decorators: [{
         | 
| 2183 2084 | 
             
                        type: NgModule,
         | 
| 2184 2085 | 
             
                        args: [{
         | 
| 2185 | 
            -
                                declarations: [ | 
| 2086 | 
            +
                                declarations: [
         | 
| 2087 | 
            +
                                    ScContragentsAccordionComponent,
         | 
| 2088 | 
            +
                                    ScContragentsAccordionItemComponent,
         | 
| 2089 | 
            +
                                    ScNewContragentBankAccountsFormComponent,
         | 
| 2090 | 
            +
                                    ScAddContragentBankAccountsDialogComponent,
         | 
| 2091 | 
            +
                                    ScAddContragentDialogComponent,
         | 
| 2092 | 
            +
                                    ScNewContragentFormComponent,
         | 
| 2093 | 
            +
                                ],
         | 
| 2186 2094 | 
             
                                imports: [
         | 
| 2187 2095 | 
             
                                    FormsModule,
         | 
| 2188 2096 | 
             
                                    ReactiveFormsModule,
         | 
| @@ -2206,9 +2114,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 2206 2114 | 
             
                                    ScFormFieldsModule,
         | 
| 2207 2115 | 
             
                                    TuiElasticContainerModule,
         | 
| 2208 2116 | 
             
                                    TuiCarouselModule,
         | 
| 2209 | 
            -
                                    ScCarouselItemHiddenModule
         | 
| 2210 2117 | 
             
                                ],
         | 
| 2211 | 
            -
                                exports: [ | 
| 2118 | 
            +
                                exports: [
         | 
| 2119 | 
            +
                                    ScContragentsAccordionComponent,
         | 
| 2120 | 
            +
                                    ScNewContragentBankAccountsFormComponent,
         | 
| 2121 | 
            +
                                    ScAddContragentBankAccountsDialogComponent,
         | 
| 2122 | 
            +
                                    ScAddContragentDialogComponent,
         | 
| 2123 | 
            +
                                    ScNewContragentFormComponent,
         | 
| 2124 | 
            +
                                ],
         | 
| 2212 2125 | 
             
                            }]
         | 
| 2213 2126 | 
             
                    }] });
         | 
| 2214 2127 |  | 
| @@ -2308,8 +2221,7 @@ ScAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: " | |
| 2308 2221 | 
             
                    TuiSelectModule,
         | 
| 2309 2222 | 
             
                    TuiElasticContainerModule,
         | 
| 2310 2223 | 
             
                    ScContragentsModule,
         | 
| 2311 | 
            -
                    ScContactsModule,
         | 
| 2312 | 
            -
                    ScCarouselItemHiddenModule], exports: [ScSignInFormComponent, ScSignInFormByPhoneComponent, ScSignInFormByEmailComponent, ScSignUpFormComponent] });
         | 
| 2224 | 
            +
                    ScContactsModule], exports: [ScSignInFormComponent, ScSignInFormByPhoneComponent, ScSignInFormByEmailComponent, ScSignUpFormComponent] });
         | 
| 2313 2225 | 
             
            ScAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAuthModule, imports: [CommonModule,
         | 
| 2314 2226 | 
             
                    FormsModule,
         | 
| 2315 2227 | 
             
                    ReactiveFormsModule,
         | 
| @@ -2336,8 +2248,7 @@ ScAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: " | |
| 2336 2248 | 
             
                    TuiSelectModule,
         | 
| 2337 2249 | 
             
                    TuiElasticContainerModule,
         | 
| 2338 2250 | 
             
                    ScContragentsModule,
         | 
| 2339 | 
            -
                    ScContactsModule | 
| 2340 | 
            -
                    ScCarouselItemHiddenModule] });
         | 
| 2251 | 
            +
                    ScContactsModule] });
         | 
| 2341 2252 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAuthModule, decorators: [{
         | 
| 2342 2253 | 
             
                        type: NgModule,
         | 
| 2343 2254 | 
             
                        args: [{
         | 
| @@ -2370,7 +2281,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 2370 2281 | 
             
                                    TuiElasticContainerModule,
         | 
| 2371 2282 | 
             
                                    ScContragentsModule,
         | 
| 2372 2283 | 
             
                                    ScContactsModule,
         | 
| 2373 | 
            -
                                    ScCarouselItemHiddenModule,
         | 
| 2374 2284 | 
             
                                ],
         | 
| 2375 2285 | 
             
                                exports: [ScSignInFormComponent, ScSignInFormByPhoneComponent, ScSignInFormByEmailComponent, ScSignUpFormComponent],
         | 
| 2376 2286 | 
             
                            }]
         | 
| @@ -2645,12 +2555,13 @@ const SC_LINEAR_VALUES = ['пог.м.', 'м.', 'м2']; | |
| 2645 2555 | 
             
             */
         | 
| 2646 2556 | 
             
            const SC_LINEAR_VALUES_TOKEN = tuiCreateToken(SC_LINEAR_VALUES);
         | 
| 2647 2557 |  | 
| 2558 | 
            +
            /* eslint-disable lodash/prefer-lodash-method */
         | 
| 2648 2559 | 
             
            /**
         | 
| 2649 2560 | 
             
             * Класс хэлпер для работы со значениями единиц измерения товара.
         | 
| 2650 2561 | 
             
             */
         | 
| 2651 | 
            -
            class  | 
| 2562 | 
            +
            class ScUnitsHelper {
         | 
| 2652 2563 | 
             
                /**
         | 
| 2653 | 
            -
                 * Инициирует экземпляр класса {@link  | 
| 2564 | 
            +
                 * Инициирует экземпляр класса {@link ScUnitsHelper}.
         | 
| 2654 2565 | 
             
                 *
         | 
| 2655 2566 | 
             
                 * @param linearValues Единицы измерения линейной величины.
         | 
| 2656 2567 | 
             
                 */
         | 
| @@ -2660,7 +2571,7 @@ class UnitsHelper { | |
| 2660 2571 | 
             
                /**
         | 
| 2661 2572 | 
             
                 * Возвращает признак возможности продажи товара на метраж.
         | 
| 2662 2573 | 
             
                 *
         | 
| 2663 | 
            -
                 * @param  | 
| 2574 | 
            +
                 * @param product Товар для которого нужно проверить возможность продажи на метраж.
         | 
| 2664 2575 | 
             
                 */
         | 
| 2665 2576 | 
             
                productIsMeasurable(product) {
         | 
| 2666 2577 | 
             
                    return this.linearValues.includes(product.unit);
         | 
| @@ -2668,18 +2579,18 @@ class UnitsHelper { | |
| 2668 2579 | 
             
                /**
         | 
| 2669 2580 | 
             
                 * Возвращает кратность количества для товара.
         | 
| 2670 2581 | 
             
                 *
         | 
| 2671 | 
            -
                 * @param  | 
| 2582 | 
            +
                 * @param product Товар для которого нужно вернуть кратность количества.
         | 
| 2672 2583 | 
             
                 */
         | 
| 2673 2584 | 
             
                productMultiplicity(product) {
         | 
| 2674 | 
            -
                    return product | 
| 2585 | 
            +
                    return product.minCount && !this.linearValues.includes(product.unit) ? product.minCount : 1;
         | 
| 2675 2586 | 
             
                }
         | 
| 2676 2587 | 
             
            }
         | 
| 2677 | 
            -
             | 
| 2678 | 
            -
             | 
| 2679 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type:  | 
| 2588 | 
            +
            ScUnitsHelper.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScUnitsHelper, deps: [{ token: SC_LINEAR_VALUES_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable });
         | 
| 2589 | 
            +
            ScUnitsHelper.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScUnitsHelper, providedIn: 'root' });
         | 
| 2590 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScUnitsHelper, decorators: [{
         | 
| 2680 2591 | 
             
                        type: Injectable,
         | 
| 2681 2592 | 
             
                        args: [{
         | 
| 2682 | 
            -
                                providedIn: 'root'
         | 
| 2593 | 
            +
                                providedIn: 'root',
         | 
| 2683 2594 | 
             
                            }]
         | 
| 2684 2595 | 
             
                    }], ctorParameters: function () { return [{ type: undefined, decorators: [{
         | 
| 2685 2596 | 
             
                                type: Inject,
         | 
| @@ -2879,6 +2790,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 2879 2790 | 
             
                            type: Input
         | 
| 2880 2791 | 
             
                        }] } });
         | 
| 2881 2792 |  | 
| 2793 | 
            +
            /* eslint-disable no-underscore-dangle */
         | 
| 2882 2794 | 
             
            /**
         | 
| 2883 2795 | 
             
             * Компонент карточки элемента корзины.
         | 
| 2884 2796 | 
             
             */
         | 
| @@ -2946,7 +2858,7 @@ class ScCartItemMobileComponent { | |
| 2946 2858 | 
             
                 * Отобразить спецификацию.
         | 
| 2947 2859 | 
             
                 */
         | 
| 2948 2860 | 
             
                showSpecification() {
         | 
| 2949 | 
            -
                    this.previewDialogService.open(this.specificationPreviewRef  | 
| 2861 | 
            +
                    this.previewDialogService.open(this.specificationPreviewRef ?? '').subscribe();
         | 
| 2950 2862 | 
             
                }
         | 
| 2951 2863 | 
             
                /**
         | 
| 2952 2864 | 
             
                 * Возвращает ссылку на изображение карточки товара.
         | 
| @@ -2955,12 +2867,12 @@ class ScCartItemMobileComponent { | |
| 2955 2867 | 
             
                    return this.product?.getImagePreview(this.urls.imgServerUrl) ?? this.urls.imgServerUrl + this.pathImageNotFound;
         | 
| 2956 2868 | 
             
                }
         | 
| 2957 2869 | 
             
            }
         | 
| 2958 | 
            -
            ScCartItemMobileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCartItemMobileComponent, deps: [{ token:  | 
| 2870 | 
            +
            ScCartItemMobileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCartItemMobileComponent, deps: [{ token: ScUnitsHelper }, { token: TuiPreviewDialogService }, { token: SC_URLS }, { token: SC_PATH_IMAGE_NOT_FOUND }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 2959 2871 | 
             
            ScCartItemMobileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScCartItemMobileComponent, selector: "sc-cart-item-mobile", inputs: { cartItem: "cartItem" }, outputs: { quantityValueChanges: "quantityValueChanges", clickDeleteEvent: "clickDeleteEvent", clickSettingsEvent: "clickSettingsEvent", clickCardEvent: "clickCardEvent" }, viewQueries: [{ propertyName: "specificationPreviewRef", first: true, predicate: ["specificationPreview"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"cartItem && product; else skeleton\">\n    <!-- TODO: \u041D\u0435\u043E\u0431\u0445\u043E\u0434\u0438\u043C\u0430 \u0440\u0435\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u044F \u0444\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B\u0430.\n    <button tuiIconButton size=\"m\" icon=\"scIconVerticalThreeDots\" appearance=\"float\" tuiMode=\"onLight\" class=\"!absolute right-0 top-0\"></button> -->\n    <div class=\"flex bg-white border border-tui-base-04 shadow-sc-2 rounded-xl min-w-[18rem] gap-2 p-2\">\n        <div class=\"flex w-40 items-center\">\n            <img (click)=\"clickCardEvent.emit()\" [src]=\"getCardImage()\" [alt]=\"product.name\" class=\"rounded-xl w-full max-h-full object-cover\" />\n        </div>\n        <div class=\"flex flex-col sm:flex-row sm:gap-5 items-center gap-2 justify-between w-full\">\n            <div class=\"flex flex-col self-start max-w-full gap-1\">\n                <a tuiLink (click)=\"clickCardEvent.emit()\">\n                    <span class=\"font-bold\">{{ product.name }}</span>\n                </a>\n\n                <div class=\"flex flex-wrap gap-y-1 gap-x-2 w-full text-xs text-tui-base-05\">\n                    <p *ngIf=\"product.pack\">\u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}</p>\n                    <p>\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n                </div>\n\n                <div class=\"flex flex-wrap items-center gap-y-1 gap-x-2 w-full\">\n                    <p *ngIf=\"!product.priceInRub\" class=\"font-bold\">{{ product.costString }}</p>\n                    <p class=\"font-bold text-xs text-tui-base-05\">{{ product.costRubString }}</p>\n                    <span *ngIf=\"product.discount\" class=\"flex items-center\">\n                        <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                        <span class=\"text-tui-success-fill font-bold\"> -{{ product.discount.percent }}% </span>\n                        <tui-svg src=\"tuiIconInfoLarge\" [tuiHint]=\"discountHint\" [tuiHintShowDelay]=\"100\" tuiHintDirection=\"top\" class=\"!text-xs !h-4\"></tui-svg>\n                        <ng-template #discountHint>\n                            <div class=\"font-bold\">{{ product.discount.name }}</div>\n                            <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                        </ng-template>\n                    </span>\n                </div>\n\n                <sc-price-warehouse-stock [product]=\"product\"></sc-price-warehouse-stock>\n\n                <div *ngIf=\"cartItem.height || cartItem.length || cartItem.width\" class=\"flex gap-1 items-center\">\n                    <button\n                        tuiIconButton\n                        icon=\"tuiIconSettings\"\n                        (click)=\"clickSettingsEvent.emit()\"\n                        size=\"s\"\n                        appearance=\"secondary\"\n                        tuiMode=\"onLight\"\n                        class=\"mr-2 !self-center\"\n                    ></button>\n                    <div class=\"flex flex-wrap gap-x-2 font-thin text-xs text-tui-base-04\">\n                        <p *ngIf=\"cartItem.marker\">\u041C\u0430\u0440\u043A\u0438\u0440\u043E\u0432\u043A\u0430: {{ cartItem.marker }}</p>\n                        <p *ngIf=\"cartItem.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ cartItem.width }} \u043C.</p>\n                        <ng-container *ngIf=\"cartItem.height; else length\">\n                            <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ cartItem.height }} \u043C.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"cartItem.length\">\u0414\u043B\u0438\u043D\u0430: {{ cartItem.length }} \u043C.</p>\n                        </ng-template>\n                    </div>\n                </div>\n\n                <a tuiLink *ngIf=\"cartItem.specificationImgUrl\" (click)=\"showSpecification()\">\u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F</a>\n                <ng-template #specificationPreview let-preview>\n                    <tui-preview [rotatable]=\"false\" [zoomable]=\"false\">\n                        <img *polymorpheusOutlet=\"cartItem.specificationImgUrl as src\" alt=\"preview\" [src]=\"cartItem.specificationImgUrl\" />\n                        <button icon=\"tuiIconClose\" title=\"Close\" tuiIconButton tuiPreviewAction type=\"button\" (click)=\"preview.complete()\"></button>\n                    </tui-preview>\n                </ng-template>\n            </div>\n            <div class=\"flex flex-col self-start gap-1 sm:mr-9 sm:self-center\">\n                <div class=\"flex gap-2\">\n                    <sc-input-quantity\n                        #inputQuantity\n                        *ngIf=\"quantityControl\"\n                        [formControl]=\"quantityControl\"\n                        [showCross]=\"false\"\n                        size=\"s\"\n                        [step]=\"unitsHelper.productMultiplicity(product)\"\n                        (keydown.enter)=\"inputQuantity.nativeFocusableElement?.blur()\"\n                        class=\"w-28\"\n                    ></sc-input-quantity>\n                    <button tuiIconButton icon=\"tuiIconTrash2\" shape=\"rounded\" size=\"xs\" (click)=\"clickDeleteEvent.emit()\"></button>\n                </div>\n                <p class=\"font-bold text-tui-text-01 text-sm\">\u0418\u0442\u043E\u0433\u043E: {{ cartItem.costRub | tuiFormatNumber }} {{ 'RUB' | tuiCurrency }}</p>\n            </div>\n        </div>\n    </div>\n</ng-container>\n\n<ng-template #skeleton>\n    <div class=\"flex gap-2 w-full\">\n        <div class=\"h-20 w-20 bg-tui-base-02 rounded-xl\"></div>\n        <div class=\"flex flex-col grow gap-2.5 bg-white\">\n            <div class=\"w-full h-4 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"w-3/5 h-4 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"w-4/5 h-4 rounded-xl bg-tui-base-02\"></div>\n        </div>\n    </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { kind: "component", type: ScInputQuantityComponent, selector: "sc-input-quantity", inputs: ["step", "showLoader", "showCross", "appearance", "isDisabled", "size"], outputs: ["clickClearEvent"] }, { kind: "component", type: ScPriceWarehouseStockComponent, selector: "sc-price-warehouse-stock", inputs: ["classList", "product", "withStockHint", "fromMain"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i4.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "component", type: i4.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { kind: "directive", type: i4.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { kind: "directive", type: i4.TuiHintDriverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)" }, { kind: "directive", type: i4.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"], exportAs: ["tuiHintHover"] }, { kind: "directive", type: i4.TuiHintPositionDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintDirection"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i7$1.TuiPreviewComponent, selector: "tui-preview", inputs: ["zoomable", "rotatable"] }, { kind: "directive", type: i7$1.TuiPreviewActionDirective, selector: "[tuiPreviewAction]" }, { kind: "directive", type: i2$1.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "pipe", type: i9.TuiCurrencyPipe, name: "tuiCurrency" }, { kind: "pipe", type: i4.TuiFormatNumberPipe, name: "tuiFormatNumber" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 2960 2872 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScCartItemMobileComponent, decorators: [{
         | 
| 2961 2873 | 
             
                        type: Component,
         | 
| 2962 2874 | 
             
                        args: [{ selector: 'sc-cart-item-mobile', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"cartItem && product; else skeleton\">\n    <!-- TODO: \u041D\u0435\u043E\u0431\u0445\u043E\u0434\u0438\u043C\u0430 \u0440\u0435\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u044F \u0444\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B\u0430.\n    <button tuiIconButton size=\"m\" icon=\"scIconVerticalThreeDots\" appearance=\"float\" tuiMode=\"onLight\" class=\"!absolute right-0 top-0\"></button> -->\n    <div class=\"flex bg-white border border-tui-base-04 shadow-sc-2 rounded-xl min-w-[18rem] gap-2 p-2\">\n        <div class=\"flex w-40 items-center\">\n            <img (click)=\"clickCardEvent.emit()\" [src]=\"getCardImage()\" [alt]=\"product.name\" class=\"rounded-xl w-full max-h-full object-cover\" />\n        </div>\n        <div class=\"flex flex-col sm:flex-row sm:gap-5 items-center gap-2 justify-between w-full\">\n            <div class=\"flex flex-col self-start max-w-full gap-1\">\n                <a tuiLink (click)=\"clickCardEvent.emit()\">\n                    <span class=\"font-bold\">{{ product.name }}</span>\n                </a>\n\n                <div class=\"flex flex-wrap gap-y-1 gap-x-2 w-full text-xs text-tui-base-05\">\n                    <p *ngIf=\"product.pack\">\u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}</p>\n                    <p>\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n                </div>\n\n                <div class=\"flex flex-wrap items-center gap-y-1 gap-x-2 w-full\">\n                    <p *ngIf=\"!product.priceInRub\" class=\"font-bold\">{{ product.costString }}</p>\n                    <p class=\"font-bold text-xs text-tui-base-05\">{{ product.costRubString }}</p>\n                    <span *ngIf=\"product.discount\" class=\"flex items-center\">\n                        <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                        <span class=\"text-tui-success-fill font-bold\"> -{{ product.discount.percent }}% </span>\n                        <tui-svg src=\"tuiIconInfoLarge\" [tuiHint]=\"discountHint\" [tuiHintShowDelay]=\"100\" tuiHintDirection=\"top\" class=\"!text-xs !h-4\"></tui-svg>\n                        <ng-template #discountHint>\n                            <div class=\"font-bold\">{{ product.discount.name }}</div>\n                            <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                        </ng-template>\n                    </span>\n                </div>\n\n                <sc-price-warehouse-stock [product]=\"product\"></sc-price-warehouse-stock>\n\n                <div *ngIf=\"cartItem.height || cartItem.length || cartItem.width\" class=\"flex gap-1 items-center\">\n                    <button\n                        tuiIconButton\n                        icon=\"tuiIconSettings\"\n                        (click)=\"clickSettingsEvent.emit()\"\n                        size=\"s\"\n                        appearance=\"secondary\"\n                        tuiMode=\"onLight\"\n                        class=\"mr-2 !self-center\"\n                    ></button>\n                    <div class=\"flex flex-wrap gap-x-2 font-thin text-xs text-tui-base-04\">\n                        <p *ngIf=\"cartItem.marker\">\u041C\u0430\u0440\u043A\u0438\u0440\u043E\u0432\u043A\u0430: {{ cartItem.marker }}</p>\n                        <p *ngIf=\"cartItem.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ cartItem.width }} \u043C.</p>\n                        <ng-container *ngIf=\"cartItem.height; else length\">\n                            <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ cartItem.height }} \u043C.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"cartItem.length\">\u0414\u043B\u0438\u043D\u0430: {{ cartItem.length }} \u043C.</p>\n                        </ng-template>\n                    </div>\n                </div>\n\n                <a tuiLink *ngIf=\"cartItem.specificationImgUrl\" (click)=\"showSpecification()\">\u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F</a>\n                <ng-template #specificationPreview let-preview>\n                    <tui-preview [rotatable]=\"false\" [zoomable]=\"false\">\n                        <img *polymorpheusOutlet=\"cartItem.specificationImgUrl as src\" alt=\"preview\" [src]=\"cartItem.specificationImgUrl\" />\n                        <button icon=\"tuiIconClose\" title=\"Close\" tuiIconButton tuiPreviewAction type=\"button\" (click)=\"preview.complete()\"></button>\n                    </tui-preview>\n                </ng-template>\n            </div>\n            <div class=\"flex flex-col self-start gap-1 sm:mr-9 sm:self-center\">\n                <div class=\"flex gap-2\">\n                    <sc-input-quantity\n                        #inputQuantity\n                        *ngIf=\"quantityControl\"\n                        [formControl]=\"quantityControl\"\n                        [showCross]=\"false\"\n                        size=\"s\"\n                        [step]=\"unitsHelper.productMultiplicity(product)\"\n                        (keydown.enter)=\"inputQuantity.nativeFocusableElement?.blur()\"\n                        class=\"w-28\"\n                    ></sc-input-quantity>\n                    <button tuiIconButton icon=\"tuiIconTrash2\" shape=\"rounded\" size=\"xs\" (click)=\"clickDeleteEvent.emit()\"></button>\n                </div>\n                <p class=\"font-bold text-tui-text-01 text-sm\">\u0418\u0442\u043E\u0433\u043E: {{ cartItem.costRub | tuiFormatNumber }} {{ 'RUB' | tuiCurrency }}</p>\n            </div>\n        </div>\n    </div>\n</ng-container>\n\n<ng-template #skeleton>\n    <div class=\"flex gap-2 w-full\">\n        <div class=\"h-20 w-20 bg-tui-base-02 rounded-xl\"></div>\n        <div class=\"flex flex-col grow gap-2.5 bg-white\">\n            <div class=\"w-full h-4 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"w-3/5 h-4 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"w-4/5 h-4 rounded-xl bg-tui-base-02\"></div>\n        </div>\n    </div>\n</ng-template>\n" }]
         | 
| 2963 | 
            -
                    }], ctorParameters: function () { return [{ type:  | 
| 2875 | 
            +
                    }], ctorParameters: function () { return [{ type: ScUnitsHelper }, { type: i7$1.TuiPreviewDialogService, decorators: [{
         | 
| 2964 2876 | 
             
                                type: Inject,
         | 
| 2965 2877 | 
             
                                args: [TuiPreviewDialogService]
         | 
| 2966 2878 | 
             
                            }] }, { type: undefined, decorators: [{
         | 
| @@ -2969,11 +2881,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 2969 2881 | 
             
                            }] }, { type: undefined, decorators: [{
         | 
| 2970 2882 | 
             
                                type: Inject,
         | 
| 2971 2883 | 
             
                                args: [SC_PATH_IMAGE_NOT_FOUND]
         | 
| 2972 | 
            -
                            }] }]; }, propDecorators: {  | 
| 2884 | 
            +
                            }] }]; }, propDecorators: { cartItem: [{
         | 
| 2885 | 
            +
                            type: Input
         | 
| 2886 | 
            +
                        }], specificationPreviewRef: [{
         | 
| 2973 2887 | 
             
                            type: ViewChild,
         | 
| 2974 2888 | 
             
                            args: ['specificationPreview']
         | 
| 2975 | 
            -
                        }], cartItem: [{
         | 
| 2976 | 
            -
                            type: Input
         | 
| 2977 2889 | 
             
                        }], quantityValueChanges: [{
         | 
| 2978 2890 | 
             
                            type: Output
         | 
| 2979 2891 | 
             
                        }], clickDeleteEvent: [{
         | 
| @@ -3208,36 +3120,69 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 3208 3120 | 
             
                            args: ['mouseleave']
         | 
| 3209 3121 | 
             
                        }] } });
         | 
| 3210 3122 |  | 
| 3211 | 
            -
            /* eslint-disable  | 
| 3123 | 
            +
            /* eslint-disable lodash/prefer-lodash-method */
         | 
| 3212 3124 | 
             
            /**
         | 
| 3213 | 
            -
             *  | 
| 3125 | 
            +
             * Директива для перехода по нажатию клавиши enter на следующее поле ввода формы.
         | 
| 3214 3126 | 
             
             */
         | 
| 3215 | 
            -
            class  | 
| 3127 | 
            +
            class ScNextInputFocusDirective {
         | 
| 3216 3128 | 
             
                /**
         | 
| 3217 | 
            -
                 *  | 
| 3129 | 
            +
                 * Слушатель нажатия на клавишу enter. Предотвращает событие submit, выполняет смену фокуса на следующее поле ввода TuiFocusableElementAccessor.
         | 
| 3218 3130 | 
             
                 *
         | 
| 3219 | 
            -
                 * @param  | 
| 3220 | 
            -
                 * @param authService Сервис аутентификации пользователей.
         | 
| 3221 | 
            -
                 * @param warehouseService Сервис для работы со складами.
         | 
| 3222 | 
            -
                 * @param urls Список ссылок на разделы backend'a.
         | 
| 3223 | 
            -
                 * @param pathImageNotFound Путь до изображения 'Товар не найден'.
         | 
| 3224 | 
            -
                 * @param search$ Провайдер поиска терма.
         | 
| 3225 | 
            -
                 * @param cdr Объект для работы с обнаружением изменений.
         | 
| 3226 | 
            -
                 * @param imageHelper Хелпер для работы с изображениями товара.
         | 
| 3131 | 
            +
                 * @param event Объект события нажатия на клавишу.
         | 
| 3227 3132 | 
             
                 */
         | 
| 3228 | 
            -
                 | 
| 3229 | 
            -
                     | 
| 3230 | 
            -
                     | 
| 3231 | 
            -
                     | 
| 3232 | 
            -
                     | 
| 3233 | 
            -
             | 
| 3234 | 
            -
             | 
| 3235 | 
            -
             | 
| 3236 | 
            -
             | 
| 3133 | 
            +
                onFormKeyDownEnter(event) {
         | 
| 3134 | 
            +
                    event.preventDefault();
         | 
| 3135 | 
            +
                    const elements = this.focusableElements.toArray();
         | 
| 3136 | 
            +
                    const focusedIndex = elements.findIndex((control) => control.focused);
         | 
| 3137 | 
            +
                    if (focusedIndex !== -1) {
         | 
| 3138 | 
            +
                        const nextElement = elements[focusedIndex + 1]?.nativeFocusableElement;
         | 
| 3139 | 
            +
                        if (nextElement) {
         | 
| 3140 | 
            +
                            nextElement.focus();
         | 
| 3141 | 
            +
                        }
         | 
| 3142 | 
            +
                    }
         | 
| 3143 | 
            +
                }
         | 
| 3144 | 
            +
            }
         | 
| 3145 | 
            +
            ScNextInputFocusDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
         | 
| 3146 | 
            +
            ScNextInputFocusDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: ScNextInputFocusDirective, selector: "form[ScNextInputFocus]", host: { listeners: { "keydown.enter": "onFormKeyDownEnter($event)" } }, queries: [{ propertyName: "focusableElements", predicate: AbstractTuiControl, descendants: true }], ngImport: i0 });
         | 
| 3147 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusDirective, decorators: [{
         | 
| 3148 | 
            +
                        type: Directive,
         | 
| 3149 | 
            +
                        args: [{
         | 
| 3150 | 
            +
                                selector: 'form[ScNextInputFocus]',
         | 
| 3151 | 
            +
                            }]
         | 
| 3152 | 
            +
                    }], propDecorators: { focusableElements: [{
         | 
| 3153 | 
            +
                            type: ContentChildren,
         | 
| 3154 | 
            +
                            args: [AbstractTuiControl, { descendants: true }]
         | 
| 3155 | 
            +
                        }], onFormKeyDownEnter: [{
         | 
| 3156 | 
            +
                            type: HostListener,
         | 
| 3157 | 
            +
                            args: ['keydown.enter', ['$event']]
         | 
| 3158 | 
            +
                        }] } });
         | 
| 3159 | 
            +
             | 
| 3160 | 
            +
            /**
         | 
| 3161 | 
            +
             * Модуль директивы для перехода по нажатию клавиши enter на следующее поле ввода формы.
         | 
| 3162 | 
            +
             */
         | 
| 3163 | 
            +
            class ScNextInputFocusModule {
         | 
| 3164 | 
            +
            }
         | 
| 3165 | 
            +
            ScNextInputFocusModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
         | 
| 3166 | 
            +
            ScNextInputFocusModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, declarations: [ScNextInputFocusDirective], exports: [ScNextInputFocusDirective] });
         | 
| 3167 | 
            +
            ScNextInputFocusModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule });
         | 
| 3168 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScNextInputFocusModule, decorators: [{
         | 
| 3169 | 
            +
                        type: NgModule,
         | 
| 3170 | 
            +
                        args: [{
         | 
| 3171 | 
            +
                                declarations: [ScNextInputFocusDirective],
         | 
| 3172 | 
            +
                                exports: [ScNextInputFocusDirective],
         | 
| 3173 | 
            +
                            }]
         | 
| 3174 | 
            +
                    }] });
         | 
| 3175 | 
            +
             | 
| 3176 | 
            +
            /* eslint-disable no-underscore-dangle */
         | 
| 3177 | 
            +
            /**
         | 
| 3178 | 
            +
             * Директива абстрактной карточки товара.
         | 
| 3179 | 
            +
             */
         | 
| 3180 | 
            +
            class AbstractScPriceCard {
         | 
| 3181 | 
            +
                constructor() {
         | 
| 3237 3182 | 
             
                    /**
         | 
| 3238 | 
            -
                     *  | 
| 3183 | 
            +
                     * {@link FormControl} поля ввода количества товара в корзине.
         | 
| 3239 3184 | 
             
                     */
         | 
| 3240 | 
            -
                    this. | 
| 3185 | 
            +
                    this.quantityControl = new FormControl(3, { updateOn: 'blur' });
         | 
| 3241 3186 | 
             
                    /**
         | 
| 3242 3187 | 
             
                     * Признак, что необходимо отобразить лоадер для поля ввода количества товара.
         | 
| 3243 3188 | 
             
                     */
         | 
| @@ -3246,6 +3191,18 @@ class ScPriceCardComponent { | |
| 3246 3191 | 
             
                     * Признак, что необходимо отобразить лоадер для кнопки избранных товаров и категорий.
         | 
| 3247 3192 | 
             
                     */
         | 
| 3248 3193 | 
             
                    this.favoriteShowLoader = false;
         | 
| 3194 | 
            +
                    /**
         | 
| 3195 | 
            +
                     * {@link Observable} изменения выбранного склада.
         | 
| 3196 | 
            +
                     */
         | 
| 3197 | 
            +
                    this.warehouseSelect$ = inject(ScWarehouseService).getWarehouseSelectChange$();
         | 
| 3198 | 
            +
                    /**
         | 
| 3199 | 
            +
                     * {@link Observable} изменения статуса авторизации.
         | 
| 3200 | 
            +
                     */
         | 
| 3201 | 
            +
                    this.authStatus$ = inject(ScAuthService).getAuthChange();
         | 
| 3202 | 
            +
                    /**
         | 
| 3203 | 
            +
                     * {@link Observable} поиска терма.
         | 
| 3204 | 
            +
                     */
         | 
| 3205 | 
            +
                    this.search$ = inject(SEARCH_TERM);
         | 
| 3249 3206 | 
             
                    /**
         | 
| 3250 3207 | 
             
                     * Признак, что необходимо отобразить поле ввода количества товара.
         | 
| 3251 3208 | 
             
                     */
         | 
| @@ -3267,25 +3224,25 @@ class ScPriceCardComponent { | |
| 3267 3224 | 
             
                     */
         | 
| 3268 3225 | 
             
                    this.clickCardEvent = new EventEmitter();
         | 
| 3269 3226 | 
             
                    /**
         | 
| 3270 | 
            -
                     *  | 
| 3227 | 
            +
                     * Событие нажатия на историю цен.
         | 
| 3271 3228 | 
             
                     */
         | 
| 3272 | 
            -
                    this. | 
| 3273 | 
            -
                    /**
         | 
| 3274 | 
            -
                     * {@link FormControl} поля ввода количества товара в корзине.
         | 
| 3275 | 
            -
                     */
         | 
| 3276 | 
            -
                    this.quantityControl = new FormControl(null, { updateOn: 'blur' });
         | 
| 3229 | 
            +
                    this.clickPriceHistoryEvent = new EventEmitter();
         | 
| 3277 3230 | 
             
                    /**
         | 
| 3278 3231 | 
             
                     * {@link Observable} изменения количества товара в корзине.
         | 
| 3279 3232 | 
             
                     */
         | 
| 3280 3233 | 
             
                    this.quantityValueChanges = this.quantityControl.valueChanges;
         | 
| 3281 3234 | 
             
                    /**
         | 
| 3282 | 
            -
                     *  | 
| 3235 | 
            +
                     * Экземпляр класса-помощника для работы со значениями единиц измерения товара.
         | 
| 3283 3236 | 
             
                     */
         | 
| 3284 | 
            -
                    this. | 
| 3237 | 
            +
                    this.unitsHelper = inject(ScUnitsHelper);
         | 
| 3285 3238 | 
             
                    /**
         | 
| 3286 | 
            -
                     *  | 
| 3239 | 
            +
                     * Хелпер для работы с изображениями товара.
         | 
| 3287 3240 | 
             
                     */
         | 
| 3288 | 
            -
                    this. | 
| 3241 | 
            +
                    this.imageHelper = inject(ScImageHelper);
         | 
| 3242 | 
            +
                    /**
         | 
| 3243 | 
            +
                     * Путь до изображения 'Товар не найден'.
         | 
| 3244 | 
            +
                     */
         | 
| 3245 | 
            +
                    this.pathImageNotFound = inject(SC_PATH_IMAGE_NOT_FOUND);
         | 
| 3289 3246 | 
             
                }
         | 
| 3290 3247 | 
             
                /**
         | 
| 3291 3248 | 
             
                 * Позиция товара в корзине.
         | 
| @@ -3305,13 +3262,6 @@ class ScPriceCardComponent { | |
| 3305 3262 | 
             
                    this.quantityControl.patchValue(this._cartItem?.quantity ?? null, { emitEvent: false });
         | 
| 3306 3263 | 
             
                    this.quantityShowLoader = false;
         | 
| 3307 3264 | 
             
                }
         | 
| 3308 | 
            -
                /**
         | 
| 3309 | 
            -
                 * Конвертация размера для компонента sc-input-quantity.
         | 
| 3310 | 
            -
                 * TODO: Решить проблему с функционалом size для разных платформ.
         | 
| 3311 | 
            -
                 */
         | 
| 3312 | 
            -
                get getQuantitySize() {
         | 
| 3313 | 
            -
                    return this.size === 'xs' ? 's' : this.size;
         | 
| 3314 | 
            -
                }
         | 
| 3315 3265 | 
             
                /**
         | 
| 3316 3266 | 
             
                 * Признак, что нужно показать скелетон.
         | 
| 3317 3267 | 
             
                 */
         | 
| @@ -3324,33 +3274,17 @@ class ScPriceCardComponent { | |
| 3324 3274 | 
             
                getCardImagePreview() {
         | 
| 3325 3275 | 
             
                    return this.product ? this.imageHelper.getImagePreview(this.product) : this.pathImageNotFound;
         | 
| 3326 3276 | 
             
                }
         | 
| 3327 | 
            -
                /**
         | 
| 3328 | 
            -
                 * Устанавливает компонент в очередь на обновление.
         | 
| 3329 | 
            -
                 */
         | 
| 3330 | 
            -
                markForCheck() {
         | 
| 3331 | 
            -
                    this.cdr.markForCheck();
         | 
| 3332 | 
            -
                }
         | 
| 3333 3277 | 
             
            }
         | 
| 3334 | 
            -
             | 
| 3335 | 
            -
            ScPriceCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScPriceCardComponent, selector: "sc-price-card", inputs: { cartItem: "cartItem", showQuantityControl: "showQuantityControl", product: "product", size: "size" }, outputs: { clickFavoriteEvent: "clickFavoriteEvent", clickAddToCartEvent: "clickAddToCartEvent", clickClearEvent: "clickClearEvent", clickCardEvent: "clickCardEvent", quantityValueChanges: "quantityValueChanges" }, host: { properties: { "attr.data-size": "this.size" } }, providers: [SEARCH_TERM_PROVIDERS], ngImport: i0, template: "<!-- TODO: \u0440\u0435\u0430\u043B\u0438\u0437\u043E\u0432\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0439 \u043A\u043E\u043C\u043F\u043E\u043D\u0435\u043D\u0442 \u0438 \u0434\u043B\u044F \u0434\u0435\u0441\u043A\u0442\u043E\u043F\u0430 \u0438 \u0434\u043B\u044F \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u043E\u0433\u043E \u043F\u0440\u0438\u043B\u043E\u0436\u0435\u043D\u0438\u044F. \u0418\u0441\u043F\u0440\u0430\u0432\u0438\u0442\u044C \u0432\u0441\u0435 \u0433\u043B\u043E\u0431\u0430\u043B\u044C\u043D\u044B\u0435 \u0442\u0430\u0439\u0433\u043E\u0432\u0441\u043A\u0438\u0435 \u0441\u0442\u0438\u043B\u0438, \u043F\u0440\u0438\u0432\u0435\u0441\u0442\u0438 \u0438\u0445 \u0432 \u043F\u043E\u0440\u044F\u0434\u043E\u043A \u0441\u043E\u0433\u043B\u0430\u0441\u043D\u043E \u0441 \u0434\u0438\u0437\u0430\u0439\u043D\u043E\u043C. -->\n<div\n    *ngIf=\"product; else skeleton\"\n    class=\"relative grid h-[19rem] w-auto min-w-40 rounded-xl p-2 text-xs shadow-md\"\n>\n    <div class=\"overflow-hidden\">\n        <img\n            (click)=\"clickCardEvent.emit()\"\n            [src]=\"getCardImagePreview()\"\n            [alt]=\"product.name\"\n            class=\"max-h-full w-full rounded-xl object-cover\"\n        />\n    </div>\n    <sc-favorite-btn\n        *ngIf=\"authStatus$ | async\"\n        class=\"absolute left-0 top-0\"\n        (clickEvent)=\"clickFavoriteEvent.emit()\"\n        [showLoader]=\"favoriteShowLoader\"\n        [isFavorite]=\"product.isFavorite\"\n        [disabled]=\"!!product.primaryCategory?.isFavorite\"\n    ></sc-favorite-btn>\n    <tui-svg\n        *ngIf=\"product.isPreviouslyOrdered\"\n        src=\"scIconStar\"\n        class=\"absolute right-0 top-0 text-red-700\"\n    ></tui-svg>\n\n    <a\n        class=\"m-0 p-0\"\n        tuiLink\n        iconAlign=\"left\"\n        (click)=\"clickCardEvent.emit()\"\n    >\n        <p\n            class=\"line-clamp-3 text-sm font-bold\"\n            style=\"word-break: break-word\"\n            [tuiHighlight]=\"(search$ | async) ?? ''\"\n        >\n            {{ product.name }}\n        </p>\n    </a>\n    <p\n        *ngIf=\"product?.pack\"\n        class=\"text-tui-text-02\"\n    >\n        \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n    </p>\n\n    <p\n        [tuiHighlight]=\"(search$ | async) ?? ''\"\n        class=\"text-tui-text-02\"\n    >\n        \u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}\n    </p>\n    <p\n        *ngIf=\"(authStatus$ | async) && product?.costDate\"\n        class=\"text-tui-text-02\"\n    >\n        \u0414\u0430\u0442\u0430: {{ product.costDate }}\n    </p>\n    <div\n        *ngIf=\"warehouseSelect$ | async as warehouseSelect\"\n        class=\"flex flex-col\"\n    >\n        <span\n            *ngIf=\"product.discount && !isMobile\"\n            class=\"flex items-center text-tui-text-02\"\n        >\n            <span class=\"line-through\">{{ product.discountCostString }}</span>  \n            <span class=\"font-bold text-tui-success-fill\"> -{{ product.discount.percent }}% </span>\n            <tui-svg\n                src=\"tuiIconInfoLarge\"\n                [tuiHint]=\"discountHint\"\n                [tuiHintShowDelay]=\"100\"\n                tuiHintDirection=\"top\"\n                class=\"!h-4 !text-xs text-black\"\n            ></tui-svg>\n            <ng-template #discountHint>\n                <div class=\"font-bold\">{{ product.discount.name }}</div>\n                <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n            </ng-template>\n        </span>\n        <span\n            [class.text-tui-text-02]=\"!product.isWarehouseStockExist(warehouseSelect.id)\"\n            class=\"cost font-bold\"\n            >{{ product.costRubString }}</span\n        >\n        <span\n            *ngIf=\"!product.priceInRub\"\n            class=\"hidden text-xs font-bold text-tui-text-02 group-hover:block\"\n            >{{ product.costString }}</span\n        >\n        <sc-price-warehouse-stock [product]=\"product\"></sc-price-warehouse-stock>\n    </div>\n    <div\n        *ngIf=\"!showQuantityControl\"\n        class=\"mt-1 flex max-w-full items-center justify-stretch gap-2\"\n    >\n        <button\n            tuiButton\n            (click)=\"clickAddToCartEvent.emit(product)\"\n            [showLoader]=\"quantityShowLoader\"\n            [size]=\"size\"\n            class=\"grow\"\n        >\n            <tui-svg\n                src=\"scIconCart\"\n                class=\"!h-4 !text-xs\"\n            >\n            </tui-svg>\n            \u0412 \u043A\u043E\u0440\u0437\u0438\u043D\u0443\n        </button>\n        <div\n            *ngIf=\"cartItem\"\n            class=\"flex justify-center\"\n        >\n            <tui-svg\n                src=\"tuiIconCheck\"\n                class=\"!h-5 !w-5 rounded-md bg-tui-primary text-black\"\n            ></tui-svg>\n        </div>\n    </div>\n    <sc-input-quantity\n        #inputQuantity\n        *ngIf=\"showQuantityControl\"\n        [formControl]=\"quantityControl\"\n        [size]=\"getQuantitySize\"\n        [step]=\"unitsHelper.productMultiplicity(product)\"\n        [showLoader]=\"quantityShowLoader\"\n        (clickClearEvent)=\"clickClearEvent.emit(cartItem)\"\n        class=\"mt-2 w-full\"\n        (keydown.enter)=\"inputQuantity.nativeFocusableElement?.blur()\"\n    ></sc-input-quantity>\n</div>\n\n<ng-template #skeleton>\n    <div class=\"card-wrapper flex flex-col overflow-hidden rounded-xl bg-white shadow-sc-1\">\n        <!-- \u0418\u0437\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u0438\u0435 \u0442\u043E\u0432\u0430\u0440\u0430 -->\n        <div class=\"h-3/5 w-full rounded-t bg-tui-base-02\"></div>\n        <!-- \u041A\u0440\u0430\u0442\u043A\u0430\u044F \u0438\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F \u043E \u0442\u043E\u0432\u0430\u0440\u0435 -->\n        <div class=\"flex grow flex-col gap-2.5 rounded-b bg-white p-5\">\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-3/5 rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n        </div>\n    </div>\n</ng-template>\n", styles: [":host[data-size=s] .card-wrapper{width:10rem;height:16rem}:host[data-size=s] .card-wrapper .wrapper-info{padding:8px}:host[data-size=s] .card-wrapper .wrapper-info .cost{font-size:.875rem;line-height:1.25rem}:host[data-size=s] .card-wrapper .button-wrapper tui-svg{font-size:.75rem;line-height:1rem;width:1rem}:host[data-size=m] .card-wrapper{width:12.5rem;height:20rem}:host[data-size=m] .card-wrapper .wrapper-info{padding-inline:16px;padding-block:8px}:host[data-size=m] .card-wrapper .name{font-size:.875rem;line-height:1.25rem;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;max-height:3rem}:host[data-size=m] .card-wrapper .info{max-height:1rem}:host[data-size=m] .card-wrapper .cost{font-size:1.125rem;line-height:1.75rem}:host[data-size=m] .card-wrapper .button-wrapper{max-height:0px;font-size:.75rem;line-height:1rem}:host[data-size=m] .card-wrapper:hover .name{-webkit-line-clamp:unset;max-height:6rem}:host[data-size=m] .card-wrapper:hover .info{max-height:3rem}:host[data-size=m] .card-wrapper:hover .button-wrapper{max-height:3rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "component", type: i4.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { kind: "directive", type: i4.TuiHintDriverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)" }, { kind: "directive", type: i4.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"], exportAs: ["tuiHintHover"] }, { kind: "directive", type: i4.TuiHintPositionDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintDirection"] }, { kind: "component", type: i4.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { kind: "directive", type: i4$1.TuiHighlightDirective, selector: "[tuiHighlight]", inputs: ["tuiHighlight", "tuiHighlightColor"] }, { kind: "component", type: ScFavoriteBtnComponent, selector: "sc-favorite-btn", inputs: ["isFavorite", "showLoader", "disabled"], outputs: ["clickEvent"] }, { kind: "component", type: ScInputQuantityComponent, selector: "sc-input-quantity", inputs: ["step", "showLoader", "showCross", "appearance", "isDisabled", "size"], outputs: ["clickClearEvent"] }, { kind: "component", type: ScPriceWarehouseStockComponent, selector: "sc-price-warehouse-stock", inputs: ["classList", "product", "withStockHint", "fromMain"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 3336 | 
            -
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type:  | 
| 3337 | 
            -
                        type:  | 
| 3338 | 
            -
             | 
| 3339 | 
            -
                    }], ctorParameters: function () { return [{ type: UnitsHelper }, { type: i1.ScAuthService }, { type: i1.ScWarehouseService }, { type: undefined, decorators: [{
         | 
| 3340 | 
            -
                                type: Inject,
         | 
| 3341 | 
            -
                                args: [SC_URLS]
         | 
| 3342 | 
            -
                            }] }, { type: undefined, decorators: [{
         | 
| 3343 | 
            -
                                type: Inject,
         | 
| 3344 | 
            -
                                args: [SC_PATH_IMAGE_NOT_FOUND]
         | 
| 3345 | 
            -
                            }] }, { type: i10.Observable, decorators: [{
         | 
| 3346 | 
            -
                                type: Inject,
         | 
| 3347 | 
            -
                                args: [SEARCH_TERM]
         | 
| 3348 | 
            -
                            }] }, { type: i0.ChangeDetectorRef }, { type: i1.ScImageHelper }]; }, propDecorators: { cartItem: [{
         | 
| 3349 | 
            -
                            type: Input
         | 
| 3350 | 
            -
                        }], showQuantityControl: [{
         | 
| 3278 | 
            +
            AbstractScPriceCard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AbstractScPriceCard, deps: [], target: i0.ɵɵFactoryTarget.Directive });
         | 
| 3279 | 
            +
            AbstractScPriceCard.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: AbstractScPriceCard, inputs: { cartItem: "cartItem", product: "product", showQuantityControl: "showQuantityControl" }, outputs: { clickFavoriteEvent: "clickFavoriteEvent", clickAddToCartEvent: "clickAddToCartEvent", clickClearEvent: "clickClearEvent", clickCardEvent: "clickCardEvent", clickPriceHistoryEvent: "clickPriceHistoryEvent", quantityValueChanges: "quantityValueChanges" }, ngImport: i0 });
         | 
| 3280 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AbstractScPriceCard, decorators: [{
         | 
| 3281 | 
            +
                        type: Directive
         | 
| 3282 | 
            +
                    }], propDecorators: { cartItem: [{
         | 
| 3351 3283 | 
             
                            type: Input
         | 
| 3352 3284 | 
             
                        }], product: [{
         | 
| 3353 3285 | 
             
                            type: Input
         | 
| 3286 | 
            +
                        }], showQuantityControl: [{
         | 
| 3287 | 
            +
                            type: Input
         | 
| 3354 3288 | 
             
                        }], clickFavoriteEvent: [{
         | 
| 3355 3289 | 
             
                            type: Output
         | 
| 3356 3290 | 
             
                        }], clickAddToCartEvent: [{
         | 
| @@ -3359,13 +3293,62 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 3359 3293 | 
             
                            type: Output
         | 
| 3360 3294 | 
             
                        }], clickCardEvent: [{
         | 
| 3361 3295 | 
             
                            type: Output
         | 
| 3296 | 
            +
                        }], clickPriceHistoryEvent: [{
         | 
| 3297 | 
            +
                            type: Output
         | 
| 3362 3298 | 
             
                        }], quantityValueChanges: [{
         | 
| 3363 3299 | 
             
                            type: Output
         | 
| 3364 | 
            -
                        }] | 
| 3300 | 
            +
                        }] } });
         | 
| 3301 | 
            +
             | 
| 3302 | 
            +
            /**
         | 
| 3303 | 
            +
             * Компонент карточки товара.
         | 
| 3304 | 
            +
             */
         | 
| 3305 | 
            +
            class ScPriceCardComponent extends AbstractScPriceCard {
         | 
| 3306 | 
            +
                /**
         | 
| 3307 | 
            +
                 * Инициирует экземпляр класса {@link ScPriceCardComponent}.
         | 
| 3308 | 
            +
                 *
         | 
| 3309 | 
            +
                 * @param cdr Объект для работы с обнаружением изменений.
         | 
| 3310 | 
            +
                 */
         | 
| 3311 | 
            +
                constructor(cdr) {
         | 
| 3312 | 
            +
                    super();
         | 
| 3313 | 
            +
                    this.cdr = cdr;
         | 
| 3314 | 
            +
                    /**
         | 
| 3315 | 
            +
                     * Размер компонента.
         | 
| 3316 | 
            +
                     */
         | 
| 3317 | 
            +
                    this.size = 'm';
         | 
| 3318 | 
            +
                    /**
         | 
| 3319 | 
            +
                     * Признак того, что этот компонент отображается на мобильном устройстве.
         | 
| 3320 | 
            +
                     */
         | 
| 3321 | 
            +
                    this.isMobile = inject(TUI_IS_MOBILE);
         | 
| 3322 | 
            +
                }
         | 
| 3323 | 
            +
                /**
         | 
| 3324 | 
            +
                 * Признак того, что компонент находится в корзине.
         | 
| 3325 | 
            +
                 */
         | 
| 3326 | 
            +
                get isInCart() {
         | 
| 3327 | 
            +
                    return Boolean(this.cartItem);
         | 
| 3328 | 
            +
                }
         | 
| 3329 | 
            +
                /**
         | 
| 3330 | 
            +
                 * Устанавливает компонент в очередь на обновление.
         | 
| 3331 | 
            +
                 */
         | 
| 3332 | 
            +
                markForCheck() {
         | 
| 3333 | 
            +
                    this.cdr.markForCheck();
         | 
| 3334 | 
            +
                }
         | 
| 3335 | 
            +
            }
         | 
| 3336 | 
            +
            ScPriceCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScPriceCardComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 3337 | 
            +
            ScPriceCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScPriceCardComponent, selector: "sc-price-card", inputs: { size: "size" }, host: { properties: { "attr.data-size": "this.size", "attr.is_mobile": "this.isMobile", "attr.is_in_cart": "this.isInCart" } }, providers: [SEARCH_TERM_PROVIDERS], usesInheritance: true, ngImport: i0, template: "<div\n    *ngIf=\"product; else skeleton\"\n    class=\"card-wrapper relative flex w-auto min-w-40 flex-col rounded-xl shadow-md\"\n>\n    <div class=\"flex grow flex-col justify-center overflow-hidden rounded-xl p-2\">\n        <img\n            (click)=\"clickCardEvent.emit()\"\n            [src]=\"getCardImagePreview()\"\n            [alt]=\"product.name\"\n            class=\"max-h-full w-full rounded-xl object-cover\"\n        />\n        <sc-favorite-btn\n            *ngIf=\"authStatus$ | async\"\n            class=\"absolute left-2 top-2\"\n            (clickEvent)=\"clickFavoriteEvent.emit()\"\n            [showLoader]=\"favoriteShowLoader\"\n            [isFavorite]=\"product.isFavorite\"\n            [disabled]=\"!!product.primaryCategory?.isFavorite\"\n        ></sc-favorite-btn>\n        <div class=\"absolute right-2 top-2 m-1 flex gap-2\">\n            <tui-svg\n                *ngIf=\"product.isPreviouslyOrdered\"\n                src=\"tuiIconStarLarge\"\n                class=\"!size-6 rounded-lg !fill-white text-tui-negative\"\n            ></tui-svg>\n            <tui-svg\n                *ngIf=\"product.cartItem\"\n                src=\"tuiIconCheck\"\n                class=\"!size-6 rounded-lg bg-tui-primary text-white\"\n            ></tui-svg>\n        </div>\n    </div>\n    <div class=\"p-2\">\n        <tui-elastic-container class=\"shrink-0\">\n            <a\n                tuiLink\n                class=\"name\"\n                iconAlign=\"left\"\n                [tuiHighlight]=\"(search$ | async) ?? ''\"\n                (click)=\"clickCardEvent.emit()\"\n            >\n                {{ product.name }}\n            </a>\n        </tui-elastic-container>\n        <tui-elastic-container class=\"shrink-0\">\n            <p\n                *ngIf=\"product?.pack\"\n                class=\"text-tui-text-02\"\n            >\n                \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n            </p>\n            <p\n                [tuiHighlight]=\"(search$ | async) ?? ''\"\n                class=\"code text-tui-text-02\"\n            >\n                \u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}\n            </p>\n\n            <a\n                tuiLink\n                *ngIf=\"!isMobile && (authStatus$ | async) && product?.costDate\"\n                iconAlign=\"left\"\n                aria-disabled=\"true\"\n                class=\"history\"\n                (click)=\"clickPriceHistoryEvent.emit()\"\n            >\n                \u0414\u0430\u0442\u0430: {{ product.costDate }}\n            </a>\n        </tui-elastic-container>\n        <div\n            *ngIf=\"warehouseSelect$ | async as warehouseSelect\"\n            class=\"flex flex-col\"\n        >\n            <span\n                *ngIf=\"product.discount && !isMobile\"\n                class=\"flex items-center text-tui-text-02\"\n            >\n                <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                <span class=\"font-bold text-tui-success-fill\"> -{{ product.discount.percent }}% </span>\n                <tui-svg\n                    src=\"tuiIconInfoLarge\"\n                    [tuiHint]=\"discountHint\"\n                    [tuiHintShowDelay]=\"100\"\n                    tuiHintDirection=\"top\"\n                    class=\"!h-4 text-black\"\n                ></tui-svg>\n                <ng-template #discountHint>\n                    <div class=\"font-bold\">{{ product.discount.name }}</div>\n                    <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                </ng-template>\n            </span>\n            <span\n                [class.text-tui-text-02]=\"!product.isWarehouseStockExist(warehouseSelect.id)\"\n                class=\"cost font-bold\"\n                >{{ product.costRubString }}</span\n            >\n            <span\n                *ngIf=\"!product.priceInRub\"\n                class=\"hidden font-bold text-tui-text-02 group-hover:block\"\n                >{{ product.costString }}</span\n            >\n            <sc-price-warehouse-stock [product]=\"product\"></sc-price-warehouse-stock>\n        </div>\n        <div class=\"cart-actions flex shrink-0 overflow-hidden\">\n            <button\n                *ngIf=\"!showQuantityControl\"\n                tuiButton\n                (click)=\"clickAddToCartEvent.emit(product)\"\n                [showLoader]=\"quantityShowLoader\"\n                [size]=\"size === 's' ? 'xs' : 's'\"\n                class=\"mt-2 grow\"\n                icon=\"tuiIconShoppingCart\"\n            >\n                \u0412 \u043A\u043E\u0440\u0437\u0438\u043D\u0443\n            </button>\n            <sc-input-quantity\n                #inputQuantity\n                *ngIf=\"showQuantityControl\"\n                [formControl]=\"quantityControl\"\n                [size]=\"size\"\n                [step]=\"unitsHelper.productMultiplicity(product)\"\n                [showLoader]=\"quantityShowLoader\"\n                (clickClearEvent)=\"clickClearEvent.emit(cartItem)\"\n                class=\"mt-2 w-full\"\n                (keydown.enter)=\"inputQuantity.nativeFocusableElement?.blur()\"\n            ></sc-input-quantity>\n        </div>\n    </div>\n</div>\n\n<ng-template #skeleton>\n    <div class=\"card-wrapper flex flex-col overflow-hidden rounded-xl bg-white shadow-sc-1\">\n        <!-- \u0418\u0437\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u0438\u0435 \u0442\u043E\u0432\u0430\u0440\u0430 -->\n        <div class=\"h-3/5 w-full rounded-t bg-tui-base-02\"></div>\n        <!-- \u041A\u0440\u0430\u0442\u043A\u0430\u044F \u0438\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F \u043E \u0442\u043E\u0432\u0430\u0440\u0435 -->\n        <div class=\"flex grow flex-col gap-2.5 rounded-b bg-white p-5\">\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-3/5 rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n        </div>\n    </div>\n</ng-template>\n", styles: [":host .name{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4}:host[data-size=s] .card-wrapper{height:16rem;font:var(--tui-font-text-xs)}:host[data-size=s] .card-wrapper .name,:host[data-size=s] .card-wrapper .cost{font:var(--tui-font-text-s);font-weight:800}:host[data-size=m] .card-wrapper{height:20rem;font:var(--tui-font-text-s)}:host[data-size=m] .card-wrapper .name,:host[data-size=m] .card-wrapper .cost{font:var(--tui-font-text-m);font-weight:800}:host[is_mobile=false][is_in_cart=false] .name{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}:host[is_mobile=false][is_in_cart=false] .code,:host[is_mobile=false][is_in_cart=false] .history{display:none}:host[is_mobile=false][is_in_cart=false] .cart-actions{max-height:0;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}:host[is_mobile=false][is_in_cart=false]:hover .code,:host[is_mobile=false][is_in_cart=false]:hover .history,:host[is_mobile=false][is_in_cart=false]:hover .name{display:-webkit-box;-webkit-line-clamp:4}:host[is_mobile=false][is_in_cart=false]:hover .cart-actions{max-height:3rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "component", type: i4.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { kind: "directive", type: i4.TuiHintDriverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)" }, { kind: "directive", type: i4.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"], exportAs: ["tuiHintHover"] }, { kind: "directive", type: i4.TuiHintPositionDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintDirection"] }, { kind: "component", type: i4.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { kind: "component", type: i4$1.TuiElasticContainerComponent, selector: "tui-elastic-container" }, { kind: "directive", type: i4$1.TuiHighlightDirective, selector: "[tuiHighlight]", inputs: ["tuiHighlight", "tuiHighlightColor"] }, { kind: "component", type: ScFavoriteBtnComponent, selector: "sc-favorite-btn", inputs: ["isFavorite", "showLoader", "disabled"], outputs: ["clickEvent"] }, { kind: "component", type: ScInputQuantityComponent, selector: "sc-input-quantity", inputs: ["step", "showLoader", "showCross", "appearance", "isDisabled", "size"], outputs: ["clickClearEvent"] }, { kind: "component", type: ScPriceWarehouseStockComponent, selector: "sc-price-warehouse-stock", inputs: ["classList", "product", "withStockHint", "fromMain"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 3338 | 
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScPriceCardComponent, decorators: [{
         | 
| 3339 | 
            +
                        type: Component,
         | 
| 3340 | 
            +
                        args: [{ selector: 'sc-price-card', providers: [SEARCH_TERM_PROVIDERS], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n    *ngIf=\"product; else skeleton\"\n    class=\"card-wrapper relative flex w-auto min-w-40 flex-col rounded-xl shadow-md\"\n>\n    <div class=\"flex grow flex-col justify-center overflow-hidden rounded-xl p-2\">\n        <img\n            (click)=\"clickCardEvent.emit()\"\n            [src]=\"getCardImagePreview()\"\n            [alt]=\"product.name\"\n            class=\"max-h-full w-full rounded-xl object-cover\"\n        />\n        <sc-favorite-btn\n            *ngIf=\"authStatus$ | async\"\n            class=\"absolute left-2 top-2\"\n            (clickEvent)=\"clickFavoriteEvent.emit()\"\n            [showLoader]=\"favoriteShowLoader\"\n            [isFavorite]=\"product.isFavorite\"\n            [disabled]=\"!!product.primaryCategory?.isFavorite\"\n        ></sc-favorite-btn>\n        <div class=\"absolute right-2 top-2 m-1 flex gap-2\">\n            <tui-svg\n                *ngIf=\"product.isPreviouslyOrdered\"\n                src=\"tuiIconStarLarge\"\n                class=\"!size-6 rounded-lg !fill-white text-tui-negative\"\n            ></tui-svg>\n            <tui-svg\n                *ngIf=\"product.cartItem\"\n                src=\"tuiIconCheck\"\n                class=\"!size-6 rounded-lg bg-tui-primary text-white\"\n            ></tui-svg>\n        </div>\n    </div>\n    <div class=\"p-2\">\n        <tui-elastic-container class=\"shrink-0\">\n            <a\n                tuiLink\n                class=\"name\"\n                iconAlign=\"left\"\n                [tuiHighlight]=\"(search$ | async) ?? ''\"\n                (click)=\"clickCardEvent.emit()\"\n            >\n                {{ product.name }}\n            </a>\n        </tui-elastic-container>\n        <tui-elastic-container class=\"shrink-0\">\n            <p\n                *ngIf=\"product?.pack\"\n                class=\"text-tui-text-02\"\n            >\n                \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n            </p>\n            <p\n                [tuiHighlight]=\"(search$ | async) ?? ''\"\n                class=\"code text-tui-text-02\"\n            >\n                \u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}\n            </p>\n\n            <a\n                tuiLink\n                *ngIf=\"!isMobile && (authStatus$ | async) && product?.costDate\"\n                iconAlign=\"left\"\n                aria-disabled=\"true\"\n                class=\"history\"\n                (click)=\"clickPriceHistoryEvent.emit()\"\n            >\n                \u0414\u0430\u0442\u0430: {{ product.costDate }}\n            </a>\n        </tui-elastic-container>\n        <div\n            *ngIf=\"warehouseSelect$ | async as warehouseSelect\"\n            class=\"flex flex-col\"\n        >\n            <span\n                *ngIf=\"product.discount && !isMobile\"\n                class=\"flex items-center text-tui-text-02\"\n            >\n                <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                <span class=\"font-bold text-tui-success-fill\"> -{{ product.discount.percent }}% </span>\n                <tui-svg\n                    src=\"tuiIconInfoLarge\"\n                    [tuiHint]=\"discountHint\"\n                    [tuiHintShowDelay]=\"100\"\n                    tuiHintDirection=\"top\"\n                    class=\"!h-4 text-black\"\n                ></tui-svg>\n                <ng-template #discountHint>\n                    <div class=\"font-bold\">{{ product.discount.name }}</div>\n                    <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                </ng-template>\n            </span>\n            <span\n                [class.text-tui-text-02]=\"!product.isWarehouseStockExist(warehouseSelect.id)\"\n                class=\"cost font-bold\"\n                >{{ product.costRubString }}</span\n            >\n            <span\n                *ngIf=\"!product.priceInRub\"\n                class=\"hidden font-bold text-tui-text-02 group-hover:block\"\n                >{{ product.costString }}</span\n            >\n            <sc-price-warehouse-stock [product]=\"product\"></sc-price-warehouse-stock>\n        </div>\n        <div class=\"cart-actions flex shrink-0 overflow-hidden\">\n            <button\n                *ngIf=\"!showQuantityControl\"\n                tuiButton\n                (click)=\"clickAddToCartEvent.emit(product)\"\n                [showLoader]=\"quantityShowLoader\"\n                [size]=\"size === 's' ? 'xs' : 's'\"\n                class=\"mt-2 grow\"\n                icon=\"tuiIconShoppingCart\"\n            >\n                \u0412 \u043A\u043E\u0440\u0437\u0438\u043D\u0443\n            </button>\n            <sc-input-quantity\n                #inputQuantity\n                *ngIf=\"showQuantityControl\"\n                [formControl]=\"quantityControl\"\n                [size]=\"size\"\n                [step]=\"unitsHelper.productMultiplicity(product)\"\n                [showLoader]=\"quantityShowLoader\"\n                (clickClearEvent)=\"clickClearEvent.emit(cartItem)\"\n                class=\"mt-2 w-full\"\n                (keydown.enter)=\"inputQuantity.nativeFocusableElement?.blur()\"\n            ></sc-input-quantity>\n        </div>\n    </div>\n</div>\n\n<ng-template #skeleton>\n    <div class=\"card-wrapper flex flex-col overflow-hidden rounded-xl bg-white shadow-sc-1\">\n        <!-- \u0418\u0437\u043E\u0431\u0440\u0430\u0436\u0435\u043D\u0438\u0435 \u0442\u043E\u0432\u0430\u0440\u0430 -->\n        <div class=\"h-3/5 w-full rounded-t bg-tui-base-02\"></div>\n        <!-- \u041A\u0440\u0430\u0442\u043A\u0430\u044F \u0438\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F \u043E \u0442\u043E\u0432\u0430\u0440\u0435 -->\n        <div class=\"flex grow flex-col gap-2.5 rounded-b bg-white p-5\">\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-3/5 rounded bg-tui-base-02\"></div>\n            <div class=\"h-4 w-full rounded bg-tui-base-02\"></div>\n        </div>\n    </div>\n</ng-template>\n", styles: [":host .name{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4}:host[data-size=s] .card-wrapper{height:16rem;font:var(--tui-font-text-xs)}:host[data-size=s] .card-wrapper .name,:host[data-size=s] .card-wrapper .cost{font:var(--tui-font-text-s);font-weight:800}:host[data-size=m] .card-wrapper{height:20rem;font:var(--tui-font-text-s)}:host[data-size=m] .card-wrapper .name,:host[data-size=m] .card-wrapper .cost{font:var(--tui-font-text-m);font-weight:800}:host[is_mobile=false][is_in_cart=false] .name{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}:host[is_mobile=false][is_in_cart=false] .code,:host[is_mobile=false][is_in_cart=false] .history{display:none}:host[is_mobile=false][is_in_cart=false] .cart-actions{max-height:0;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}:host[is_mobile=false][is_in_cart=false]:hover .code,:host[is_mobile=false][is_in_cart=false]:hover .history,:host[is_mobile=false][is_in_cart=false]:hover .name{display:-webkit-box;-webkit-line-clamp:4}:host[is_mobile=false][is_in_cart=false]:hover .cart-actions{max-height:3rem}\n"] }]
         | 
| 3341 | 
            +
                    }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { size: [{
         | 
| 3365 3342 | 
             
                            type: Input
         | 
| 3366 3343 | 
             
                        }, {
         | 
| 3367 3344 | 
             
                            type: HostBinding,
         | 
| 3368 3345 | 
             
                            args: ['attr.data-size']
         | 
| 3346 | 
            +
                        }], isMobile: [{
         | 
| 3347 | 
            +
                            type: HostBinding,
         | 
| 3348 | 
            +
                            args: ['attr.is_mobile']
         | 
| 3349 | 
            +
                        }], isInCart: [{
         | 
| 3350 | 
            +
                            type: HostBinding,
         | 
| 3351 | 
            +
                            args: ['attr.is_in_cart']
         | 
| 3369 3352 | 
             
                        }] } });
         | 
| 3370 3353 |  | 
| 3371 3354 | 
             
            /**
         | 
| @@ -3468,7 +3451,7 @@ __decorate([ | |
| 3468 3451 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScPriceHistoryComponent, decorators: [{
         | 
| 3469 3452 | 
             
                        type: Component,
         | 
| 3470 3453 | 
             
                        args: [{ selector: 'sc-price-history', changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-loader [showLoader]=\"!!(loadingHistory$ | async)\"> </tui-loader>\n\n<div\n    *ngIf=\"(loadingHistory$ | async) === false\"\n    class=\"flex flex-col items-center\"\n>\n    <ng-container *ngIf=\"priceInfo$ | async as priceInfo; else isNotExist\">\n        <div class=\"w-174 mb-1 text-end text-lg font-bold\">\u043E\u0442 {{ priceInfo.min.toLocaleString() }} \u20BD \u0434\u043E {{ priceInfo.max.toLocaleString() }} \u20BD</div>\n\n        <ng-container *ngIf=\"history$ | async as history\">\n            <div\n                *ngIf=\"range$ | async as range\"\n                class=\"relative h-56 w-full p-5 text-tui-primary\"\n            >\n                <tui-axes\n                    *ngIf=\"computeLabels$(range) | async as labels\"\n                    class=\"h-full\"\n                    [axisXLabels]=\"labels\"\n                    [horizontalLines]=\"4\"\n                    [verticalLines]=\"labels.length\"\n                >\n                    <tui-line-days-chart\n                        class=\"chart\"\n                        [height]=\"priceInfo.max\"\n                        [smoothingFactor]=\"10\"\n                        [y]=\"priceInfo.min - (priceInfo.min * 1) / 4\"\n                        [value]=\"computeValue(range, history)\"\n                        [xStringify]=\"xStringify$ | async\"\n                        [yStringify]=\"yStringify\"\n                        [hintContent]=\"hint\"\n                    ></tui-line-days-chart>\n                </tui-axes>\n            </div>\n        </ng-container>\n    </ng-container>\n    <ng-template #isNotExist>\n        <p class=\"text-base font-bold\">\u0426\u0435\u043D\u0430 \u043D\u0430 \u0442\u043E\u0432\u0430\u0440 \u043D\u0435 \u0438\u0437\u043C\u0435\u043D\u044F\u043B\u0430\u0441\u044C</p>\n    </ng-template>\n    <ng-template\n        #hint\n        let-data\n    >\n        <div class=\"font-bold\">{{ data[1].toLocaleString() }} \u20BD</div>\n        <div>{{ data[0] }}</div>\n    </ng-template>\n</div>\n" }]
         | 
| 3471 | 
            -
                    }], ctorParameters: function () { return [{ type: i1.ScCatalogService }, { type:  | 
| 3454 | 
            +
                    }], ctorParameters: function () { return [{ type: i1.ScCatalogService }, { type: i5.Observable, decorators: [{
         | 
| 3472 3455 | 
             
                                type: Inject,
         | 
| 3473 3456 | 
             
                                args: [TUI_MONTHS]
         | 
| 3474 3457 | 
             
                            }] }, { type: i1.ScUserMetrikaService }, { type: undefined, decorators: [{
         | 
| @@ -3590,10 +3573,10 @@ class ScPriceListPaginationComponent { | |
| 3590 3573 | 
             
                }
         | 
| 3591 3574 | 
             
            }
         | 
| 3592 3575 | 
             
            ScPriceListPaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScPriceListPaginationComponent, deps: [{ token: SC_NEXT_PAGE_PAGINATION_CLICK }, { token: SC_PRODUCT_PAGINATION_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 3593 | 
            -
            ScPriceListPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScPriceListPaginationComponent, selector: "sc-price-list-pagination", inputs: { meta: "meta", loadingPagination: "loadingPagination" }, providers: [SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS], ngImport: i0, template: "<button | 
| 3576 | 
            +
            ScPriceListPaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScPriceListPaginationComponent, selector: "sc-price-list-pagination", inputs: { meta: "meta", loadingPagination: "loadingPagination" }, providers: [SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS], ngImport: i0, template: "<button\n    *ngIf=\"meta?.currentPage !== meta?.lastPage\"\n    tuiButton\n    (click)=\"nextPageClickEvent.emit()\"\n    [disabled]=\"loadingPagination\"\n    appearance=\"secondary\"\n    class=\"!font-bold\"\n>\n    \u041F\u043E\u043A\u0430\u0437\u0430\u0442\u044C \u0435\u0449\u0451 {{ options.perPage }} \u0442\u043E\u0432\u0430\u0440\u043E\u0432\n</button>\n<!-- \u0412 \u0431\u0443\u0434\u0443\u0449\u0435\u043C \u043C\u043E\u0436\u043D\u043E \u0434\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043F\u0430\u0433\u0438\u043D\u0430\u0446\u0438\u044E \u043F\u043E \u043D\u043E\u043C\u0435\u0440\u0430\u043C \u0441\u0442\u0440\u0430\u043D\u0438\u0446\u044B. -->\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 3594 3577 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScPriceListPaginationComponent, decorators: [{
         | 
| 3595 3578 | 
             
                        type: Component,
         | 
| 3596 | 
            -
                        args: [{ selector: 'sc-price-list-pagination', changeDetection: ChangeDetectionStrategy.OnPush, providers: [SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS], template: "<button | 
| 3579 | 
            +
                        args: [{ selector: 'sc-price-list-pagination', changeDetection: ChangeDetectionStrategy.OnPush, providers: [SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS], template: "<button\n    *ngIf=\"meta?.currentPage !== meta?.lastPage\"\n    tuiButton\n    (click)=\"nextPageClickEvent.emit()\"\n    [disabled]=\"loadingPagination\"\n    appearance=\"secondary\"\n    class=\"!font-bold\"\n>\n    \u041F\u043E\u043A\u0430\u0437\u0430\u0442\u044C \u0435\u0449\u0451 {{ options.perPage }} \u0442\u043E\u0432\u0430\u0440\u043E\u0432\n</button>\n<!-- \u0412 \u0431\u0443\u0434\u0443\u0449\u0435\u043C \u043C\u043E\u0436\u043D\u043E \u0434\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043F\u0430\u0433\u0438\u043D\u0430\u0446\u0438\u044E \u043F\u043E \u043D\u043E\u043C\u0435\u0440\u0430\u043C \u0441\u0442\u0440\u0430\u043D\u0438\u0446\u044B. -->\n" }]
         | 
| 3597 3580 | 
             
                    }], ctorParameters: function () { return [{ type: i0.EventEmitter, decorators: [{
         | 
| 3598 3581 | 
             
                                type: Inject,
         | 
| 3599 3582 | 
             
                                args: [SC_NEXT_PAGE_PAGINATION_CLICK]
         | 
| @@ -4555,12 +4538,12 @@ class ScOrderItemMobileComponent { | |
| 4555 4538 | 
             
                    return this.product?.getImage(this.urls.imgServerUrl) ?? this.urls.imgServerUrl + this.pathImageNotFound;
         | 
| 4556 4539 | 
             
                }
         | 
| 4557 4540 | 
             
            }
         | 
| 4558 | 
            -
            ScOrderItemMobileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScOrderItemMobileComponent, deps: [{ token:  | 
| 4541 | 
            +
            ScOrderItemMobileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScOrderItemMobileComponent, deps: [{ token: ScUnitsHelper }, { token: TuiPreviewDialogService }, { token: SC_URLS }, { token: SC_PATH_IMAGE_NOT_FOUND }], target: i0.ɵɵFactoryTarget.Component });
         | 
| 4559 4542 | 
             
            ScOrderItemMobileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScOrderItemMobileComponent, selector: "sc-order-item-mobile", inputs: { orderItem: "orderItem" }, outputs: { clickCardEvent: "clickCardEvent", clickActionsEvent: "clickActionsEvent" }, viewQueries: [{ propertyName: "specificationPreviewRef", first: true, predicate: ["specificationPreview"], descendants: true }], ngImport: i0, template: "<div class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\">\n    <ng-container *ngIf=\"orderItem && product; else skeleton\">\n        <button\n            tuiIconButton\n            (click)=\"clickActionsEvent.emit()\"\n            size=\"m\"\n            icon=\"scIconVerticalThreeDots\"\n            appearance=\"float\"\n            tuiMode=\"onLight\"\n            class=\"!absolute right-0 top-0 !hidden\"\n        ></button>\n        <div class=\"flex grow gap-2\">\n            <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n                <img\n                    (click)=\"clickCardEvent.emit()\"\n                    [src]=\"getCardImage()\"\n                    [alt]=\"product.name\"\n                    [class.p-5]=\"!product.images?.length\"\n                    class=\"cursor-pointer\"\n                />\n            </div>\n\n            <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n                <div class=\"flex grow basis-min-content flex-col\">\n                    <a\n                        tuiLink\n                        (click)=\"clickCardEvent.emit()\"\n                    >\n                        <span class=\"font-bold\">{{ product.name }}</span>\n                    </a>\n                    <div class=\"flex flex-col gap-y-0.5 text-xs text-tui-text-02\">\n                        <div class=\"flex flex-wrap gap-y-0.5\">\n                            <p class=\"w-40\">\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n                            <p\n                                class=\"w-40\"\n                                *ngIf=\"product.pack\"\n                            >\n                                \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n                            </p>\n                        </div>\n                        <a\n                            tuiLink\n                            *ngIf=\"orderItem.specificationImgUrl\"\n                            (click)=\"showSpecification()\"\n                            >\u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F</a\n                        >\n                        <ng-template\n                            #specificationPreview\n                            let-preview\n                        >\n                            <tui-preview\n                                [rotatable]=\"false\"\n                                [zoomable]=\"false\"\n                            >\n                                <img\n                                    *polymorpheusOutlet=\"orderItem.specificationImgUrl as src\"\n                                    alt=\"preview\"\n                                    [src]=\"orderItem.specificationImgUrl\"\n                                />\n                                <button\n                                    icon=\"tuiIconClose\"\n                                    title=\"Close\"\n                                    tuiIconButton\n                                    tuiPreviewAction\n                                    type=\"button\"\n                                    (click)=\"preview.complete()\"\n                                ></button>\n                            </tui-preview>\n                        </ng-template>\n                    </div>\n                </div>\n                <div class=\"flex flex-wrap content-center\">\n                    <div class=\"flex w-40 flex-col gap-x-8 gap-y-0.5\">\n                        <span\n                            *ngIf=\"product.discount\"\n                            class=\"flex items-center text-xs text-tui-text-02\"\n                        >\n                            <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                            <span class=\"font-bold text-tui-success-fill\"> -{{ product.discount.percent }}% </span>\n                            <ng-template #discountHint>\n                                <div class=\"font-bold\">{{ product.discount.name }}</div>\n                                <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                            </ng-template>\n                        </span>\n                        <p class=\"flex flex-col items-baseline gap-x-2 font-bold\">\n                            <span>{{ product.costRubString }}</span>\n                            <span\n                                *ngIf=\"!product.priceInRub\"\n                                class=\"text-xs text-tui-text-02\"\n                                >{{ product.costString }}</span\n                            >\n                        </p>\n                        <sc-price-warehouse-stock\n                            [product]=\"product\"\n                            [fromMain]=\"false\"\n                        ></sc-price-warehouse-stock>\n                    </div>\n\n                    <div class=\"w-40 text-xs text-tui-text-02\">\n                        <ng-container *ngIf=\"orderItem.height; else length\">\n                            <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ orderItem.height }} \u043C.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"orderItem.length\">\u0414\u043B\u0438\u043D\u0430: {{ orderItem.length }} \u043C.</p>\n                        </ng-template>\n                        <p *ngIf=\"orderItem.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ orderItem.width }} \u043C.</p>\n                        <p class=\"text-sm text-tui-base-09\">\n                            \u0421\u0443\u043C\u043C\u0430: <span class=\"whitespace-nowrap font-bold\"> {{ orderItem.getCostRubStr() }} </span>\n                        </p>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-template #skeleton>\n        <div class=\"flex w-full gap-2\">\n            <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"flex grow flex-col gap-2.5 bg-white\">\n                <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i4.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "component", type: i7$1.TuiPreviewComponent, selector: "tui-preview", inputs: ["zoomable", "rotatable"] }, { kind: "directive", type: i7$1.TuiPreviewActionDirective, selector: "[tuiPreviewAction]" }, { kind: "component", type: ScPriceWarehouseStockComponent, selector: "sc-price-warehouse-stock", inputs: ["classList", "product", "withStockHint", "fromMain"] }, { kind: "directive", type: i2$1.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
         | 
| 4560 4543 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScOrderItemMobileComponent, decorators: [{
         | 
| 4561 4544 | 
             
                        type: Component,
         | 
| 4562 4545 | 
             
                        args: [{ selector: 'sc-order-item-mobile', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\">\n    <ng-container *ngIf=\"orderItem && product; else skeleton\">\n        <button\n            tuiIconButton\n            (click)=\"clickActionsEvent.emit()\"\n            size=\"m\"\n            icon=\"scIconVerticalThreeDots\"\n            appearance=\"float\"\n            tuiMode=\"onLight\"\n            class=\"!absolute right-0 top-0 !hidden\"\n        ></button>\n        <div class=\"flex grow gap-2\">\n            <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n                <img\n                    (click)=\"clickCardEvent.emit()\"\n                    [src]=\"getCardImage()\"\n                    [alt]=\"product.name\"\n                    [class.p-5]=\"!product.images?.length\"\n                    class=\"cursor-pointer\"\n                />\n            </div>\n\n            <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n                <div class=\"flex grow basis-min-content flex-col\">\n                    <a\n                        tuiLink\n                        (click)=\"clickCardEvent.emit()\"\n                    >\n                        <span class=\"font-bold\">{{ product.name }}</span>\n                    </a>\n                    <div class=\"flex flex-col gap-y-0.5 text-xs text-tui-text-02\">\n                        <div class=\"flex flex-wrap gap-y-0.5\">\n                            <p class=\"w-40\">\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n                            <p\n                                class=\"w-40\"\n                                *ngIf=\"product.pack\"\n                            >\n                                \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n                            </p>\n                        </div>\n                        <a\n                            tuiLink\n                            *ngIf=\"orderItem.specificationImgUrl\"\n                            (click)=\"showSpecification()\"\n                            >\u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F</a\n                        >\n                        <ng-template\n                            #specificationPreview\n                            let-preview\n                        >\n                            <tui-preview\n                                [rotatable]=\"false\"\n                                [zoomable]=\"false\"\n                            >\n                                <img\n                                    *polymorpheusOutlet=\"orderItem.specificationImgUrl as src\"\n                                    alt=\"preview\"\n                                    [src]=\"orderItem.specificationImgUrl\"\n                                />\n                                <button\n                                    icon=\"tuiIconClose\"\n                                    title=\"Close\"\n                                    tuiIconButton\n                                    tuiPreviewAction\n                                    type=\"button\"\n                                    (click)=\"preview.complete()\"\n                                ></button>\n                            </tui-preview>\n                        </ng-template>\n                    </div>\n                </div>\n                <div class=\"flex flex-wrap content-center\">\n                    <div class=\"flex w-40 flex-col gap-x-8 gap-y-0.5\">\n                        <span\n                            *ngIf=\"product.discount\"\n                            class=\"flex items-center text-xs text-tui-text-02\"\n                        >\n                            <span class=\"line-through\">{{ product.discountCostString }}</span>  \n                            <span class=\"font-bold text-tui-success-fill\"> -{{ product.discount.percent }}% </span>\n                            <ng-template #discountHint>\n                                <div class=\"font-bold\">{{ product.discount.name }}</div>\n                                <div *ngIf=\"product.discount.expiredAt as expiredAt\">\u0414\u0430\u0442\u0430 \u043E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u044F: {{ expiredAt }}</div>\n                            </ng-template>\n                        </span>\n                        <p class=\"flex flex-col items-baseline gap-x-2 font-bold\">\n                            <span>{{ product.costRubString }}</span>\n                            <span\n                                *ngIf=\"!product.priceInRub\"\n                                class=\"text-xs text-tui-text-02\"\n                                >{{ product.costString }}</span\n                            >\n                        </p>\n                        <sc-price-warehouse-stock\n                            [product]=\"product\"\n                            [fromMain]=\"false\"\n                        ></sc-price-warehouse-stock>\n                    </div>\n\n                    <div class=\"w-40 text-xs text-tui-text-02\">\n                        <ng-container *ngIf=\"orderItem.height; else length\">\n                            <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ orderItem.height }} \u043C.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"orderItem.length\">\u0414\u043B\u0438\u043D\u0430: {{ orderItem.length }} \u043C.</p>\n                        </ng-template>\n                        <p *ngIf=\"orderItem.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ orderItem.width }} \u043C.</p>\n                        <p class=\"text-sm text-tui-base-09\">\n                            \u0421\u0443\u043C\u043C\u0430: <span class=\"whitespace-nowrap font-bold\"> {{ orderItem.getCostRubStr() }} </span>\n                        </p>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-template #skeleton>\n        <div class=\"flex w-full gap-2\">\n            <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"flex grow flex-col gap-2.5 bg-white\">\n                <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n" }]
         | 
| 4563 | 
            -
                    }], ctorParameters: function () { return [{ type:  | 
| 4546 | 
            +
                    }], ctorParameters: function () { return [{ type: ScUnitsHelper }, { type: i7$1.TuiPreviewDialogService, decorators: [{
         | 
| 4564 4547 | 
             
                                type: Inject,
         | 
| 4565 4548 | 
             
                                args: [TuiPreviewDialogService]
         | 
| 4566 4549 | 
             
                            }] }, { type: undefined, decorators: [{
         | 
| @@ -4781,7 +4764,7 @@ ScUpdateUserInfoDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: | |
| 4781 4764 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScUpdateUserInfoDialogComponent, decorators: [{
         | 
| 4782 4765 | 
             
                        type: Component,
         | 
| 4783 4766 | 
             
                        args: [{ selector: 'sc-update-user-info-dialog', providers: [SC_USER_PROVIDERS], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" *ngIf=\"user$ | async as user\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4\">\n    <label [tuiLabel]=\"user.isOrg ? '\u041D\u0430\u0437\u0432\u0430\u043D\u0438\u0435 \u043E\u0440\u0433\u0430\u043D\u0438\u0437\u0430\u0446\u0438\u0438 \u0438\u043B\u0438 \u0418\u041F' : '\u0424.\u0418.\u041E.'\">\n        <tui-input formControlName=\"name\">\n            {{ user.isOrg ? '\u041D\u0430\u0437\u0432\u0430\u043D\u0438\u0435 \u043E\u0440\u0433\u0430\u043D\u0438\u0437\u0430\u0446\u0438\u0438 \u0438\u043B\u0438 \u0418\u041F' : '\u0424.\u0418.\u041E.' }}\n            <ng-container *ngIf=\"user.isOrg\">\n                <sc-suggestion-field *tuiDataList [type]=\"suggestionType.organization\"></sc-suggestion-field>\n            </ng-container>\n        </tui-input>\n        <tui-error formControlName=\"name\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n    </label>\n    <sc-verification-phone-check-form\n        *tuiLet=\"user.contacts.phone.value === form.value.phone as phoneIsChange\"\n        [showCodeFields]=\"!phoneIsChange\"\n        [shouldBeBusy]=\"phoneIsChange\"\n        class=\"w-full\"\n    ></sc-verification-phone-check-form>\n    <label tuiLabel=\"\u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\" class=\"w-full\">\n        <tui-input formControlName=\"email\">\n            \u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\n            <sc-suggestion-field *tuiDataList [type]=\"suggestionType.email\"></sc-suggestion-field>\n        </tui-input>\n        <tui-error formControlName=\"email\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n    </label>\n    <sc-addresses-selection-field></sc-addresses-selection-field>\n    <tui-checkbox-labeled formControlName=\"getNews\" class=\"w-full\"> \u042F \u0445\u043E\u0447\u0443 \u043F\u043E\u043B\u0443\u0447\u0430\u0442\u044C \u0440\u0430\u0441\u0441\u044B\u043B\u043A\u0443 \u0421\u043D\u0430\u0431\u0446\u0435\u043D\u0442\u0440 \u043E \u0441\u043A\u0438\u0434\u043A\u0430\u0445 \u0438 \u043D\u043E\u0432\u043E\u0441\u0442\u044F\u0445 \u043F\u043E \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u0435. </tui-checkbox-labeled>\n    <div class=\"flex gap-4 justify-center\">\n        <button tuiButton (click)=\"context ? context.$implicit.complete() : cancelButtonClick.emit()\" type=\"button\" icon=\"tuiIconXLarge\" appearance=\"secondary\">\u041E\u0442\u043C\u0435\u043D\u0430</button>\n        <button tuiButton tuiMode=\"onLight\" [disabled]=\"form.invalid\" [showLoader]=\"!!(loading$ | async)\" type=\"submit\" icon=\"scIconSave\">\u0421\u043E\u0445\u0440\u0430\u043D\u0438\u0442\u044C</button>\n    </div>\n</form>\n" }]
         | 
| 4784 | 
            -
                    }], ctorParameters: function () { return [{ type:  | 
| 4767 | 
            +
                    }], ctorParameters: function () { return [{ type: i5.Observable, decorators: [{
         | 
| 4785 4768 | 
             
                                type: Inject,
         | 
| 4786 4769 | 
             
                                args: [SC_USER_INFO]
         | 
| 4787 4770 | 
             
                            }] }, { type: i1.ScUserService }, { type: undefined, decorators: [{
         | 
| @@ -4895,7 +4878,7 @@ ScUserPhoneApproveDialogComponent = __decorate([ | |
| 4895 4878 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScUserPhoneApproveDialogComponent, decorators: [{
         | 
| 4896 4879 | 
             
                        type: Component,
         | 
| 4897 4880 | 
             
                        args: [{ selector: 'sc-user-phone-approve-dialog', providers: [SC_USER_PROVIDERS], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"user$ | async as user\">\n    <form [formGroup]=\"form\" *tuiLet=\"!!(loading$ | async) as loadingApproveCode\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-3\">\n        <sc-verification-phone-check-form\n            [(haveCode)]=\"haveCode\"\n            [shouldBeConfirmed]=\"false\"\n            [showCodeFields]=\"!user.contacts.phone.isApproved\"\n            [readOnly]=\"true\"\n            class=\"w-full\"\n        ></sc-verification-phone-check-form>\n        <div *ngIf=\"user.contacts.phone.isApproved || haveCode\" class=\"flex gap-4 justify-center\">\n            <button *ngIf=\"user.contacts.phone.isApproved && context\" tuiButton (click)=\"context.$implicit.complete()\" type=\"button\" appearance=\"secondary\">\u0417\u0430\u043A\u0440\u044B\u0442\u044C</button>\n            <button *ngIf=\"haveCode\" tuiButton type=\"submit\" [showLoader]=\"loadingApproveCode\" [disabled]=\"form.invalid || loadingApproveCode\" icon=\"scIconLogIn\">\n                \u041F\u043E\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u0442\u044C\n            </button>\n        </div>\n    </form>\n</ng-container>\n" }]
         | 
| 4898 | 
            -
                    }], ctorParameters: function () { return [{ type: i1.ScVerificationService }, { type:  | 
| 4881 | 
            +
                    }], ctorParameters: function () { return [{ type: i1.ScVerificationService }, { type: i5.Observable, decorators: [{
         | 
| 4899 4882 | 
             
                                type: Inject,
         | 
| 4900 4883 | 
             
                                args: [SC_USER_INFO]
         | 
| 4901 4884 | 
             
                            }] }, { type: i1.ScUserService }, { type: undefined, decorators: [{
         | 
| @@ -5110,7 +5093,7 @@ __decorate([ | |
| 5110 5093 | 
             
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScProfileAccordionsContentComponent, decorators: [{
         | 
| 5111 5094 | 
             
                        type: Component,
         | 
| 5112 5095 | 
             
                        args: [{ selector: 'sc-profile-accordions-content', providers: [SC_USER_PROVIDERS], animations: [tuiFadeIn], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *tuiLet=\"user$ | async as user\" class=\"flex flex-col gap-4\">\n    <sc-accordion [showArrow]=\"false\" [showAddButton]=\"false\" [open]=\"true\">\n        \u041E\u0431\u0449\u0438\u0435 \u0434\u0430\u043D\u043D\u044B\u0435\n        <ng-template scAccordionContent>\n            <tui-loader [overlay]=\"true\" [showLoader]=\"user === null\">\n                <div class=\"flex gap-2 pl-4\">\n                    <div *ngIf=\"user\" class=\"flex flex-col flex-grow gap-2\">\n                        <span class=\"font-medium\">{{ user.name }}</span>\n                        <div *ngIf=\"user.city && (getUserCity$(user.city) | async) as city\" class=\"flex items-center gap-1\">\n                            <tui-svg src=\"tuiIconMapPin\"></tui-svg>\n                            <div class=\"flex flex-wrap\">\n                                <span>\u0433. {{ city.name }}, </span>\n                                <span *ngIf=\"city.region\">{{ city.region.name }}</span>\n                            </div>\n                        </div>\n                        <div class=\"flex flex-wrap gap-2\">\n                            <a\n                                tuiLink\n                                tuiMode=\"onLight\"\n                                icon=\"tuiIconPhone\"\n                                iconAlign=\"left\"\n                                [pseudo]=\"true\"\n                                href=\"tel:{{ user.contacts.phone.value}}\"\n                                >{{ user.contacts.phone.value | tuiFormatPhone }}</a\n                            >\n                            <span *ngIf=\"!user.contacts.phone.isApproved\" class=\"text-tui-text-03\">\n                                (\u0422\u0435\u043B\u0435\u0444\u043E\u043D \u043D\u0435 \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043D. <button tuiLink [pseudo]=\"true\" (click)=\"approvePhoneClick.emit()\">\u041F\u043E\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u0442\u044C</button>)\n                            </span>\n                        </div>\n                        <div *tuiLet=\"!!(isSendApproveEmail$ | async) as isSendApproveEmail\" class=\"flex flex-wrap gap-x-2\">\n                            <a tuiLink tuiMode=\"onLight\" icon=\"tuiIconMail\" iconAlign=\"left\" [pseudo]=\"true\" href=\"mailto:{{ user.contacts.email.value }}\">\n                                {{ user.contacts.email.value }}\n                            </a>\n                            <span *ngIf=\"!isSendApproveEmail && !user.contacts.email.isApproved\" class=\"text-tui-text-03 inline-flex flex-wrap gap-1\">\n                                E-mail \u043D\u0435 \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043D.\n                                <tui-loader [showLoader]=\"!!(approveEmailLoading$ | async)\" [overlay]=\"true\">\n                                    <button tuiLink [pseudo]=\"true\" (click)=\"onSendApproveEmail.next(user.contacts.email.value)\">\u041F\u043E\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u0442\u044C</button>\n                                </tui-loader>\n                            </span>\n                            <span *ngIf=\"isSendApproveEmail\" class=\"text-tui-success-fill\" @tuiFadeIn>\n                                \u041F\u0438\u0441\u044C\u043C\u043E \u0434\u043B\u044F \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043D\u0438\u044F \u0443\u0441\u043F\u0435\u0448\u043D\u043E \u043E\u0442\u043F\u0440\u0430\u0432\u043B\u0435\u043D\u043E. \u041F\u0435\u0440\u0435\u0439\u0434\u0438\u0442\u0435 \u043F\u043E \u0441\u0441\u044B\u043B\u043A\u0435 \u0432 \u043F\u0438\u0441\u044C\u043C\u0435 \u0438 \u043E\u0431\u043D\u043E\u0432\u0438\u0442\u0435 \u044D\u0442\u0443 \u0441\u0442\u0440\u0430\u043D\u0438\u0446\u0443.\n                            </span>\n                        </div>\n                        <tui-loader [showLoader]=\"!!(getNewsLoading$ | async)\" [overlay]=\"true\">\n                            <tui-checkbox-labeled size=\"m\" class=\"w-full\" [formControl]=\"getNewsControl\" [ngModel]=\"user.getNews\">\n                                \u042F \u0445\u043E\u0447\u0443 \u043F\u043E\u043B\u0443\u0447\u0430\u0442\u044C \u0440\u0430\u0441\u0441\u044B\u043B\u043A\u0443 \u0421\u043D\u0430\u0431\u0446\u0435\u043D\u0442\u0440 \u043E \u0441\u043A\u0438\u0434\u043A\u0430\u0445 \u0438 \u043D\u043E\u0432\u043E\u0441\u0442\u044F\u0445 \u043F\u043E \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u0435.\n                            </tui-checkbox-labeled>\n                        </tui-loader>\n                    </div>\n\n                    <button tuiIconButton size=\"m\" type=\"button\" icon=\"tuiIconEdit3Large\" tuiMode=\"onLight\" appearance=\"flat\" (click)=\"editProfileClick.emit()\"></button>\n                </div>\n            </tui-loader>\n        </ng-template>\n    </sc-accordion>\n    <sc-contragents-accordion\n        (addContragentClick)=\"addContragentClick.emit()\"\n        (deleteContragentClick)=\"deleteContragentClick.emit($event)\"\n        (addContragentBankAccountClick)=\"addContragentBankAccountClick.emit($event)\"\n        (deleteContragentBankAccountClick)=\"deleteContragentBankAccountClick.emit($event)\"\n        (addContragentContactClick)=\"addContragentContactClick.emit($event)\"\n        (deleteContragentContactClick)=\"deleteContragentContactClick.emit($event)\"\n    ></sc-contragents-accordion>\n    <sc-delivery-address-accordion\n        (addDeliveryAddressClick)=\"addDeliveryAddressClick.emit()\"\n        (deleteDeliveryAddressClick)=\"deleteDeliveryAddressClick.emit($event)\"\n        (addDeliveryAddressContactClick)=\"addDeliveryAddressContactClick.emit($event)\"\n        (deleteDeliveryAddressContactClick)=\"deleteDeliveryAddressContactClick.emit($event)\"\n    ></sc-delivery-address-accordion>\n    <sc-contacts-accordion *ngIf=\"user\" [contacts$]=\"userContacts$\" (addContactClick)=\"addUserContactClick.emit(user.id)\" (deleteButtonClick)=\"deleteUserContactClick.emit($event)\"></sc-contacts-accordion>\n    <sc-accordion #passwordAccordion [showArrow]=\"false\" [showAddButton]=\"false\">\n        \u0418\u0437\u043C\u0435\u043D\u0438\u0442\u044C \u043F\u0430\u0440\u043E\u043B\u044C\n        <ng-template scAccordionContent>\n            <sc-reset-user-password (successResetPassword)=\"passwordAccordion.close()\"></sc-reset-user-password>\n        </ng-template>\n    </sc-accordion>\n</div>\n" }]
         | 
| 5113 | 
            -
                    }], ctorParameters: function () { return [{ type:  | 
| 5096 | 
            +
                    }], ctorParameters: function () { return [{ type: i5.Observable, decorators: [{
         | 
| 5114 5097 | 
             
                                type: Inject,
         | 
| 5115 5098 | 
             
                                args: [SC_USER_INFO]
         | 
| 5116 5099 | 
             
                            }] }, { type: i1.ScLocationsService }, { type: i1.ScUserService }, { type: i1.ScVerificationService }]; }, propDecorators: { editProfileClick: [{
         | 
| @@ -5218,5 +5201,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor | |
| 5218 5201 | 
             
             * Generated bundle index. Do not edit.
         | 
| 5219 5202 | 
             
             */
         | 
| 5220 5203 |  | 
| 5221 | 
            -
            export { AuthMethod, FilesAndDocumentsComponent, FilesAndDocumentsModule, SC_LINEAR_VALUES, SC_LINEAR_VALUES_TOKEN, SC_LOADING_PAGINATION_CHANGE_INFO, SC_NEXT_PAGE_PAGINATION_CHANGE_INFO, SC_NEXT_PAGE_PAGINATION_CLICK, SC_PRODUCT_PAGINATION_CHANGE_INFO, SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS, SC_PRODUCT_PAGINATION_DEFAULT_OPTIONS, SC_PRODUCT_PAGINATION_OPTIONS, SC_PRODUCT_PAGINATION_PARAMS, SC_USER_INFO, SC_USER_PROVIDERS, ScAccordionComponent, ScAccordionContentDirective, ScAccordionModule, ScAddContactDialogComponent, ScAddContragentBankAccountsDialogComponent, ScAddContragentDialogComponent, ScAddDeliveryAddressDialogComponent, ScAddressesSelectionFieldComponent, ScAuthModule, ScBannerComponent, ScBannerModule,  | 
| 5204 | 
            +
            export { AbstractScPriceCard, AuthMethod, FilesAndDocumentsComponent, FilesAndDocumentsModule, SC_LINEAR_VALUES, SC_LINEAR_VALUES_TOKEN, SC_LOADING_PAGINATION_CHANGE_INFO, SC_NEXT_PAGE_PAGINATION_CHANGE_INFO, SC_NEXT_PAGE_PAGINATION_CLICK, SC_PRODUCT_PAGINATION_CHANGE_INFO, SC_PRODUCT_PAGINATION_CHANGE_PROVIDERS, SC_PRODUCT_PAGINATION_DEFAULT_OPTIONS, SC_PRODUCT_PAGINATION_OPTIONS, SC_PRODUCT_PAGINATION_PARAMS, SC_USER_INFO, SC_USER_PROVIDERS, ScAccordionComponent, ScAccordionContentDirective, ScAccordionModule, ScAddContactDialogComponent, ScAddContragentBankAccountsDialogComponent, ScAddContragentDialogComponent, ScAddDeliveryAddressDialogComponent, ScAddressesSelectionFieldComponent, ScAuthModule, ScBannerComponent, ScBannerModule, ScCartItemMobileComponent, ScCartModule, ScCatalogModule, ScCategoriesListComponent, ScCategoryCardComponent, ScContactsAccordionComponent, ScContactsModule, ScContragentsAccordionComponent, ScContragentsAccordionItemComponent, ScContragentsModule, ScDeliveryAddressAccordionComponent, ScDeliveryAddressAccordionItemComponent, ScDeliveryAddressModule, ScFavoriteBtnComponent, ScFormFieldsModule, ScInputQuantityComponent, ScNewContactFormComponent, ScNewContragentBankAccountsFormComponent, ScNewContragentFormComponent, ScNewsCardComponent, ScNewsCardSkeletonComponent, ScNewsModule, ScNextInputFocusDirective, ScNextInputFocusModule, ScOrderItemMobileComponent, ScOrderModule, ScPaymentStatusComponent, ScPriceCardComponent, ScPriceHistoryComponent, ScPriceListPaginationComponent, ScPriceWarehouseStockComponent, ScProfileAccordionsContentComponent, ScProfileModule, ScResetUserPasswordComponent, ScShareButtonComponent, ScShareButtonModule, ScSignInFormByEmailComponent, ScSignInFormByPhoneComponent, ScSignInFormComponent, ScSignUpFormComponent, ScSuggestionFieldComponent, ScUpdateUserInfoDialogComponent, ScUserManagersComponent, ScUserModule, ScUserPhoneApproveDialogComponent, ScVerificationModule, ScVerificationPhoneCheckFormComponent, TreeDirective, TreeIconService, TreeLoaderService, TreeTopDirective, nextPageClickEvent, paginationParams$, scBicValidator, scClientUiIconsName, scCorrespondentAccountValidator, scPasswordConfirmMatchingValidator, scUserFactory, stepValidator };
         | 
| 5222 5205 | 
             
            //# sourceMappingURL=snabcentr-client-ui.mjs.map
         |