@colijnit/product 256.1.5 → 256.1.6
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/app/components/image-carousel/image-carousel.component.d.ts +16 -13
- package/app/service/product-event.service.d.ts +1 -1
- package/bundles/colijnit-product.umd.js +102 -41
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/image-carousel/image-carousel.component.js +127 -70
- package/esm2015/app/components/product-page/product-page.component.js +1 -1
- package/esm2015/app/product-version.js +3 -3
- package/esm2015/app/service/product-event.service.js +1 -1
- package/fesm2015/colijnit-product.js +128 -70
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +2 -2
|
@@ -1,43 +1,56 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewChild } from '@angular/core';
|
|
2
3
|
import { CoDocument } from '@colijnit/mainapi/build/model/co-document';
|
|
3
4
|
import { ProductConnectorService } from '../../service/product-connector.service';
|
|
4
5
|
import { ProductEventService } from '../../service/product-event.service';
|
|
5
|
-
import { IconEnum } from '../../enum/icon.enum';
|
|
6
|
-
import { IconCacheService } from '../../service/icon-cache.service';
|
|
7
6
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
7
|
+
export class ImageViewModel {
|
|
8
|
+
}
|
|
8
9
|
export class ImageCarouselComponent {
|
|
9
|
-
constructor(_ione, _appEventService, _changeDetector, _domSanitizer
|
|
10
|
+
constructor(_ione, _appEventService, _changeDetector, _domSanitizer) {
|
|
10
11
|
this._ione = _ione;
|
|
11
12
|
this._appEventService = _appEventService;
|
|
12
13
|
this._changeDetector = _changeDetector;
|
|
13
14
|
this._domSanitizer = _domSanitizer;
|
|
14
|
-
this.iconCache = iconCache;
|
|
15
|
-
this.icons = IconEnum;
|
|
16
|
-
this.showLoader = false;
|
|
17
15
|
this.showRefresh = false;
|
|
18
16
|
this.resizing = false;
|
|
17
|
+
this.imageViewModels = [];
|
|
18
|
+
this.showLoader = false;
|
|
19
19
|
this._currentIndex = 0;
|
|
20
20
|
this._images = [];
|
|
21
21
|
this._subs = [];
|
|
22
|
+
this._resizeCanvasHeight = 500;
|
|
22
23
|
this._subs.push(this._appEventService.onRenderStarted.subscribe(() => {
|
|
23
24
|
this.showLoader = true;
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
this.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
25
|
+
this._changeDetector.detectChanges();
|
|
26
|
+
setTimeout(() => {
|
|
27
|
+
this.showLoader = false;
|
|
28
|
+
this._changeDetector.detectChanges();
|
|
29
|
+
}, 10000);
|
|
30
|
+
}), this._appEventService.onDraftRenderImageReceived.subscribe((event) => {
|
|
31
|
+
if (event && event.detail) {
|
|
32
|
+
if (this._images[0] instanceof CoDocument) {
|
|
33
|
+
this._images.unshift(event.detail);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this._images[0] = event.detail;
|
|
37
|
+
}
|
|
38
|
+
this._loadAndRescaleImages();
|
|
30
39
|
}
|
|
31
40
|
this.showLoader = false;
|
|
41
|
+
this._changeDetector.detectChanges();
|
|
32
42
|
}));
|
|
33
43
|
}
|
|
34
44
|
set images(value) {
|
|
35
45
|
if (value && value.length > 0) {
|
|
36
46
|
this._images = this._filterValidImages(value);
|
|
37
|
-
this.
|
|
47
|
+
this._loadAndRescaleImages();
|
|
38
48
|
this._changeDetector.detectChanges();
|
|
39
49
|
}
|
|
40
50
|
}
|
|
51
|
+
get images() {
|
|
52
|
+
return this._images;
|
|
53
|
+
}
|
|
41
54
|
handleWindowResize() {
|
|
42
55
|
this.resizing = true;
|
|
43
56
|
this._scrollCarouselToIndex();
|
|
@@ -62,11 +75,6 @@ export class ImageCarouselComponent {
|
|
|
62
75
|
this._currentIndex = value;
|
|
63
76
|
this._scrollCarouselToIndex();
|
|
64
77
|
}
|
|
65
|
-
get images() {
|
|
66
|
-
return this._images;
|
|
67
|
-
}
|
|
68
|
-
ngOnInit() {
|
|
69
|
-
}
|
|
70
78
|
ngOnDestroy() {
|
|
71
79
|
this.carousel = undefined;
|
|
72
80
|
this._subs.forEach(s => s.unsubscribe());
|
|
@@ -77,43 +85,90 @@ export class ImageCarouselComponent {
|
|
|
77
85
|
onForceRenderImage() {
|
|
78
86
|
this._appEventService.onForceRenderImage.next();
|
|
79
87
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
88
|
+
handleShowImage(imageViewModel) {
|
|
89
|
+
if (imageViewModel && imageViewModel.originalSource) {
|
|
90
|
+
let popupWindow = window.open('', 'Image zoom', 'width=600,height=400');
|
|
91
|
+
// Set the content of the popup window
|
|
92
|
+
popupWindow.document.write('<html><head><title>Image zoom</title></head><body>');
|
|
93
|
+
popupWindow.document.write(`<img src=${imageViewModel.originalSource} alt="Image" style="width:100%; height:auto;">`);
|
|
94
|
+
popupWindow.document.write('</body></html>');
|
|
95
|
+
// Close the document to render the popup window
|
|
96
|
+
popupWindow.document.close();
|
|
89
97
|
}
|
|
90
|
-
else if (image.detail !== undefined) {
|
|
91
|
-
source = image.detail;
|
|
92
|
-
}
|
|
93
|
-
return this._domSanitizer.bypassSecurityTrustUrl(source);
|
|
94
98
|
}
|
|
95
99
|
_filterValidImages(value) {
|
|
96
100
|
if (!value) {
|
|
97
101
|
return [];
|
|
98
102
|
}
|
|
99
|
-
return value.filter(doc => {
|
|
103
|
+
return value.filter((doc) => {
|
|
100
104
|
const pattern = /\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;
|
|
101
|
-
return pattern.test(doc.fileName) || !!doc.filePath;
|
|
105
|
+
return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);
|
|
102
106
|
});
|
|
103
107
|
}
|
|
104
|
-
|
|
108
|
+
_loadAndRescaleImages() {
|
|
109
|
+
this.imageViewModels.length = 0;
|
|
105
110
|
if (this._images) {
|
|
106
111
|
this._images.forEach((i) => {
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
112
|
+
let imageViewModel = new ImageViewModel();
|
|
113
|
+
imageViewModel.image = i;
|
|
114
|
+
if (typeof i === 'string') { // is a rendered image coming from configurator
|
|
115
|
+
this._resizeAndSanitizeSource(i, imageViewModel);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
if (i.filePath) {
|
|
119
|
+
this._resizeAndSanitizeSource(i.filePath, imageViewModel);
|
|
120
|
+
}
|
|
121
|
+
else if (i.documentBody) {
|
|
122
|
+
this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
this._ione.getDocumentContent(i.documentId, false).then((content) => {
|
|
126
|
+
if (content) {
|
|
127
|
+
i.documentBody = content.documentContent;
|
|
128
|
+
this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);
|
|
129
|
+
this._changeDetector.detectChanges();
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
113
133
|
}
|
|
134
|
+
this.imageViewModels.push(imageViewModel);
|
|
135
|
+
this._changeDetector.detectChanges();
|
|
114
136
|
});
|
|
115
137
|
}
|
|
116
138
|
}
|
|
139
|
+
_resizeAndSanitizeSource(source, imageViewModel) {
|
|
140
|
+
const resizeCanvas = document.createElement('canvas');
|
|
141
|
+
const resizeCanvasContext = resizeCanvas.getContext('2d');
|
|
142
|
+
const resizeImage = document.createElement('img');
|
|
143
|
+
resizeImage.onload = () => __awaiter(this, void 0, void 0, function* () {
|
|
144
|
+
resizeCanvasContext.imageSmoothingEnabled = true;
|
|
145
|
+
resizeCanvasContext.imageSmoothingQuality = 'high';
|
|
146
|
+
// Get the original image dimensions
|
|
147
|
+
const originalWidth = resizeImage.width;
|
|
148
|
+
const originalHeight = resizeImage.height;
|
|
149
|
+
// Calculate the aspect ratio
|
|
150
|
+
const aspectRatio = originalWidth / originalHeight;
|
|
151
|
+
// Calculate the new width and height while maintaining the aspect ratio
|
|
152
|
+
let newWidth = this._resizeCanvasHeight;
|
|
153
|
+
let newHeight = this._resizeCanvasHeight;
|
|
154
|
+
if (originalWidth > originalHeight) {
|
|
155
|
+
newHeight = this._resizeCanvasHeight / aspectRatio;
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
newWidth = this._resizeCanvasHeight * aspectRatio;
|
|
159
|
+
}
|
|
160
|
+
// Set the canvas size to the new width and height
|
|
161
|
+
resizeCanvas.width = newWidth;
|
|
162
|
+
resizeCanvas.height = newHeight;
|
|
163
|
+
const imageWidth = this._resizeCanvasHeight * (resizeImage.height / resizeImage.width);
|
|
164
|
+
resizeCanvasContext.drawImage(resizeImage, 0, 0, newWidth, newHeight);
|
|
165
|
+
const resizedSource = resizeCanvas.toDataURL('image/jpeg');
|
|
166
|
+
imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);
|
|
167
|
+
imageViewModel.originalSource = source;
|
|
168
|
+
});
|
|
169
|
+
// @ts-ignore
|
|
170
|
+
resizeImage.src = source;
|
|
171
|
+
}
|
|
117
172
|
_scrollCarouselToIndex() {
|
|
118
173
|
if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {
|
|
119
174
|
const movePx = this.currentIndex * this.carousel.nativeElement.clientWidth;
|
|
@@ -131,45 +186,47 @@ ImageCarouselComponent.decorators = [
|
|
|
131
186
|
{ type: Component, args: [{
|
|
132
187
|
selector: 'app-image-carousel',
|
|
133
188
|
template: `
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
189
|
+
<div id="product_page_carousel">
|
|
190
|
+
<div id="product_page_carousel_items">
|
|
191
|
+
<co-loader [isShown]="true" *ngIf="showLoader"></co-loader>
|
|
192
|
+
<div #carousel class="inner-carousel">
|
|
193
|
+
<!-- This has been taken out of the for loop to prevent flashing images when updating. -->
|
|
194
|
+
<div *ngIf="imageViewModels[0]" class="carousel-item" [id]="'slide-0'" [class.active]="isCurrentIndex(0)" (click)="handleShowImage(imageViewModels[0])">
|
|
195
|
+
<img [src]="imageViewModels[0].source">
|
|
196
|
+
</div>
|
|
197
|
+
<div *ngFor="let imageViewModel of imageViewModels.slice(1); let index = index" class="carousel-item"
|
|
198
|
+
[id]="'slide-' + (index + 1)" [class.active]="isCurrentIndex((index + 1))" (click)="handleShowImage(imageViewModel)">
|
|
199
|
+
<img [src]="imageViewModel.source">
|
|
200
|
+
</div>
|
|
201
|
+
<div class="carousel-scroller-layer" *ngIf="imageViewModels && imageViewModels.length > 1">
|
|
202
|
+
<div class="carousel-item-scroller prev" (click)="gotoPrevSlide()" *ngIf="currentIndex > 0"></div>
|
|
203
|
+
<div class="carousel-item-scroller next" (click)="gotoNextSlide()" *ngIf="currentIndex < images.length - 1"></div>
|
|
204
|
+
</div>
|
|
205
|
+
</div>
|
|
206
|
+
<!--
|
|
207
|
+
<co-icon class="selector-type-icon refresh-button" [iconData]="iconCache.getIcon(icons.Refresh)" (click)="onForceRenderImage()" [class.loading]="showLoader" *ngIf="showRefresh"></co-icon>
|
|
208
|
+
-->
|
|
141
209
|
</div>
|
|
142
|
-
<div *ngFor="let image of images.slice(1); let index = index" class="carousel-item" [id]="'slide-' + (index + 1)" [class.active]="isCurrentIndex((index + 1))">
|
|
143
|
-
<img [src]="getImageSrc(image)">
|
|
144
|
-
</div>
|
|
145
|
-
<div class="carousel-scroller-layer" *ngIf="images && images.length > 1">
|
|
146
|
-
<div class="carousel-item-scroller prev" (click)="gotoPrevSlide()" *ngIf="currentIndex > 0"></div>
|
|
147
|
-
<div class="carousel-item-scroller next" (click)="gotoNextSlide()" *ngIf="currentIndex < images.length - 1"></div>
|
|
148
|
-
</div>
|
|
149
|
-
</div>
|
|
150
|
-
<!--
|
|
151
|
-
<co-icon class="selector-type-icon refresh-button" [iconData]="iconCache.getIcon(icons.Refresh)" (click)="onForceRenderImage()" [class.loading]="showLoader" *ngIf="showRefresh"></co-icon>
|
|
152
|
-
-->
|
|
153
|
-
</div>
|
|
154
210
|
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
211
|
+
<div id="product_page_carousel_thumbs">
|
|
212
|
+
<co-scroll-container class="scroll-container" *ngIf="imageViewModels && imageViewModels.length > 1">
|
|
213
|
+
<div *ngFor="let imageViewModel of imageViewModels; let index = index" class="carousel-thumb"
|
|
214
|
+
[class.active]="index === currentIndex">
|
|
215
|
+
<img [src]="imageViewModel.source" (click)="handleThumbClick(index)"/>
|
|
216
|
+
</div>
|
|
217
|
+
</co-scroll-container>
|
|
159
218
|
</div>
|
|
160
|
-
</co-scroll-container>
|
|
161
219
|
</div>
|
|
162
|
-
</div>
|
|
163
220
|
`,
|
|
164
|
-
|
|
221
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
222
|
+
styles: [":host{max-height:540px;height:100%;position:relative}:host:not(.resizing) .inner-carousel{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}#product_page_carousel{position:relative}#product_page_carousel .refresh-button{position:absolute;bottom:10px;right:10px;background:#fff}#product_page_carousel .refresh-button.loading{animation:spin 1s linear infinite}#product_page_carousel .refresh-button:hover{box-shadow:none;background:#74B77F;transition:all .2s ease-in-out}#product_page_carousel .refresh-button:hover ::ng-deep svg path{fill:#fff!important}#product_page_carousel #product_page_carousel_items{position:relative;margin-bottom:10px}#product_page_carousel #product_page_carousel_items ::ng-deep co-loader{position:absolute}#product_page_carousel .inner-carousel{display:flex;flex-direction:row;align-items:center;overflow:hidden;max-height:500px;border:1px solid #efefef}#product_page_carousel .carousel-item{max-height:500px;width:100%;display:flex;cursor:zoom-in;flex-shrink:0;flex-grow:0}#product_page_carousel .carousel-item img{width:100%;height:auto;-o-object-fit:contain;object-fit:contain}#product_page_carousel .carousel-scroller-layer{height:100%;width:100%;position:absolute;pointer-events:none;top:0;left:0}#product_page_carousel #product_page_carousel_thumbs{display:flex;justify-content:flex-start;height:80px;margin-left:auto;margin-right:auto}#product_page_carousel #product_page_carousel_thumbs ::ng-deep co-scroll-container{padding:0 22px}#product_page_carousel #product_page_carousel_thumbs ::ng-deep co-scroll-container .content-wrapper{padding:0}#product_page_carousel #product_page_carousel_thumbs .carousel-thumb{opacity:1;cursor:pointer;transition:all .2s ease;padding:4px;border:1px solid #f6f5f4}#product_page_carousel #product_page_carousel_thumbs .carousel-thumb.active,#product_page_carousel #product_page_carousel_thumbs .carousel-thumb:hover{border-color:#22313c}#product_page_carousel #product_page_carousel_thumbs .carousel-thumb:not(:last-child){margin-right:10px}#product_page_carousel #product_page_carousel_thumbs .carousel-thumb img{height:68px}@media screen and (max-width: 650px){#product_page_carousel_thumbs{height:57px!important}#product_page_carousel_thumbs .carousel-thumb img{height:50px!important}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"]
|
|
165
223
|
},] }
|
|
166
224
|
];
|
|
167
225
|
ImageCarouselComponent.ctorParameters = () => [
|
|
168
226
|
{ type: ProductConnectorService },
|
|
169
227
|
{ type: ProductEventService },
|
|
170
228
|
{ type: ChangeDetectorRef },
|
|
171
|
-
{ type: DomSanitizer }
|
|
172
|
-
{ type: IconCacheService }
|
|
229
|
+
{ type: DomSanitizer }
|
|
173
230
|
];
|
|
174
231
|
ImageCarouselComponent.propDecorators = {
|
|
175
232
|
carousel: [{ type: ViewChild, args: ['carousel', { read: ElementRef },] }],
|
|
@@ -180,4 +237,4 @@ ImageCarouselComponent.propDecorators = {
|
|
|
180
237
|
gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
|
|
181
238
|
resizing: [{ type: HostBinding, args: ['class.resizing',] }]
|
|
182
239
|
};
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/image-carousel/image-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { CoDocument } from '@colijnit/mainapi/build/model/co-document';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport { Subscription } from 'rxjs';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\n\n@Component({\n  selector: 'app-image-carousel',\n  template: `\n    <div id=\"product_page_carousel\">\n      <div id=\"product_page_carousel_items\">\n        <co-loader [isShown]=\"showLoader\"></co-loader>\n        <div #carousel class=\"inner-carousel\">\n          <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\n          <div *ngIf=\"images[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\">\n            <img [src]=\"getImageSrc(images[0])\">\n          </div>\n          <div *ngFor=\"let image of images.slice(1); let index = index\" class=\"carousel-item\" [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\">\n            <img [src]=\"getImageSrc(image)\">\n          </div>\n          <div class=\"carousel-scroller-layer\" *ngIf=\"images && images.length > 1\">\n            <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\n            <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\n          </div>\n        </div>\n<!--\n        <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\n-->\n      </div>\n\n      <div id=\"product_page_carousel_thumbs\">\n        <co-scroll-container class=\"scroll-container\" *ngIf=\"images && images.length > 1\">\n          <div *ngFor=\"let image of images; let index = index\" class=\"carousel-thumb\" [class.active]=\"index === currentIndex\">\n            <img [src]=\"getImageSrc(image)\" (click)=\"handleThumbClick(index)\"/>\n          </div>\n        </co-scroll-container>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./image-carousel.component.scss']\n})\nexport class ImageCarouselComponent implements OnInit, OnDestroy {\n\n  public readonly icons: typeof IconEnum = IconEnum;\n\n  public showLoader: boolean = false;\n\n  @ViewChild('carousel', { read: ElementRef })\n  public carousel: ElementRef;\n\n  @Input()\n  public showRefresh: boolean = false;\n\n  @Input()\n  public set images(value: CoDocument[]) {\n    if (value && value.length > 0) {\n      this._images = this._filterValidImages(value);\n      this._loadImages();\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  @HostListener('window:resize')\n  public handleWindowResize(): void {\n    this.resizing = true;\n    this._scrollCarouselToIndex();\n    clearTimeout(this._resizeTimer);\n    this._resizeTimer = setTimeout(() => {\n      this.resizing = false;\n    }, 200);\n  }\n\n  @HostListener('swipeleft')\n  public gotoNextSlide(): void {\n    this.currentIndex++;\n  }\n\n  @HostListener('swiperight')\n  public gotoPrevSlide(): void {\n    this.currentIndex--;\n  }\n\n  public isCurrentIndex(index: number): boolean {\n    return this.currentIndex === index;\n  }\n\n  public get currentIndex(): number {\n    return this._currentIndex;\n  }\n\n  public set currentIndex(value: number) {\n    this._currentIndex = value;\n    this._scrollCarouselToIndex();\n  }\n\n  @HostBinding('class.resizing')\n  public resizing = false;\n\n  public get images(): CoDocument[] {\n    return this._images;\n  }\n\n  private _resizeTimer: any;\n\n  private _currentIndex = 0;\n\n  private _images = [];\n  private _subs: Subscription[] = [];\n\n  constructor(\n    private _ione: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _changeDetector: ChangeDetectorRef,\n    private _domSanitizer: DomSanitizer,\n    public iconCache: IconCacheService,\n  ) {\n    this._subs.push(\n      this._appEventService.onRenderStarted.subscribe(() => {\n        this.showLoader = true;\n      }),\n      this._appEventService.onDraftRenderImageReceived.subscribe((url: string) => {\n        if (this._images[0] instanceof CoDocument) {\n          this._images.unshift(url);\n        } else {\n          this._images[0] = url;\n        }\n        this.showLoader = false;\n      }),\n    );\n\n  }\n\n  ngOnInit() {\n  }\n\n  ngOnDestroy(): void {\n    this.carousel = undefined;\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  public handleThumbClick(index: number): void {\n    this.currentIndex = index;\n  }\n\n  public onForceRenderImage(): void {\n    this._appEventService.onForceRenderImage.next();\n  }\n\n  public getImageSrc(image: CoDocument | CustomEvent): SafeUrl {\n    let source = '';\n    if (image instanceof CoDocument) {\n      if (image.filePath) {\n        source = image.filePath;\n      } else {\n        source = image.documentBodyAsDataUri;\n      }\n    } else if (image.detail !== undefined) {\n      source = image.detail;\n    }\n\n    return this._domSanitizer.bypassSecurityTrustUrl(source);\n  }\n\n  private _filterValidImages(value: CoDocument[]): CoDocument[] {\n    if (!value) {\n      return [];\n    }\n    return value.filter(doc => {\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\n      return pattern.test(doc.fileName) || !!doc.filePath;\n    });\n  }\n\n  private _loadImages(): void {\n    if (this._images) {\n      this._images.forEach((i: CoDocument) => {\n        if (!i.documentBody && !i.filePath) {\n          this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\n            if (content) {\n              i.documentBody = content.documentContent;\n            }\n          });\n        }\n      });\n    }\n  }\n\n  private _scrollCarouselToIndex(): void {\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\n      if (this.carousel && this.carousel.nativeElement) {\n        this.carousel.nativeElement.scrollLeft = movePx;\n        // this.carousel.nativeElement.scrollTo({\n        //   left: movePx,\n        //   behavior: 'smooth'\n        // });\n      }\n    }\n  }\n\n}\n"]}
|
|
240
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/image-carousel/image-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  ViewChild\n} from '@angular/core';\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {Subscription} from 'rxjs';\nimport {IconEnum} from '../../enum/icon.enum';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\n\nexport class ImageViewModel {\n  public image: CoDocument | string;\n  public source: SafeUrl;\n  public originalSource: string;\n}\n\n@Component({\n  selector: 'app-image-carousel',\n  template: `\n      <div id=\"product_page_carousel\">\n          <div id=\"product_page_carousel_items\">\n              <co-loader [isShown]=\"true\" *ngIf=\"showLoader\"></co-loader>\n              <div #carousel class=\"inner-carousel\">\n                  <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\n                  <div *ngIf=\"imageViewModels[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\" (click)=\"handleShowImage(imageViewModels[0])\">\n                      <img [src]=\"imageViewModels[0].source\">\n                  </div>\n                  <div *ngFor=\"let imageViewModel of imageViewModels.slice(1); let index = index\" class=\"carousel-item\"\n                       [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\" (click)=\"handleShowImage(imageViewModel)\">\n                      <img [src]=\"imageViewModel.source\">\n                  </div>\n                  <div class=\"carousel-scroller-layer\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                      <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\n                      <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\n                  </div>\n              </div>\n              <!--\n                      <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\n              -->\n          </div>\n\n          <div id=\"product_page_carousel_thumbs\">\n              <co-scroll-container class=\"scroll-container\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                  <div *ngFor=\"let imageViewModel of imageViewModels; let index = index\" class=\"carousel-thumb\"\n                       [class.active]=\"index === currentIndex\">\n                      <img [src]=\"imageViewModel.source\" (click)=\"handleThumbClick(index)\"/>\n                  </div>\n              </co-scroll-container>\n          </div>\n      </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['./image-carousel.component.scss']\n})\nexport class ImageCarouselComponent implements OnDestroy {\n  @ViewChild('carousel', {read: ElementRef})\n  public carousel: ElementRef;\n\n  @Input()\n  public showRefresh: boolean = false;\n\n  @Input()\n  public set images(value: (CoDocument | string)[]) {\n    if (value && value.length > 0) {\n      this._images = this._filterValidImages(value);\n      this._loadAndRescaleImages();\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  public get images(): (CoDocument | string)[] {\n    return this._images;\n  }\n\n  @HostListener('window:resize')\n  public handleWindowResize(): void {\n    this.resizing = true;\n    this._scrollCarouselToIndex();\n    clearTimeout(this._resizeTimer);\n    this._resizeTimer = setTimeout(() => {\n      this.resizing = false;\n    }, 200);\n  }\n\n  @HostListener('swipeleft')\n  public gotoNextSlide(): void {\n    this.currentIndex++;\n  }\n\n  @HostListener('swiperight')\n  public gotoPrevSlide(): void {\n    this.currentIndex--;\n  }\n\n  public isCurrentIndex(index: number): boolean {\n    return this.currentIndex === index;\n  }\n\n  public get currentIndex(): number {\n    return this._currentIndex;\n  }\n\n  public set currentIndex(value: number) {\n    this._currentIndex = value;\n    this._scrollCarouselToIndex();\n  }\n\n  @HostBinding('class.resizing')\n  public resizing = false;\n\n  public imageViewModels: ImageViewModel[] = [];\n  public showLoader: boolean = false;\n\n  private _resizeTimer: any;\n  private _currentIndex = 0;\n  private _images: (CoDocument | string)[] = [];\n  private _subs: Subscription[] = [];\n\n  private _resizeCanvasHeight: number = 500;\n\n  constructor(\n    private _ione: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _changeDetector: ChangeDetectorRef,\n    private _domSanitizer: DomSanitizer\n  ) {\n    this._subs.push(\n      this._appEventService.onRenderStarted.subscribe(() => {\n        this.showLoader = true;\n        this._changeDetector.detectChanges();\n        setTimeout(() => {\n          this.showLoader = false;\n          this._changeDetector.detectChanges();\n        }, 10000);\n      }),\n      this._appEventService.onDraftRenderImageReceived.subscribe((event: CustomEvent) => {\n        if (event && event.detail) {\n          if (this._images[0] instanceof CoDocument) {\n            this._images.unshift(event.detail);\n          } else {\n            this._images[0] = event.detail;\n          }\n          this._loadAndRescaleImages();\n        }\n        this.showLoader = false;\n        this._changeDetector.detectChanges();\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.carousel = undefined;\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  public handleThumbClick(index: number): void {\n    this.currentIndex = index;\n  }\n\n  public onForceRenderImage(): void {\n    this._appEventService.onForceRenderImage.next();\n  }\n\n  public handleShowImage(imageViewModel: ImageViewModel): void {\n    if (imageViewModel && imageViewModel.originalSource) {\n      let popupWindow: Window = window.open('', 'Image zoom', 'width=600,height=400');\n      // Set the content of the popup window\n      popupWindow.document.write('<html><head><title>Image zoom</title></head><body>');\n      popupWindow.document.write(`<img src=${imageViewModel.originalSource} alt=\"Image\" style=\"width:100%; height:auto;\">`);\n      popupWindow.document.write('</body></html>');\n      // Close the document to render the popup window\n      popupWindow.document.close();\n    }\n  }\n\n  private _filterValidImages(value: (CoDocument | string)[]): (CoDocument | string)[] {\n    if (!value) {\n      return [];\n    }\n    return value.filter((doc: CoDocument | string) => {\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\n      return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);\n    });\n  }\n\n  private _loadAndRescaleImages(): void {\n    this.imageViewModels.length = 0;\n    if (this._images) {\n      this._images.forEach((i: CoDocument | string) => {\n        let imageViewModel = new ImageViewModel();\n        imageViewModel.image = i;\n        if (typeof i === 'string') { // is a rendered image coming from configurator\n          this._resizeAndSanitizeSource(i, imageViewModel);\n        } else {\n          if (i.filePath) {\n            this._resizeAndSanitizeSource(i.filePath, imageViewModel);\n          } else if (i.documentBody) {\n            this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n          } else {\n            this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\n              if (content) {\n                i.documentBody = content.documentContent;\n                this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n                this._changeDetector.detectChanges();\n              }\n            });\n          }\n        }\n        this.imageViewModels.push(imageViewModel);\n        this._changeDetector.detectChanges();\n      });\n    }\n  }\n\n  private _resizeAndSanitizeSource(source: string, imageViewModel: ImageViewModel): void {\n    const resizeCanvas: HTMLCanvasElement = document.createElement('canvas');\n    const resizeCanvasContext: CanvasRenderingContext2D = resizeCanvas.getContext('2d');\n    const resizeImage: HTMLImageElement = document.createElement('img');\n    resizeImage.onload = async () => {\n      resizeCanvasContext.imageSmoothingEnabled = true;\n      resizeCanvasContext.imageSmoothingQuality = 'high';\n      // Get the original image dimensions\n      const originalWidth = resizeImage.width;\n      const originalHeight = resizeImage.height;\n\n      // Calculate the aspect ratio\n      const aspectRatio = originalWidth / originalHeight;\n\n      // Calculate the new width and height while maintaining the aspect ratio\n      let newWidth: number = this._resizeCanvasHeight;\n      let newHeight: number = this._resizeCanvasHeight;\n\n      if (originalWidth > originalHeight) {\n        newHeight = this._resizeCanvasHeight / aspectRatio;\n      } else {\n        newWidth = this._resizeCanvasHeight * aspectRatio;\n      }\n\n      // Set the canvas size to the new width and height\n      resizeCanvas.width = newWidth;\n      resizeCanvas.height = newHeight;\n\n      const imageWidth: number = this._resizeCanvasHeight * (resizeImage.height / resizeImage.width);\n      resizeCanvasContext.drawImage(resizeImage, 0, 0, newWidth, newHeight);\n      const resizedSource = resizeCanvas.toDataURL('image/jpeg');\n\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\n      imageViewModel.originalSource = source;\n    };\n    // @ts-ignore\n    resizeImage.src = source;\n  }\n\n  private _scrollCarouselToIndex(): void {\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\n      if (this.carousel && this.carousel.nativeElement) {\n        this.carousel.nativeElement.scrollLeft = movePx;\n        // this.carousel.nativeElement.scrollTo({\n        //   left: movePx,\n        //   behavior: 'smooth'\n        // });\n      }\n    }\n  }\n\n}\n"]}
|
|
@@ -198,7 +198,7 @@ ProductPageComponent.decorators = [
|
|
|
198
198
|
transition('void => *', animate('200ms ease-in-out')),
|
|
199
199
|
])
|
|
200
200
|
],
|
|
201
|
-
styles: [".page-wrapper{font-family:iOneMontserrat;font-size:12px;display:flex;flex-direction:column;max-width:1400px;padding:0 15px;margin:0 auto}.page-wrapper-content{display:flex;flex-direction:row;margin:40px 0}.page-wrapper-content:first-child{margin-top:0}.page-wrapper-content.no-top-margin{margin-top:0}.page-wrapper-left{display:flex;width:55%;flex-direction:column}.page-wrapper-right{display:flex;width:45%;flex-direction:column}.page-wrapper-full{display:flex;width:100%;flex-direction:column}.page-wrapper-66{display:flex;width:60%;flex-direction:column}.page-wrapper-33{display:flex;width:40%;flex-direction:column}.threed-selections{display:none}.threed-selections.show-selections{display:block}.threed-selections ::ng-deep .rp-lite-selector .rp-answers-slideout ::ng-deep co-slideout{width:480px;z-index:3}.product-action-buttons{position:relative}.product-action-buttons.full-screen{z-index:10}.product-image-container{grid-column:1/7;grid-row:1/6;position:relative}.product-page-block-selector-type{width:auto;position:absolute;top:10px;right:10px;z-index:2}.product-page-block-image{box-sizing:border-box;width:100%;z-index:1;position:relative}.product-page-block-image .threed-configurator{border:1px solid #efefef}.product-page-block-image .threed-configurator .layer .viewer canvas{height:100%;width:100%}.product-page-block-image .threed-configurator ::ng-deep .rp-element-toolbar{top:30px}.product-page-block-image app-image-carousel.show-animated,.product-page-block-image threed-configurator.show-animated{opacity:1;z-index:0;transition:all .2s ease-in-out}.product-page-block-image .fullscreen-button{cursor:pointer;height:50px;width:50px;position:absolute;left:30px;z-index:100;top:30px}.product-page-block-image.full{grid-column:1/11;grid-row:2/span 10;z-index:3}.product-page-block-description{grid-column:7/12;grid-row:1/1}.product-page-block-additional{width:100%}.product-page-block-additional-description{width:100%}.product-page-block-price{grid-column:1/3;grid-row:2/2;align-self:center}.product-page-block-price.full{grid-column:1/5}.product-page-block-addtocart{grid-column:3/5;grid-row:2/2;align-self:center;padding-top:30px!important}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button:hover div.rippler{background:#f6f5f4}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button ::ng-deep co-icon{position:relative;z-index:2}.product-page-block-addtocart ::ng-deep co-button.cart-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-button.cart-button:hover{background:#74B77F}.addtocart-reserved{grid-column:1/3;grid-row:3/3}.product-page-block-stock{grid-column:1/3;grid-row:4/4}.product-page-block-delivery{grid-column:3/5;grid-row:4/4}::ng-deep co-scroll-container{overflow:hidden;position:relative}::ng-deep co-scroll-container .content-wrapper{padding:0}::ng-deep co-scroll-container .scroll-layer{left:0;top:0}::ng-deep co-scroll-container .scroll-layer .scroller{width:34px;height:34px;border-radius:36px;background:#fff;cursor:pointer;box-shadow:0 0 5px #0003}::ng-deep co-scroll-container .scroll-layer .scroller:hover{background:#f6f5f4}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll{left:5px}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll:before{border-width:0 3px 3px 0;padding:4px;margin-left:13px;margin-top:11px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll{right:5px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll:after{border-width:0 3px 3px 0;padding:4px;margin-left:9px;margin-top:11px}.product-page-block-variants{margin:20px 0 0}.product-page-block-variants ::ng-deep app-product-related>div{display:flex;grid-gap:15px;gap:15px;align-items:center;border-top:1px solid #f6f5f4;padding:5px 0 7px 15px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep app-header h3{font-size:14px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container{width:320px;max-width:100%;padding:0 16px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller{width:26px;height:26px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll{left:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll:before{border-width:0 2px 2px 0;margin-left:9px;margin-top:9px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll{right:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll:after{border-width:0 2px 2px 0;margin-left:6px;margin-top:9px}.product-page-block-variants ::ng-deep co-tile.small{min-width:50px!important;max-width:50px!important;border:1px solid #f6f5f4;margin:0 10px 0 0;border-radius:4px}.product-page-block-variants ::ng-deep co-tile.small:hover{border-color:#22313c}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper{padding:0}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-top{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image{height:40px!important;padding:5px;margin-bottom:10px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper .no-image{width:40px;height:40px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper span{display:none!important}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-bottom{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-extra-bottom{display:none}.product-page-block-alternatives ::ng-deep .article-wrapper{margin:0 20px 0 0}.product-page-block-alternatives ::ng-deep .article-wrapper:last-child{margin:0}.product-page-block-alternatives ::ng-deep co-tile{cursor:pointer;transition:all .14s ease-out;border:1px solid transparent;border-bottom-color:#f6f5f4;padding:15px 10px 0;width:319px;max-width:none;min-width:0;box-sizing:border-box}.product-page-block-alternatives ::ng-deep co-tile:hover{box-shadow:none;border-color:#f6f5f4}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper div.image co-image{transform:scale(1.05)}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper .tile-bottom{margin:0}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-extra-bottom .main .description{text-decoration:underline}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper{padding:0;position:relative;outline:none;overflow:hidden}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-top{position:absolute;left:0;top:0;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image{position:relative;padding:1px;display:flex;align-items:center;justify-content:center;overflow:hidden;max-width:250px;margin:0 auto 10px;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image:after{content:\"\";padding:100% 0 0;float:left;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image co-image{position:absolute;left:0;top:0;overflow:hidden;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;z-index:-1;transition:all .2s ease}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image .no-image-wrapper{position:absolute;display:flex;left:50%;top:50%;margin:-48px 0 0 -54px;flex-direction:column;align-items:center;opacity:.25}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom{transition:all .2s ease;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button{margin:0 0 5px!important;width:36px;height:36px;border:1px solid #22313C;cursor:pointer;border-radius:4px;padding:0!important;font-size:0}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button co-icon{width:32px;height:32px;margin:0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom{outline:none;padding:15px 0;background:transparent!important;min-height:60px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main{padding:0 10px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .description{font-size:15px;font-weight:bold;margin:0 0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .price{font-size:16px;margin:15px 0 0;font-weight:bold;color:#2b60a7}.product-page-block-additional-information{grid-column:1/6;grid-row:4/4}.product-page-block-properties{grid-column:7/10;grid-row:3/3}.product-page-block-related-articles{grid-column:2/6;grid-row:4/4}.product-page-block-alternative-articles{grid-column:6/10;grid-row:4/4}.product-page-block-documents{grid-column:2/6;grid-row:5/5}.product-page-block-symbols{grid-column:6/10;grid-row:5/5}@media screen and (max-width: 950px){.default-padding{padding-top:20px;padding-bottom:20px}.m-padding{padding-top:15px;padding-bottom:15px}.s-padding{padding-top:5px;padding-bottom:5px}.page-wrapper{max-width:650px}.page-wrapper .page-wrapper-content{flex-direction:column;margin:30px 0}.page-wrapper .page-wrapper-content .page-wrapper-left{width:100%}.page-wrapper .page-wrapper-content .page-wrapper-right{width:100%}.product-page-block-alternatives ::ng-deep co-tile{width:284px!important}}@media screen and (max-width: 650px){[class*=-padding]{padding-left:0!important;padding-right:0!important}.product-page-block-addtocart ::ng-deep co-number-picker co-button{height:38px!important}.product-page-block-addtocart ::ng-deep co-number-picker co-input-text{height:38px!important;width:36px!important}.product-page-block-addtocart ::ng-deep co-button.cart-button{height:40px;font-size:13px}}\n"]
|
|
201
|
+
styles: [".page-wrapper{font-family:iOneMontserrat;font-size:12px;display:flex;flex-direction:column;max-width:1400px;padding:0 15px;margin:0 auto}.page-wrapper-content{display:flex;flex-direction:row;margin:40px 0}.page-wrapper-content:first-child{margin-top:0}.page-wrapper-content.no-top-margin{margin-top:0}.page-wrapper-left{display:flex;width:55%;flex-direction:column}.page-wrapper-right{display:flex;width:45%;flex-direction:column}.page-wrapper-full{display:flex;width:100%;flex-direction:column}.page-wrapper-66{display:flex;width:60%;flex-direction:column}.page-wrapper-33{display:flex;width:40%;flex-direction:column}.threed-selections{display:none}.threed-selections.show-selections{display:block}.threed-selections ::ng-deep .rp-lite-selector .rp-answers-slideout ::ng-deep co-slideout{width:480px;z-index:3}.threed-selections ::ng-deep .co-summary-line{cursor:pointer}.product-action-buttons{position:relative}.product-action-buttons.full-screen{z-index:10}.product-image-container{grid-column:1/7;grid-row:1/6;position:relative}.product-page-block-selector-type{width:auto;position:absolute;top:10px;right:10px;z-index:2}.product-page-block-image{box-sizing:border-box;width:100%;z-index:1;position:relative}.product-page-block-image .threed-configurator{border:1px solid #efefef}.product-page-block-image .threed-configurator .layer .viewer canvas{height:100%;width:100%}.product-page-block-image .threed-configurator ::ng-deep .rp-element-toolbar{top:30px}.product-page-block-image app-image-carousel.show-animated,.product-page-block-image threed-configurator.show-animated{opacity:1;z-index:0;transition:all .2s ease-in-out}.product-page-block-image .fullscreen-button{cursor:pointer;height:50px;width:50px;position:absolute;left:30px;z-index:100;top:30px}.product-page-block-image.full{grid-column:1/11;grid-row:2/span 10;z-index:3}.product-page-block-description{grid-column:7/12;grid-row:1/1}.product-page-block-additional{width:100%}.product-page-block-additional-description{width:100%}.product-page-block-price{grid-column:1/3;grid-row:2/2;align-self:center}.product-page-block-price.full{grid-column:1/5}.product-page-block-addtocart{grid-column:3/5;grid-row:2/2;align-self:center;padding-top:30px!important}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button:hover div.rippler{background:#f6f5f4}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button ::ng-deep co-icon{position:relative;z-index:2}.product-page-block-addtocart ::ng-deep co-button.cart-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-button.cart-button:hover{background:#74B77F}.addtocart-reserved{grid-column:1/3;grid-row:3/3}.product-page-block-stock{grid-column:1/3;grid-row:4/4}.product-page-block-delivery{grid-column:3/5;grid-row:4/4}::ng-deep co-scroll-container{overflow:hidden;position:relative}::ng-deep co-scroll-container .content-wrapper{padding:0}::ng-deep co-scroll-container .scroll-layer{left:0;top:0}::ng-deep co-scroll-container .scroll-layer .scroller{width:34px;height:34px;border-radius:36px;background:#fff;cursor:pointer;box-shadow:0 0 5px #0003}::ng-deep co-scroll-container .scroll-layer .scroller:hover{background:#f6f5f4}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll{left:5px}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll:before{border-width:0 3px 3px 0;padding:4px;margin-left:13px;margin-top:11px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll{right:5px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll:after{border-width:0 3px 3px 0;padding:4px;margin-left:9px;margin-top:11px}.product-page-block-variants{margin:20px 0 0}.product-page-block-variants ::ng-deep app-product-related>div{display:flex;grid-gap:15px;gap:15px;align-items:center;border-top:1px solid #f6f5f4;padding:5px 0 7px 15px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep app-header h3{font-size:14px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container{width:320px;max-width:100%;padding:0 16px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller{width:26px;height:26px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll{left:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll:before{border-width:0 2px 2px 0;margin-left:9px;margin-top:9px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll{right:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll:after{border-width:0 2px 2px 0;margin-left:6px;margin-top:9px}.product-page-block-variants ::ng-deep co-tile.small{min-width:50px!important;max-width:50px!important;border:1px solid #f6f5f4;margin:0 10px 0 0;border-radius:4px}.product-page-block-variants ::ng-deep co-tile.small:hover{border-color:#22313c}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper{padding:0}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-top{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image{height:40px!important;padding:5px;margin-bottom:10px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper .no-image{width:40px;height:40px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper span{display:none!important}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-bottom{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-extra-bottom{display:none}.product-page-block-alternatives ::ng-deep .article-wrapper{margin:0 20px 0 0}.product-page-block-alternatives ::ng-deep .article-wrapper:last-child{margin:0}.product-page-block-alternatives ::ng-deep co-tile{cursor:pointer;transition:all .14s ease-out;border:1px solid transparent;border-bottom-color:#f6f5f4;padding:15px 10px 0;width:319px;max-width:none;min-width:0;box-sizing:border-box}.product-page-block-alternatives ::ng-deep co-tile:hover{box-shadow:none;border-color:#f6f5f4}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper div.image co-image{transform:scale(1.05)}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper .tile-bottom{margin:0}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-extra-bottom .main .description{text-decoration:underline}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper{padding:0;position:relative;outline:none;overflow:hidden}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-top{position:absolute;left:0;top:0;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image{position:relative;padding:1px;display:flex;align-items:center;justify-content:center;overflow:hidden;max-width:250px;margin:0 auto 10px;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image:after{content:\"\";padding:100% 0 0;float:left;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image co-image{position:absolute;left:0;top:0;overflow:hidden;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;z-index:-1;transition:all .2s ease}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image .no-image-wrapper{position:absolute;display:flex;left:50%;top:50%;margin:-48px 0 0 -54px;flex-direction:column;align-items:center;opacity:.25}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom{transition:all .2s ease;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button{margin:0 0 5px!important;width:36px;height:36px;border:1px solid #22313C;cursor:pointer;border-radius:4px;padding:0!important;font-size:0}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button co-icon{width:32px;height:32px;margin:0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom{outline:none;padding:15px 0;background:transparent!important;min-height:60px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main{padding:0 10px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .description{font-size:15px;font-weight:bold;margin:0 0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .price{font-size:16px;margin:15px 0 0;font-weight:bold;color:#2b60a7}.product-page-block-additional-information{grid-column:1/6;grid-row:4/4}.product-page-block-properties{grid-column:7/10;grid-row:3/3}.product-page-block-related-articles{grid-column:2/6;grid-row:4/4}.product-page-block-alternative-articles{grid-column:6/10;grid-row:4/4}.product-page-block-documents{grid-column:2/6;grid-row:5/5}.product-page-block-symbols{grid-column:6/10;grid-row:5/5}@media screen and (max-width: 950px){.default-padding{padding-top:20px;padding-bottom:20px}.m-padding{padding-top:15px;padding-bottom:15px}.s-padding{padding-top:5px;padding-bottom:5px}.page-wrapper{max-width:650px}.page-wrapper .page-wrapper-content{flex-direction:column;margin:30px 0}.page-wrapper .page-wrapper-content .page-wrapper-left{width:100%}.page-wrapper .page-wrapper-content .page-wrapper-right{width:100%}.product-page-block-alternatives ::ng-deep co-tile{width:284px!important}}@media screen and (max-width: 650px){[class*=-padding]{padding-left:0!important;padding-right:0!important}.product-page-block-addtocart ::ng-deep co-number-picker co-button{height:38px!important}.product-page-block-addtocart ::ng-deep co-number-picker co-input-text{height:38px!important;width:36px!important}.product-page-block-addtocart ::ng-deep co-button.cart-button{height:40px;font-size:13px}}\n"]
|
|
202
202
|
},] }
|
|
203
203
|
];
|
|
204
204
|
ProductPageComponent.ctorParameters = () => [
|
|
@@ -3,8 +3,8 @@ export class Version {
|
|
|
3
3
|
constructor() {
|
|
4
4
|
this.name = "@colijnit/product";
|
|
5
5
|
this.description = "Product detail page project for iOne";
|
|
6
|
-
this.symVer = "256.1.
|
|
7
|
-
this.publishDate = "
|
|
6
|
+
this.symVer = "256.1.6";
|
|
7
|
+
this.publishDate = "14-3-2025 14:06:38";
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9wcm9kdWN0LXZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBQ1MsU0FBSSxHQUFHLG1CQUFtQixDQUFDO1FBQzNCLGdCQUFXLEdBQUcsc0NBQXNDLENBQUM7UUFDckQsV0FBTSxHQUFHLFNBQVMsQ0FBQztRQUNuQixnQkFBVyxHQUFHLG9CQUFvQixDQUFDO0lBQzVDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRoaXMgZmlsZSBpcyBkeW5hbWljYWxseSBjcmVhdGVkLCBkbyBub3QgY2hhbmdlIHRoaXNcbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIG5hbWUgPSBcIkBjb2xpam5pdC9wcm9kdWN0XCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiUHJvZHVjdCBkZXRhaWwgcGFnZSBwcm9qZWN0IGZvciBpT25lXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1Ni4xLjZcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCIxNC0zLTIwMjUgMTQ6MDY6MzhcIjtcbn0iXX0=
|
|
@@ -21,4 +21,4 @@ ProductEventService.decorators = [
|
|
|
21
21
|
{ type: Directive },
|
|
22
22
|
{ type: Injectable }
|
|
23
23
|
];
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1ldmVudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwcC9zZXJ2aWNlL3Byb2R1Y3QtZXZlbnQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBVTdCLE1BQU0sT0FBTyxtQkFBbUI7SUFGaEM7UUFJUyxnQkFBVyxHQUErRSxJQUFJLE9BQU8sRUFBcUUsQ0FBQztRQUMzSyx1QkFBa0IsR0FBK0IsSUFBSSxPQUFPLEVBQXFCLENBQUM7UUFDbEYsaUJBQVksR0FBb0IsSUFBSSxPQUFPLEVBQVUsQ0FBQztRQUN0RCx1QkFBa0IsR0FBa0IsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUN4RCxzQkFBaUIsR0FBNkIsSUFBSSxPQUFPLEVBQW1CLENBQUM7UUFDN0UseUJBQW9CLEdBQXlCLElBQUksT0FBTyxFQUFlLENBQUM7UUFDeEUsb0JBQWUsR0FBb0IsSUFBSSxPQUFPLEVBQVUsQ0FBQztRQUN6RCxvQkFBZSxHQUFrQixJQUFJLE9BQU8sRUFBUSxDQUFDO1FBQ3JELDBCQUFxQixHQUFvQixJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQy9ELCtCQUEwQixHQUF5QixJQUFJLE9BQU8sRUFBZSxDQUFDO1FBQzlFLDBCQUFxQixHQUFvQixJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQy9ELDJCQUFzQixHQUFvQixJQUFJLE9BQU8sRUFBVSxDQUFDO1FBQ2hFLGlCQUFZLEdBQWlDLElBQUksT0FBTyxFQUF1QixDQUFDO0lBQ3pGLENBQUM7OztZQWpCQSxTQUFTO1lBQ1QsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBJbmplY3RhYmxlLCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQge0FydGljbGVMaXN0T2JqZWN0fSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLWxpc3Qtb2JqZWN0JztcclxuaW1wb3J0IHtTZWxlY3Rpb259IGZyb20gJ0Bjb2xpam5pdC9hcnRpY2xlYXBpL2J1aWxkL21vZGVsL3NlbGVjdGlvbic7XHJcbmltcG9ydCB7QXJ0aWNsZVF1aWNrU2VsfSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLXF1aWNrLXNlbCc7XHJcbmltcG9ydCB7QXJ0aWNsZUV4dGVuZGVkfSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLWV4dGVuZGVkLmJvJztcclxuaW1wb3J0IHtBcnRpY2xlTGlzdE9iamVjdEV4dGVuZGVkfSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLWxpc3Qtb2JqZWN0LWV4dGVuZGVkLmJvJztcclxuaW1wb3J0IHtWYWxpZGF0aW9uTWVzc2FnZX0gZnJvbSAnQGNvbGlqbml0L2lvbmVjb25uZWN0b3IvYnVpbGQvbW9kZWwvdmFsaWRhdGlvbi1tZXNzYWdlJztcclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBQcm9kdWN0RXZlbnRTZXJ2aWNlIHtcclxuXHJcbiAgcHVibGljIG9uQWRkVG9DYXJ0OiBTdWJqZWN0PHsgYXJ0aWNsZTogc3RyaW5nIHwgQXJ0aWNsZUxpc3RPYmplY3RFeHRlbmRlZCwgcXVhbnRpdHk6IG51bWJlciB9PiA9IG5ldyBTdWJqZWN0PHsgYXJ0aWNsZTogc3RyaW5nIHwgQXJ0aWNsZUxpc3RPYmplY3RFeHRlbmRlZCwgcXVhbnRpdHk6IG51bWJlciB9PigpO1xyXG4gIHB1YmxpYyBvbkFsdGVybmF0aXZlQ2xpY2s6IFN1YmplY3Q8QXJ0aWNsZUxpc3RPYmplY3Q+ID0gbmV3IFN1YmplY3Q8QXJ0aWNsZUxpc3RPYmplY3Q+KCk7XHJcbiAgcHVibGljIG9uQWRkVG9RdW90ZTogU3ViamVjdDxzdHJpbmc+ID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xyXG4gIHB1YmxpYyBvbkZvcmNlUmVuZGVySW1hZ2U6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gIHB1YmxpYyBvbkFydGljbGVSZWNlaXZlZDogU3ViamVjdDxBcnRpY2xlUXVpY2tTZWw+ID0gbmV3IFN1YmplY3Q8QXJ0aWNsZVF1aWNrU2VsPigpO1xyXG4gIHB1YmxpYyBvblNlbGVjdGlvbnNSZWNlaXZlZDogU3ViamVjdDxTZWxlY3Rpb25bXT4gPSBuZXcgU3ViamVjdDxTZWxlY3Rpb25bXT4oKTtcclxuICBwdWJsaWMgb25JbWFnZVJlY2VpdmVkOiBTdWJqZWN0PHN0cmluZz4gPSBuZXcgU3ViamVjdDxzdHJpbmc+KCk7XHJcbiAgcHVibGljIG9uUmVuZGVyU3RhcnRlZDogU3ViamVjdDx2b2lkPiA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgcHVibGljIG9uUmVuZGVySW1hZ2VSZWNlaXZlZDogU3ViamVjdDxzdHJpbmc+ID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xyXG4gIHB1YmxpYyBvbkRyYWZ0UmVuZGVySW1hZ2VSZWNlaXZlZDogU3ViamVjdDxDdXN0b21FdmVudD4gPSBuZXcgU3ViamVjdDxDdXN0b21FdmVudD4oKTtcclxuICBwdWJsaWMgb25BcnRpY2xlSW5mb1JlY2VpdmVkOiBTdWJqZWN0PHN0cmluZz4gPSBuZXcgU3ViamVjdDxzdHJpbmc+KCk7XHJcbiAgcHVibGljIG9uVXBkYXRlUHJvZHVjdEluZm9UYWI6IFN1YmplY3Q8bnVtYmVyPiA9IG5ldyBTdWJqZWN0PG51bWJlcj4oKTtcclxuICBwdWJsaWMgZXJyb3JNZXNzYWdlOiBTdWJqZWN0PFZhbGlkYXRpb25NZXNzYWdlW10+ID0gbmV3IFN1YmplY3Q8VmFsaWRhdGlvbk1lc3NhZ2VbXT4oKTtcclxufVxyXG4iXX0=
|