@colijnit/product 258.1.5 → 258.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 +5 -0
- package/app/components/product-addtocart/product-addtocart.component.d.ts +5 -1
- package/app/components/product-page/product-page.component.d.ts +1 -0
- package/app/service/product-connector-adapter.service.d.ts +1 -0
- package/app/service/product-connector.service.d.ts +2 -0
- package/bundles/colijnit-product.umd.js +166 -67
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/colijnit-product-258.1.5.tgz +0 -0
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/image-carousel/image-carousel.component.js +82 -36
- package/esm2015/app/components/product-addtocart/product-addtocart.component.js +38 -8
- package/esm2015/app/components/product-info-tabs/product-info-tabs.component.js +2 -2
- package/esm2015/app/components/product-page/product-page.component.js +19 -6
- package/esm2015/app/product-version.js +3 -3
- package/esm2015/app/service/product-connector-adapter.service.js +9 -1
- package/esm2015/app/service/product-connector.service.js +5 -1
- package/fesm2015/colijnit-product.js +151 -51
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewChild } from '@angular/core';
|
|
3
2
|
import { CoDocument } from '@colijnit/mainapi/build/model/co-document';
|
|
4
3
|
import { ProductConnectorService } from '../../service/product-connector.service';
|
|
@@ -12,6 +11,7 @@ export class ImageCarouselComponent {
|
|
|
12
11
|
this._appEventService = _appEventService;
|
|
13
12
|
this._changeDetector = _changeDetector;
|
|
14
13
|
this._domSanitizer = _domSanitizer;
|
|
14
|
+
this.isPopupOpen = false;
|
|
15
15
|
this.showRefresh = false;
|
|
16
16
|
this.resizing = false;
|
|
17
17
|
this.imageViewModels = [];
|
|
@@ -41,6 +41,12 @@ export class ImageCarouselComponent {
|
|
|
41
41
|
this._changeDetector.detectChanges();
|
|
42
42
|
}));
|
|
43
43
|
}
|
|
44
|
+
// Close on ESC
|
|
45
|
+
onEsc() {
|
|
46
|
+
if (this.isPopupOpen) {
|
|
47
|
+
this.closePopup();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
44
50
|
set images(value) {
|
|
45
51
|
if (value && value.length > 0) {
|
|
46
52
|
this._images = this._filterValidImages(value);
|
|
@@ -87,15 +93,16 @@ export class ImageCarouselComponent {
|
|
|
87
93
|
}
|
|
88
94
|
handleShowImage(imageViewModel) {
|
|
89
95
|
if (imageViewModel && imageViewModel.originalSource) {
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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();
|
|
96
|
+
this.selectedImage = imageViewModel;
|
|
97
|
+
this.isPopupOpen = true;
|
|
98
|
+
this._changeDetector.markForCheck();
|
|
97
99
|
}
|
|
98
100
|
}
|
|
101
|
+
closePopup() {
|
|
102
|
+
this.isPopupOpen = false;
|
|
103
|
+
this.selectedImage = undefined;
|
|
104
|
+
this._changeDetector.markForCheck();
|
|
105
|
+
}
|
|
99
106
|
_filterValidImages(value) {
|
|
100
107
|
if (!value) {
|
|
101
108
|
return [];
|
|
@@ -138,38 +145,54 @@ export class ImageCarouselComponent {
|
|
|
138
145
|
}
|
|
139
146
|
_resizeAndSanitizeSource(source, imageViewModel) {
|
|
140
147
|
const resizeCanvas = document.createElement('canvas');
|
|
141
|
-
const
|
|
142
|
-
const
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
const
|
|
149
|
-
const
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
let newHeight = this._resizeCanvasHeight;
|
|
155
|
-
if (originalWidth > originalHeight) {
|
|
156
|
-
newHeight = this._resizeCanvasHeight / aspectRatio;
|
|
148
|
+
const ctx = resizeCanvas.getContext('2d');
|
|
149
|
+
const img = document.createElement('img');
|
|
150
|
+
img.crossOrigin = 'anonymous';
|
|
151
|
+
img.onload = () => {
|
|
152
|
+
ctx.imageSmoothingEnabled = true;
|
|
153
|
+
ctx.imageSmoothingQuality = 'high';
|
|
154
|
+
const ow = img.width;
|
|
155
|
+
const oh = img.height;
|
|
156
|
+
const aspect = ow / oh;
|
|
157
|
+
let newW = this._resizeCanvasHeight;
|
|
158
|
+
let newH = this._resizeCanvasHeight;
|
|
159
|
+
if (ow > oh) {
|
|
160
|
+
newH = this._resizeCanvasHeight / aspect;
|
|
157
161
|
}
|
|
158
162
|
else {
|
|
159
|
-
|
|
163
|
+
newW = this._resizeCanvasHeight * aspect;
|
|
160
164
|
}
|
|
161
|
-
|
|
162
|
-
resizeCanvas.
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
const
|
|
165
|
+
resizeCanvas.width = Math.round(newW);
|
|
166
|
+
resizeCanvas.height = Math.round(newH);
|
|
167
|
+
// Ensure transparent background before drawing
|
|
168
|
+
ctx.clearRect(0, 0, resizeCanvas.width, resizeCanvas.height);
|
|
169
|
+
ctx.drawImage(img, 0, 0, resizeCanvas.width, resizeCanvas.height);
|
|
170
|
+
const mime = this._detectPreferredMime(source);
|
|
171
|
+
const resizedSource = mime === 'image/jpeg'
|
|
172
|
+
? resizeCanvas.toDataURL('image/jpeg', 0.92) // only if original was JPEG
|
|
173
|
+
: resizeCanvas.toDataURL(mime); // PNG/WebP keep alpha
|
|
167
174
|
imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);
|
|
168
175
|
imageViewModel.originalSource = source;
|
|
169
176
|
this._changeDetector.detectChanges();
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
|
|
177
|
+
};
|
|
178
|
+
img.src = source;
|
|
179
|
+
}
|
|
180
|
+
_detectPreferredMime(source) {
|
|
181
|
+
// Data URI check
|
|
182
|
+
const m = source.match(/^data:(image\/[a-zA-Z+.-]+);base64,/);
|
|
183
|
+
if (m) {
|
|
184
|
+
const t = m[1].toLowerCase();
|
|
185
|
+
if (t === 'image/png' || t === 'image/webp' || t === 'image/jpeg')
|
|
186
|
+
return t;
|
|
187
|
+
}
|
|
188
|
+
const lower = source.toLowerCase();
|
|
189
|
+
if (lower.endsWith('.png'))
|
|
190
|
+
return 'image/png';
|
|
191
|
+
if (lower.endsWith('.webp'))
|
|
192
|
+
return 'image/webp';
|
|
193
|
+
if (lower.endsWith('.jpg') || lower.endsWith('.jpeg'))
|
|
194
|
+
return 'image/jpeg';
|
|
195
|
+
return 'image/png';
|
|
173
196
|
}
|
|
174
197
|
_scrollCarouselToIndex() {
|
|
175
198
|
if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {
|
|
@@ -219,9 +242,31 @@ ImageCarouselComponent.decorators = [
|
|
|
219
242
|
</co-scroll-container>
|
|
220
243
|
</div>
|
|
221
244
|
</div>
|
|
245
|
+
<!-- Modal (real popup) -->
|
|
246
|
+
<div
|
|
247
|
+
class="image-modal"
|
|
248
|
+
*ngIf="isPopupOpen"
|
|
249
|
+
(click)="closePopup()"
|
|
250
|
+
role="dialog"
|
|
251
|
+
aria-modal="true"
|
|
252
|
+
aria-label="Image preview"
|
|
253
|
+
>
|
|
254
|
+
<div class="image-modal__content" (click)="$event.stopPropagation()">
|
|
255
|
+
<button
|
|
256
|
+
class="image-modal__close"
|
|
257
|
+
type="button"
|
|
258
|
+
aria-label="Close"
|
|
259
|
+
(click)="closePopup()"
|
|
260
|
+
>
|
|
261
|
+
×
|
|
262
|
+
</button>
|
|
263
|
+
|
|
264
|
+
<img [src]="selectedImage?.originalSource" alt="Image preview" />
|
|
265
|
+
</div>
|
|
266
|
+
</div>
|
|
222
267
|
`,
|
|
223
268
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
224
|
-
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"]
|
|
269
|
+
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}.image-modal{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1000}.image-modal__content{position:relative;max-width:90vw;max-height:90vh}.image-modal__content img{max-width:90vw;max-height:90vh;-o-object-fit:contain;object-fit:contain;display:block}.image-modal__close{position:fixed;top:15px;right:30px;background:transparent;border:none;color:#fff;font-size:60px;line-height:1;cursor:pointer}@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"]
|
|
225
270
|
},] }
|
|
226
271
|
];
|
|
227
272
|
ImageCarouselComponent.ctorParameters = () => [
|
|
@@ -232,6 +277,7 @@ ImageCarouselComponent.ctorParameters = () => [
|
|
|
232
277
|
];
|
|
233
278
|
ImageCarouselComponent.propDecorators = {
|
|
234
279
|
carousel: [{ type: ViewChild, args: ['carousel', { read: ElementRef },] }],
|
|
280
|
+
onEsc: [{ type: HostListener, args: ['document:keydown.escape',] }],
|
|
235
281
|
showRefresh: [{ type: Input }],
|
|
236
282
|
images: [{ type: Input }],
|
|
237
283
|
handleWindowResize: [{ type: HostListener, args: ['window:resize',] }],
|
|
@@ -239,4 +285,4 @@ ImageCarouselComponent.propDecorators = {
|
|
|
239
285
|
gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
|
|
240
286
|
resizing: [{ type: HostBinding, args: ['class.resizing',] }]
|
|
241
287
|
};
|
|
242
|
-
//# 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.crossOrigin = 'anonymous';\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      this._changeDetector.detectChanges();\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"]}
|
|
288
|
+
//# 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      <!-- Modal (real popup) -->\n      <div\n        class=\"image-modal\"\n        *ngIf=\"isPopupOpen\"\n        (click)=\"closePopup()\"\n        role=\"dialog\"\n        aria-modal=\"true\"\n        aria-label=\"Image preview\"\n      >\n        <div class=\"image-modal__content\" (click)=\"$event.stopPropagation()\">\n          <button\n            class=\"image-modal__close\"\n            type=\"button\"\n            aria-label=\"Close\"\n            (click)=\"closePopup()\"\n          >\n            ×\n          </button>\n\n          <img [src]=\"selectedImage?.originalSource\" alt=\"Image preview\" />\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  public isPopupOpen = false;\n  public selectedImage?: ImageViewModel;\n\n  // Close on ESC\n  @HostListener('document:keydown.escape')\n  onEsc(): void {\n    if (this.isPopupOpen) {\n      this.closePopup();\n    }\n  }\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      this.selectedImage = imageViewModel;\n      this.isPopupOpen = true;\n      this._changeDetector.markForCheck();\n    }\n  }\n\n  public closePopup(): void {\n    this.isPopupOpen = false;\n    this.selectedImage = undefined;\n    this._changeDetector.markForCheck();\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 ctx = resizeCanvas.getContext('2d')!;\n    const img: HTMLImageElement = document.createElement('img');\n    img.crossOrigin = 'anonymous';\n\n    img.onload = () => {\n      ctx.imageSmoothingEnabled = true;\n      ctx.imageSmoothingQuality = 'high';\n\n      const ow = img.width;\n      const oh = img.height;\n      const aspect = ow / oh;\n\n      let newW = this._resizeCanvasHeight;\n      let newH = this._resizeCanvasHeight;\n      if (ow > oh) {\n        newH = this._resizeCanvasHeight / aspect;\n      } else {\n        newW = this._resizeCanvasHeight * aspect;\n      }\n\n      resizeCanvas.width = Math.round(newW);\n      resizeCanvas.height = Math.round(newH);\n\n      // Ensure transparent background before drawing\n      ctx.clearRect(0, 0, resizeCanvas.width, resizeCanvas.height);\n\n      ctx.drawImage(img, 0, 0, resizeCanvas.width, resizeCanvas.height);\n\n      const mime = this._detectPreferredMime(source);\n      const resizedSource =\n        mime === 'image/jpeg'\n          ? resizeCanvas.toDataURL('image/jpeg', 0.92) // only if original was JPEG\n          : resizeCanvas.toDataURL(mime);              // PNG/WebP keep alpha\n\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\n      imageViewModel.originalSource = source;\n      this._changeDetector.detectChanges();\n    };\n\n    img.src = source;\n  }\n\n  private _detectPreferredMime(source: string): 'image/png' | 'image/webp' | 'image/jpeg' {\n    // Data URI check\n    const m = source.match(/^data:(image\\/[a-zA-Z+.-]+);base64,/);\n    if (m) {\n      const t = m[1].toLowerCase();\n      if (t === 'image/png' || t === 'image/webp' || t === 'image/jpeg') return t as any;\n    }\n\n    const lower = source.toLowerCase();\n    if (lower.endsWith('.png')) return 'image/png';\n    if (lower.endsWith('.webp')) return 'image/webp';\n    if (lower.endsWith('.jpg') || lower.endsWith('.jpeg')) return 'image/jpeg';\n\n    return 'image/png';\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"]}
|
|
@@ -6,12 +6,14 @@ import { ProductConnectorService } from '../../service/product-connector.service
|
|
|
6
6
|
import { ProductEventService } from '../../service/product-event.service';
|
|
7
7
|
import { ConfiguratorStatisticsEnvironment } from '@colijnit/articleapi/build/model/configurator-statistics-environment';
|
|
8
8
|
import { ProductSettingsService } from '../../service/product-settings.service';
|
|
9
|
+
import { ProductConnectorAdapterService } from '../../service/product-connector-adapter.service';
|
|
9
10
|
export class ProductAddtocartComponent {
|
|
10
|
-
constructor(iconCache, _ioneControllerService, _appEventService, _settingsService) {
|
|
11
|
+
constructor(iconCache, _ioneControllerService, _appEventService, _settingsService, _productConnectorAdapterService) {
|
|
11
12
|
this.iconCache = iconCache;
|
|
12
13
|
this._ioneControllerService = _ioneControllerService;
|
|
13
14
|
this._appEventService = _appEventService;
|
|
14
15
|
this._settingsService = _settingsService;
|
|
16
|
+
this._productConnectorAdapterService = _productConnectorAdapterService;
|
|
15
17
|
this.icon = IconEnum;
|
|
16
18
|
this.createFrozenArticle = true;
|
|
17
19
|
this.configurable = false;
|
|
@@ -51,9 +53,14 @@ export class ProductAddtocartComponent {
|
|
|
51
53
|
return __awaiter(this, void 0, void 0, function* () {
|
|
52
54
|
if (this.createFrozenArticle) {
|
|
53
55
|
if (this.article.goodType === 'B') {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
56
|
+
if (this.article.isConfigurable) {
|
|
57
|
+
const article = yield this._getJSONFromArticleObject({ article: this.article, quantity: quantity });
|
|
58
|
+
if (article) {
|
|
59
|
+
this._appEventService.onAddToCart.next({ article: article, quantity: quantity });
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
yield this._handleGeneratedArticleDirectly(quantity);
|
|
57
64
|
}
|
|
58
65
|
}
|
|
59
66
|
else {
|
|
@@ -70,8 +77,15 @@ export class ProductAddtocartComponent {
|
|
|
70
77
|
}
|
|
71
78
|
}
|
|
72
79
|
else {
|
|
73
|
-
|
|
74
|
-
|
|
80
|
+
if (this.article.goodType === 'B') {
|
|
81
|
+
if (!this.article.isConfigurable) {
|
|
82
|
+
yield this._handleGeneratedArticleDirectly(quantity);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
const article = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);
|
|
87
|
+
this._appEventService.onAddToCart.next({ article: article, quantity: quantity });
|
|
88
|
+
}
|
|
75
89
|
}
|
|
76
90
|
});
|
|
77
91
|
}
|
|
@@ -80,6 +94,21 @@ export class ProductAddtocartComponent {
|
|
|
80
94
|
this._appEventService.onAddToQuote.next(yield this._getJSONFromArticleObject({ article: this.article, quantity: quantity }));
|
|
81
95
|
});
|
|
82
96
|
}
|
|
97
|
+
_handleGeneratedArticleDirectly(quantity) {
|
|
98
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
99
|
+
const generatedGoodId = yield this._getGeneratedArtDirectly(this.article.goodId);
|
|
100
|
+
if (generatedGoodId) {
|
|
101
|
+
const articleFull = yield this._productConnectorAdapterService.getArticleFullObject(generatedGoodId, true);
|
|
102
|
+
const article = this._ioneControllerService.convertArticleFullObjectToArticleExtended(articleFull);
|
|
103
|
+
this._appEventService.onAddToCart.next({ article: article, quantity: quantity });
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
_getGeneratedArtDirectly(goodId) {
|
|
108
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
109
|
+
return yield this._ioneControllerService.getGeneratedArtDirectly(goodId, true);
|
|
110
|
+
});
|
|
111
|
+
}
|
|
83
112
|
_getJSONFromArticleObject(article) {
|
|
84
113
|
return __awaiter(this, void 0, void 0, function* () {
|
|
85
114
|
const configuratorStatistics = new ConfiguratorStatisticsEnvironment();
|
|
@@ -134,7 +163,8 @@ ProductAddtocartComponent.ctorParameters = () => [
|
|
|
134
163
|
{ type: IconCacheService },
|
|
135
164
|
{ type: ProductConnectorService },
|
|
136
165
|
{ type: ProductEventService },
|
|
137
|
-
{ type: ProductSettingsService }
|
|
166
|
+
{ type: ProductSettingsService },
|
|
167
|
+
{ type: ProductConnectorAdapterService }
|
|
138
168
|
];
|
|
139
169
|
ProductAddtocartComponent.propDecorators = {
|
|
140
170
|
addToCartButton: [{ type: ViewChild, args: ['addtocartbutton', { read: ElementRef },] }],
|
|
@@ -152,4 +182,4 @@ ProductAddtocartComponent.propDecorators = {
|
|
|
152
182
|
addToQuoteClick: [{ type: Output }],
|
|
153
183
|
showRelatedPopup: [{ type: Output }]
|
|
154
184
|
};
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-addtocart.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-addtocart/product-addtocart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { ArticleQuantity } from '../../model/article-quantity.model';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport {ConfiguratorStatisticsEnvironment} from '@colijnit/articleapi/build/model/configurator-statistics-environment';\nimport {ProductSettingsService} from '../../service/product-settings.service';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\n\n@Component({\n  selector: 'app-product-addtocart',\n  template: `\n    <div class=\"atc-wrapper\">\n      <ng-container *ngIf=\"isReturn\">\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"-100\" horizontal></co-number-picker>\n      </ng-container>\n\n      <ng-container *ngIf=\"!isReturn\">\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"1\" horizontal></co-number-picker>\n      </ng-container>\n\n      <div class=\"button-wrapper\" *ngIf=\"configurable\">\n        <co-button class=\"configure-button\"\n                   [iconData]=\"iconCache.getIcon(icon.MagicWand)\"\n                   [label]=\"'CONFIGURE' | localize\"\n                   (onClick)=\"startConfiguration.emit()\"\n        ></co-button>\n      </div>\n      <div class=\"button-wrapper\" *ngIf=\"showAddToCart && !configurable\">\n        <co-button #addtocartbutton class=\"cart-button\"\n                   [iconData]=\"iconCache.getIcon(icon.AddToCartDrop)\"\n                   [label]=\"'SHOPPING_CART_IN' | localize\"\n                   (onClick)=\"handleAddToCartClick(quantity)\"\n        ></co-button>\n        <co-button class=\"cart-button quote\" *ngIf=\"showQuoteButton\"\n                   [iconData]=\"iconCache.getIcon(icon.Quote)\"\n                   [label]=\"'QUOTATION' | localize\"\n                   (onClick)=\"handleAddToQuoteClick(quantity)\"\n        ></co-button>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./product-addtocart.component.scss']\n})\nexport class ProductAddtocartComponent implements OnInit, OnDestroy {\n\n  public readonly icon: typeof IconEnum = IconEnum;\n\n  @ViewChild('addtocartbutton', { read: ElementRef })\n  public addToCartButton: ElementRef;\n\n  @Input()\n  public article: ArticleFullObject;\n\n  @Input()\n  public externalSource: ExternalSource;\n\n  @Input()\n  public createFrozenArticle: boolean = true;\n\n  @Input()\n  public configurable: boolean = false;\n\n  @Input()\n  public configuring: boolean = false;\n\n  @Input()\n  public showAddToCart: boolean = false;\n\n  @Input()\n  public isReturn: boolean = false;\n\n  @HostBinding('class.full-screen')\n  @Input()\n  public fullscreen: boolean = false;\n\n  @Input()\n  public set quantity(value: number) {\n    if (this.isReturn) {\n      if (this._quantity === 1) {\n        this._quantity = -1;\n      } else {\n        this._quantity = value\n      }\n    } else {\n      this._quantity = Math.max(1, value);\n    }\n  }\n\n  public get quantity(): number {\n    return this._quantity;\n  }\n\n  @Output()\n  public startConfiguration: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public addToCartClick: EventEmitter<number> = new EventEmitter<number>();\n\n  @Output()\n  public addToQuoteClick: EventEmitter<number> = new EventEmitter<number>();\n\n  @Output()\n  public showRelatedPopup: EventEmitter<boolean> = new EventEmitter<boolean>()\n\n  public showQuoteButton: boolean = false;\n\n  private _quantity = 1;\n\n  constructor(\n    public iconCache: IconCacheService,\n    private _ioneControllerService: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService\n    ) { }\n\n  ngOnInit() {\n  }\n\n  ngOnDestroy(): void {\n    this.addToCartButton = undefined;\n  }\n\n  public async handleAddToCartClick(quantity: number): Promise<void> {\n    if (this.createFrozenArticle) {\n      if (this.article.goodType === 'B') {\n        const article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\n        if (article) {\n          this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n        }\n      } else {\n        let article: ArticleListObjectExtended | string;\n        if (!!this.externalSource) {\n          article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\n        } else {\n          article = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\n        }\n        if (article) {\n          this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n        }\n      }\n    } else {\n      const article: ArticleListObjectExtended = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\n      this._appEventService.onAddToCart.next({ article: article, quantity: quantity });\n    }\n  }\n\n  public async handleAddToQuoteClick(quantity: number): Promise<void> {\n    this._appEventService.onAddToQuote.next(await this._getJSONFromArticleObject({article: this.article, quantity: quantity}));\n  }\n\n  private async _getJSONFromArticleObject(article: ArticleQuantity): Promise<string> {\n    const configuratorStatistics = new ConfiguratorStatisticsEnvironment();\n    configuratorStatistics.userType = 'iOneProductPage';\n    configuratorStatistics.transactionType = 'Sales';\n    configuratorStatistics.actionDomain = 'bundle';\n    configuratorStatistics.sessionId = this._settingsService.settings.session ? this._settingsService.settings.session.sessionId : 'unknown';\n    configuratorStatistics.webHost = window.location.host;\n    configuratorStatistics.bundleHost = window.location.host;\n    return await this._ioneControllerService.getJsonArticleFlatTree(\n        article.article.goodId, article.article.goodType, article.quantity, !!this.externalSource, true, configuratorStatistics);\n  }\n}\n"]}
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-addtocart.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-addtocart/product-addtocart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { ArticleQuantity } from '../../model/article-quantity.model';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport {ConfiguratorStatisticsEnvironment} from '@colijnit/articleapi/build/model/configurator-statistics-environment';\nimport {ProductSettingsService} from '../../service/product-settings.service';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\n\n@Component({\n  selector: 'app-product-addtocart',\n  template: `\n    <div class=\"atc-wrapper\">\n      <ng-container *ngIf=\"isReturn\">\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"-100\" horizontal></co-number-picker>\n      </ng-container>\n\n      <ng-container *ngIf=\"!isReturn\">\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"1\" horizontal></co-number-picker>\n      </ng-container>\n\n      <div class=\"button-wrapper\" *ngIf=\"configurable\">\n        <co-button class=\"configure-button\"\n                   [iconData]=\"iconCache.getIcon(icon.MagicWand)\"\n                   [label]=\"'CONFIGURE' | localize\"\n                   (onClick)=\"startConfiguration.emit()\"\n        ></co-button>\n      </div>\n      <div class=\"button-wrapper\" *ngIf=\"showAddToCart && !configurable\">\n        <co-button #addtocartbutton class=\"cart-button\"\n                   [iconData]=\"iconCache.getIcon(icon.AddToCartDrop)\"\n                   [label]=\"'SHOPPING_CART_IN' | localize\"\n                   (onClick)=\"handleAddToCartClick(quantity)\"\n        ></co-button>\n        <co-button class=\"cart-button quote\" *ngIf=\"showQuoteButton\"\n                   [iconData]=\"iconCache.getIcon(icon.Quote)\"\n                   [label]=\"'QUOTATION' | localize\"\n                   (onClick)=\"handleAddToQuoteClick(quantity)\"\n        ></co-button>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./product-addtocart.component.scss']\n})\nexport class ProductAddtocartComponent implements OnInit, OnDestroy {\n\n  public readonly icon: typeof IconEnum = IconEnum;\n\n  @ViewChild('addtocartbutton', { read: ElementRef })\n  public addToCartButton: ElementRef;\n\n  @Input()\n  public article: ArticleFullObject;\n\n  @Input()\n  public externalSource: ExternalSource;\n\n  @Input()\n  public createFrozenArticle: boolean = true;\n\n  @Input()\n  public configurable: boolean = false;\n\n  @Input()\n  public configuring: boolean = false;\n\n  @Input()\n  public showAddToCart: boolean = false;\n\n  @Input()\n  public isReturn: boolean = false;\n\n  @HostBinding('class.full-screen')\n  @Input()\n  public fullscreen: boolean = false;\n\n  @Input()\n  public set quantity(value: number) {\n    if (this.isReturn) {\n      if (this._quantity === 1) {\n        this._quantity = -1;\n      } else {\n        this._quantity = value\n      }\n    } else {\n      this._quantity = Math.max(1, value);\n    }\n  }\n\n  public get quantity(): number {\n    return this._quantity;\n  }\n\n  @Output()\n  public startConfiguration: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public addToCartClick: EventEmitter<number> = new EventEmitter<number>();\n\n  @Output()\n  public addToQuoteClick: EventEmitter<number> = new EventEmitter<number>();\n\n  @Output()\n  public showRelatedPopup: EventEmitter<boolean> = new EventEmitter<boolean>()\n\n  public showQuoteButton: boolean = false;\n\n  private _quantity = 1;\n\n  constructor(\n    public iconCache: IconCacheService,\n    private _ioneControllerService: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService,\n    private _productConnectorAdapterService: ProductConnectorAdapterService\n    ) { }\n\n  ngOnInit() {\n  }\n\n  ngOnDestroy(): void {\n    this.addToCartButton = undefined;\n  }\n\n  public async handleAddToCartClick(quantity: number): Promise<void> {\n    if (this.createFrozenArticle) {\n      if (this.article.goodType === 'B') {\n\n        if (this.article.isConfigurable) {\n          const article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\n          if (article) {\n            this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n          }\n        } else {\n          await this._handleGeneratedArticleDirectly(quantity);\n        }\n      } else {\n        let article: ArticleListObjectExtended | string;\n        if (!!this.externalSource) {\n          article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\n        } else {\n          article = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\n        }\n        if (article) {\n          this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n        }\n      }\n    } else {\n      if (this.article.goodType === 'B') {\n        if (!this.article.isConfigurable) {\n          await this._handleGeneratedArticleDirectly(quantity);\n        }\n      } else {\n        const article: ArticleListObjectExtended = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\n        this._appEventService.onAddToCart.next({ article: article, quantity: quantity });\n      }\n    }\n  }\n\n  public async handleAddToQuoteClick(quantity: number): Promise<void> {\n    this._appEventService.onAddToQuote.next(await this._getJSONFromArticleObject({article: this.article, quantity: quantity}));\n  }\n\n  private async _handleGeneratedArticleDirectly(quantity: number): Promise<void> {\n    const generatedGoodId: number = await this._getGeneratedArtDirectly(this.article.goodId);\n    if (generatedGoodId) {\n      const articleFull: ArticleFullObject = await this._productConnectorAdapterService.getArticleFullObject(generatedGoodId, true);\n      const article: ArticleListObjectExtended = this._ioneControllerService.convertArticleFullObjectToArticleExtended(articleFull);\n      this._appEventService.onAddToCart.next({article: article, quantity: quantity});\n    }\n  }\n\n  private async _getGeneratedArtDirectly(goodId: number): Promise<number> {\n    return await this._ioneControllerService.getGeneratedArtDirectly(goodId, true);\n  }\n\n  private async _getJSONFromArticleObject(article: ArticleQuantity): Promise<string> {\n    const configuratorStatistics = new ConfiguratorStatisticsEnvironment();\n    configuratorStatistics.userType = 'iOneProductPage';\n    configuratorStatistics.transactionType = 'Sales';\n    configuratorStatistics.actionDomain = 'bundle';\n    configuratorStatistics.sessionId = this._settingsService.settings.session ? this._settingsService.settings.session.sessionId : 'unknown';\n    configuratorStatistics.webHost = window.location.host;\n    configuratorStatistics.bundleHost = window.location.host;\n    return await this._ioneControllerService.getJsonArticleFlatTree(\n        article.article.goodId, article.article.goodType, article.quantity, !!this.externalSource, true, configuratorStatistics);\n  }\n}\n"]}
|
|
@@ -26,7 +26,7 @@ export class ProductInfoTabsComponent {
|
|
|
26
26
|
this.updateHeight(tabIndex);
|
|
27
27
|
}
|
|
28
28
|
updateHeight(tabIndex) {
|
|
29
|
-
if (this.tabContent.nativeElement.children.length > 0) {
|
|
29
|
+
if (this.tabContent && this.tabContent.nativeElement.children.length > 0) {
|
|
30
30
|
if (this.tabContent.nativeElement.children[tabIndex] !== undefined) {
|
|
31
31
|
this.activeTabHeight = this.tabContent.nativeElement.children[tabIndex].offsetHeight;
|
|
32
32
|
}
|
|
@@ -79,4 +79,4 @@ ProductInfoTabsComponent.propDecorators = {
|
|
|
79
79
|
tabContent: [{ type: ViewChild, args: ['tabContent',] }],
|
|
80
80
|
article: [{ type: Input }]
|
|
81
81
|
};
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1pbmZvLXRhYnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9jb21wb25lbnRzL3Byb2R1Y3QtaW5mby10YWJzL3Byb2R1Y3QtaW5mby10YWJzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBYyxLQUFLLEVBQWEsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3RHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBNkIxRSxNQUFNLE9BQU8sd0JBQXdCO0lBdUJuQyxZQUNVLGdCQUFxQztRQUFyQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQXFCO1FBckJ4QyxvQkFBZSxHQUFXLENBQUMsQ0FBQztRQUs1QixTQUFJLEdBQVUsRUFBRSxDQUFDO1FBYWhCLFVBQUssR0FBbUIsRUFBRSxDQUFDO1FBS2pDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtZQUN2RSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3RCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO0lBcEJELElBQ0ksT0FBTyxDQUFDLEtBQXdCO1FBQ2xDLElBQUksS0FBSyxFQUFFO1lBQ1QsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7WUFDM0IsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2xCLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDbkI7SUFDSCxDQUFDO0lBZUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVNLFNBQVMsQ0FBQyxRQUFnQjtRQUMvQixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztRQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFTSxZQUFZLENBQUMsUUFBZ0I7UUFDbEMsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3hFLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFLLFNBQVMsRUFBRTtnQkFDbEUsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDO2FBQ3RGO1NBQ0Y7SUFDSCxDQUFDO0lBRU8sVUFBVTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxhQUFhLEVBQUUsQ0FBQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7UUFFdEMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN6RixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO1NBQ3hDO1FBRUQsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNyRixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1NBQ3RDO0lBRUgsQ0FBQzs7O1lBMUZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsdUJBQXVCO2dCQUNqQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQlQ7O2FBRUY7OztZQTVCUSxtQkFBbUI7Ozt5QkFrQ3pCLFNBQVMsU0FBQyxZQUFZO3NCQU90QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIE9uRGVzdHJveSwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBcnRpY2xlRnVsbE9iamVjdCB9IGZyb20gJ0Bjb2xpam5pdC9hcnRpY2xlYXBpL2J1aWxkL21vZGVsL2FydGljbGUtZnVsbC1vYmplY3QnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBQcm9kdWN0RXZlbnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZS9wcm9kdWN0LWV2ZW50LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtcHJvZHVjdC1pbmZvLXRhYnMnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJ0YWItY29udGFpbmVyXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwidGFiLWhlYWRlclwiPlxuICAgICAgICA8YnV0dG9uICpuZ0Zvcj1cImxldCB0YWIgb2YgdGFiczsgbGV0IGkgPSBpbmRleFwiIGNsYXNzPVwidGFiLWhlYWRlci1idXR0b25cIiBbY2xhc3MuYWN0aXZlXT1cImFjdGl2ZVRhYiA9PT0gaVwiIFt0ZXh0Q29udGVudF09XCJ0YWIudGl0bGUgfCBsb2NhbGl6ZVwiIChjbGljayk9XCJ1cGRhdGVUYWIoaSlcIj48L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cInRhYi1jb250ZW50XCIgI3RhYkNvbnRlbnQgW3N0eWxlLmhlaWdodC5weF09XCIoYWN0aXZlVGFiSGVpZ2h0ID4gMCA/IGFjdGl2ZVRhYkhlaWdodCA6ICcnKVwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGFiLWNvbnRlbnQtaXRlbVwiICpuZ0Zvcj1cImxldCB0YWIgb2YgdGFiczsgbGV0IGkgPSBpbmRleFwiIFtjbGFzcy5hY3RpdmVdPVwiYWN0aXZlVGFiID09PSBpXCI+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImkgPT09IDBcIj5cbiAgICAgICAgICAgIDxhcHAtcHJvZHVjdC1hZGRpdGlvbmFsLWluZm8gY2xhc3M9XCJcIiBbYXJ0aWNsZV09XCJhcnRpY2xlT2JqZWN0XCIgW3Nob3dMYWJlbF09XCJmYWxzZVwiPjwvYXBwLXByb2R1Y3QtYWRkaXRpb25hbC1pbmZvPlxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJpID09PSAxXCI+XG4gICAgICAgICAgICA8YXBwLXByb2R1Y3QtcHJvcGVydGllcyBjbGFzcz1cIlwiIFthcnRpY2xlXT1cImFydGljbGVPYmplY3RcIiBbc2hvd0xhYmVsXT1cImZhbHNlXCI+PC9hcHAtcHJvZHVjdC1wcm9wZXJ0aWVzPlxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJpID09PSAyXCI+XG4gICAgICAgICAgICA8YXBwLXByb2R1Y3QtZG9jdW1lbnRzIFtzaG93TGFiZWxdPVwiZmFsc2VcIiBjbGFzcz1cIlwiICpuZ0lmPVwiYXJ0aWNsZU9iamVjdD8uZG9jdW1lbnRzICYmIGFydGljbGVPYmplY3Q/LmRvY3VtZW50cy5sZW5ndGggPiAwXCIgW2RvY3VtZW50c109XCJhcnRpY2xlT2JqZWN0Py5kb2N1bWVudHNcIj48L2FwcC1wcm9kdWN0LWRvY3VtZW50cz5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaSA9PT0gM1wiPlxuICAgICAgICAgICAgPGFwcC1wcm9kdWN0LXN5bWJvbHMgY2xhc3M9XCJcIiAqbmdJZj1cImFydGljbGVPYmplY3Q/LnN5bWJvbHMgJiYgYXJ0aWNsZU9iamVjdD8uc3ltYm9scy5sZW5ndGggPiAwXCIgW3N5bWJvbHNdPVwiYXJ0aWNsZU9iamVjdD8uc3ltYm9sc1wiPjwvYXBwLXByb2R1Y3Qtc3ltYm9scz5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vcHJvZHVjdC1pbmZvLXRhYnMuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0SW5mb1RhYnNDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuXG4gIHB1YmxpYyBhY3RpdmVUYWI6IG51bWJlcjtcbiAgcHVibGljIGFjdGl2ZVRhYkhlaWdodDogbnVtYmVyID0gMDtcblxuICBAVmlld0NoaWxkKCd0YWJDb250ZW50JylcbiAgcHVibGljIHRhYkNvbnRlbnQ6IEVsZW1lbnRSZWY7XG5cbiAgcHVibGljIHRhYnM6IGFueVtdID0gW107XG5cbiAgcHVibGljIGFydGljbGVPYmplY3Q6IEFydGljbGVGdWxsT2JqZWN0O1xuXG4gIEBJbnB1dCAoKVxuICBzZXQgYXJ0aWNsZSh2YWx1ZTogQXJ0aWNsZUZ1bGxPYmplY3QpIHtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuYXJ0aWNsZU9iamVjdCA9IHZhbHVlO1xuICAgICAgdGhpcy5fc2V0dXBUYWJzKCk7XG4gICAgICB0aGlzLnVwZGF0ZVRhYigwKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9zdWJzOiBTdWJzY3JpcHRpb25bXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgX2FwcEV2ZW50U2VydmljZTogUHJvZHVjdEV2ZW50U2VydmljZVxuICApIHtcbiAgICB0aGlzLl9zdWJzLnB1c2goXG4gICAgICB0aGlzLl9hcHBFdmVudFNlcnZpY2Uub25VcGRhdGVQcm9kdWN0SW5mb1RhYi5zdWJzY3JpYmUoKGluZGV4OiBudW1iZXIpID0+IHtcbiAgICAgICAgdGhpcy51cGRhdGVUYWIoaW5kZXgpO1xuICAgICAgICB0aGlzLnRhYkNvbnRlbnQubmF0aXZlRWxlbWVudC5zY3JvbGxJbnRvVmlldyh7IGJlaGF2aW9yOiAnc21vb3RoJyB9KTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX3N1YnMuZm9yRWFjaChzID0+IHMudW5zdWJzY3JpYmUoKSk7XG4gIH1cblxuICBwdWJsaWMgdXBkYXRlVGFiKHRhYkluZGV4OiBudW1iZXIpIHtcbiAgICB0aGlzLmFjdGl2ZVRhYiA9IHRhYkluZGV4O1xuICAgIHRoaXMudXBkYXRlSGVpZ2h0KHRhYkluZGV4KTtcbiAgfVxuXG4gIHB1YmxpYyB1cGRhdGVIZWlnaHQodGFiSW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgIGlmICh0aGlzLnRhYkNvbnRlbnQgJiYgdGhpcy50YWJDb250ZW50Lm5hdGl2ZUVsZW1lbnQuY2hpbGRyZW4ubGVuZ3RoID4gMCkge1xuICAgICAgaWYgKHRoaXMudGFiQ29udGVudC5uYXRpdmVFbGVtZW50LmNoaWxkcmVuW3RhYkluZGV4XSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHRoaXMuYWN0aXZlVGFiSGVpZ2h0ID0gdGhpcy50YWJDb250ZW50Lm5hdGl2ZUVsZW1lbnQuY2hpbGRyZW5bdGFiSW5kZXhdLm9mZnNldEhlaWdodDtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBwcml2YXRlIF9zZXR1cFRhYnMoKTogdm9pZCB7XG4gICAgdGhpcy50YWJzLnB1c2goeyB0aXRsZTogJ0RFU0NSSVBUSU9OJyB9KTtcbiAgICB0aGlzLnRhYnMucHVzaCh7IHRpdGxlOiAnRkVBVFVSRVMnIH0pO1xuXG4gICAgaWYgKHRoaXMuYXJ0aWNsZU9iamVjdC5kb2N1bWVudHMgIT09IHVuZGVmaW5lZCAmJiB0aGlzLmFydGljbGVPYmplY3QuZG9jdW1lbnRzLmxlbmd0aCA+IDApIHtcbiAgICAgIHRoaXMudGFicy5wdXNoKHsgdGl0bGU6ICdET1dOTE9BRFMnIH0pO1xuICAgIH1cblxuICAgIGlmICh0aGlzLmFydGljbGVPYmplY3Quc3ltYm9scyAhPT0gdW5kZWZpbmVkICYmIHRoaXMuYXJ0aWNsZU9iamVjdC5zeW1ib2xzLmxlbmd0aCA+IDApIHtcbiAgICAgIHRoaXMudGFicy5wdXNoKHsgdGl0bGU6ICdTWU1CT0xTJyB9KTtcbiAgICB9XG5cbiAgfVxuXG59XG4iXX0=
|