@snabcentr/client-ui 3.36.2 → 3.36.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -47,7 +47,7 @@ export class ScHoverImageCarouselComponent {
47
47
  * Обработчик события `mouseleave.silent`.
48
48
  */
49
49
  onLeave() {
50
- if (this.images.length <= 1) {
50
+ if (this.images().length <= 1) {
51
51
  return;
52
52
  }
53
53
  this.currentIndex.set(0);
@@ -73,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
73
73
  '(mouseleave.silent)': 'onLeave()',
74
74
  }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"overflow-hidden rounded-xl\"\n [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n [style.aspect-ratio]=\"'20/19'\"\n>\n @let image = currentImage();\n <picture>\n @if (image.imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"image.imageWebp\"\n />\n }\n\n @if (image.image) {\n <img\n [src]=\"image.image\"\n [alt]=\"image.alt\"\n class=\"size-full rounded-xl object-contain\"\n />\n }\n </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n <div\n (mousemove.silent)=\"$event.stopPropagation()\"\n class=\"flex justify-center\"\n >\n <button\n *tuiRepeatTimes=\"let indexItem of images().length\"\n #element\n tuiButton\n type=\"button\"\n class=\"button button_small\"\n [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n ></button>\n </div>\n}\n", styles: [".button{flex-shrink:0}.button:first-child{margin-inline-start:0}.button:last-child{margin-inline-end:0}.button_small{inline-size:.5rem;block-size:.5rem;font-size:0;padding:0;margin:0}.button_small:not(:first-child){margin-left:.5rem}\n"] }]
