@snabcentr/client-ui 3.32.4 → 3.33.1
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/banner/sc-banner.module.d.ts +2 -1
- package/catalog/category-card/sc-category-card.component.d.ts +0 -6
- package/catalog/hover-image-carousel/{hover-image-carousel.component.d.ts → sc-hover-image-carousel.component.d.ts} +16 -7
- package/catalog/index.d.ts +1 -0
- package/catalog/sc-catalog.module.d.ts +3 -2
- package/directives/abstract-price-card/abstract-sc-price-card.directive.d.ts +4 -4
- package/esm2022/banner/sc-banner.component.mjs +3 -3
- package/esm2022/banner/sc-banner.module.mjs +4 -3
- package/esm2022/cart/cart-item/sc-cart-item.component.mjs +4 -4
- package/esm2022/catalog/category-card/sc-category-card.component.mjs +4 -11
- package/esm2022/catalog/hover-image-carousel/sc-hover-image-carousel.component.mjs +76 -0
- package/esm2022/catalog/index.mjs +2 -1
- package/esm2022/catalog/price-card/sc-price-card.component.mjs +2 -2
- package/esm2022/catalog/price-card-inline/sc-price-card-inline.component.mjs +4 -4
- package/esm2022/catalog/sc-catalog.module.mjs +8 -5
- package/esm2022/directives/abstract-price-card/abstract-sc-price-card.directive.mjs +5 -6
- package/esm2022/news/news-card/sc-news-card.component.mjs +4 -8
- package/esm2022/news/sc-news.module.mjs +4 -3
- package/esm2022/order/order-item-mobile/sc-order-item-mobile.component.mjs +15 -20
- package/fesm2022/snabcentr-client-ui.mjs +60 -76
- package/fesm2022/snabcentr-client-ui.mjs.map +1 -1
- package/news/news-card/sc-news-card.component.d.ts +1 -5
- package/news/sc-news.module.d.ts +2 -1
- package/order/order-item-mobile/sc-order-item-mobile.component.d.ts +8 -14
- package/package.json +2 -2
- package/release_notes.tmp +2 -2
- package/styles/tailwind/tailwind.scss +0 -4
- package/esm2022/catalog/hover-image-carousel/hover-image-carousel.component.mjs +0 -76
@@ -1,7 +1,7 @@
|
|
1
1
|
/* eslint-disable no-underscore-dangle */
|
2
2
|
import { ChangeDetectorRef, Directive, EventEmitter, inject, Input, Output, signal } from '@angular/core';
|
3
3
|
import { FormControl } from '@angular/forms';
|
4
|
-
import { SC_PATH_IMAGE_NOT_FOUND, ScAuthService, ScImageHelper, ScUnitsHelper, SEARCH_TERM } from '@snabcentr/client-core';
|
4
|
+
import { SC_PATH_IMAGE_NOT_FOUND, ScAuthService, ScImage, ScImageHelper, ScUnitsHelper, SEARCH_TERM } from '@snabcentr/client-core';
|
5
5
|
import { TUI_IS_MOBILE } from '@taiga-ui/cdk';
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
/**
|
@@ -119,10 +119,10 @@ export class AbstractScPriceCard {
|
|
119
119
|
return !this.product;
|
120
120
|
}
|
121
121
|
/**
|
122
|
-
* Возвращает
|
122
|
+
* Возвращает данные для preview-изображения карточки товара.
|
123
123
|
*/
|
124
124
|
getCardImagePreview() {
|
125
|
-
return this.product ? this.imageHelper.getImagePreview(this.product) : this.pathImageNotFound;
|
125
|
+
return this.product ? this.imageHelper.getImagePreview(this.product) : new ScImage(this.pathImageNotFound, `Товар не найден`);
|
126
126
|
}
|
127
127
|
/**
|
128
128
|
* Возвращает массив превью-изображений товара.
|
@@ -130,8 +130,7 @@ export class AbstractScPriceCard {
|
|
130
130
|
* @param product Объект товара.
|
131
131
|
*/
|
132
132
|
getCardImagePreviewList(product) {
|
133
|
-
|
134
|
-
return images.length > 0 ? images : [this.pathImageNotFound];
|
133
|
+
return this.imageHelper.getProductImagePreviewList(product, true);
|
135
134
|
}
|
136
135
|
/**
|
137
136
|
* Устанавливает компонент в очередь на обновление.
|
@@ -168,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
168
167
|
}], quantityValueChanges: [{
|
169
168
|
type: Output
|
170
169
|
}] } });
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-sc-price-card.directive.js","sourceRoot":"","sources":["../../../../../projects/client-ui/directives/abstract-price-card/abstract-sc-price-card.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\n\nimport { ChangeDetectorRef, Directive, EventEmitter, inject, Input, Output, signal, WritableSignal } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { SC_PATH_IMAGE_NOT_FOUND, ScAuthService, ScCartItem, ScImageHelper, ScProduct, ScUnitsHelper, SEARCH_TERM } from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE } from '@taiga-ui/cdk';\nimport { Observable } from 'rxjs';\n\n/**\n * Директива абстрактной карточки товара.\n */\n@Directive({\n    host: { ngSkipHydration: 'true' },\n}) // Абстрактный класс имеет декоратор @Directive() для внедрения его в DI, с целью получения функционала inject внутри абстракции, и возможности получать потомков через DI или через декоратор @ViewChild.\nexport class AbstractScPriceCard {\n    /**\n     * Позиция товара в корзине.\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    public get cartItem(): ScCartItem | undefined {\n        return this._cartItem;\n    }\n\n    /**\n     * Позиция товара в корзине\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    @Input()\n    public set cartItem(value: ScCartItem | undefined) {\n        this._cartItem = value;\n\n        this.quantityControl.patchValue(this._cartItem?.quantity ?? null, { emitEvent: false });\n        this.quantityShowLoader = false;\n    }\n\n    /**\n     * Объект товара.\n     */\n    public get product(): ScProduct | undefined {\n        return this._product;\n    }\n\n    /**\n     * Объект товара.\n     */\n    @Input()\n    public set product(value: ScProduct | undefined) {\n        this._product = value;\n    }\n\n    /**\n     * Признак того, что этот компонент отображается на мобильном устройстве.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * {@link FormControl} поля ввода количества товара в корзине.\n     */\n    public quantityControl: FormControl<number | null> = new FormControl<number | null>(null, { updateOn: 'blur' });\n\n    /**\n     * Признак, что необходимо отобразить лоадер для поля ввода количества товара.\n     */\n    public quantityShowLoader: boolean = false;\n\n    /**\n     * Признак, что необходимо отобразить лоадер для кнопки избранных товаров и категорий.\n     */\n    public favoriteShowLoader: boolean = false;\n\n    /**\n     * {@link Observable} изменения статуса авторизации.\n     */\n    public readonly authStatus$: Observable<boolean> = inject(ScAuthService).getAuthChange();\n\n    /**\n     * {@link Observable} поиска терма.\n     */\n    public readonly search$ = inject(SEARCH_TERM);\n\n    /**\n     * Признак, что необходимо отобразить поле ввода количества товара.\n     */\n    @Input()\n    public showQuantityControl: boolean = false;\n\n    /**\n     * Ссылка на страницу товара. Используется именно `href`, так как остановить событие клика для `routerLink` не вышло.\n     */\n    @Input()\n    public href?: string;\n\n    /**\n     * Событие нажатия на кнопку \"В избранное\".\n     */\n    @Output()\n    public readonly clickFavoriteEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Событие нажатия на кнопку \"В корзину\".\n     */\n    @Output()\n    public readonly clickAddToCartEvent: EventEmitter<ScProduct> = new EventEmitter<ScProduct>();\n\n    /**\n     * Событие нажатия на кнопку очистки количества товара.\n     */\n    @Output()\n    public readonly clickClearEvent: EventEmitter<ScCartItem> = new EventEmitter<ScCartItem>();\n\n    /**\n     * Событие нажатия на карточку товара.\n     */\n    @Output()\n    public readonly clickCardEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Событие нажатия на историю цен.\n     */\n    @Output()\n    public readonly clickPriceHistoryEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * {@link Observable} изменения количества товара в корзине.\n     */\n    @Output()\n    public readonly quantityValueChanges: Observable<number | null> = this.quantityControl.valueChanges;\n\n    /**\n     * Признак, что необходимо автоматичеси выставить фокус на поле ввода колличества товара.\n     */\n    public readonly autoFocuseQuantityInput: WritableSignal<boolean> = signal(false);\n\n    /**\n     * Экземпляр класса-помощника для работы со значениями единиц измерения товара.\n     */\n    protected readonly unitsHelper: ScUnitsHelper = inject(ScUnitsHelper);\n\n    /**\n     * Хелпер для работы с изображениями товара.\n     */\n    protected readonly imageHelper: ScImageHelper = inject(ScImageHelper);\n\n    /**\n     * Путь до изображения 'Товар не найден'.\n     */\n    private readonly pathImageNotFound: string = inject(SC_PATH_IMAGE_NOT_FOUND);\n\n    /**\n     * Объект слежения за изменениями.\n     */\n    private readonly cdr: ChangeDetectorRef = inject(ChangeDetectorRef);\n\n    /**\n     * Объект товара.\n     */\n    private _product: ScProduct | undefined;\n\n    /**\n     * Позиция товара в корзине.\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    private _cartItem: ScCartItem | undefined;\n\n    /**\n     * Признак, что нужно показать скелетон.\n     */\n    public get skeletonVisible(): boolean {\n        return !this.product;\n    }\n\n    /**\n     * Возвращает ссылку на preview-изображение карточки товара.\n     */\n    public getCardImagePreview(): string {\n        return this.product ? this.imageHelper.getImagePreview(this.product) : this.pathImageNotFound;\n    }\n\n    /**\n     * Возвращает массив превью-изображений товара.\n     *\n     * @param product Объект товара.\n     */\n    public getCardImagePreviewList(product: ScProduct): string[] {\n        const images = this.imageHelper.getProductImagePreviewList(product);\n\n        return images.length > 0 ? images : [this.pathImageNotFound];\n    }\n\n    /**\n     * Устанавливает компонент в очередь на обновление.\n     */\n    public markForCheck(): void {\n        this.cdr.markForCheck();\n    }\n}\n"]}
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-sc-price-card.directive.js","sourceRoot":"","sources":["../../../../../projects/client-ui/directives/abstract-price-card/abstract-sc-price-card.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\n\nimport { ChangeDetectorRef, Directive, EventEmitter, inject, Input, Output, signal, WritableSignal } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { SC_PATH_IMAGE_NOT_FOUND, ScAuthService, ScCartItem, ScIImage, ScImage, ScImageHelper, ScProduct, ScUnitsHelper, SEARCH_TERM } from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE } from '@taiga-ui/cdk';\nimport { Observable } from 'rxjs';\n\n/**\n * Директива абстрактной карточки товара.\n */\n@Directive({\n    host: { ngSkipHydration: 'true' },\n}) // Абстрактный класс имеет декоратор @Directive() для внедрения его в DI, с целью получения функционала inject внутри абстракции, и возможности получать потомков через DI или через декоратор @ViewChild.\nexport class AbstractScPriceCard {\n    /**\n     * Позиция товара в корзине.\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    public get cartItem(): ScCartItem | undefined {\n        return this._cartItem;\n    }\n\n    /**\n     * Позиция товара в корзине\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    @Input()\n    public set cartItem(value: ScCartItem | undefined) {\n        this._cartItem = value;\n\n        this.quantityControl.patchValue(this._cartItem?.quantity ?? null, { emitEvent: false });\n        this.quantityShowLoader = false;\n    }\n\n    /**\n     * Объект товара.\n     */\n    public get product(): ScProduct | undefined {\n        return this._product;\n    }\n\n    /**\n     * Объект товара.\n     */\n    @Input()\n    public set product(value: ScProduct | undefined) {\n        this._product = value;\n    }\n\n    /**\n     * Признак того, что этот компонент отображается на мобильном устройстве.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * {@link FormControl} поля ввода количества товара в корзине.\n     */\n    public quantityControl: FormControl<number | null> = new FormControl<number | null>(null, { updateOn: 'blur' });\n\n    /**\n     * Признак, что необходимо отобразить лоадер для поля ввода количества товара.\n     */\n    public quantityShowLoader: boolean = false;\n\n    /**\n     * Признак, что необходимо отобразить лоадер для кнопки избранных товаров и категорий.\n     */\n    public favoriteShowLoader: boolean = false;\n\n    /**\n     * {@link Observable} изменения статуса авторизации.\n     */\n    public readonly authStatus$: Observable<boolean> = inject(ScAuthService).getAuthChange();\n\n    /**\n     * {@link Observable} поиска терма.\n     */\n    public readonly search$ = inject(SEARCH_TERM);\n\n    /**\n     * Признак, что необходимо отобразить поле ввода количества товара.\n     */\n    @Input()\n    public showQuantityControl: boolean = false;\n\n    /**\n     * Ссылка на страницу товара. Используется именно `href`, так как остановить событие клика для `routerLink` не вышло.\n     */\n    @Input()\n    public href?: string;\n\n    /**\n     * Событие нажатия на кнопку \"В избранное\".\n     */\n    @Output()\n    public readonly clickFavoriteEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Событие нажатия на кнопку \"В корзину\".\n     */\n    @Output()\n    public readonly clickAddToCartEvent: EventEmitter<ScProduct> = new EventEmitter<ScProduct>();\n\n    /**\n     * Событие нажатия на кнопку очистки количества товара.\n     */\n    @Output()\n    public readonly clickClearEvent: EventEmitter<ScCartItem> = new EventEmitter<ScCartItem>();\n\n    /**\n     * Событие нажатия на карточку товара.\n     */\n    @Output()\n    public readonly clickCardEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Событие нажатия на историю цен.\n     */\n    @Output()\n    public readonly clickPriceHistoryEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * {@link Observable} изменения количества товара в корзине.\n     */\n    @Output()\n    public readonly quantityValueChanges: Observable<number | null> = this.quantityControl.valueChanges;\n\n    /**\n     * Признак, что необходимо автоматичеси выставить фокус на поле ввода колличества товара.\n     */\n    public readonly autoFocuseQuantityInput: WritableSignal<boolean> = signal(false);\n\n    /**\n     * Экземпляр класса-помощника для работы со значениями единиц измерения товара.\n     */\n    protected readonly unitsHelper: ScUnitsHelper = inject(ScUnitsHelper);\n\n    /**\n     * Хелпер для работы с изображениями товара.\n     */\n    protected readonly imageHelper: ScImageHelper = inject(ScImageHelper);\n\n    /**\n     * Путь до изображения 'Товар не найден'.\n     */\n    private readonly pathImageNotFound: string = inject(SC_PATH_IMAGE_NOT_FOUND);\n\n    /**\n     * Объект слежения за изменениями.\n     */\n    private readonly cdr: ChangeDetectorRef = inject(ChangeDetectorRef);\n\n    /**\n     * Объект товара.\n     */\n    private _product: ScProduct | undefined;\n\n    /**\n     * Позиция товара в корзине.\n     *\n     * TODO: Сделать товар в корзине наблюдаемой переменной после реализации TASK:[#7144].\n     */\n    private _cartItem: ScCartItem | undefined;\n\n    /**\n     * Признак, что нужно показать скелетон.\n     */\n    public get skeletonVisible(): boolean {\n        return !this.product;\n    }\n\n    /**\n     * Возвращает данные для preview-изображения карточки товара.\n     */\n    public getCardImagePreview(): ScIImage {\n        return this.product ? this.imageHelper.getImagePreview(this.product) : new ScImage(this.pathImageNotFound, `Товар не найден`);\n    }\n\n    /**\n     * Возвращает массив превью-изображений товара.\n     *\n     * @param product Объект товара.\n     */\n    public getCardImagePreviewList(product: ScProduct): ScIImage[] {\n        return this.imageHelper.getProductImagePreviewList(product, true);\n    }\n\n    /**\n     * Устанавливает компонент в очередь на обновление.\n     */\n    public markForCheck(): void {\n        this.cdr.markForCheck();\n    }\n}\n"]}
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
|
2
|
-
import { ScImageHelper } from '@snabcentr/client-core';
|
3
2
|
import { TUI_IS_MOBILE } from '@taiga-ui/cdk';
|
4
3
|
import * as i0 from "@angular/core";
|
5
4
|
import * as i1 from "@angular/router";
|
6
5
|
import * as i2 from "../../pipes/sc-format-date";
|
6
|
+
import * as i3 from "@snabcentr/client-core";
|
7
7
|
/**
|
8
8
|
* Компонент карточки новости.
|
9
9
|
*/
|
@@ -21,18 +21,14 @@ export class ScNewsCardComponent {
|
|
21
21
|
* Признак того, что этот компонент отображается на мобильном устройстве.
|
22
22
|
*/
|
23
23
|
this.isMobile = inject(TUI_IS_MOBILE);
|
24
|
-
/**
|
25
|
-
* Класс с вспомогательными методами для работы с изображениями.
|
26
|
-
*/
|
27
|
-
this.imageHelper = inject(ScImageHelper);
|
28
24
|
}
|
29
25
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScNewsCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
26
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ScNewsCardComponent, selector: "sc-news-card", inputs: { news: { classPropertyName: "news", publicName: "news", isSignal: true, isRequired: true, transformFunction: null }, href: { classPropertyName: "href", publicName: "href", isSignal: true, isRequired: true, transformFunction: null } }, host: { properties: { "class.is_mobile": "isMobile" } }, ngImport: i0, template: "<a\n [routerLink]=\"href()\"\n class=\"black-link relative flex h-full cursor-pointer flex-col gap-2 overflow-hidden rounded-xl bg-white px-2 pb-4 pt-2 shadow-sc\"\n>\n <div class=\"w-full grow overflow-hidden rounded-xl bg-tui-base-02 bg-cover bg-center bg-no-repeat\">\n <picture>\n @if (news().imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"news().imageWebp | scMediaImageTransformer\"\n />\n }\n <img\n [src]=\"news().image | scMediaImageTransformer: true\"\n [alt]=\"news().subject\"\n class=\"size-full object-cover\"\n />\n </picture>\n </div>\n <div class=\"flex w-full shrink-0 flex-col justify-between gap-2 overflow-hidden bg-white align-baseline\">\n <p class=\"text-sm font-medium text-tui-text-02\">{{ news().createdAt | scFormatDate }}</p>\n\n <div class=\"line-clamp-3 font-extrabold\">{{ news().subject }}</div>\n </div>\n</a>\n", styles: [":host{display:block;height:20.5rem}:host.is_mobile{height:17rem}\n"], dependencies: [{ kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: i2.ScFormatDatePipe, name: "scFormatDate" }, { kind: "pipe", type: i3.ScMediaImageTransformerPipe, name: "scMediaImageTransformer" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
31
27
|
}
|
32
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScNewsCardComponent, decorators: [{
|
33
29
|
type: Component,
|
34
30
|
args: [{ selector: 'sc-news-card', host: {
|
35
31
|
'[class.is_mobile]': 'isMobile',
|
36
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<a\n [routerLink]=\"href()\"\n class=\"black-link relative flex h-full cursor-pointer flex-col gap-2 overflow-hidden rounded-xl bg-white px-2 pb-4 pt-2 shadow-sc\"\n>\n <div
|
32
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<a\n [routerLink]=\"href()\"\n class=\"black-link relative flex h-full cursor-pointer flex-col gap-2 overflow-hidden rounded-xl bg-white px-2 pb-4 pt-2 shadow-sc\"\n>\n <div class=\"w-full grow overflow-hidden rounded-xl bg-tui-base-02 bg-cover bg-center bg-no-repeat\">\n <picture>\n @if (news().imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"news().imageWebp | scMediaImageTransformer\"\n />\n }\n <img\n [src]=\"news().image | scMediaImageTransformer: true\"\n [alt]=\"news().subject\"\n class=\"size-full object-cover\"\n />\n </picture>\n </div>\n <div class=\"flex w-full shrink-0 flex-col justify-between gap-2 overflow-hidden bg-white align-baseline\">\n <p class=\"text-sm font-medium text-tui-text-02\">{{ news().createdAt | scFormatDate }}</p>\n\n <div class=\"line-clamp-3 font-extrabold\">{{ news().subject }}</div>\n </div>\n</a>\n", styles: [":host{display:block;height:20.5rem}:host.is_mobile{height:17rem}\n"] }]
|
37
33
|
}] });
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtbmV3cy1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC11aS9uZXdzL25ld3MtY2FyZC9zYy1uZXdzLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL25ld3MvbmV3cy1jYXJkL3NjLW5ld3MtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFFL0YsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFFOUM7O0dBRUc7QUFVSCxNQUFNLE9BQU8sbUJBQW1CO0lBVGhDO1FBVUk7O1dBRUc7UUFDSSxTQUFJLEdBQTRCLEtBQUssQ0FBQyxRQUFRLEVBQWMsQ0FBQztRQUVwRTs7V0FFRztRQUNJLFNBQUksR0FBK0IsS0FBSyxDQUFDLFFBQVEsRUFBaUIsQ0FBQztRQUUxRTs7V0FFRztRQUNhLGFBQVEsR0FBWSxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7S0FDN0Q7K0dBZlksbUJBQW1CO21HQUFuQixtQkFBbUIsaVdDaEJoQyxxaUNBeUJBOzs0RkRUYSxtQkFBbUI7a0JBVC9CLFNBQVM7K0JBQ0ksY0FBYyxRQUdsQjt3QkFDRixtQkFBbUIsRUFBRSxVQUFVO3FCQUNsQyxtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQsIElucHV0U2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTY05ld3NUaWxlIH0gZnJvbSAnQHNuYWJjZW50ci9jbGllbnQtY29yZSc7XG5pbXBvcnQgeyBUVUlfSVNfTU9CSUxFIH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbi8qKlxuICog0JrQvtC80L/QvtC90LXQvdGCINC60LDRgNGC0L7Rh9C60Lgg0L3QvtCy0L7RgdGC0LguXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc2MtbmV3cy1jYXJkJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc2MtbmV3cy1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zYy1uZXdzLWNhcmQuY29tcG9uZW50LnNjc3MnXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbY2xhc3MuaXNfbW9iaWxlXSc6ICdpc01vYmlsZScsXG4gICAgfSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2NOZXdzQ2FyZENvbXBvbmVudCB7XG4gICAgLyoqXG4gICAgICog0JTQsNC90L3Ri9C1INC+INC90L7QstC+0YHRgtC4LlxuICAgICAqL1xuICAgIHB1YmxpYyBuZXdzOiBJbnB1dFNpZ25hbDxTY05ld3NUaWxlPiA9IGlucHV0LnJlcXVpcmVkPFNjTmV3c1RpbGU+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQodGB0YvQu9C60LAg0L3QsCDRgdGC0YDQsNC90LjRhtGDINC90L7QstC+0YHRgtC4LiDQmNGB0L/QvtC70YzQt9GD0LXRgtGB0Y8g0LjQvNC10L3QvdC+IGBocmVmYCwg0YLQsNC6INC60LDQuiDQvtGB0YLQsNC90L7QstC40YLRjCDRgdC+0LHRi9GC0LjQtSDQutC70LjQutCwINC00LvRjyBgcm91dGVyTGlua2Ag0L3QtSDQstGL0YjQu9C+LlxuICAgICAqL1xuICAgIHB1YmxpYyBocmVmOiBJbnB1dFNpZ25hbDxzdHJpbmcgfCBudWxsPiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZyB8IG51bGw+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQn9GA0LjQt9C90LDQuiDRgtC+0LPQviwg0YfRgtC+INGN0YLQvtGCINC60L7QvNC/0L7QvdC10L3RgiDQvtGC0L7QsdGA0LDQttCw0LXRgtGB0Y8g0L3QsCDQvNC+0LHQuNC70YzQvdC+0Lwg0YPRgdGC0YDQvtC50YHRgtCy0LUuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGlzTW9iaWxlOiBib29sZWFuID0gaW5qZWN0KFRVSV9JU19NT0JJTEUpO1xufVxuIiwiPGFcbiAgICBbcm91dGVyTGlua109XCJocmVmKClcIlxuICAgIGNsYXNzPVwiYmxhY2stbGluayByZWxhdGl2ZSBmbGV4IGgtZnVsbCBjdXJzb3ItcG9pbnRlciBmbGV4LWNvbCBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy13aGl0ZSBweC0yIHBiLTQgcHQtMiBzaGFkb3ctc2NcIlxuPlxuICAgIDxkaXYgY2xhc3M9XCJ3LWZ1bGwgZ3JvdyBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy10dWktYmFzZS0wMiBiZy1jb3ZlciBiZy1jZW50ZXIgYmctbm8tcmVwZWF0XCI+XG4gICAgICAgIDxwaWN0dXJlPlxuICAgICAgICAgICAgQGlmIChuZXdzKCkuaW1hZ2VXZWJwKSB7XG4gICAgICAgICAgICAgICAgPHNvdXJjZVxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiaW1hZ2Uvd2VicFwiXG4gICAgICAgICAgICAgICAgICAgIFtzcmNzZXRdPVwibmV3cygpLmltYWdlV2VicCB8IHNjTWVkaWFJbWFnZVRyYW5zZm9ybWVyXCJcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgPGltZ1xuICAgICAgICAgICAgICAgIFtzcmNdPVwibmV3cygpLmltYWdlIHwgc2NNZWRpYUltYWdlVHJhbnNmb3JtZXI6IHRydWVcIlxuICAgICAgICAgICAgICAgIFthbHRdPVwibmV3cygpLnN1YmplY3RcIlxuICAgICAgICAgICAgICAgIGNsYXNzPVwic2l6ZS1mdWxsIG9iamVjdC1jb3ZlclwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L3BpY3R1cmU+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImZsZXggdy1mdWxsIHNocmluay0wIGZsZXgtY29sIGp1c3RpZnktYmV0d2VlbiBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gYmctd2hpdGUgYWxpZ24tYmFzZWxpbmVcIj5cbiAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXNtIGZvbnQtbWVkaXVtIHRleHQtdHVpLXRleHQtMDJcIj57eyBuZXdzKCkuY3JlYXRlZEF0IHwgc2NGb3JtYXREYXRlIH19PC9wPlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJsaW5lLWNsYW1wLTMgZm9udC1leHRyYWJvbGRcIj57eyBuZXdzKCkuc3ViamVjdCB9fTwvZGl2PlxuICAgIDwvZGl2PlxuPC9hPlxuIl19
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
2
2
|
import { NgModule } from '@angular/core';
|
3
3
|
import { RouterModule } from '@angular/router';
|
4
|
+
import { ScMediaImageTransformerPipe } from '@snabcentr/client-core';
|
4
5
|
import { ScFormatDatePipe } from '../pipes/sc-format-date';
|
5
6
|
import { ScShareButtonModule } from '../share-button';
|
6
7
|
import { ScNewsCardComponent } from './news-card/sc-news-card.component';
|
@@ -11,15 +12,15 @@ import * as i0 from "@angular/core";
|
|
11
12
|
*/
|
12
13
|
export class ScNewsModule {
|
13
14
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScNewsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
14
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: ScNewsModule, declarations: [ScNewsCardComponent, ScNewsCardSkeletonComponent], imports: [CommonModule, RouterModule, ScShareButtonModule, ScFormatDatePipe], exports: [ScNewsCardComponent, ScNewsCardSkeletonComponent] }); }
|
15
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: ScNewsModule, declarations: [ScNewsCardComponent, ScNewsCardSkeletonComponent], imports: [CommonModule, RouterModule, ScShareButtonModule, ScFormatDatePipe, ScMediaImageTransformerPipe], exports: [ScNewsCardComponent, ScNewsCardSkeletonComponent] }); }
|
15
16
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScNewsModule, imports: [CommonModule, RouterModule, ScShareButtonModule] }); }
|
16
17
|
}
|
17
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScNewsModule, decorators: [{
|
18
19
|
type: NgModule,
|
19
20
|
args: [{
|
20
21
|
declarations: [ScNewsCardComponent, ScNewsCardSkeletonComponent],
|
21
|
-
imports: [CommonModule, RouterModule, ScShareButtonModule, ScFormatDatePipe],
|
22
|
+
imports: [CommonModule, RouterModule, ScShareButtonModule, ScFormatDatePipe, ScMediaImageTransformerPipe],
|
22
23
|
exports: [ScNewsCardComponent, ScNewsCardSkeletonComponent],
|
23
24
|
}]
|
24
25
|
}] });
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtbmV3cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvbmV3cy9zYy1uZXdzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFckUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sc0RBQXNELENBQUM7O0FBRW5HOztHQUVHO0FBTUgsTUFBTSxPQUFPLFlBQVk7K0dBQVosWUFBWTtnSEFBWixZQUFZLGlCQUpOLG1CQUFtQixFQUFFLDJCQUEyQixhQUNyRCxZQUFZLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGdCQUFnQixFQUFFLDJCQUEyQixhQUM5RixtQkFBbUIsRUFBRSwyQkFBMkI7Z0hBRWpELFlBQVksWUFIWCxZQUFZLEVBQUUsWUFBWSxFQUFFLG1CQUFtQjs7NEZBR2hELFlBQVk7a0JBTHhCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsbUJBQW1CLEVBQUUsMkJBQTJCLENBQUM7b0JBQ2hFLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsbUJBQW1CLEVBQUUsZ0JBQWdCLEVBQUUsMkJBQTJCLENBQUM7b0JBQ3pHLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixFQUFFLDJCQUEyQixDQUFDO2lCQUM5RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IFNjTWVkaWFJbWFnZVRyYW5zZm9ybWVyUGlwZSB9IGZyb20gJ0BzbmFiY2VudHIvY2xpZW50LWNvcmUnO1xuXG5pbXBvcnQgeyBTY0Zvcm1hdERhdGVQaXBlIH0gZnJvbSAnLi4vcGlwZXMvc2MtZm9ybWF0LWRhdGUnO1xuaW1wb3J0IHsgU2NTaGFyZUJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL3NoYXJlLWJ1dHRvbic7XG5pbXBvcnQgeyBTY05ld3NDYXJkQ29tcG9uZW50IH0gZnJvbSAnLi9uZXdzLWNhcmQvc2MtbmV3cy1jYXJkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTY05ld3NDYXJkU2tlbGV0b25Db21wb25lbnQgfSBmcm9tICcuL25ld3MtY2FyZC1za2VsZXRvbi9zYy1uZXdzLWNhcmQtc2tlbGV0b24uY29tcG9uZW50JztcblxuLyoqXG4gKiDQnNC+0LTRg9C70Ywg0YDQsNCx0L7RgtGLINGBINC90L7QstC+0YHRgtGP0LzQuC5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtTY05ld3NDYXJkQ29tcG9uZW50LCBTY05ld3NDYXJkU2tlbGV0b25Db21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFJvdXRlck1vZHVsZSwgU2NTaGFyZUJ1dHRvbk1vZHVsZSwgU2NGb3JtYXREYXRlUGlwZSwgU2NNZWRpYUltYWdlVHJhbnNmb3JtZXJQaXBlXSxcbiAgICBleHBvcnRzOiBbU2NOZXdzQ2FyZENvbXBvbmVudCwgU2NOZXdzQ2FyZFNrZWxldG9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2NOZXdzTW9kdWxlIHt9XG4iXX0=
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Inject,
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, EventEmitter, Inject, input, Output, ViewChild } from '@angular/core';
|
2
2
|
import { TuiPreviewDialogService } from '@taiga-ui/kit';
|
3
3
|
import { AbstractScPriceCard } from '../../directives';
|
4
4
|
import * as i0 from "@angular/core";
|
@@ -20,16 +20,21 @@ export class ScOrderItemMobileComponent extends AbstractScPriceCard {
|
|
20
20
|
constructor(previewDialogService) {
|
21
21
|
super();
|
22
22
|
this.previewDialogService = previewDialogService;
|
23
|
+
/**
|
24
|
+
* Элемент заказа.
|
25
|
+
*/
|
26
|
+
this.orderItem = input();
|
23
27
|
/**
|
24
28
|
* Событие нажатия на дополнительные действия.
|
25
29
|
*/
|
26
30
|
this.clickActionsEvent = new EventEmitter();
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
31
|
+
/**
|
32
|
+
* Изображение товара в заказе.
|
33
|
+
*/
|
34
|
+
this.cartImage = computed(() => {
|
35
|
+
const product = this.orderItem()?.product;
|
36
|
+
return product ? this.imageHelper.getImage(product) : undefined;
|
37
|
+
});
|
33
38
|
}
|
34
39
|
/**
|
35
40
|
* Отобразить спецификацию.
|
@@ -37,29 +42,19 @@ export class ScOrderItemMobileComponent extends AbstractScPriceCard {
|
|
37
42
|
showSpecification() {
|
38
43
|
this.previewDialogService.open(this.specificationPreviewRef ?? '').subscribe();
|
39
44
|
}
|
40
|
-
/**
|
41
|
-
* Возвращает ссылку на изображение карточки товара.
|
42
|
-
*
|
43
|
-
* @param product Позиция товара/услуги.
|
44
|
-
*/
|
45
|
-
getCardImage(product) {
|
46
|
-
return this.imageHelper.getImage(product);
|
47
|
-
}
|
48
45
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScOrderItemMobileComponent, deps: [{ token: TuiPreviewDialogService }], target: i0.ɵɵFactoryTarget.Component }); }
|
49
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
46
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ScOrderItemMobileComponent, selector: "sc-order-item-mobile", inputs: { orderItem: { classPropertyName: "orderItem", publicName: "orderItem", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { clickActionsEvent: "clickActionsEvent" }, viewQueries: [{ propertyName: "specificationPreviewRef", first: true, predicate: ["specificationPreview"], descendants: true }], usesInheritance: true, ngImport: i0, template: "@let orderItemData = orderItem();\n@let product = orderItemData?.product;\n@let cartImageData = cartImage();\n\n<div\n [style.opacity]=\"product?.isHidden ? 'var(--tui-disabled-opacity)' : ''\"\n class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\"\n>\n <ng-container *ngIf=\"orderItemData && product; else skeleton\">\n <button\n tuiIconButton\n (click)=\"product.isHidden ? null : clickActionsEvent.emit()\"\n size=\"m\"\n iconStart=\"@tui.ellipsis-vertical\"\n appearance=\"float\"\n class=\"!absolute right-0 top-0 !hidden\"\n ></button>\n <div class=\"flex grow gap-2\">\n <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n <picture *ngIf=\"cartImageData\">\n @if (cartImageData.imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"cartImageData.imageWebp\"\n />\n }\n @if (cartImageData.image) {\n <img\n (click)=\"product.isHidden ? null : clickCardEvent.emit()\"\n [src]=\"cartImageData.image\"\n [alt]=\"product.name\"\n [class.p-5]=\"!product.images?.length\"\n class=\"cursor-pointer\"\n />\n }\n </picture>\n </div>\n\n <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n <div class=\"flex grow basis-min-content flex-col\">\n <a\n [attr.href]=\"href ?? null\"\n [class.disabled]=\"product.isHidden\"\n tuiLink\n (click)=\"$event.preventDefault(); clickCardEvent.emit()\"\n >\n <span class=\"font-bold\">{{ product.name }}</span>\n </a>\n <div class=\"flex flex-col gap-y-0.5 text-tui-text-02\">\n <div class=\"flex flex-wrap\">\n <p class=\"w-40\">\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n <p\n class=\"w-40\"\n *ngIf=\"product.pack\"\n >\n \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n </p>\n </div>\n <a\n tuiLink\n *ngIf=\"orderItemData.specificationImgUrl\"\n (click)=\"showSpecification()\"\n [class.disabled]=\"product.isHidden\"\n >\n \u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F\n </a>\n <ng-template\n #specificationPreview\n let-preview\n >\n <tui-preview\n [rotatable]=\"false\"\n [zoomable]=\"false\"\n >\n <img\n *polymorpheusOutlet=\"orderItemData.specificationImgUrl as src\"\n alt=\"preview\"\n [src]=\"orderItemData.specificationImgUrl\"\n />\n <button\n iconStart=\"@tui.x\"\n title=\"Close\"\n tuiIconButton\n tuiPreviewAction\n type=\"button\"\n (click)=\"preview.complete()\"\n ></button>\n </tui-preview>\n </ng-template>\n </div>\n\n <sc-cost-with-discount [product]=\"product\" />\n </div>\n <div class=\"flex flex-wrap content-center\">\n <div class=\"w-50 flex flex-col gap-x-8 gap-y-0.5\">\n <ng-container *ngIf=\"orderItemData.height; else length\">\n <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ orderItemData.height }} \u043C.</p>\n </ng-container>\n <ng-template #length>\n <p *ngIf=\"orderItemData.length\">\u0414\u043B\u0438\u043D\u0430: {{ orderItemData.length }} \u043C.</p>\n </ng-template>\n <p *ngIf=\"orderItemData.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ orderItemData.width }} \u043C.</p>\n <p class=\"flex flex-col items-baseline gap-x-2\">\n <span class=\"whitespace-nowrap text-body-m-bold\">\n \u041A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E: <span class=\"whitespace-nowrap\">{{ orderItemData.quantity }}</span>\n </span>\n </p>\n </div>\n\n <div class=\"w-50 flex flex-col gap-y-0.5\">\n <p class=\"whitespace-nowrap text-body-m-bold\">\n \u0421\u0443\u043C\u043C\u0430: <span class=\"whitespace-nowrap\"> {{ orderItemData.getCostRubStr() }} </span>\n </p>\n <sc-price-warehouse-stock\n [product]=\"product\"\n [fromMain]=\"false\"\n />\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-template #skeleton>\n <div class=\"flex w-full gap-2\">\n <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n <div class=\"flex grow flex-col gap-2.5 bg-white\">\n <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n </div>\n </div>\n </ng-template>\n</div>\n", styles: ["a[tuilink].disabled{pointer-events:none!important;cursor:default;opacity:var(--tui-disabled-opacity)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }, { kind: "directive", type: i2.TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "component", type: i3.TuiPreviewComponent, selector: "tui-preview", inputs: ["zoomable", "rotatable"] }, { kind: "directive", type: i3.TuiPreviewAction, selector: "[tuiPreviewAction]" }, { kind: "directive", type: i4.PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: i5.ScPriceWarehouseStockComponent, selector: "sc-price-warehouse-stock", inputs: ["classList", "product", "withStockHint", "fromMain"] }, { kind: "component", type: i6.CostWithDiscountComponent, selector: "sc-cost-with-discount", inputs: ["product", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
50
47
|
}
|
51
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ScOrderItemMobileComponent, decorators: [{
|
52
49
|
type: Component,
|
53
|
-
args: [{ selector: 'sc-order-item-mobile', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n [style.opacity]=\"product?.isHidden ? 'var(--tui-disabled-opacity)' : ''\"\n class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\"\n>\n <ng-container *ngIf=\"
|
50
|
+
args: [{ selector: 'sc-order-item-mobile', changeDetection: ChangeDetectionStrategy.OnPush, template: "@let orderItemData = orderItem();\n@let product = orderItemData?.product;\n@let cartImageData = cartImage();\n\n<div\n [style.opacity]=\"product?.isHidden ? 'var(--tui-disabled-opacity)' : ''\"\n class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\"\n>\n <ng-container *ngIf=\"orderItemData && product; else skeleton\">\n <button\n tuiIconButton\n (click)=\"product.isHidden ? null : clickActionsEvent.emit()\"\n size=\"m\"\n iconStart=\"@tui.ellipsis-vertical\"\n appearance=\"float\"\n class=\"!absolute right-0 top-0 !hidden\"\n ></button>\n <div class=\"flex grow gap-2\">\n <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n <picture *ngIf=\"cartImageData\">\n @if (cartImageData.imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"cartImageData.imageWebp\"\n />\n }\n @if (cartImageData.image) {\n <img\n (click)=\"product.isHidden ? null : clickCardEvent.emit()\"\n [src]=\"cartImageData.image\"\n [alt]=\"product.name\"\n [class.p-5]=\"!product.images?.length\"\n class=\"cursor-pointer\"\n />\n }\n </picture>\n </div>\n\n <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n <div class=\"flex grow basis-min-content flex-col\">\n <a\n [attr.href]=\"href ?? null\"\n [class.disabled]=\"product.isHidden\"\n tuiLink\n (click)=\"$event.preventDefault(); clickCardEvent.emit()\"\n >\n <span class=\"font-bold\">{{ product.name }}</span>\n </a>\n <div class=\"flex flex-col gap-y-0.5 text-tui-text-02\">\n <div class=\"flex flex-wrap\">\n <p class=\"w-40\">\u0410\u0440\u0442\u0438\u043A\u0443\u043B: {{ product.code }}</p>\n <p\n class=\"w-40\"\n *ngIf=\"product.pack\"\n >\n \u041D\u043E\u0440\u043C\u0430 \u0443\u043F\u0430\u043A\u043E\u0432\u043A\u0438: {{ product.pack }}\n </p>\n </div>\n <a\n tuiLink\n *ngIf=\"orderItemData.specificationImgUrl\"\n (click)=\"showSpecification()\"\n [class.disabled]=\"product.isHidden\"\n >\n \u0421\u043F\u0435\u0446\u0438\u0444\u0438\u043A\u0430\u0446\u0438\u044F\n </a>\n <ng-template\n #specificationPreview\n let-preview\n >\n <tui-preview\n [rotatable]=\"false\"\n [zoomable]=\"false\"\n >\n <img\n *polymorpheusOutlet=\"orderItemData.specificationImgUrl as src\"\n alt=\"preview\"\n [src]=\"orderItemData.specificationImgUrl\"\n />\n <button\n iconStart=\"@tui.x\"\n title=\"Close\"\n tuiIconButton\n tuiPreviewAction\n type=\"button\"\n (click)=\"preview.complete()\"\n ></button>\n </tui-preview>\n </ng-template>\n </div>\n\n <sc-cost-with-discount [product]=\"product\" />\n </div>\n <div class=\"flex flex-wrap content-center\">\n <div class=\"w-50 flex flex-col gap-x-8 gap-y-0.5\">\n <ng-container *ngIf=\"orderItemData.height; else length\">\n <p>\u0412\u044B\u0441\u043E\u0442\u0430: {{ orderItemData.height }} \u043C.</p>\n </ng-container>\n <ng-template #length>\n <p *ngIf=\"orderItemData.length\">\u0414\u043B\u0438\u043D\u0430: {{ orderItemData.length }} \u043C.</p>\n </ng-template>\n <p *ngIf=\"orderItemData.width\">\u0428\u0438\u0440\u0438\u043D\u0430: {{ orderItemData.width }} \u043C.</p>\n <p class=\"flex flex-col items-baseline gap-x-2\">\n <span class=\"whitespace-nowrap text-body-m-bold\">\n \u041A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E: <span class=\"whitespace-nowrap\">{{ orderItemData.quantity }}</span>\n </span>\n </p>\n </div>\n\n <div class=\"w-50 flex flex-col gap-y-0.5\">\n <p class=\"whitespace-nowrap text-body-m-bold\">\n \u0421\u0443\u043C\u043C\u0430: <span class=\"whitespace-nowrap\"> {{ orderItemData.getCostRubStr() }} </span>\n </p>\n <sc-price-warehouse-stock\n [product]=\"product\"\n [fromMain]=\"false\"\n />\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <ng-template #skeleton>\n <div class=\"flex w-full gap-2\">\n <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n <div class=\"flex grow flex-col gap-2.5 bg-white\">\n <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n </div>\n </div>\n </ng-template>\n</div>\n", styles: ["a[tuilink].disabled{pointer-events:none!important;cursor:default;opacity:var(--tui-disabled-opacity)}\n"] }]
|
54
51
|
}], ctorParameters: () => [{ type: i3.TuiPreviewDialogService, decorators: [{
|
55
52
|
type: Inject,
|
56
53
|
args: [TuiPreviewDialogService]
|
57
54
|
}] }], propDecorators: { specificationPreviewRef: [{
|
58
55
|
type: ViewChild,
|
59
56
|
args: ['specificationPreview']
|
60
|
-
}], orderItem: [{
|
61
|
-
type: Input
|
62
57
|
}], clickActionsEvent: [{
|
63
58
|
type: Output
|
64
59
|
}] } });
|
65
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-order-item-mobile.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/order/order-item-mobile/sc-order-item-mobile.component.ts","../../../../../projects/client-ui/order/order-item-mobile/sc-order-item-mobile.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAe,SAAS,EAAE,MAAM,eAAe,CAAC;AAGhI,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;AAEvD;;GAEG;AAOH,MAAM,OAAO,0BAA2B,SAAQ,mBAAmB;IAmB/D;;;;OAIG;IACH,YAEqB,oBAA6C;QAE9D,KAAK,EAAE,CAAC;QAFS,yBAAoB,GAApB,oBAAoB,CAAyB;QAblE;;WAEG;QAEI,sBAAiB,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAYxE,CAAC;IAED;;OAEG;IACH,IAAoB,OAAO;QACvB,OAAO,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC;IACnC,CAAC;IAED;;OAEG;IACI,iBAAiB;QACpB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAuB,IAAI,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;IACnF,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,OAAkB;QAClC,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;+GApDQ,0BAA0B,kBAyBvB,uBAAuB;mGAzB1B,0BAA0B,6SChBvC,o9LAwHA;;4FDxGa,0BAA0B;kBANtC,SAAS;+BACI,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM;;0BA2B1C,MAAM;2BAAC,uBAAuB;yCApBlB,uBAAuB;sBADvC,SAAS;uBAAC,sBAAsB;gBAO1B,SAAS;sBADf,KAAK;gBAOC,iBAAiB;sBADvB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output, TemplateRef, ViewChild } from '@angular/core';\nimport { ScCartItem, ScProduct } from '@snabcentr/client-core';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { TuiPreviewDialogService } from '@taiga-ui/kit';\n\nimport { AbstractScPriceCard } from '../../directives';\n\n/**\n * Компонент карточки элемента заказа.\n */\n@Component({\n    selector: 'sc-order-item-mobile',\n    templateUrl: './sc-order-item-mobile.component.html',\n    styleUrl: './sc-order-item-mobile.component.less',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScOrderItemMobileComponent extends AbstractScPriceCard {\n    /**\n     * Ссылка на представление спецификации.\n     */\n    @ViewChild('specificationPreview')\n    private readonly specificationPreviewRef?: TemplateRef<TuiDialogContext>;\n\n    /**\n     * Элемент заказа.\n     */\n    @Input()\n    public orderItem?: ScCartItem;\n\n    /**\n     * Событие нажатия на дополнительные действия.\n     */\n    @Output()\n    public clickActionsEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Инициирует экземпляр класса {@link ScOrderItemMobileComponent}.\n     *\n     * @param previewDialogService Сервис диалогового окна предварительного просмотра.\n     */\n    public constructor(\n        @Inject(TuiPreviewDialogService)\n        private readonly previewDialogService: TuiPreviewDialogService\n    ) {\n        super();\n    }\n\n    /**\n     * Продукт элемента заказа.\n     */\n    public override get product(): ScProduct | undefined {\n        return this.orderItem?.product;\n    }\n\n    /**\n     * Отобразить спецификацию.\n     */\n    public showSpecification(): void {\n        this.previewDialogService.open(this.specificationPreviewRef ?? '').subscribe();\n    }\n\n    /**\n     * Возвращает ссылку на изображение карточки товара.\n     *\n     * @param product Позиция товара/услуги.\n     */\n    public getCardImage(product: ScProduct): string {\n        return this.imageHelper.getImage(product);\n    }\n}\n","<div\n    [style.opacity]=\"product?.isHidden ? 'var(--tui-disabled-opacity)' : ''\"\n    class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\"\n>\n    <ng-container *ngIf=\"orderItem && product; else skeleton\">\n        <button\n            tuiIconButton\n            (click)=\"product.isHidden ? null : clickActionsEvent.emit()\"\n            size=\"m\"\n            iconStart=\"@tui.ellipsis-vertical\"\n            appearance=\"float\"\n            class=\"!absolute right-0 top-0 !hidden\"\n        ></button>\n        <div class=\"flex grow gap-2\">\n            <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n                <img\n                    (click)=\"product.isHidden ? null : clickCardEvent.emit()\"\n                    [src]=\"getCardImage(product)\"\n                    [alt]=\"product.name\"\n                    [class.p-5]=\"!product.images?.length\"\n                    class=\"cursor-pointer\"\n                />\n            </div>\n\n            <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n                <div class=\"flex grow basis-min-content flex-col\">\n                    <a\n                        [attr.href]=\"href ?? null\"\n                        [class.disabled]=\"product.isHidden\"\n                        tuiLink\n                        (click)=\"$event.preventDefault(); clickCardEvent.emit()\"\n                    >\n                        <span class=\"font-bold\">{{ product.name }}</span>\n                    </a>\n                    <div class=\"flex flex-col gap-y-0.5 text-tui-text-02\">\n                        <div class=\"flex flex-wrap\">\n                            <p class=\"w-40\">Артикул: {{ product.code }}</p>\n                            <p\n                                class=\"w-40\"\n                                *ngIf=\"product.pack\"\n                            >\n                                Норма упаковки: {{ product.pack }}\n                            </p>\n                        </div>\n                        <a\n                            tuiLink\n                            *ngIf=\"orderItem.specificationImgUrl\"\n                            (click)=\"showSpecification()\"\n                            [class.disabled]=\"product.isHidden\"\n                        >\n                            Спецификация\n                        </a>\n                        <ng-template\n                            #specificationPreview\n                            let-preview\n                        >\n                            <tui-preview\n                                [rotatable]=\"false\"\n                                [zoomable]=\"false\"\n                            >\n                                <img\n                                    *polymorpheusOutlet=\"orderItem.specificationImgUrl as src\"\n                                    alt=\"preview\"\n                                    [src]=\"orderItem.specificationImgUrl\"\n                                />\n                                <button\n                                    iconStart=\"@tui.x\"\n                                    title=\"Close\"\n                                    tuiIconButton\n                                    tuiPreviewAction\n                                    type=\"button\"\n                                    (click)=\"preview.complete()\"\n                                ></button>\n                            </tui-preview>\n                        </ng-template>\n                    </div>\n\n                    <sc-cost-with-discount [product]=\"product\" />\n                </div>\n                <div class=\"flex flex-wrap content-center\">\n                    <div class=\"w-50 flex flex-col gap-x-8 gap-y-0.5\">\n                        <ng-container *ngIf=\"orderItem.height; else length\">\n                            <p>Высота: {{ orderItem.height }} м.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"orderItem.length\">Длина: {{ orderItem.length }} м.</p>\n                        </ng-template>\n                        <p *ngIf=\"orderItem.width\">Ширина: {{ orderItem.width }} м.</p>\n                        <p class=\"flex flex-col items-baseline gap-x-2\">\n                            <span class=\"whitespace-nowrap text-body-m-bold\">\n                                Количество: <span class=\"whitespace-nowrap\">{{ orderItem.quantity }}</span>\n                            </span>\n                        </p>\n                    </div>\n\n                    <div class=\"w-50 flex flex-col gap-y-0.5\">\n                        <p class=\"whitespace-nowrap text-body-m-bold\">\n                            Сумма: <span class=\"whitespace-nowrap\"> {{ orderItem.getCostRubStr() }} </span>\n                        </p>\n                        <sc-price-warehouse-stock\n                            [product]=\"product\"\n                            [fromMain]=\"false\"\n                        />\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-template #skeleton>\n        <div class=\"flex w-full gap-2\">\n            <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"flex grow flex-col gap-2.5 bg-white\">\n                <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n"]}
|
60
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-order-item-mobile.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/order/order-item-mobile/sc-order-item-mobile.component.ts","../../../../../projects/client-ui/order/order-item-mobile/sc-order-item-mobile.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAe,MAAM,EAAuB,SAAS,EAAE,MAAM,eAAe,CAAC;AAG/J,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;AAEvD;;GAEG;AAOH,MAAM,OAAO,0BAA2B,SAAQ,mBAAmB;IA0B/D;;;;OAIG;IACH,YAEqB,oBAA6C;QAE9D,KAAK,EAAE,CAAC;QAFS,yBAAoB,GAApB,oBAAoB,CAAyB;QA1BlE;;WAEG;QACa,cAAS,GAAwC,KAAK,EAA0B,CAAC;QAEjG;;WAEG;QAEI,sBAAiB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAExE;;WAEG;QACa,cAAS,GAAiC,QAAQ,CAAC,GAAG,EAAE;YACpE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,EAAE,OAAO,CAAC;YAC1C,OAAO,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACpE,CAAC,CAAC,CAAC;IAYH,CAAC;IAED;;OAEG;IACI,iBAAiB;QACpB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAuB,IAAI,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;IACnF,CAAC;+GA3CQ,0BAA0B,kBAgCvB,uBAAuB;mGAhC1B,0BAA0B,yZChBvC,6jNAsIA;;4FDtHa,0BAA0B;kBANtC,SAAS;+BACI,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM;;0BAkC1C,MAAM;2BAAC,uBAAuB;yCA3BlB,uBAAuB;sBADvC,SAAS;uBAAC,sBAAsB;gBAY1B,iBAAiB;sBADvB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, EventEmitter, Inject, input, InputSignal, Output, Signal, TemplateRef, ViewChild } from '@angular/core';\nimport { ScCartItem, ScIImage } from '@snabcentr/client-core';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { TuiPreviewDialogService } from '@taiga-ui/kit';\n\nimport { AbstractScPriceCard } from '../../directives';\n\n/**\n * Компонент карточки элемента заказа.\n */\n@Component({\n    selector: 'sc-order-item-mobile',\n    templateUrl: './sc-order-item-mobile.component.html',\n    styleUrl: './sc-order-item-mobile.component.less',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScOrderItemMobileComponent extends AbstractScPriceCard {\n    /**\n     * Ссылка на представление спецификации.\n     */\n    @ViewChild('specificationPreview')\n    private readonly specificationPreviewRef?: TemplateRef<TuiDialogContext>;\n\n    /**\n     * Элемент заказа.\n     */\n    public readonly orderItem: InputSignal<ScCartItem | undefined> = input<ScCartItem | undefined>();\n\n    /**\n     * Событие нажатия на дополнительные действия.\n     */\n    @Output()\n    public clickActionsEvent: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Изображение товара в заказе.\n     */\n    public readonly cartImage: Signal<ScIImage | undefined> = computed(() => {\n        const product = this.orderItem()?.product;\n        return product ? this.imageHelper.getImage(product) : undefined;\n    });\n\n    /**\n     * Инициирует экземпляр класса {@link ScOrderItemMobileComponent}.\n     *\n     * @param previewDialogService Сервис диалогового окна предварительного просмотра.\n     */\n    public constructor(\n        @Inject(TuiPreviewDialogService)\n        private readonly previewDialogService: TuiPreviewDialogService\n    ) {\n        super();\n    }\n\n    /**\n     * Отобразить спецификацию.\n     */\n    public showSpecification(): void {\n        this.previewDialogService.open(this.specificationPreviewRef ?? '').subscribe();\n    }\n}\n","@let orderItemData = orderItem();\n@let product = orderItemData?.product;\n@let cartImageData = cartImage();\n\n<div\n    [style.opacity]=\"product?.isHidden ? 'var(--tui-disabled-opacity)' : ''\"\n    class=\"relative flex flex-wrap gap-x-4 gap-y-2 rounded-xl border border-tui-base-04 bg-white p-4 shadow-sc-2\"\n>\n    <ng-container *ngIf=\"orderItemData && product; else skeleton\">\n        <button\n            tuiIconButton\n            (click)=\"product.isHidden ? null : clickActionsEvent.emit()\"\n            size=\"m\"\n            iconStart=\"@tui.ellipsis-vertical\"\n            appearance=\"float\"\n            class=\"!absolute right-0 top-0 !hidden\"\n        ></button>\n        <div class=\"flex grow gap-2\">\n            <div class=\"flex size-20 shrink-0 items-center justify-center overflow-hidden\">\n                <picture *ngIf=\"cartImageData\">\n                    @if (cartImageData.imageWebp) {\n                        <source\n                            type=\"image/webp\"\n                            [srcset]=\"cartImageData.imageWebp\"\n                        />\n                    }\n                    @if (cartImageData.image) {\n                        <img\n                            (click)=\"product.isHidden ? null : clickCardEvent.emit()\"\n                            [src]=\"cartImageData.image\"\n                            [alt]=\"product.name\"\n                            [class.p-5]=\"!product.images?.length\"\n                            class=\"cursor-pointer\"\n                        />\n                    }\n                </picture>\n            </div>\n\n            <div class=\"flex grow flex-wrap gap-x-8 self-center\">\n                <div class=\"flex grow basis-min-content flex-col\">\n                    <a\n                        [attr.href]=\"href ?? null\"\n                        [class.disabled]=\"product.isHidden\"\n                        tuiLink\n                        (click)=\"$event.preventDefault(); clickCardEvent.emit()\"\n                    >\n                        <span class=\"font-bold\">{{ product.name }}</span>\n                    </a>\n                    <div class=\"flex flex-col gap-y-0.5 text-tui-text-02\">\n                        <div class=\"flex flex-wrap\">\n                            <p class=\"w-40\">Артикул: {{ product.code }}</p>\n                            <p\n                                class=\"w-40\"\n                                *ngIf=\"product.pack\"\n                            >\n                                Норма упаковки: {{ product.pack }}\n                            </p>\n                        </div>\n                        <a\n                            tuiLink\n                            *ngIf=\"orderItemData.specificationImgUrl\"\n                            (click)=\"showSpecification()\"\n                            [class.disabled]=\"product.isHidden\"\n                        >\n                            Спецификация\n                        </a>\n                        <ng-template\n                            #specificationPreview\n                            let-preview\n                        >\n                            <tui-preview\n                                [rotatable]=\"false\"\n                                [zoomable]=\"false\"\n                            >\n                                <img\n                                    *polymorpheusOutlet=\"orderItemData.specificationImgUrl as src\"\n                                    alt=\"preview\"\n                                    [src]=\"orderItemData.specificationImgUrl\"\n                                />\n                                <button\n                                    iconStart=\"@tui.x\"\n                                    title=\"Close\"\n                                    tuiIconButton\n                                    tuiPreviewAction\n                                    type=\"button\"\n                                    (click)=\"preview.complete()\"\n                                ></button>\n                            </tui-preview>\n                        </ng-template>\n                    </div>\n\n                    <sc-cost-with-discount [product]=\"product\" />\n                </div>\n                <div class=\"flex flex-wrap content-center\">\n                    <div class=\"w-50 flex flex-col gap-x-8 gap-y-0.5\">\n                        <ng-container *ngIf=\"orderItemData.height; else length\">\n                            <p>Высота: {{ orderItemData.height }} м.</p>\n                        </ng-container>\n                        <ng-template #length>\n                            <p *ngIf=\"orderItemData.length\">Длина: {{ orderItemData.length }} м.</p>\n                        </ng-template>\n                        <p *ngIf=\"orderItemData.width\">Ширина: {{ orderItemData.width }} м.</p>\n                        <p class=\"flex flex-col items-baseline gap-x-2\">\n                            <span class=\"whitespace-nowrap text-body-m-bold\">\n                                Количество: <span class=\"whitespace-nowrap\">{{ orderItemData.quantity }}</span>\n                            </span>\n                        </p>\n                    </div>\n\n                    <div class=\"w-50 flex flex-col gap-y-0.5\">\n                        <p class=\"whitespace-nowrap text-body-m-bold\">\n                            Сумма: <span class=\"whitespace-nowrap\"> {{ orderItemData.getCostRubStr() }} </span>\n                        </p>\n                        <sc-price-warehouse-stock\n                            [product]=\"product\"\n                            [fromMain]=\"false\"\n                        />\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-template #skeleton>\n        <div class=\"flex w-full gap-2\">\n            <div class=\"size-20 rounded-xl bg-tui-base-02\"></div>\n            <div class=\"flex grow flex-col gap-2.5 bg-white\">\n                <div class=\"h-4 w-full rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-3/5 rounded-xl bg-tui-base-02\"></div>\n                <div class=\"h-4 w-4/5 rounded-xl bg-tui-base-02\"></div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n"]}
|