@snabcentr/client-ui 3.49.3 → 3.50.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/auth/interfaces/index.d.ts +0 -1
- package/banner/sc-banner.component.d.ts +23 -29
- package/cart/add-or-editing-cart-item-dialog/add-or-editing-cart-item-form/sc-add-or-editing-cart-item-form.component.d.ts +5 -5
- package/cart/add-or-editing-cart-item-dialog/sc-add-or-editing-cart-item-dialog.component.d.ts +5 -5
- package/cart/index.d.ts +0 -1
- package/catalog/price-card-inline/sc-price-card-inline.component.d.ts +1 -1
- package/configurators/sandwich/sc-i-new-cart-item-sandwich.d.ts +2 -2
- package/configurators/sandwich/sc-sandwich.component.d.ts +2 -2
- package/directives/abstract-price-card/abstract-sc-price-card.directive.d.ts +6 -6
- package/esm2022/auth/interfaces/index.mjs +1 -2
- package/esm2022/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.mjs +1 -1
- package/esm2022/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.mjs +1 -1
- package/esm2022/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.mjs +1 -1
- package/esm2022/auth/sign-up-form/sc-sign-up-form.component.mjs +3 -3
- package/esm2022/banner/sc-banner.component.mjs +53 -59
- package/esm2022/cart/add-or-editing-cart-item-dialog/add-or-editing-cart-item-form/sc-add-or-editing-cart-item-form.component.mjs +11 -11
- package/esm2022/cart/add-or-editing-cart-item-dialog/sc-add-or-editing-cart-item-dialog.component.mjs +6 -6
- package/esm2022/cart/index.mjs +1 -2
- package/esm2022/catalog/notify-when-in-stock-dialog/sc-notify-when-in-stock-dialog.component.mjs +1 -1
- package/esm2022/catalog/price-card/sc-price-card.component.mjs +3 -3
- package/esm2022/catalog/price-card-inline/sc-price-card-inline.component.mjs +3 -3
- package/esm2022/catalog/price-history/sc-price-history.component.mjs +3 -3
- package/esm2022/configurators/sandwich/sc-i-new-cart-item-sandwich.mjs +1 -1
- package/esm2022/configurators/sandwich/sc-sandwich.component.mjs +6 -13
- package/esm2022/contacts/add-contact-dialog/sc-add-contact-dialog.component.mjs +1 -1
- package/esm2022/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.mjs +1 -1
- package/esm2022/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.mjs +1 -1
- package/esm2022/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.mjs +1 -1
- package/esm2022/directives/abstract-price-card/abstract-sc-price-card.directive.mjs +8 -8
- package/esm2022/feedback/feedback-form/sc-feedback-form.component.mjs +1 -1
- package/esm2022/form-fields/suggestion-field/sc-suggestion-field.component.mjs +3 -3
- package/esm2022/order/draft/sc-draft.component.mjs +117 -0
- package/esm2022/order/index.mjs +7 -2
- package/esm2022/order/models/sc-i-cart-items-by-direction.mjs +22 -0
- package/esm2022/order/order-item/sc-order-item.component.mjs +85 -0
- package/esm2022/order/order-items-list/sc-order-items-list.component.mjs +203 -0
- package/esm2022/order/order-items-list-by-directions/sc-order-items-list-by-directions.component.mjs +72 -0
- package/esm2022/order/order-items-list-by-stock/sc-order-items-list-by-stock.component.mjs +75 -0
- package/esm2022/order/sc-order.module.mjs +5 -6
- package/esm2022/providers/index.mjs +2 -1
- package/esm2022/providers/sc-dialog-service.providers.mjs +6 -0
- package/esm2022/user/reset-user-password/sc-reset-user-password.component.mjs +1 -1
- package/esm2022/user/update-user-info-dialog/sc-update-user-info-dialog.component.mjs +2 -2
- package/esm2022/user/user-phone-approve-dialog/sc-user-phone-approve-dialog.component.mjs +2 -2
- package/esm2022/verification/verification-phone-check-form/sc-verification-phone-check-form.component.mjs +1 -1
- package/fesm2022/snabcentr-client-ui.mjs +1971 -1580
- package/fesm2022/snabcentr-client-ui.mjs.map +1 -1
- package/order/draft/sc-draft.component.d.ts +63 -0
- package/order/index.d.ts +6 -1
- package/order/models/sc-i-cart-items-by-direction.d.ts +25 -0
- package/{cart/cart-item/sc-cart-item.component.d.ts → order/order-item/sc-order-item.component.d.ts} +7 -3
- package/order/order-items-list/sc-order-items-list.component.d.ts +102 -0
- package/order/order-items-list-by-directions/sc-order-items-list-by-directions.component.d.ts +55 -0
- package/order/order-items-list-by-stock/sc-order-items-list-by-stock.component.d.ts +55 -0
- package/order/sc-order.module.d.ts +10 -11
- package/package.json +3 -2
- package/providers/index.d.ts +1 -0
- package/providers/sc-dialog-service.providers.d.ts +41 -0
- package/styles/taiga/snabcentr-tailwind-preset.js +2 -3
- package/styles/tailwind/tailwind.scss +96 -100
- package/auth/interfaces/api-error-response.d.ts +0 -13
- package/esm2022/auth/interfaces/api-error-response.mjs +0 -2
- package/esm2022/cart/cart-item/sc-cart-item.component.mjs +0 -71
- package/esm2022/helpers/index.mjs +0 -2
- package/esm2022/helpers/sc-px-converter.mjs +0 -27
- package/esm2022/order/order-item-mobile/sc-order-item-mobile.component.mjs +0 -60
- package/helpers/index.d.ts +0 -1
- package/helpers/sc-px-converter.d.ts +0 -15
- package/order/order-item-mobile/sc-order-item-mobile.component.d.ts +0 -39
|
@@ -115,7 +115,7 @@ export class ScPriceHistoryComponent {
|
|
|
115
115
|
}, []));
|
|
116
116
|
}
|
|
117
117
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScPriceHistoryComponent, deps: [{ token: i1.ScCatalogService }, { token: TUI_MONTHS }, { token: i1.ScUserMetrikaService }, { token: POLYMORPHEUS_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
118
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ScPriceHistoryComponent, selector: "sc-price-history", inputs: { product: "product" }, ngImport: i0, 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 @let height = priceInfo.max - priceInfo.min;\n <
|
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ScPriceHistoryComponent, selector: "sc-price-history", inputs: { product: "product" }, ngImport: i0, 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 @let height = priceInfo.max - priceInfo.min;\n <tui-line-days-chart\n *ngIf=\"(height / 100) * paddingPercent as padding\"\n [height]=\"height + (height / 100) * paddingPercent * 2\"\n [smoothingFactor]=\"10\"\n [y]=\"priceInfo.min - (height / 100) * paddingPercent\"\n [value]=\"computeValue(range, history)\"\n [xStringify]=\"xStringify$ | async\"\n [yStringify]=\"yStringify\"\n [hintContent]=\"hint\"\n class=\"chart\"\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", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "component", type: i4.TuiLineDaysChart, selector: "tui-line-days-chart", inputs: ["y", "height", "smoothingFactor", "hintContent", "xStringify", "yStringify", "dots", "value"] }, { kind: "component", type: i4.TuiAxes, selector: "tui-axes", inputs: ["axisX", "axisXLabels", "axisY", "axisYInset", "axisYLabels", "axisYName", "axisYSecondaryInset", "axisYSecondaryLabels", "axisYSecondaryName", "horizontalLines", "horizontalLinesHandler", "verticalLines", "verticalLinesHandler"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
119
119
|
}
|
|
120
120
|
__decorate([
|
|
121
121
|
tuiPure
|
|
@@ -125,7 +125,7 @@ __decorate([
|
|
|
125
125
|
], ScPriceHistoryComponent.prototype, "computeValue", null);
|
|
126
126
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScPriceHistoryComponent, decorators: [{
|
|
127
127
|
type: Component,
|
|
128
|
-
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 @let height = priceInfo.max - priceInfo.min;\n <
|
|
128
|
+
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 @let height = priceInfo.max - priceInfo.min;\n <tui-line-days-chart\n *ngIf=\"(height / 100) * paddingPercent as padding\"\n [height]=\"height + (height / 100) * paddingPercent * 2\"\n [smoothingFactor]=\"10\"\n [y]=\"priceInfo.min - (height / 100) * paddingPercent\"\n [value]=\"computeValue(range, history)\"\n [xStringify]=\"xStringify$ | async\"\n [yStringify]=\"yStringify\"\n [hintContent]=\"hint\"\n class=\"chart\"\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" }]
|
|
129
129
|
}], ctorParameters: () => [{ type: i1.ScCatalogService }, { type: i5.Observable, decorators: [{
|
|
130
130
|
type: Inject,
|
|
131
131
|
args: [TUI_MONTHS]
|
|
@@ -137,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
137
137
|
}] }], propDecorators: { product: [{
|
|
138
138
|
type: Input
|
|
139
139
|
}], computeLabels$: [], computeValue: [] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-price-history.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/price-history/sc-price-history.component.ts","../../../../../projects/client-ui/catalog/price-history/sc-price-history.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this,lodash/prefer-lodash-method */\n\nimport { ChangeDetectionStrategy, Component, Inject, inject, Input, OnInit, Optional } from '@angular/core';\nimport { ScCatalogService, ScProduct, ScUserMetrikaGoalsEnum, ScUserMetrikaService } from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE, TuiDay, TuiDayRange, tuiIsFalsy, tuiIsPresent, TuiMonth, tuiPure, TuiStringHandler } from '@taiga-ui/cdk';\nimport { TUI_MONTHS, TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { filter, map, Observable, shareReplay, startWith, tap } from 'rxjs';\n\n/**\n * График истории цен товара или услуги.\n */\n@Component({\n    selector: 'sc-price-history',\n    templateUrl: './sc-price-history.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScPriceHistoryComponent implements OnInit {\n    /**\n     * {@link Observable} временного промежутка истории цен.\n     */\n    public range$: Observable<TuiDayRange>;\n\n    /**\n     * Товар или услуга, для которого необходимо отобразить историю цен.\n     */\n    @Input() public product: ScProduct;\n\n    /**\n     * {@link Observable} истории цен.\n     */\n    public history$?: Observable<ReadonlyArray<[TuiDay, number]> | null>;\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных истории цен.\n     */\n    public loadingHistory$?: Observable<boolean>;\n\n    /**\n     * Максимальная цена товара.\n     */\n    public priceInfo$?: Observable<{\n        min: number;\n        max: number;\n    }>;\n\n    /**\n     * Признак того, отображается этот компонент на мобильном устройстве или нет.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * {@link Observable} функция для преобразования значения number в строку в подсказке по оси X.\n     */\n    public readonly xStringify$: Observable<TuiStringHandler<TuiDay>> = this.months$.pipe(\n        map(\n            (months) =>\n                ({ month, day }) =>\n                    // eslint-disable-next-line security/detect-object-injection\n                    `${months[month]}, ${day}`\n        )\n    );\n\n    /**\n     * Относительные отступы от верхнего и нижнего края в процентах.\n     */\n    public readonly paddingPercent: number = 10;\n\n    /**\n     * Функция для преобразования значения number в строку в подсказке по оси Y.\n     *\n     * @param value Значение оси Y.\n     */\n    public readonly yStringify: TuiStringHandler<number> = (value) => `${value.toLocaleString('ru-RU')} ₽`;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScPriceHistoryComponent}.\n     *\n     * @param catalogService Сервис для работы с каталогом.\n     * @param months$ Перечисление месяцев.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly catalogService: ScCatalogService,\n        @Inject(TUI_MONTHS) private readonly months$: Observable<readonly string[]>,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Optional()\n        @Inject(POLYMORPHEUS_CONTEXT)\n        private readonly context?: TuiDialogContext<void, { product: ScProduct }>\n    ) {\n        if (context) {\n            this.product = context.data.product;\n        }\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.history$ = this.catalogService.getPriceHistory$(this.product).pipe(\n            filter(tuiIsPresent),\n            map((history) =>\n                Object.keys(history)\n                    // eslint-disable-next-line security/detect-object-injection\n                    .map((item): [TuiDay, number] => [TuiDay.normalizeParse(item, 'DMY'), history[item].cost])\n                    .sort((a, b) => (a[0] > b[0] ? 1 : -1))\n            ),\n            startWith(null),\n            shareReplay({ bufferSize: 1, refCount: true })\n        );\n\n        this.loadingHistory$ = this.history$.pipe(map(tuiIsFalsy));\n\n        this.priceInfo$ = this.history$.pipe(\n            filter(tuiIsPresent),\n            tap(() => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.productPriceHistoryShow,\n                    params: {\n                        product_id: this.product.id,\n                    },\n                });\n            }),\n            filter((history) => history.length > 1),\n            map((history) => history.map((item) => item[1])),\n            map((values) => ({\n                min: Math.min(...values),\n                max: Math.max(...values),\n            }))\n        );\n\n        this.range$ = this.history$.pipe(\n            filter(tuiIsPresent),\n            filter((history) => history.length > 1),\n            map((value: ReadonlyArray<[TuiDay, number]>) => ({ from: value.at(0)?.[0], to: value.at(-1)?.[0] })),\n            filter((range): range is { from: TuiDay; to: TuiDay } => !!range.from && !!range.to),\n            map((range) => new TuiDayRange(range.from, range.to))\n        );\n    }\n\n    /**\n     * Вычисляет подписи даты к оси X.\n     *\n     * @param param0 {@link TuiDayRange} Временной промежуток истории цен.\n     * @param param0.from {@link TuiDay} Дата начала истории цен.\n     * @param param0.to {@link TuiDay} Дата конца истории цен.\n     */\n    @tuiPure\n    public computeLabels$({ from, to }: TuiDayRange): Observable<readonly string[]> {\n        return this.months$.pipe(\n            map((months) => [\n                ...Array.from({ length: TuiMonth.lengthBetween(from, to) + 1 }, (_, index) => {\n                    const previousYear = from.append({ month: index - 1 }).year; // Начальный год\n                    const currentYear = from.append({ month: index }).year;\n\n                    return `${this.isMobile || previousYear === currentYear ? '' : currentYear} ${months[from.append({ month: index }).month]}`;\n                }),\n                '',\n            ])\n        );\n    }\n\n    /**\n     * Вычисляет данные для отображения на графике.\n     *\n     * @param param0 {@link TuiDayRange} Временной промежуток истории цен.\n     * @param param0.from {@link TuiDay} Дата начала истории цен.\n     * @param param0.to {@link TuiDay} Дата конца истории цен.\n     * @param history История цен.\n     */\n    @tuiPure\n    public computeValue({ from, to }: TuiDayRange, history: ReadonlyArray<[TuiDay, number]>): ReadonlyArray<[TuiDay, number]> {\n        return (\n            Array.from({ length: TuiDay.lengthBetween(from, to) + 1 })\n                .fill(0)\n                // eslint-disable-next-line unicorn/no-array-reduce\n                .reduce<ReadonlyArray<[TuiDay, number]>>((array, _, index) => {\n                    const data = from.append({ day: index });\n                    return [\n                        ...array,\n                        [\n                            data,\n                            (history.find((valueHistory, indexHistory, arrayHistory) => data.daySame(valueHistory[0]) || data.dayBefore(arrayHistory[indexHistory + 1][0])) ??\n                                history[0])[1],\n                        ],\n                    ];\n                }, [])\n        );\n    }\n}\n","<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\">от {{ priceInfo.min.toLocaleString() }} ₽ до {{ priceInfo.max.toLocaleString() }} ₽</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                    @let height = priceInfo.max - priceInfo.min;\n                    <ng-container>\n                        <tui-line-days-chart\n                            *ngIf=\"(height / 100) * paddingPercent as padding\"\n                            [height]=\"height + (height / 100) * paddingPercent * 2\"\n                            [smoothingFactor]=\"10\"\n                            [y]=\"priceInfo.min - (height / 100) * paddingPercent\"\n                            [value]=\"computeValue(range, history)\"\n                            [xStringify]=\"xStringify$ | async\"\n                            [yStringify]=\"yStringify\"\n                            [hintContent]=\"hint\"\n                            class=\"chart\"\n                        ></tui-line-days-chart>\n                    </ng-container>\n                </tui-axes>\n            </div>\n        </ng-container>\n    </ng-container>\n    <ng-template #isNotExist>\n        <p class=\"text-base font-bold\">Цена на товар не изменялась</p>\n    </ng-template>\n    <ng-template\n        #hint\n        let-data\n    >\n        <div class=\"font-bold\">{{ data[1].toLocaleString() }} ₽</div>\n        <div>{{ data[0] }}</div>\n    </ng-template>\n</div>\n"]}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-price-history.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/price-history/sc-price-history.component.ts","../../../../../projects/client-ui/catalog/price-history/sc-price-history.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this,lodash/prefer-lodash-method */\n\nimport { ChangeDetectionStrategy, Component, Inject, inject, Input, OnInit, Optional } from '@angular/core';\nimport { ScCatalogService, ScProduct, ScUserMetrikaGoalsEnum, ScUserMetrikaService } from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE, TuiDay, TuiDayRange, tuiIsFalsy, tuiIsPresent, TuiMonth, tuiPure, TuiStringHandler } from '@taiga-ui/cdk';\nimport { TUI_MONTHS, TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { filter, map, Observable, shareReplay, startWith, tap } from 'rxjs';\n\n/**\n * График истории цен товара или услуги.\n */\n@Component({\n    selector: 'sc-price-history',\n    templateUrl: './sc-price-history.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScPriceHistoryComponent implements OnInit {\n    /**\n     * {@link Observable} временного промежутка истории цен.\n     */\n    public range$: Observable<TuiDayRange>;\n\n    /**\n     * Товар или услуга, для которого необходимо отобразить историю цен.\n     */\n    @Input() public product: ScProduct;\n\n    /**\n     * {@link Observable} истории цен.\n     */\n    public history$?: Observable<ReadonlyArray<[TuiDay, number]> | null>;\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных истории цен.\n     */\n    public loadingHistory$?: Observable<boolean>;\n\n    /**\n     * Максимальная цена товара.\n     */\n    public priceInfo$?: Observable<{\n        min: number;\n        max: number;\n    }>;\n\n    /**\n     * Признак того, отображается этот компонент на мобильном устройстве или нет.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * {@link Observable} функция для преобразования значения number в строку в подсказке по оси X.\n     */\n    public readonly xStringify$: Observable<TuiStringHandler<TuiDay>> = this.months$.pipe(\n        map(\n            (months) =>\n                ({ month, day }) =>\n                    // eslint-disable-next-line security/detect-object-injection\n                    `${months[month]}, ${day}`\n        )\n    );\n\n    /**\n     * Относительные отступы от верхнего и нижнего края в процентах.\n     */\n    public readonly paddingPercent: number = 10;\n\n    /**\n     * Функция для преобразования значения number в строку в подсказке по оси Y.\n     *\n     * @param value Значение оси Y.\n     */\n    public readonly yStringify: TuiStringHandler<number> = (value) => `${value.toLocaleString('ru-RU')} ₽`;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScPriceHistoryComponent}.\n     *\n     * @param catalogService Сервис для работы с каталогом.\n     * @param months$ Перечисление месяцев.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly catalogService: ScCatalogService,\n        @Inject(TUI_MONTHS) private readonly months$: Observable<readonly string[]>,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Optional()\n        @Inject(POLYMORPHEUS_CONTEXT)\n        private readonly context?: TuiDialogContext<void, { product: ScProduct }>\n    ) {\n        if (context) {\n            this.product = context.data.product;\n        }\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.history$ = this.catalogService.getPriceHistory$(this.product).pipe(\n            filter(tuiIsPresent),\n            map((history) =>\n                Object.keys(history)\n                    // eslint-disable-next-line security/detect-object-injection\n                    .map((item): [TuiDay, number] => [TuiDay.normalizeParse(item, 'DMY'), history[item].cost])\n                    .sort((a, b) => (a[0] > b[0] ? 1 : -1))\n            ),\n            startWith(null),\n            shareReplay({ bufferSize: 1, refCount: true })\n        );\n\n        this.loadingHistory$ = this.history$.pipe(map(tuiIsFalsy));\n\n        this.priceInfo$ = this.history$.pipe(\n            filter(tuiIsPresent),\n            tap(() => {\n                this.userMetrikaService.emitUserMetrikaEvent({\n                    target: ScUserMetrikaGoalsEnum.productPriceHistoryShow,\n                    params: {\n                        product_id: this.product.id,\n                    },\n                });\n            }),\n            filter((history) => history.length > 1),\n            map((history) => history.map((item) => item[1])),\n            map((values) => ({\n                min: Math.min(...values),\n                max: Math.max(...values),\n            }))\n        );\n\n        this.range$ = this.history$.pipe(\n            filter(tuiIsPresent),\n            filter((history) => history.length > 1),\n            map((value: ReadonlyArray<[TuiDay, number]>) => ({ from: value.at(0)?.[0], to: value.at(-1)?.[0] })),\n            filter((range): range is { from: TuiDay; to: TuiDay } => !!range.from && !!range.to),\n            map((range) => new TuiDayRange(range.from, range.to))\n        );\n    }\n\n    /**\n     * Вычисляет подписи даты к оси X.\n     *\n     * @param param0 {@link TuiDayRange} Временной промежуток истории цен.\n     * @param param0.from {@link TuiDay} Дата начала истории цен.\n     * @param param0.to {@link TuiDay} Дата конца истории цен.\n     */\n    @tuiPure\n    public computeLabels$({ from, to }: TuiDayRange): Observable<readonly string[]> {\n        return this.months$.pipe(\n            map((months) => [\n                ...Array.from({ length: TuiMonth.lengthBetween(from, to) + 1 }, (_, index) => {\n                    const previousYear = from.append({ month: index - 1 }).year; // Начальный год\n                    const currentYear = from.append({ month: index }).year;\n\n                    return `${this.isMobile || previousYear === currentYear ? '' : currentYear} ${months[from.append({ month: index }).month]}`;\n                }),\n                '',\n            ])\n        );\n    }\n\n    /**\n     * Вычисляет данные для отображения на графике.\n     *\n     * @param param0 {@link TuiDayRange} Временной промежуток истории цен.\n     * @param param0.from {@link TuiDay} Дата начала истории цен.\n     * @param param0.to {@link TuiDay} Дата конца истории цен.\n     * @param history История цен.\n     */\n    @tuiPure\n    public computeValue({ from, to }: TuiDayRange, history: ReadonlyArray<[TuiDay, number]>): ReadonlyArray<[TuiDay, number]> {\n        return (\n            Array.from({ length: TuiDay.lengthBetween(from, to) + 1 })\n                .fill(0)\n                // eslint-disable-next-line unicorn/no-array-reduce\n                .reduce<ReadonlyArray<[TuiDay, number]>>((array, _, index) => {\n                    const data = from.append({ day: index });\n                    return [\n                        ...array,\n                        [\n                            data,\n                            (history.find((valueHistory, indexHistory, arrayHistory) => data.daySame(valueHistory[0]) || data.dayBefore(arrayHistory[indexHistory + 1][0])) ??\n                                history[0])[1],\n                        ],\n                    ];\n                }, [])\n        );\n    }\n}\n","<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\">от {{ priceInfo.min.toLocaleString() }} ₽ до {{ priceInfo.max.toLocaleString() }} ₽</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                    @let height = priceInfo.max - priceInfo.min;\n                    <tui-line-days-chart\n                        *ngIf=\"(height / 100) * paddingPercent as padding\"\n                        [height]=\"height + (height / 100) * paddingPercent * 2\"\n                        [smoothingFactor]=\"10\"\n                        [y]=\"priceInfo.min - (height / 100) * paddingPercent\"\n                        [value]=\"computeValue(range, history)\"\n                        [xStringify]=\"xStringify$ | async\"\n                        [yStringify]=\"yStringify\"\n                        [hintContent]=\"hint\"\n                        class=\"chart\"\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\">Цена на товар не изменялась</p>\n    </ng-template>\n    <ng-template\n        #hint\n        let-data\n    >\n        <div class=\"font-bold\">{{ data[1].toLocaleString() }} ₽</div>\n        <div>{{ data[0] }}</div>\n    </ng-template>\n</div>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtaS1uZXctY2FydC1pdGVtLXNhbmR3aWNoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL2NvbmZpZ3VyYXRvcnMvc2FuZHdpY2gvc2MtaS1uZXctY2FydC1pdGVtLXNhbmR3aWNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTY0lOZXdPcmRlckl0ZW1CYXNlIH0gZnJvbSAnQHNuYWJjZW50ci9jbGllbnQtY29yZSc7XG5cbi8qKlxuICog0JzQvtC00LXQu9GMINC00LDQvdC90YvRhSDRgtC+0LLQsNGA0LAsINC60L7RgtC+0YDRi9C5INC90LXQvtCx0YXQvtC00LjQvNC+INC00L7QsdCw0LLQuNGC0Ywg0LIg0LrQvtGA0LfQuNC90YMsINC40YHQv9C+0LvRjNC30YPRjyDQutC+0L3RhNC40LPRg9GA0LDRgtC+0YAg0YDQsNGB0L/QuNC70LAg0YHRjdC90LTQstC40Yct0L/QsNC90LXQu9C10LkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2NJTmV3Q2FydEl0ZW1TYW5kd2ljaCBleHRlbmRzIFNjSU5ld09yZGVySXRlbUJhc2Uge1xuICAgIC8qKlxuICAgICAqINCY0LTQtdC90YLQuNGE0LjQutCw0YLQvtGAINC30LDQv9C40YHQuCDQutCw0YLQtdCz0L7RgNC40LguXG4gICAgICovXG4gICAgcHJvZHVjdENhdGVnb3J5SWQ6IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqINCY0LTQtdC90YLQuNGE0LjQutCw0YLQvtGAINGA0LDRgdGH0LXRgtCwLlxuICAgICAqL1xuICAgIGNhbGN1bGF0aW9uSWQ6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -6,9 +6,7 @@ import { takeUntilDestroyed, toObservable, toSignal } from '@angular/core/rxjs-i
|
|
|
6
6
|
import { FormArray, FormControl, FormGroup, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
7
7
|
import { ScCartService, ScCatalogService, ScConfiguratorService, ScConvertersService, } from '@snabcentr/client-core';
|
|
8
8
|
import { tuiControlValue } from '@taiga-ui/cdk';
|
|
9
|
-
import { TuiButton,
|
|
10
|
-
import { TuiAppearance, TuiWithAppearance } from '@taiga-ui/core/directives/appearance';
|
|
11
|
-
import { TuiIcons, TuiWithIcons } from '@taiga-ui/core/directives/icons';
|
|
9
|
+
import { TuiButton, TuiError, tuiItemsHandlersProvider, TuiLabel, TuiLoader, TuiNumberFormat, tuiNumberFormatProvider, TuiTextfield } from '@taiga-ui/core';
|
|
12
10
|
import { TuiButtonLoading, TuiChevron, TuiDataListWrapperComponent, TuiFieldErrorPipe, TuiInputNumber, tuiInputNumberOptionsProvider, TuiInputSlider, TuiSelect, } from '@taiga-ui/kit';
|
|
13
11
|
import { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';
|
|
14
12
|
import { catchError, combineLatest, debounceTime, filter, finalize, map, of, share, startWith, switchMap, tap } from 'rxjs';
|
|
@@ -218,10 +216,10 @@ export class ScSandwichComponent {
|
|
|
218
216
|
const formValue = { ...this.form.value, productId: this.product.value?.id ?? null, calculationId: calculateResult.id };
|
|
219
217
|
// Удаляем items, так как они не нужны в {@link ScINewCartItemSandwich}.
|
|
220
218
|
delete formValue.items;
|
|
221
|
-
const
|
|
222
|
-
const newCartItem$ =
|
|
223
|
-
? this.cartService.
|
|
224
|
-
: this.cartService.
|
|
219
|
+
const orderItem = this.cartItem();
|
|
220
|
+
const newCartItem$ = orderItem
|
|
221
|
+
? this.cartService.updateProduct$(orderItem.id, this.convertersService.removeNull(formValue))
|
|
222
|
+
: this.cartService.addProduct$(this.convertersService.removeNull(formValue));
|
|
225
223
|
this.isSubmitLoading.set(true);
|
|
226
224
|
newCartItem$
|
|
227
225
|
.pipe(tap(() => {
|
|
@@ -285,10 +283,6 @@ export class ScSandwichComponent {
|
|
|
285
283
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScSandwichComponent, decorators: [{
|
|
286
284
|
type: Component,
|
|
287
285
|
args: [{ standalone: true, selector: 'sc-sandwich', imports: [
|
|
288
|
-
TuiAppearance,
|
|
289
|
-
TuiWithAppearance,
|
|
290
|
-
TuiIcons,
|
|
291
|
-
TuiWithIcons,
|
|
292
286
|
TuiButton,
|
|
293
287
|
FormsModule,
|
|
294
288
|
ReactiveFormsModule,
|
|
@@ -304,7 +298,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
304
298
|
AsyncPipe,
|
|
305
299
|
TuiFieldErrorPipe,
|
|
306
300
|
TuiInputSlider,
|
|
307
|
-
TuiDataList,
|
|
308
301
|
ScSelectOnFocusinDirective,
|
|
309
302
|
TuiLoader,
|
|
310
303
|
TuiButtonLoading,
|
|
@@ -319,4 +312,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
319
312
|
}),
|
|
320
313
|
], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!cartItem() && settings()?.allowShowTable) {\n <div class=\"mb-5 flex justify-center\">\n <button\n tuiButton\n appearance=\"secondary\"\n (click)=\"toggleShowEvent.emit()\"\n type=\"button\"\n iconStart=\"@tui.layout-list\"\n >\n \u041F\u043E\u043A\u0430\u0437\u0430\u0442\u044C \u0432 \u0432\u0438\u0434\u0435 \u0441\u043F\u0438\u0441\u043A\u0430\n </button>\n </div>\n}\n<div class=\"\">\n @let calculateResult = calculateResult$ | async;\n @let products = products$ | async;\n @let productValue = product.value;\n @let validatorWidth = validatorWidth$ | async;\n @let validatorLength = validatorLength$ | async;\n\n <form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit(calculateResult)\"\n ScNextInputFocus\n class=\"flex flex-col gap-3\"\n >\n <label\n tuiLabel\n class=\"grow\"\n >\n \u0422\u043E\u0432\u0430\u0440\n <tui-textfield\n tuiChevron\n [tuiTextfieldCleaner]=\"false\"\n >\n <input\n tuiChevron\n tuiSelect\n [formControl]=\"product\"\n placeholder=\"\u0412\u044B\u0431\u0435\u0440\u0438\u0442\u0435 \u043C\u0430\u0442\u0435\u0440\u0438\u0430\u043B\"\n />\n\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n new\n [items]=\"products\"\n />\n </tui-textfield>\n @if (productValue) {\n <div class=\"ml-2 text-tui-text-secondary\">\n \u0421\u0442\u043E\u0438\u043C\u043E\u0441\u0442\u044C:\n <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/\u0448\u0442.</span>\n </div>\n }\n <tui-error\n [formControl]=\"product\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n\n @if (product.value && validatorWidth && validatorLength) {\n <p class=\"w-full font-bold\">\u0420\u0430\u0437\u043C\u0435\u0440\u044B \u0438\u0437\u0434\u0435\u043B\u0438\u0439</p>\n <p class=\"w-full\">\n \u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u0430\u044F \u0448\u0438\u0440\u0438\u043D\u0430: {{ settings()?.minWidth }} \u043C\u043C.\n <br />\n \u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u0430\u044F \u0448\u0438\u0440\u0438\u043D\u0430: {{ product.value.properties?.width }} \u043C\u043C.\n <br />\n \u041C\u0438\u043D\u0438\u043C\u0430\u043B\u044C\u043D\u0430\u044F \u0434\u043B\u0438\u043D\u0430: {{ settings()?.minLength }} \u043C\u043C.\n <br />\n \u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u0430\u044F \u0434\u043B\u0438\u043D\u0430: {{ product.value.properties?.length }} \u043C\u043C.\n <br />\n </p>\n <div\n formArrayName=\"items\"\n class=\"flex flex-col gap-3\"\n >\n @for (item of items.controls; track item) {\n <div\n class=\"flex grow gap-2\"\n [formGroupName]=\"$index\"\n >\n <div class=\"grid grow grid-cols-3 gap-2\">\n <label tuiLabel>\n \u0428\u0438\u0440\u0438\u043D\u0430, \u043C\u043C\n <tui-textfield>\n <input\n tuiInputSlider\n formControlName=\"width\"\n [min]=\"settings()?.minWidth ?? 0\"\n [max]=\"product.value.properties?.width ?? 0\"\n [tuiNumberFormat]=\"{ precision: 0 }\"\n placeholder=\"\u0428\u0438\u0440\u0438\u043D\u0430\"\n autocomplete=\"off\"\n />\n @if (product.value) {\n <input\n tuiSlider\n type=\"range\"\n />\n }\n </tui-textfield>\n @if (product.value) {\n <div class=\"slider-ticks-labels\">\n <span> 0 </span>\n <span>{{ product.value.properties?.width }}</span>\n </div>\n }\n <tui-error\n formControlName=\"width\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n\n <label tuiLabel>\n \u0414\u043B\u0438\u043D\u0430, \u043C\u043C\n <tui-textfield>\n <input\n tuiInputSlider\n formControlName=\"length\"\n [min]=\"settings()?.minLength ?? 0\"\n [max]=\"product.value.properties?.length ?? 0\"\n [tuiNumberFormat]=\"{ precision: 0 }\"\n placeholder=\"\u0414\u043B\u0438\u043D\u0430\"\n autocomplete=\"off\"\n />\n @if (product.value) {\n <input\n tuiSlider\n type=\"range\"\n />\n }\n </tui-textfield>\n @if (product.value) {\n <div class=\"slider-ticks-labels\">\n <span> 0 </span>\n <span>{{ product.value.properties?.length }}</span>\n </div>\n }\n <tui-error\n formControlName=\"length\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n <label tuiLabel>\n <span class=\"whitespace-nowrap\">\u041A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E, \u0448\u0442</span>\n <tui-textfield [tuiTextfieldCleaner]=\"false\">\n <input\n tuiInputNumber\n formControlName=\"quantity\"\n [min]=\"1\"\n [tuiNumberFormat]=\"{ precision: 0 }\"\n placeholder=\"\u041A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E\"\n autocomplete=\"off\"\n />\n </tui-textfield>\n <tui-error\n formControlName=\"quantity\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n </div>\n <button\n tuiIconButton\n (click)=\"removeItem($index)\"\n [disabled]=\"items.length <= 1\"\n size=\"m\"\n type=\"button\"\n iconStart=\"@tui.trash-2\"\n appearance=\"secondary\"\n class=\"mt-6\"\n [style.flex]=\"'0 0 auto'\"\n ></button>\n </div>\n }\n </div>\n <button\n tuiButton\n appearance=\"secondary\"\n [disabled]=\"items.invalid\"\n (click)=\"addItem()\"\n type=\"button\"\n class=\"self-center\"\n iconStart=\"@tui.plus\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0438\u0437\u0434\u0435\u043B\u0438\u0435\n </button>\n } @else if (product.value) {\n <tui-error error=\"\u0420\u0430\u0441\u0447\u0435\u0442 \u043F\u043E \u043F\u0440\u043E\u0434\u0443\u043A\u0442\u0443 \u043D\u0435\u0432\u043E\u0437\u043C\u043E\u0436\u0435\u043D. \u041E\u0431\u0440\u0430\u0442\u0438\u0442\u0435\u0441\u044C \u043A \u043C\u0435\u043D\u0435\u0434\u0436\u0435\u0440\u0443\" />\n }\n\n <label tuiLabel>\n \u041C\u0430\u0440\u043A\u0438\u0440\u043E\u0432\u043A\u0430 \u0440\u0430\u0441\u043F\u0438\u043B\u0430\n <tui-textfield>\n <input\n tuiTextfield\n formControlName=\"marker\"\n placeholder=\"\u041C\u0430\u0440\u043A\u0438\u0440\u043E\u0432\u043A\u0430 \u0440\u0430\u0441\u043F\u0438\u043B\u0430\"\n autocomplete=\"marker\"\n />\n </tui-textfield>\n\n <tui-error\n formControlName=\"marker\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n\n @if (product.value) {\n <tui-loader [showLoader]=\"isCalculateLoading()\">\n @if (calculateResult) {\n <div class=\"mt-2 flex flex-wrap items-end gap-2\">\n <div>\n \u0418\u0442\u043E\u0433\u043E: <span class=\"whitespace-nowrap text-xl font-bold\">{{ getTotalCost(calculateResult).toLocaleString() }} {{ product.value.currency.symbol }}</span>\n </div>\n @if (calculateResult?.quantity && productValue) {\n <div class=\"whitespace-nowrap text-lg text-sc-dark-grey\">\n <span class=\"font-bold\">({{ calculateResult.quantity }} \u0448\u0442.</span> x\n <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/\u0448\u0442.)</span>\n </div>\n }\n </div>\n }\n </tui-loader>\n }\n\n <tui-error [error]=\"[] | tuiFieldError | async\" />\n\n <button\n [disabled]=\"form.invalid || !calculateResult || isCalculateLoading() || isSubmitLoading()\"\n [loading]=\"isSubmitLoading()\"\n tuiButton\n class=\"self-center\"\n iconStart=\"@tui.check\"\n >\n {{ !cartItem() ? '\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0432 \u043A\u043E\u0440\u0437\u0438\u043D\u0443' : '\u0418\u0437\u043C\u0435\u043D\u0438\u0442\u044C' }}\n </button>\n </form>\n</div>\n", styles: [":host{display:block;width:100%;max-width:30rem}.slider-ticks-labels{--t-offset: calc($thumb / 2);display:flex;font:var(--tui-font-text-s);margin-inline-start:var(--t-offset);margin-inline-end:var(--t-offset);color:var(--tui-text-secondary)}.slider-ticks-labels>*{position:relative;flex:2;text-align:center}.slider-ticks-labels>*:first-child{left:calc(-1 * var(--t-offset));inset-inline-start:calc(-1 * var(--t-offset));flex:1;text-align:start}.slider-ticks-labels>*:last-child{right:calc(-1 * var(--t-offset));flex:1;text-align:end}@supports (inset-inline-end: 0){.slider-ticks-labels>*:last-child{right:unset;inset-inline-end:calc(-1 * var(--t-offset))}}tui-input-slider+.slider-ticks-labels{margin-inline-start:calc(var(--tui-radius-m) / 2 + var(--t-offset))}tui-textfield+.slider-ticks-labels{--t-offset: calc(var(--tui-radius-m) / 2 + $thumb / 2)}tui-textfield[data-size=l]+.slider-ticks-labels{--t-offset: calc(var(--tui-radius-l) / 2 + $thumb / 2)}tui-input-range:not([new])+.slider-ticks-labels,tui-range+.slider-ticks-labels{--t-offset: $thumb}tui-input-range[new]+.slider-ticks-labels{--t-offset: calc(map-get($track-inset, $input-size) + $thumb)}\n"] }]
|
|
321
314
|
}] });
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-sandwich.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/configurators/sandwich/sc-sandwich.component.ts","../../../../../projects/client-ui/configurators/sandwich/sc-sandwich.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/unbound-method */\n\nimport { AsyncPipe } from '@angular/common';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, DestroyRef, inject, input, OnInit, output, signal } from '@angular/core';\nimport { takeUntilDestroyed, toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { FormArray, FormControl, FormGroup, FormsModule, ReactiveFormsModule, ValidatorFn, Validators } from '@angular/forms';\nimport {\n    ISandwichCalculate,\n    ISandwichCalculateItem,\n    ScCart,\n    ScCartItem,\n    ScCartService,\n    ScCatalogService,\n    ScConfiguratorService,\n    ScConvertersService,\n    ScIConfiguratorCalculateResult,\n    ScProduct,\n} from '@snabcentr/client-core';\nimport { tuiControlValue } from '@taiga-ui/cdk';\nimport {\n    TuiButton,\n    TuiDataList,\n    TuiDialogContext,\n    TuiError,\n    tuiItemsHandlersProvider,\n    TuiLabel,\n    TuiLoader,\n    TuiNumberFormat,\n    tuiNumberFormatProvider,\n    TuiTextfield,\n} from '@taiga-ui/core';\nimport { TuiAppearance, TuiWithAppearance } from '@taiga-ui/core/directives/appearance';\nimport { TuiIcons, TuiWithIcons } from '@taiga-ui/core/directives/icons';\nimport {\n    TuiButtonLoading,\n    TuiChevron,\n    TuiDataListWrapperComponent,\n    TuiFieldErrorPipe,\n    TuiInputNumber,\n    tuiInputNumberOptionsProvider,\n    TuiInputSlider,\n    TuiSelect,\n} from '@taiga-ui/kit';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, combineLatest, debounceTime, filter, finalize, map, Observable, of, share, startWith, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { ScNextInputFocusModule } from '../../directives/next-input-focus/sc-next-input-focus.module';\nimport { ScSelectOnFocusinDirective } from '../../directives/select-on-focusin/sc-select-on-focusin.directive';\nimport { SC_DEBOUNCE_TIME_DEFAULT } from '../../providers';\nimport { stepValidator } from '../../validators/step-validator';\nimport { ScISandwichSettings } from '../models/sandwich/sc-i-sandwich-settings';\nimport { ScINewCartItemSandwich } from './sc-i-new-cart-item-sandwich';\n\n/**\n * Конфигуратор распила сэндвич-панелей.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-sandwich',\n    templateUrl: './sc-sandwich.component.html',\n    styleUrl: './sc-sandwich.component.scss',\n    imports: [\n        TuiAppearance,\n        TuiWithAppearance,\n        TuiIcons,\n        TuiWithIcons,\n        TuiButton,\n        FormsModule,\n        ReactiveFormsModule,\n        ScNextInputFocusModule,\n        TuiLabel,\n        TuiDataListWrapperComponent,\n        TuiError,\n        TuiTextfield,\n        TuiChevron,\n        TuiSelect,\n        TuiInputNumber,\n        TuiNumberFormat,\n        AsyncPipe,\n        TuiFieldErrorPipe,\n        TuiInputSlider,\n        TuiDataList,\n        ScSelectOnFocusinDirective,\n        TuiLoader,\n        TuiButtonLoading,\n    ],\n    providers: [\n        tuiNumberFormatProvider({ precision: 0 }),\n        tuiInputNumberOptionsProvider({\n            min: 0,\n        }),\n        tuiItemsHandlersProvider({\n            stringify: signal((x: ScProduct) => x.name),\n            identityMatcher: signal((a: ScProduct, b: ScProduct) => a.id === b.id),\n        }),\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSandwichComponent implements OnInit {\n    /**\n     * Данные настроек окружения.\n     */\n    private readonly debounceTimeDefault: number = inject<number>(SC_DEBOUNCE_TIME_DEFAULT);\n\n    /**\n     * Настройки для конфигуратора сэндвич-панелей.\n     */\n    public readonly settings = input<ScISandwichSettings>();\n\n    /**\n     * Идентификатор категории.\n     */\n    public readonly categoryId = input.required<number | string>();\n\n    /**\n     * Название конфигуратора.\n     */\n    public readonly editor = input.required<string>();\n\n    /**\n     * Позиция товара/услуги в корзине.\n     */\n    public readonly cartItem = input.required<ScCartItem | undefined>();\n\n    /**\n     * Событие переключения отображения товаров.\n     */\n    public readonly toggleShowEvent = output();\n\n    /**\n     * Форма добавления/редактирования продукта в корзине.\n     */\n    protected readonly form = new FormGroup({\n        productCategoryId: new FormControl<number | null>(null, { validators: Validators.required, nonNullable: false }),\n        configurator: new FormControl<string | null>(null, { validators: Validators.required, nonNullable: false }),\n        quantity: new FormControl<number | null>(null, { validators: [Validators.required, stepValidator(1)], nonNullable: false }),\n        marker: new FormControl<string>('', { nonNullable: true }),\n        items: new FormArray<ReturnType<ScSandwichComponent['createItemGroup']>>([]),\n        calculationId: new FormControl<string | null>(null, { nonNullable: false }),\n    });\n\n    /**\n     * Сервис для работы с корзиной.\n     */\n    private readonly cartService: ScCartService = inject(ScCartService);\n\n    /**\n     * Сервис конвертации данных.\n     */\n    private readonly convertersService: ScConvertersService = inject(ScConvertersService);\n\n    /**\n     * Контекст диалогового окна, в котором открыт компонент.\n     */\n    private readonly context: TuiDialogContext | undefined = inject(POLYMORPHEUS_CONTEXT, { optional: true }) as TuiDialogContext | undefined;\n\n    /**\n     * Сервис для работы с каталогом.\n     */\n    private readonly catalogService: ScCatalogService = inject(ScCatalogService);\n\n    /**\n     * Сервис для работы с конфигураторами.\n     */\n    private readonly configuratorService: ScConfiguratorService = inject(ScConfiguratorService);\n\n    /**\n     * {@link Observable} списка товаров категории.\n     */\n    protected readonly products$: Observable<ScProduct[]> = toObservable(this.categoryId).pipe(\n        switchMap((categoryId) => {\n            if (!categoryId) {\n                return of([]);\n            }\n\n            return this.catalogService.getProductsCategoryCached$({ categoryId: Number(categoryId) }).pipe(map((products) => products ?? []));\n        })\n    );\n\n    /**\n     * Выбранный продукт (материал для раскроя).\n     */\n    protected readonly product = new FormControl<ScProduct | null>(null, { validators: Validators.required });\n\n    /**\n     * {@link Observable} расчета оптимизации раскладки.\n     */\n    private readonly calculate$: Observable<ScIConfiguratorCalculateResult | null | undefined> = combineLatest({\n        productId: tuiControlValue<ScProduct | null>(this.product).pipe(map((product) => product?.id ?? null)),\n        items: tuiControlValue<ISandwichCalculateItem[]>(this.items),\n    }).pipe(\n        debounceTime(this.debounceTimeDefault),\n        switchMap(({ productId, items }) => {\n            if (productId === null || items.length === 0 || this.form.controls.items.invalid) {\n                // eslint-disable-next-line unicorn/no-useless-undefined\n                return of(undefined);\n            }\n\n            return this.configuratorService.calculate$(this.categoryId(), this.editor(), { productId, items }).pipe(\n                tap((calculateResult) => {\n                    this.form.get('quantity')?.setValue(calculateResult.quantity);\n                }),\n                startWith(null),\n                catchError(() => of(null))\n            );\n        }),\n        share()\n    );\n\n    /**\n     * Результат расчета оптимизации раскладки.\n     */\n    protected readonly calculateResult$: Observable<ScIConfiguratorCalculateResult | undefined> = this.calculate$.pipe(filter((data) => data !== null));\n\n    /**\n     * Сигнал состояния загрузки расчета.\n     */\n    protected readonly isCalculateLoading = toSignal(this.calculate$.pipe(map((data) => data === null)), { initialValue: false });\n\n    /**\n     * Валидатор для ширины изделия.\n     */\n    protected readonly validatorWidth$: Observable<ValidatorFn | null> = tuiControlValue<ScProduct | null>(this.product).pipe(\n        map((product) => Validators.min(product?.properties?.width ?? 0))\n    );\n\n    /**\n     * Валидатор для длины изделия.\n     */\n    protected readonly validatorLength$: Observable<ValidatorFn | null> = tuiControlValue<ScProduct | null>(this.product).pipe(\n        map((product) => Validators.min(product?.properties?.length ?? 0))\n    );\n\n    /**\n     * Признак того, что выполняется запрос на отправку данных выполняется.\n     */\n    protected readonly isSubmitLoading = signal(false);\n\n    /**\n     * Ссылка для автоматического управления уничтожением зависимостей.\n     */\n    private readonly destroyRef: DestroyRef = inject(DestroyRef);\n\n    /**\n     * Массив изделий.\n     */\n    get items(): FormArray<ReturnType<ScSandwichComponent['createItemGroup']>> {\n        return this.form.controls.items;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.setDefaultFormValue();\n\n        this.product.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((product) => {\n            if (product) {\n                this.items.controls.forEach((item) => {\n                    const value = item.getRawValue();\n\n                    if ((product.properties?.width && value.width < product.properties.width) || (product.properties?.length && value.length < product.properties.length)) {\n                        item.patchValue({\n                            width: Math.min(value.width, product.properties.width ?? value.width),\n                            length: Math.min(value.length, product.properties.length ?? value.length),\n                        });\n                    }\n                });\n            }\n        });\n    }\n\n    /**\n     * Создает группу для изделия.\n     *\n     * @param item Параметры изделия.\n     */\n    private createItemGroup(item?: ISandwichCalculateItem): FormGroup<{\n        width: FormControl<number>;\n        length: FormControl<number>;\n        quantity: FormControl<number>;\n    }> {\n        return new FormGroup({\n            width: new FormControl<number>(item?.width ?? 0, {\n                validators: [Validators.required, Validators.min(this.settings()?.minWidth ?? 0.01)],\n                nonNullable: true,\n            }),\n            length: new FormControl<number>(item?.length ?? 0, {\n                validators: [Validators.required, Validators.min(this.settings()?.minLength ?? 0.01)],\n                nonNullable: true,\n            }),\n            quantity: new FormControl<number>(item?.quantity ?? 1, {\n                validators: [Validators.required, Validators.min(1)],\n                nonNullable: true,\n            }),\n        });\n    }\n\n    /**\n     * Добавляет новое изделие в форму.\n     */\n    protected addItem(): void {\n        this.items.push(this.createItemGroup());\n    }\n\n    /**\n     * Удаляет изделие из формы.\n     *\n     * @param index Индекс изделия.\n     */\n    protected removeItem(index: number): void {\n        this.items.removeAt(index);\n    }\n\n    /**\n     * Возвращает итоговую стоимость.\n     *\n     * @param calculateResult Результат расчета оптимизации раскладки.\n     */\n    protected getTotalCost(calculateResult: ScIConfiguratorCalculateResult): number {\n        if (!this.product.value?.costRub) {\n            return 0;\n        }\n\n        const quantity = this.form.get('quantity')?.value ?? 1;\n        const totalCost = calculateResult.quantity * this.product.value.costRub * quantity;\n\n        return Math.round(totalCost * 100) / 100;\n    }\n\n    /**\n     * Обработчик добавления/редактирования продукта в корзине.\n     *\n     * @param calculateResult Результат расчета оптимизации раскладки.\n     */\n    protected onSubmit(calculateResult: ScIConfiguratorCalculateResult | null | undefined): void {\n        if (!calculateResult || this.form.invalid || this.isCalculateLoading()) {\n            return;\n        }\n\n        const formValue = { ...this.form.value, productId: this.product.value?.id ?? null, calculationId: calculateResult.id };\n        // Удаляем items, так как они не нужны в {@link ScINewCartItemSandwich}.\n        delete formValue.items;\n        const cartItem = this.cartItem();\n\n        const newCartItem$: Observable<ScCart> = cartItem\n            ? this.cartService.patchCartItem$(cartItem.id, this.convertersService.removeNull(formValue) as ScINewCartItemSandwich)\n            : this.cartService.addToCart$(this.convertersService.removeNull(formValue) as ScINewCartItemSandwich);\n\n        this.isSubmitLoading.set(true);\n\n        newCartItem$\n            .pipe(\n                tap(() => {\n                    if (this.context) {\n                        this.context.$implicit.complete();\n                    } else {\n                        this.setDefaultFormValue();\n                    }\n                }),\n                catchError((error: unknown) => {\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        if (errors) {\n                            Object.keys(errors).forEach((key) => {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            });\n                        } else if (message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of();\n                }),\n                finalize(() => {\n                    this.isSubmitLoading.set(false);\n                })\n            )\n            .subscribe();\n    }\n\n    /**\n     * Устанавливает начальные значения для полей формы.\n     */\n    private setDefaultFormValue(): void {\n        this.form.reset({\n            productCategoryId: Number(this.categoryId()),\n            configurator: this.editor(),\n            quantity: this.cartItem()?.quantity ?? null,\n            marker: this.cartItem()?.marker ?? '',\n        });\n\n        this.items.clear();\n\n        this.product.reset(this.cartItem()?.product ?? null);\n\n        const configuratorParameters = this.cartItem()?.configuratorParams as ISandwichCalculate | undefined;\n\n        configuratorParameters?.items.forEach((item) => {\n            this.items.push(this.createItemGroup({ width: item.width, length: item.length, quantity: item.quantity }));\n        });\n\n        if (!configuratorParameters?.items.length) {\n            this.addItem();\n        }\n    }\n}\n","@if (!cartItem() && settings()?.allowShowTable) {\n    <div class=\"mb-5 flex justify-center\">\n        <button\n            tuiButton\n            appearance=\"secondary\"\n            (click)=\"toggleShowEvent.emit()\"\n            type=\"button\"\n            iconStart=\"@tui.layout-list\"\n        >\n            Показать в виде списка\n        </button>\n    </div>\n}\n<div class=\"\">\n    @let calculateResult = calculateResult$ | async;\n    @let products = products$ | async;\n    @let productValue = product.value;\n    @let validatorWidth = validatorWidth$ | async;\n    @let validatorLength = validatorLength$ | async;\n\n    <form\n        [formGroup]=\"form\"\n        (ngSubmit)=\"onSubmit(calculateResult)\"\n        ScNextInputFocus\n        class=\"flex flex-col gap-3\"\n    >\n        <label\n            tuiLabel\n            class=\"grow\"\n        >\n            Товар\n            <tui-textfield\n                tuiChevron\n                [tuiTextfieldCleaner]=\"false\"\n            >\n                <input\n                    tuiChevron\n                    tuiSelect\n                    [formControl]=\"product\"\n                    placeholder=\"Выберите материал\"\n                />\n\n                <tui-data-list-wrapper\n                    *tuiTextfieldDropdown\n                    new\n                    [items]=\"products\"\n                />\n            </tui-textfield>\n            @if (productValue) {\n                <div class=\"ml-2 text-tui-text-secondary\">\n                    Стоимость:\n                    <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/шт.</span>\n                </div>\n            }\n            <tui-error\n                [formControl]=\"product\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        @if (product.value && validatorWidth && validatorLength) {\n            <p class=\"w-full font-bold\">Размеры изделий</p>\n            <p class=\"w-full\">\n                Минимальная ширина: {{ settings()?.minWidth }} мм.\n                <br />\n                Максимальная ширина: {{ product.value.properties?.width }} мм.\n                <br />\n                Минимальная длина: {{ settings()?.minLength }} мм.\n                <br />\n                Максимальная длина: {{ product.value.properties?.length }} мм.\n                <br />\n            </p>\n            <div\n                formArrayName=\"items\"\n                class=\"flex flex-col gap-3\"\n            >\n                @for (item of items.controls; track item) {\n                    <div\n                        class=\"flex grow gap-2\"\n                        [formGroupName]=\"$index\"\n                    >\n                        <div class=\"grid grow grid-cols-3 gap-2\">\n                            <label tuiLabel>\n                                Ширина, мм\n                                <tui-textfield>\n                                    <input\n                                        tuiInputSlider\n                                        formControlName=\"width\"\n                                        [min]=\"settings()?.minWidth ?? 0\"\n                                        [max]=\"product.value.properties?.width ?? 0\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Ширина\"\n                                        autocomplete=\"off\"\n                                    />\n                                    @if (product.value) {\n                                        <input\n                                            tuiSlider\n                                            type=\"range\"\n                                        />\n                                    }\n                                </tui-textfield>\n                                @if (product.value) {\n                                    <div class=\"slider-ticks-labels\">\n                                        <span> 0 </span>\n                                        <span>{{ product.value.properties?.width }}</span>\n                                    </div>\n                                }\n                                <tui-error\n                                    formControlName=\"width\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n\n                            <label tuiLabel>\n                                Длина, мм\n                                <tui-textfield>\n                                    <input\n                                        tuiInputSlider\n                                        formControlName=\"length\"\n                                        [min]=\"settings()?.minLength ?? 0\"\n                                        [max]=\"product.value.properties?.length ?? 0\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Длина\"\n                                        autocomplete=\"off\"\n                                    />\n                                    @if (product.value) {\n                                        <input\n                                            tuiSlider\n                                            type=\"range\"\n                                        />\n                                    }\n                                </tui-textfield>\n                                @if (product.value) {\n                                    <div class=\"slider-ticks-labels\">\n                                        <span> 0 </span>\n                                        <span>{{ product.value.properties?.length }}</span>\n                                    </div>\n                                }\n                                <tui-error\n                                    formControlName=\"length\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n                            <label tuiLabel>\n                                <span class=\"whitespace-nowrap\">Количество, шт</span>\n                                <tui-textfield [tuiTextfieldCleaner]=\"false\">\n                                    <input\n                                        tuiInputNumber\n                                        formControlName=\"quantity\"\n                                        [min]=\"1\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Количество\"\n                                        autocomplete=\"off\"\n                                    />\n                                </tui-textfield>\n                                <tui-error\n                                    formControlName=\"quantity\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n                        </div>\n                        <button\n                            tuiIconButton\n                            (click)=\"removeItem($index)\"\n                            [disabled]=\"items.length <= 1\"\n                            size=\"m\"\n                            type=\"button\"\n                            iconStart=\"@tui.trash-2\"\n                            appearance=\"secondary\"\n                            class=\"mt-6\"\n                            [style.flex]=\"'0 0 auto'\"\n                        ></button>\n                    </div>\n                }\n            </div>\n            <button\n                tuiButton\n                appearance=\"secondary\"\n                [disabled]=\"items.invalid\"\n                (click)=\"addItem()\"\n                type=\"button\"\n                class=\"self-center\"\n                iconStart=\"@tui.plus\"\n            >\n                Добавить изделие\n            </button>\n        } @else if (product.value) {\n            <tui-error error=\"Расчет по продукту невозможен. Обратитесь к менеджеру\" />\n        }\n\n        <label tuiLabel>\n            Маркировка распила\n            <tui-textfield>\n                <input\n                    tuiTextfield\n                    formControlName=\"marker\"\n                    placeholder=\"Маркировка распила\"\n                    autocomplete=\"marker\"\n                />\n            </tui-textfield>\n\n            <tui-error\n                formControlName=\"marker\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        @if (product.value) {\n            <tui-loader [showLoader]=\"isCalculateLoading()\">\n                @if (calculateResult) {\n                    <div class=\"mt-2 flex flex-wrap items-end gap-2\">\n                        <div>\n                            Итого: <span class=\"whitespace-nowrap text-xl font-bold\">{{ getTotalCost(calculateResult).toLocaleString() }} {{ product.value.currency.symbol }}</span>\n                        </div>\n                        @if (calculateResult?.quantity && productValue) {\n                            <div class=\"whitespace-nowrap text-lg text-sc-dark-grey\">\n                                <span class=\"font-bold\">({{ calculateResult.quantity }} шт.</span> x\n                                <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/шт.)</span>\n                            </div>\n                        }\n                    </div>\n                }\n            </tui-loader>\n        }\n\n        <tui-error [error]=\"[] | tuiFieldError | async\" />\n\n        <button\n            [disabled]=\"form.invalid || !calculateResult || isCalculateLoading() || isSubmitLoading()\"\n            [loading]=\"isSubmitLoading()\"\n            tuiButton\n            class=\"self-center\"\n            iconStart=\"@tui.check\"\n        >\n            {{ !cartItem() ? 'Добавить в корзину' : 'Изменить' }}\n        </button>\n    </form>\n</div>\n"]}
|
|
315
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-sandwich.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/configurators/sandwich/sc-sandwich.component.ts","../../../../../projects/client-ui/configurators/sandwich/sc-sandwich.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/unbound-method */\n\nimport { AsyncPipe } from '@angular/common';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, DestroyRef, inject, input, OnInit, output, signal } from '@angular/core';\nimport { takeUntilDestroyed, toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { FormArray, FormControl, FormGroup, FormsModule, ReactiveFormsModule, ValidatorFn, Validators } from '@angular/forms';\nimport {\n    ISandwichCalculate,\n    ISandwichCalculateItem,\n    ScCart,\n    ScCartService,\n    ScCatalogService,\n    ScConfiguratorService,\n    ScConvertersService,\n    ScIApiErrorResponse,\n    ScIConfiguratorCalculateResult,\n    ScOrderItem,\n    ScProduct,\n} from '@snabcentr/client-core';\nimport { tuiControlValue } from '@taiga-ui/cdk';\nimport { TuiButton, TuiDialogContext, TuiError, tuiItemsHandlersProvider, TuiLabel, TuiLoader, TuiNumberFormat, tuiNumberFormatProvider, TuiTextfield } from '@taiga-ui/core';\nimport {\n    TuiButtonLoading,\n    TuiChevron,\n    TuiDataListWrapperComponent,\n    TuiFieldErrorPipe,\n    TuiInputNumber,\n    tuiInputNumberOptionsProvider,\n    TuiInputSlider,\n    TuiSelect,\n} from '@taiga-ui/kit';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, combineLatest, debounceTime, filter, finalize, map, Observable, of, share, startWith, switchMap, tap } from 'rxjs';\n\nimport { ScNextInputFocusModule } from '../../directives/next-input-focus/sc-next-input-focus.module';\nimport { ScSelectOnFocusinDirective } from '../../directives/select-on-focusin/sc-select-on-focusin.directive';\nimport { SC_DEBOUNCE_TIME_DEFAULT } from '../../providers';\nimport { stepValidator } from '../../validators/step-validator';\nimport { ScISandwichSettings } from '../models/sandwich/sc-i-sandwich-settings';\nimport { ScINewCartItemSandwich } from './sc-i-new-cart-item-sandwich';\n\n/**\n * Конфигуратор распила сэндвич-панелей.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-sandwich',\n    templateUrl: './sc-sandwich.component.html',\n    styleUrl: './sc-sandwich.component.scss',\n    imports: [\n        TuiButton,\n        FormsModule,\n        ReactiveFormsModule,\n        ScNextInputFocusModule,\n        TuiLabel,\n        TuiDataListWrapperComponent,\n        TuiError,\n        TuiTextfield,\n        TuiChevron,\n        TuiSelect,\n        TuiInputNumber,\n        TuiNumberFormat,\n        AsyncPipe,\n        TuiFieldErrorPipe,\n        TuiInputSlider,\n        ScSelectOnFocusinDirective,\n        TuiLoader,\n        TuiButtonLoading,\n    ],\n    providers: [\n        tuiNumberFormatProvider({ precision: 0 }),\n        tuiInputNumberOptionsProvider({\n            min: 0,\n        }),\n        tuiItemsHandlersProvider({\n            stringify: signal((x: ScProduct) => x.name),\n            identityMatcher: signal((a: ScProduct, b: ScProduct) => a.id === b.id),\n        }),\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSandwichComponent implements OnInit {\n    /**\n     * Данные настроек окружения.\n     */\n    private readonly debounceTimeDefault: number = inject<number>(SC_DEBOUNCE_TIME_DEFAULT);\n\n    /**\n     * Настройки для конфигуратора сэндвич-панелей.\n     */\n    public readonly settings = input<ScISandwichSettings>();\n\n    /**\n     * Идентификатор категории.\n     */\n    public readonly categoryId = input.required<number | string>();\n\n    /**\n     * Название конфигуратора.\n     */\n    public readonly editor = input.required<string>();\n\n    /**\n     * Позиция товара/услуги в корзине.\n     */\n    public readonly cartItem = input.required<ScOrderItem | undefined>();\n\n    /**\n     * Событие переключения отображения товаров.\n     */\n    public readonly toggleShowEvent = output();\n\n    /**\n     * Форма добавления/редактирования продукта в корзине.\n     */\n    protected readonly form = new FormGroup({\n        productCategoryId: new FormControl<number | null>(null, { validators: Validators.required, nonNullable: false }),\n        configurator: new FormControl<string | null>(null, { validators: Validators.required, nonNullable: false }),\n        quantity: new FormControl<number | null>(null, { validators: [Validators.required, stepValidator(1)], nonNullable: false }),\n        marker: new FormControl<string>('', { nonNullable: true }),\n        items: new FormArray<ReturnType<ScSandwichComponent['createItemGroup']>>([]),\n        calculationId: new FormControl<string | null>(null, { nonNullable: false }),\n    });\n\n    /**\n     * Сервис для работы с корзиной.\n     */\n    private readonly cartService: ScCartService = inject(ScCartService);\n\n    /**\n     * Сервис конвертации данных.\n     */\n    private readonly convertersService: ScConvertersService = inject(ScConvertersService);\n\n    /**\n     * Контекст диалогового окна, в котором открыт компонент.\n     */\n    private readonly context: TuiDialogContext | undefined = inject(POLYMORPHEUS_CONTEXT, { optional: true }) as TuiDialogContext | undefined;\n\n    /**\n     * Сервис для работы с каталогом.\n     */\n    private readonly catalogService: ScCatalogService = inject(ScCatalogService);\n\n    /**\n     * Сервис для работы с конфигураторами.\n     */\n    private readonly configuratorService: ScConfiguratorService = inject(ScConfiguratorService);\n\n    /**\n     * {@link Observable} списка товаров категории.\n     */\n    protected readonly products$: Observable<ScProduct[]> = toObservable(this.categoryId).pipe(\n        switchMap((categoryId) => {\n            if (!categoryId) {\n                return of([]);\n            }\n\n            return this.catalogService.getProductsCategoryCached$({ categoryId: Number(categoryId) }).pipe(map((products) => products ?? []));\n        })\n    );\n\n    /**\n     * Выбранный продукт (материал для раскроя).\n     */\n    protected readonly product = new FormControl<ScProduct | null>(null, { validators: Validators.required });\n\n    /**\n     * {@link Observable} расчета оптимизации раскладки.\n     */\n    private readonly calculate$: Observable<ScIConfiguratorCalculateResult | null | undefined> = combineLatest({\n        productId: tuiControlValue<ScProduct | null>(this.product).pipe(map((product) => product?.id ?? null)),\n        items: tuiControlValue<ISandwichCalculateItem[]>(this.items),\n    }).pipe(\n        debounceTime(this.debounceTimeDefault),\n        switchMap(({ productId, items }) => {\n            if (productId === null || items.length === 0 || this.form.controls.items.invalid) {\n                // eslint-disable-next-line unicorn/no-useless-undefined\n                return of(undefined);\n            }\n\n            return this.configuratorService.calculate$(this.categoryId(), this.editor(), { productId, items }).pipe(\n                tap((calculateResult) => {\n                    this.form.get('quantity')?.setValue(calculateResult.quantity);\n                }),\n                startWith(null),\n                catchError(() => of(null))\n            );\n        }),\n        share()\n    );\n\n    /**\n     * Результат расчета оптимизации раскладки.\n     */\n    protected readonly calculateResult$: Observable<ScIConfiguratorCalculateResult | undefined> = this.calculate$.pipe(filter((data) => data !== null));\n\n    /**\n     * Сигнал состояния загрузки расчета.\n     */\n    protected readonly isCalculateLoading = toSignal(this.calculate$.pipe(map((data) => data === null)), { initialValue: false });\n\n    /**\n     * Валидатор для ширины изделия.\n     */\n    protected readonly validatorWidth$: Observable<ValidatorFn | null> = tuiControlValue<ScProduct | null>(this.product).pipe(\n        map((product) => Validators.min(product?.properties?.width ?? 0))\n    );\n\n    /**\n     * Валидатор для длины изделия.\n     */\n    protected readonly validatorLength$: Observable<ValidatorFn | null> = tuiControlValue<ScProduct | null>(this.product).pipe(\n        map((product) => Validators.min(product?.properties?.length ?? 0))\n    );\n\n    /**\n     * Признак того, что выполняется запрос на отправку данных выполняется.\n     */\n    protected readonly isSubmitLoading = signal(false);\n\n    /**\n     * Ссылка для автоматического управления уничтожением зависимостей.\n     */\n    private readonly destroyRef: DestroyRef = inject(DestroyRef);\n\n    /**\n     * Массив изделий.\n     */\n    get items(): FormArray<ReturnType<ScSandwichComponent['createItemGroup']>> {\n        return this.form.controls.items;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.setDefaultFormValue();\n\n        this.product.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((product) => {\n            if (product) {\n                this.items.controls.forEach((item) => {\n                    const value = item.getRawValue();\n\n                    if ((product.properties?.width && value.width < product.properties.width) || (product.properties?.length && value.length < product.properties.length)) {\n                        item.patchValue({\n                            width: Math.min(value.width, product.properties.width ?? value.width),\n                            length: Math.min(value.length, product.properties.length ?? value.length),\n                        });\n                    }\n                });\n            }\n        });\n    }\n\n    /**\n     * Создает группу для изделия.\n     *\n     * @param item Параметры изделия.\n     */\n    private createItemGroup(item?: ISandwichCalculateItem): FormGroup<{\n        width: FormControl<number>;\n        length: FormControl<number>;\n        quantity: FormControl<number>;\n    }> {\n        return new FormGroup({\n            width: new FormControl<number>(item?.width ?? 0, {\n                validators: [Validators.required, Validators.min(this.settings()?.minWidth ?? 0.01)],\n                nonNullable: true,\n            }),\n            length: new FormControl<number>(item?.length ?? 0, {\n                validators: [Validators.required, Validators.min(this.settings()?.minLength ?? 0.01)],\n                nonNullable: true,\n            }),\n            quantity: new FormControl<number>(item?.quantity ?? 1, {\n                validators: [Validators.required, Validators.min(1)],\n                nonNullable: true,\n            }),\n        });\n    }\n\n    /**\n     * Добавляет новое изделие в форму.\n     */\n    protected addItem(): void {\n        this.items.push(this.createItemGroup());\n    }\n\n    /**\n     * Удаляет изделие из формы.\n     *\n     * @param index Индекс изделия.\n     */\n    protected removeItem(index: number): void {\n        this.items.removeAt(index);\n    }\n\n    /**\n     * Возвращает итоговую стоимость.\n     *\n     * @param calculateResult Результат расчета оптимизации раскладки.\n     */\n    protected getTotalCost(calculateResult: ScIConfiguratorCalculateResult): number {\n        if (!this.product.value?.costRub) {\n            return 0;\n        }\n\n        const quantity = this.form.get('quantity')?.value ?? 1;\n        const totalCost = calculateResult.quantity * this.product.value.costRub * quantity;\n\n        return Math.round(totalCost * 100) / 100;\n    }\n\n    /**\n     * Обработчик добавления/редактирования продукта в корзине.\n     *\n     * @param calculateResult Результат расчета оптимизации раскладки.\n     */\n    protected onSubmit(calculateResult: ScIConfiguratorCalculateResult | null | undefined): void {\n        if (!calculateResult || this.form.invalid || this.isCalculateLoading()) {\n            return;\n        }\n\n        const formValue = { ...this.form.value, productId: this.product.value?.id ?? null, calculationId: calculateResult.id };\n        // Удаляем items, так как они не нужны в {@link ScINewCartItemSandwich}.\n        delete formValue.items;\n        const orderItem = this.cartItem();\n\n        const newCartItem$: Observable<ScCart> = orderItem\n            ? this.cartService.updateProduct$(orderItem.id, this.convertersService.removeNull(formValue) as ScINewCartItemSandwich)\n            : this.cartService.addProduct$(this.convertersService.removeNull(formValue) as ScINewCartItemSandwich);\n\n        this.isSubmitLoading.set(true);\n\n        newCartItem$\n            .pipe(\n                tap(() => {\n                    if (this.context) {\n                        this.context.$implicit.complete();\n                    } else {\n                        this.setDefaultFormValue();\n                    }\n                }),\n                catchError((error: unknown) => {\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ScIApiErrorResponse;\n\n                        if (errors) {\n                            Object.keys(errors).forEach((key) => {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            });\n                        } else if (message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of();\n                }),\n                finalize(() => {\n                    this.isSubmitLoading.set(false);\n                })\n            )\n            .subscribe();\n    }\n\n    /**\n     * Устанавливает начальные значения для полей формы.\n     */\n    private setDefaultFormValue(): void {\n        this.form.reset({\n            productCategoryId: Number(this.categoryId()),\n            configurator: this.editor(),\n            quantity: this.cartItem()?.quantity ?? null,\n            marker: this.cartItem()?.marker ?? '',\n        });\n\n        this.items.clear();\n\n        this.product.reset(this.cartItem()?.product ?? null);\n\n        const configuratorParameters = this.cartItem()?.configuratorParams as ISandwichCalculate | undefined;\n\n        configuratorParameters?.items.forEach((item) => {\n            this.items.push(this.createItemGroup({ width: item.width, length: item.length, quantity: item.quantity }));\n        });\n\n        if (!configuratorParameters?.items.length) {\n            this.addItem();\n        }\n    }\n}\n","@if (!cartItem() && settings()?.allowShowTable) {\n    <div class=\"mb-5 flex justify-center\">\n        <button\n            tuiButton\n            appearance=\"secondary\"\n            (click)=\"toggleShowEvent.emit()\"\n            type=\"button\"\n            iconStart=\"@tui.layout-list\"\n        >\n            Показать в виде списка\n        </button>\n    </div>\n}\n<div class=\"\">\n    @let calculateResult = calculateResult$ | async;\n    @let products = products$ | async;\n    @let productValue = product.value;\n    @let validatorWidth = validatorWidth$ | async;\n    @let validatorLength = validatorLength$ | async;\n\n    <form\n        [formGroup]=\"form\"\n        (ngSubmit)=\"onSubmit(calculateResult)\"\n        ScNextInputFocus\n        class=\"flex flex-col gap-3\"\n    >\n        <label\n            tuiLabel\n            class=\"grow\"\n        >\n            Товар\n            <tui-textfield\n                tuiChevron\n                [tuiTextfieldCleaner]=\"false\"\n            >\n                <input\n                    tuiChevron\n                    tuiSelect\n                    [formControl]=\"product\"\n                    placeholder=\"Выберите материал\"\n                />\n\n                <tui-data-list-wrapper\n                    *tuiTextfieldDropdown\n                    new\n                    [items]=\"products\"\n                />\n            </tui-textfield>\n            @if (productValue) {\n                <div class=\"ml-2 text-tui-text-secondary\">\n                    Стоимость:\n                    <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/шт.</span>\n                </div>\n            }\n            <tui-error\n                [formControl]=\"product\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        @if (product.value && validatorWidth && validatorLength) {\n            <p class=\"w-full font-bold\">Размеры изделий</p>\n            <p class=\"w-full\">\n                Минимальная ширина: {{ settings()?.minWidth }} мм.\n                <br />\n                Максимальная ширина: {{ product.value.properties?.width }} мм.\n                <br />\n                Минимальная длина: {{ settings()?.minLength }} мм.\n                <br />\n                Максимальная длина: {{ product.value.properties?.length }} мм.\n                <br />\n            </p>\n            <div\n                formArrayName=\"items\"\n                class=\"flex flex-col gap-3\"\n            >\n                @for (item of items.controls; track item) {\n                    <div\n                        class=\"flex grow gap-2\"\n                        [formGroupName]=\"$index\"\n                    >\n                        <div class=\"grid grow grid-cols-3 gap-2\">\n                            <label tuiLabel>\n                                Ширина, мм\n                                <tui-textfield>\n                                    <input\n                                        tuiInputSlider\n                                        formControlName=\"width\"\n                                        [min]=\"settings()?.minWidth ?? 0\"\n                                        [max]=\"product.value.properties?.width ?? 0\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Ширина\"\n                                        autocomplete=\"off\"\n                                    />\n                                    @if (product.value) {\n                                        <input\n                                            tuiSlider\n                                            type=\"range\"\n                                        />\n                                    }\n                                </tui-textfield>\n                                @if (product.value) {\n                                    <div class=\"slider-ticks-labels\">\n                                        <span> 0 </span>\n                                        <span>{{ product.value.properties?.width }}</span>\n                                    </div>\n                                }\n                                <tui-error\n                                    formControlName=\"width\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n\n                            <label tuiLabel>\n                                Длина, мм\n                                <tui-textfield>\n                                    <input\n                                        tuiInputSlider\n                                        formControlName=\"length\"\n                                        [min]=\"settings()?.minLength ?? 0\"\n                                        [max]=\"product.value.properties?.length ?? 0\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Длина\"\n                                        autocomplete=\"off\"\n                                    />\n                                    @if (product.value) {\n                                        <input\n                                            tuiSlider\n                                            type=\"range\"\n                                        />\n                                    }\n                                </tui-textfield>\n                                @if (product.value) {\n                                    <div class=\"slider-ticks-labels\">\n                                        <span> 0 </span>\n                                        <span>{{ product.value.properties?.length }}</span>\n                                    </div>\n                                }\n                                <tui-error\n                                    formControlName=\"length\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n                            <label tuiLabel>\n                                <span class=\"whitespace-nowrap\">Количество, шт</span>\n                                <tui-textfield [tuiTextfieldCleaner]=\"false\">\n                                    <input\n                                        tuiInputNumber\n                                        formControlName=\"quantity\"\n                                        [min]=\"1\"\n                                        [tuiNumberFormat]=\"{ precision: 0 }\"\n                                        placeholder=\"Количество\"\n                                        autocomplete=\"off\"\n                                    />\n                                </tui-textfield>\n                                <tui-error\n                                    formControlName=\"quantity\"\n                                    [error]=\"[] | tuiFieldError | async\"\n                                />\n                            </label>\n                        </div>\n                        <button\n                            tuiIconButton\n                            (click)=\"removeItem($index)\"\n                            [disabled]=\"items.length <= 1\"\n                            size=\"m\"\n                            type=\"button\"\n                            iconStart=\"@tui.trash-2\"\n                            appearance=\"secondary\"\n                            class=\"mt-6\"\n                            [style.flex]=\"'0 0 auto'\"\n                        ></button>\n                    </div>\n                }\n            </div>\n            <button\n                tuiButton\n                appearance=\"secondary\"\n                [disabled]=\"items.invalid\"\n                (click)=\"addItem()\"\n                type=\"button\"\n                class=\"self-center\"\n                iconStart=\"@tui.plus\"\n            >\n                Добавить изделие\n            </button>\n        } @else if (product.value) {\n            <tui-error error=\"Расчет по продукту невозможен. Обратитесь к менеджеру\" />\n        }\n\n        <label tuiLabel>\n            Маркировка распила\n            <tui-textfield>\n                <input\n                    tuiTextfield\n                    formControlName=\"marker\"\n                    placeholder=\"Маркировка распила\"\n                    autocomplete=\"marker\"\n                />\n            </tui-textfield>\n\n            <tui-error\n                formControlName=\"marker\"\n                [error]=\"[] | tuiFieldError | async\"\n            />\n        </label>\n\n        @if (product.value) {\n            <tui-loader [showLoader]=\"isCalculateLoading()\">\n                @if (calculateResult) {\n                    <div class=\"mt-2 flex flex-wrap items-end gap-2\">\n                        <div>\n                            Итого: <span class=\"whitespace-nowrap text-xl font-bold\">{{ getTotalCost(calculateResult).toLocaleString() }} {{ product.value.currency.symbol }}</span>\n                        </div>\n                        @if (calculateResult?.quantity && productValue) {\n                            <div class=\"whitespace-nowrap text-lg text-sc-dark-grey\">\n                                <span class=\"font-bold\">({{ calculateResult.quantity }} шт.</span> x\n                                <span class=\"font-bold\">{{ productValue.costRub?.toLocaleString() }} {{ productValue.currency.symbol }}/шт.)</span>\n                            </div>\n                        }\n                    </div>\n                }\n            </tui-loader>\n        }\n\n        <tui-error [error]=\"[] | tuiFieldError | async\" />\n\n        <button\n            [disabled]=\"form.invalid || !calculateResult || isCalculateLoading() || isSubmitLoading()\"\n            [loading]=\"isSubmitLoading()\"\n            tuiButton\n            class=\"self-center\"\n            iconStart=\"@tui.check\"\n        >\n            {{ !cartItem() ? 'Добавить в корзину' : 'Изменить' }}\n        </button>\n    </form>\n</div>\n"]}
|
|
@@ -88,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
88
88
|
type: Inject,
|
|
89
89
|
args: [POLYMORPHEUS_CONTEXT]
|
|
90
90
|
}] }] });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contact-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.ts","../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    ScContactsService,\n    ScConvertersService,\n    ScIBankAccount,\n    ScIContactBase,\n    ScIContactOnDataCreate,\n    ScIContactWithRelations,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { phoneValidator } from '../../validators/sc-phone-validator';\n\n/**\n * Компонент формы создания нового контактного лица.\n */\n@Component({\n    selector: 'sc-add-contact-dialog',\n    templateUrl: './sc-add-contact-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContactDialogComponent implements AfterViewInit {\n    /**\n     * Группа с полями контактного лица.\n     */\n    public form = new FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }>({\n        name: new FormControl<string | null>(null, Validators.required),\n        phone: new FormControl<string | null>(null, [Validators.required, phoneValidator()]),\n        email: new FormControl<string | null>(null, Validators.email),\n        position: new FormControl<string | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контактного лица.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIContactOnDataCreate => this.form.valid),\n        map((value) => this.convertersService.removeNull<ScIContactOnDataCreate>({ ...value, ...this.context.data })),\n        switchMap((data) => {\n            return this.contactsService.createContact$(data).pipe(\n                tap((contact) => {\n                    this.context.completeWith(contact);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContactDialogComponent}.\n     *\n     * @param contactsService Сервис для работы с контактными лицами.\n     * @param convertersService Сервис конвертации данных.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contactsService: ScContactsService,\n        public readonly convertersService: ScConvertersService,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>\n    ) {}\n\n    /** @inheritdoc */\n    public ngAfterViewInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.userProfileContactAddShow,\n        });\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n    <div class=\"flex justify-center gap-4\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            iconStart=\"@tui.x\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [loading]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            iconStart=\"@tui.save\"\n        >\n            Сохранить\n        </button>\n    </div>\n</form>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contact-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.ts","../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    ScContactsService,\n    ScConvertersService,\n    ScIApiErrorResponse,\n    ScIBankAccount,\n    ScIContactBase,\n    ScIContactOnDataCreate,\n    ScIContactWithRelations,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { phoneValidator } from '../../validators/sc-phone-validator';\n\n/**\n * Компонент формы создания нового контактного лица.\n */\n@Component({\n    selector: 'sc-add-contact-dialog',\n    templateUrl: './sc-add-contact-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContactDialogComponent implements AfterViewInit {\n    /**\n     * Группа с полями контактного лица.\n     */\n    public form = new FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }>({\n        name: new FormControl<string | null>(null, Validators.required),\n        phone: new FormControl<string | null>(null, [Validators.required, phoneValidator()]),\n        email: new FormControl<string | null>(null, Validators.email),\n        position: new FormControl<string | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контактного лица.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIContactOnDataCreate => this.form.valid),\n        map((value) => this.convertersService.removeNull<ScIContactOnDataCreate>({ ...value, ...this.context.data })),\n        switchMap((data) => {\n            return this.contactsService.createContact$(data).pipe(\n                tap((contact) => {\n                    this.context.completeWith(contact);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ScIApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContactDialogComponent}.\n     *\n     * @param contactsService Сервис для работы с контактными лицами.\n     * @param convertersService Сервис конвертации данных.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contactsService: ScContactsService,\n        public readonly convertersService: ScConvertersService,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>\n    ) {}\n\n    /** @inheritdoc */\n    public ngAfterViewInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.userProfileContactAddShow,\n        });\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n    <div class=\"flex justify-center gap-4\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            iconStart=\"@tui.x\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [loading]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            iconStart=\"@tui.save\"\n        >\n            Сохранить\n        </button>\n    </div>\n</form>\n"]}
|
|
@@ -78,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
78
78
|
type: Inject,
|
|
79
79
|
args: [POLYMORPHEUS_CONTEXT]
|
|
80
80
|
}] }] });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contragent-bank-account-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.ts","../../../../../projects/client-ui/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ScContragentService, ScIBankAccount, ScIBankAccountOnDataCreate, ScIOpf } from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { scBicValidator, scCorrespondentAccountValidator } from '../../validators';\n\n/**\n * Компонент формы создания нового банковского счета контрагента.\n */\n@Component({\n    selector: 'sc-add-contragent-bank-account-dialog',\n    templateUrl: './sc-add-contragent-bank-account-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContragentBankAccountsDialogComponent {\n    /**\n     * Группа с полем банковских реквизитов.\n     */\n    public form = new FormGroup<{\n        bankName: FormControl<string | null>;\n        bic: FormControl<string | null>;\n        accountNumber: FormControl<string | null>;\n        correspondentAccount: FormControl<string | null>;\n        currencyId: FormControl<number | null>;\n    }>({\n        bankName: new FormControl<string | null>(null, Validators.required),\n        bic: new FormControl<string | null>(null, [Validators.required, Validators.minLength(9), scBicValidator]),\n        accountNumber: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20)]),\n        correspondentAccount: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),\n        currencyId: new FormControl<number | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса создания банковского счёта контрагента.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIBankAccountOnDataCreate => this.form.valid),\n        switchMap((value) => {\n            return this.contragentService.createContragentBankAccount$(this.context.data.contragentId, value).pipe(\n                tap((bankAccount) => {\n                    this.context.completeWith(bankAccount);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContragentBankAccountsFormComponent}.\n     *\n     * @param contragentService Сервис работы с контрагентами.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contragentService: ScContragentService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIBankAccount, { contragentId: number; opf: ScIOpf }>\n    ) {}\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <sc-new-contragent-bank-account-form\n        [opf]=\"$any(context.data).opf.slug\"\n        [form]=\"form\"\n    />\n    <div class=\"flex justify-center gap-4\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            iconStart=\"@tui.x\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [loading]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            iconStart=\"@tui.save\"\n        >\n            Сохранить\n        </button>\n    </div>\n</form>\n"]}
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contragent-bank-account-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.ts","../../../../../projects/client-ui/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ScContragentService, ScIApiErrorResponse, ScIBankAccount, ScIBankAccountOnDataCreate, ScIOpf } from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@taiga-ui/polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { scBicValidator, scCorrespondentAccountValidator } from '../../validators';\n\n/**\n * Компонент формы создания нового банковского счета контрагента.\n */\n@Component({\n    selector: 'sc-add-contragent-bank-account-dialog',\n    templateUrl: './sc-add-contragent-bank-account-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContragentBankAccountsDialogComponent {\n    /**\n     * Группа с полем банковских реквизитов.\n     */\n    public form = new FormGroup<{\n        bankName: FormControl<string | null>;\n        bic: FormControl<string | null>;\n        accountNumber: FormControl<string | null>;\n        correspondentAccount: FormControl<string | null>;\n        currencyId: FormControl<number | null>;\n    }>({\n        bankName: new FormControl<string | null>(null, Validators.required),\n        bic: new FormControl<string | null>(null, [Validators.required, Validators.minLength(9), scBicValidator]),\n        accountNumber: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20)]),\n        correspondentAccount: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),\n        currencyId: new FormControl<number | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса создания банковского счёта контрагента.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIBankAccountOnDataCreate => this.form.valid),\n        switchMap((value) => {\n            return this.contragentService.createContragentBankAccount$(this.context.data.contragentId, value).pipe(\n                tap((bankAccount) => {\n                    this.context.completeWith(bankAccount);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ScIApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                // eslint-disable-next-line security/detect-object-injection\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContragentBankAccountsFormComponent}.\n     *\n     * @param contragentService Сервис работы с контрагентами.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contragentService: ScContragentService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIBankAccount, { contragentId: number; opf: ScIOpf }>\n    ) {}\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <sc-new-contragent-bank-account-form\n        [opf]=\"$any(context.data).opf.slug\"\n        [form]=\"form\"\n    />\n    <div class=\"flex justify-center gap-4\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            iconStart=\"@tui.x\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [loading]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            iconStart=\"@tui.save\"\n        >\n            Сохранить\n        </button>\n    </div>\n</form>\n"]}
|