75
75
  }] });
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-hover-image-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.ts","../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAuB,MAAM,EAAkB,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;AAE3C;;GAEG;AAaH,MAAM,OAAO,6BAA6B;IAZ1C;QAaI;;WAEG;QACa,WAAM,GAA4B,KAAK,CAAC,QAAQ,EAAc,CAAC;QAE/E;;WAEG;QACa,kBAAa,GAAyB,KAAK,CAAU,IAAI,CAAC,CAAC;QAE3E;;WAEG;QACa,iBAAY,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACa,iBAAY,GAAqB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAEpG;;WAEG;QACa,gBAAW,GAAoC,KAAK,EAAsB,CAAC;KA2C9F;IAzCG;;;;;OAKG;IACK,OAAO,CAAC,OAAe,EAAE,MAAmB;QAChD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,YAAY,EAAE,CAAC,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAExG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACK,OAAO;QACX,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC1B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACO,YAAY,CAAC,OAAgB,EAAE,KAAa;QAClD,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC;+GAlEQ,6BAA6B;mGAA7B,6BAA6B,4mBCpB1C,koCAuCA,qSD5Bc,cAAc,6GAAE,SAAS,oIAAE,UAAU;;4FAStC,6BAA6B;kBAZzC,SAAS;iCACM,IAAI,YACN,yBAAyB,WAC1B,CAAC,cAAc,EAAE,SAAS,EAAE,UAAU,CAAC,QAG1C;wBACF,oBAAoB,EAAE,wCAAwC;wBAC9D,qBAAqB,EAAE,WAAW;qBACrC,mBACgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, InputSignal, Signal, signal, WritableSignal } from '@angular/core';\nimport { ScIImage } from '@snabcentr/client-core';\nimport { TuiHovered, TuiRepeatTimes } from '@taiga-ui/cdk';\nimport { TuiButton } from '@taiga-ui/core';\n\n/**\n * Компонент просмотра изображений через событие наведения.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-hover-image-carousel',\n    imports: [TuiRepeatTimes, TuiButton, TuiHovered],\n    templateUrl: './sc-hover-image-carousel.component.html',\n    styleUrl: './sc-hover-image-carousel.component.scss',\n    host: {\n        '(mousemove.silent)': 'onHover($event.offsetX, $event.target)',\n        '(mouseleave.silent)': 'onLeave()',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScHoverImageCarouselComponent {\n    /**\n     * Массив изображений.\n     */\n    public readonly images: InputSignal<ScIImage[]> = input.required<ScIImage[]>();\n\n    /**\n     * Признак что необходимо отобразить элементы управления.\n     */\n    public readonly isShowActions: InputSignal<boolean> = input<boolean>(true);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentIndex: WritableSignal<number> = signal(0);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentImage: Signal<ScIImage> = computed(() => this.images()[this.currentIndex()]);\n\n    /**\n     * Название товара.\n     */\n    public readonly productName: InputSignal<string | undefined> = input<string | undefined>();\n\n    /**\n     * Обработчик события `mousemove.silent`.\n     *\n     * @param offsetX Отступ курсора мыши по оси X от края {@link HTMLElement}.\n     * @param target Объект {@link HTMLElement} в котором лежат изображения\n     */\n    private onHover(offsetX: number, target: HTMLElement): void {\n        if (this.images().length <= 1 || offsetX < 0) {\n            return;\n        }\n\n        const elementWidth = target.offsetWidth;\n        const hoverPercentage = Math.min(offsetX / elementWidth, 1);\n\n        const newIndex = Math.min(Math.floor(hoverPercentage * this.images().length), this.images().length - 1);\n\n        this.currentIndex.set(newIndex);\n    }\n\n    /**\n     * Обработчик события `mouseleave.silent`.\n     */\n    private onLeave(): void {\n        if (this.images.length <= 1) {\n            return;\n        }\n\n        this.currentIndex.set(0);\n    }\n\n    /**\n     * Обработчик события наведения указателя мыши на точку.\n     *\n     * @param hovered Признак что указатель мыши наведен на точку.\n     * @param index Индекс изображения, который соответствует точке.\n     */\n    protected onDotHovered(hovered: boolean, index: number): void {\n        if (hovered) {\n            this.currentIndex.set(index);\n        }\n    }\n}\n","<div\n    class=\"overflow-hidden rounded-xl\"\n    [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n    [style.aspect-ratio]=\"'20/19'\"\n>\n    @let image = currentImage();\n    <picture>\n        @if (image.imageWebp) {\n            <source\n                type=\"image/webp\"\n                [srcset]=\"image.imageWebp\"\n            />\n        }\n\n        @if (image.image) {\n            <img\n                [src]=\"image.image\"\n                [alt]=\"image.alt\"\n                class=\"size-full rounded-xl object-contain\"\n            />\n        }\n    </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n    <div\n        (mousemove.silent)=\"$event.stopPropagation()\"\n        class=\"flex justify-center\"\n    >\n        <button\n            *tuiRepeatTimes=\"let indexItem of images().length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"button button_small\"\n            [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n            (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n        ></button>\n    </div>\n}\n"]}
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-hover-image-carousel.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.ts","../../../../../projects/client-ui/catalog/hover-image-carousel/sc-hover-image-carousel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAuB,MAAM,EAAkB,MAAM,eAAe,CAAC;AAEjI,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;AAE3C;;GAEG;AAaH,MAAM,OAAO,6BAA6B;IAZ1C;QAaI;;WAEG;QACa,WAAM,GAA4B,KAAK,CAAC,QAAQ,EAAc,CAAC;QAE/E;;WAEG;QACa,kBAAa,GAAyB,KAAK,CAAU,IAAI,CAAC,CAAC;QAE3E;;WAEG;QACa,iBAAY,GAA2B,MAAM,CAAC,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACa,iBAAY,GAAqB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAEpG;;WAEG;QACa,gBAAW,GAAoC,KAAK,EAAsB,CAAC;KA2C9F;IAzCG;;;;;OAKG;IACK,OAAO,CAAC,OAAe,EAAE,MAAmB;QAChD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,YAAY,EAAE,CAAC,CAAC,CAAC;QAE5D,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAExG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACK,OAAO;QACX,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;OAKG;IACO,YAAY,CAAC,OAAgB,EAAE,KAAa;QAClD,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC;+GAlEQ,6BAA6B;mGAA7B,6BAA6B,4mBCpB1C,koCAuCA,qSD5Bc,cAAc,6GAAE,SAAS,oIAAE,UAAU;;4FAStC,6BAA6B;kBAZzC,SAAS;iCACM,IAAI,YACN,yBAAyB,WAC1B,CAAC,cAAc,EAAE,SAAS,EAAE,UAAU,CAAC,QAG1C;wBACF,oBAAoB,EAAE,wCAAwC;wBAC9D,qBAAqB,EAAE,WAAW;qBACrC,mBACgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, InputSignal, Signal, signal, WritableSignal } from '@angular/core';\nimport { ScIImage } from '@snabcentr/client-core';\nimport { TuiHovered, TuiRepeatTimes } from '@taiga-ui/cdk';\nimport { TuiButton } from '@taiga-ui/core';\n\n/**\n * Компонент просмотра изображений через событие наведения.\n */\n@Component({\n    standalone: true,\n    selector: 'sc-hover-image-carousel',\n    imports: [TuiRepeatTimes, TuiButton, TuiHovered],\n    templateUrl: './sc-hover-image-carousel.component.html',\n    styleUrl: './sc-hover-image-carousel.component.scss',\n    host: {\n        '(mousemove.silent)': 'onHover($event.offsetX, $event.target)',\n        '(mouseleave.silent)': 'onLeave()',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScHoverImageCarouselComponent {\n    /**\n     * Массив изображений.\n     */\n    public readonly images: InputSignal<ScIImage[]> = input.required<ScIImage[]>();\n\n    /**\n     * Признак что необходимо отобразить элементы управления.\n     */\n    public readonly isShowActions: InputSignal<boolean> = input<boolean>(true);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentIndex: WritableSignal<number> = signal(0);\n\n    /**\n     * {@link WritableSignal} для отслеживания текущего индекса изображения.\n     */\n    public readonly currentImage: Signal<ScIImage> = computed(() => this.images()[this.currentIndex()]);\n\n    /**\n     * Название товара.\n     */\n    public readonly productName: InputSignal<string | undefined> = input<string | undefined>();\n\n    /**\n     * Обработчик события `mousemove.silent`.\n     *\n     * @param offsetX Отступ курсора мыши по оси X от края {@link HTMLElement}.\n     * @param target Объект {@link HTMLElement} в котором лежат изображения\n     */\n    private onHover(offsetX: number, target: HTMLElement): void {\n        if (this.images().length <= 1 || offsetX < 0) {\n            return;\n        }\n\n        const elementWidth = target.offsetWidth;\n        const hoverPercentage = Math.min(offsetX / elementWidth, 1);\n\n        const newIndex = Math.min(Math.floor(hoverPercentage * this.images().length), this.images().length - 1);\n\n        this.currentIndex.set(newIndex);\n    }\n\n    /**\n     * Обработчик события `mouseleave.silent`.\n     */\n    private onLeave(): void {\n        if (this.images().length <= 1) {\n            return;\n        }\n\n        this.currentIndex.set(0);\n    }\n\n    /**\n     * Обработчик события наведения указателя мыши на точку.\n     *\n     * @param hovered Признак что указатель мыши наведен на точку.\n     * @param index Индекс изображения, который соответствует точке.\n     */\n    protected onDotHovered(hovered: boolean, index: number): void {\n        if (hovered) {\n            this.currentIndex.set(index);\n        }\n    }\n}\n","<div\n    class=\"overflow-hidden rounded-xl\"\n    [class.mb-2]=\"images().length <= 1 && isShowActions()\"\n    [style.aspect-ratio]=\"'20/19'\"\n>\n    @let image = currentImage();\n    <picture>\n        @if (image.imageWebp) {\n            <source\n                type=\"image/webp\"\n                [srcset]=\"image.imageWebp\"\n            />\n        }\n\n        @if (image.image) {\n            <img\n                [src]=\"image.image\"\n                [alt]=\"image.alt\"\n                class=\"size-full rounded-xl object-contain\"\n            />\n        }\n    </picture>\n</div>\n@if (images().length > 1 && isShowActions()) {\n    <div\n        (mousemove.silent)=\"$event.stopPropagation()\"\n        class=\"flex justify-center\"\n    >\n        <button\n            *tuiRepeatTimes=\"let indexItem of images().length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"button button_small\"\n            [appearance]=\"indexItem === currentIndex() ? 'primary' : 'secondary'\"\n            (tuiHoveredChange)=\"onDotHovered($event, indexItem)\"\n        ></button>\n    </div>\n}\n"]}
@@ -3921,7 +3921,7 @@ class ScHoverImageCarouselComponent {
3921
3921
  * Обработчик события `mouseleave.silent`.
3922
3922
  */
3923
3923
  onLeave() {
3924
- if (this.images.length <= 1) {
3924
+ if (this.images().length <= 1) {
3925
3925
  return;
3926
3926
  }
3927
3927
  this.currentIndex.set(0);