@colijnit/product 259.1.3 → 260.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/README.md +27 -27
  2. package/app/components/product-related/product-related.component.d.ts +2 -2
  3. package/app/style/product-globals.scss +183 -183
  4. package/bundles/colijnit-product.umd.js +37 -17
  5. package/bundles/colijnit-product.umd.js.map +1 -1
  6. package/colijnit-product.metadata.json +1 -1
  7. package/esm2015/app/components/core/header/header.component.js +8 -8
  8. package/esm2015/app/components/image-carousel/image-carousel.component.js +55 -55
  9. package/esm2015/app/components/product-additional-description/product-additional-description.component.js +8 -8
  10. package/esm2015/app/components/product-additional-info/product-additional-info.component.js +6 -6
  11. package/esm2015/app/components/product-addtocart/product-addtocart.component.js +31 -31
  12. package/esm2015/app/components/product-delivery/product-delivery.component.js +10 -10
  13. package/esm2015/app/components/product-description/product-description.component.js +6 -6
  14. package/esm2015/app/components/product-documents/product-documents.component.js +7 -7
  15. package/esm2015/app/components/product-info-tabs/product-info-tabs.component.js +23 -23
  16. package/esm2015/app/components/product-page/product-page.component.js +1 -1
  17. package/esm2015/app/components/product-price/product-price.component.js +12 -12
  18. package/esm2015/app/components/product-properties/product-properties.component.js +11 -11
  19. package/esm2015/app/components/product-related/product-related.component.js +30 -28
  20. package/esm2015/app/components/product-selector-type/product-selector-type.component.js +20 -20
  21. package/esm2015/app/components/product-stock/product-stock.component.js +10 -10
  22. package/esm2015/app/components/product-symbols/product-symbols.component.js +15 -15
  23. package/esm2015/app/enum/icon.enum.js +1 -1
  24. package/esm2015/app/ione-product.component.js +12 -12
  25. package/esm2015/app/ione-product.module.js +1 -1
  26. package/esm2015/app/model/icon.js +1 -1
  27. package/esm2015/app/product-version.js +3 -3
  28. package/fesm2015/colijnit-product.js +250 -248
  29. package/fesm2015/colijnit-product.js.map +1 -1
  30. package/package.json +6 -6
@@ -7,13 +7,13 @@ export class HeaderComponent {
7
7
  HeaderComponent.decorators = [
8
8
  { type: Component, args: [{
9
9
  selector: 'app-header',
10
- template: `
11
- <ng-container *ngIf="label">
12
- <div class="header-wrapper">
13
- <h3 [textContent]="label"></h3>
14
- <span *ngIf="amount" class="amount" [textContent]="'(' + amount + ')'"></span>
15
- </div>
16
- </ng-container>
10
+ template: `
11
+ <ng-container *ngIf="label">
12
+ <div class="header-wrapper">
13
+ <h3 [textContent]="label"></h3>
14
+ <span *ngIf="amount" class="amount" [textContent]="'(' + amount + ')'"></span>
15
+ </div>
16
+ </ng-container>
17
17
  `,
18
18
  styles: [".header-wrapper{display:flex;flex-direction:row;align-items:center}.header-wrapper .amount{margin-left:5px}\n"]
19
19
  },] }
@@ -23,4 +23,4 @@ HeaderComponent.propDecorators = {
23
23
  label: [{ type: Input }],
24
24
  amount: [{ type: Input }]
25
25
  };
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9jb3JlL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBY3pELE1BQU0sT0FBTyxlQUFlO0lBUTFCLGdCQUFnQixDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDOzs7WUF2QkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxZQUFZO2dCQUN0QixRQUFRLEVBQUU7Ozs7Ozs7R0FPVDs7YUFFRjs7OztvQkFHRSxLQUFLO3FCQUdMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWhlYWRlcicsXG4gIHRlbXBsYXRlOiBgXG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImxhYmVsXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiaGVhZGVyLXdyYXBwZXJcIj5cbiAgICAgICAgPGgzIFt0ZXh0Q29udGVudF09XCJsYWJlbFwiPjwvaDM+XG4gICAgICAgIDxzcGFuICpuZ0lmPVwiYW1vdW50XCIgY2xhc3M9XCJhbW91bnRcIiBbdGV4dENvbnRlbnRdPVwiJygnICsgYW1vdW50ICsgJyknXCI+PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2hlYWRlci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGxhYmVsOiBzdHJpbmc7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGFtb3VudDogbnVtYmVyO1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cblxufVxuIl19
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9jb3JlL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBY3pELE1BQU0sT0FBTyxlQUFlO0lBUTFCLGdCQUFnQixDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDOzs7WUF2QkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxZQUFZO2dCQUN0QixRQUFRLEVBQUU7Ozs7Ozs7R0FPVDs7YUFFRjs7OztvQkFHRSxLQUFLO3FCQUdMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWhlYWRlcicsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJsYWJlbFwiPlxyXG4gICAgICA8ZGl2IGNsYXNzPVwiaGVhZGVyLXdyYXBwZXJcIj5cclxuICAgICAgICA8aDMgW3RleHRDb250ZW50XT1cImxhYmVsXCI+PC9oMz5cclxuICAgICAgICA8c3BhbiAqbmdJZj1cImFtb3VudFwiIGNsYXNzPVwiYW1vdW50XCIgW3RleHRDb250ZW50XT1cIicoJyArIGFtb3VudCArICcpJ1wiPjwvc3Bhbj5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuICBgLFxyXG4gIHN0eWxlVXJsczogWycuL2hlYWRlci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhbW91bnQ6IG51bWJlcjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG5cclxufVxyXG4iXX0=
@@ -210,60 +210,60 @@ export class ImageCarouselComponent {
210
210
  ImageCarouselComponent.decorators = [
211
211
  { type: Component, args: [{
212
212
  selector: 'app-image-carousel',
213
- template: `
214
- <div id="product_page_carousel">
215
- <div id="product_page_carousel_items">
216
- <co-loader [isShown]="true" *ngIf="showLoader"></co-loader>
217
- <div #carousel class="inner-carousel">
218
- <!-- This has been taken out of the for loop to prevent flashing images when updating. -->
219
- <div *ngIf="imageViewModels[0]" class="carousel-item" [id]="'slide-0'" [class.active]="isCurrentIndex(0)" (click)="handleShowImage(imageViewModels[0])">
220
- <img [src]="imageViewModels[0].source">
221
- </div>
222
- <div *ngFor="let imageViewModel of imageViewModels.slice(1); let index = index" class="carousel-item"
223
- [id]="'slide-' + (index + 1)" [class.active]="isCurrentIndex((index + 1))" (click)="handleShowImage(imageViewModel)">
224
- <img [src]="imageViewModel.source">
225
- </div>
226
- <div class="carousel-scroller-layer" *ngIf="imageViewModels && imageViewModels.length > 1">
227
- <div class="carousel-item-scroller prev" (click)="gotoPrevSlide()" *ngIf="currentIndex > 0"></div>
228
- <div class="carousel-item-scroller next" (click)="gotoNextSlide()" *ngIf="currentIndex < images.length - 1"></div>
229
- </div>
230
- </div>
231
- <!--
232
- <co-icon class="selector-type-icon refresh-button" [iconData]="iconCache.getIcon(icons.Refresh)" (click)="onForceRenderImage()" [class.loading]="showLoader" *ngIf="showRefresh"></co-icon>
233
- -->
234
- </div>
235
-
236
- <div id="product_page_carousel_thumbs">
237
- <co-scroll-container class="scroll-container" *ngIf="imageViewModels && imageViewModels.length > 1">
238
- <div *ngFor="let imageViewModel of imageViewModels; let index = index" class="carousel-thumb"
239
- [class.active]="index === currentIndex">
240
- <img [src]="imageViewModel.source" (click)="handleThumbClick(index)"/>
241
- </div>
242
- </co-scroll-container>
243
- </div>
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>
213
+ template: `
214
+ <div id="product_page_carousel">
215
+ <div id="product_page_carousel_items">
216
+ <co-loader [isShown]="true" *ngIf="showLoader"></co-loader>
217
+ <div #carousel class="inner-carousel">
218
+ <!-- This has been taken out of the for loop to prevent flashing images when updating. -->
219
+ <div *ngIf="imageViewModels[0]" class="carousel-item" [id]="'slide-0'" [class.active]="isCurrentIndex(0)" (click)="handleShowImage(imageViewModels[0])">
220
+ <img [src]="imageViewModels[0].source">
221
+ </div>
222
+ <div *ngFor="let imageViewModel of imageViewModels.slice(1); let index = index" class="carousel-item"
223
+ [id]="'slide-' + (index + 1)" [class.active]="isCurrentIndex((index + 1))" (click)="handleShowImage(imageViewModel)">
224
+ <img [src]="imageViewModel.source">
225
+ </div>
226
+ <div class="carousel-scroller-layer" *ngIf="imageViewModels && imageViewModels.length > 1">
227
+ <div class="carousel-item-scroller prev" (click)="gotoPrevSlide()" *ngIf="currentIndex > 0"></div>
228
+ <div class="carousel-item-scroller next" (click)="gotoNextSlide()" *ngIf="currentIndex < images.length - 1"></div>
229
+ </div>
230
+ </div>
231
+ <!--
232
+ <co-icon class="selector-type-icon refresh-button" [iconData]="iconCache.getIcon(icons.Refresh)" (click)="onForceRenderImage()" [class.loading]="showLoader" *ngIf="showRefresh"></co-icon>
233
+ -->
234
+ </div>
235
+
236
+ <div id="product_page_carousel_thumbs">
237
+ <co-scroll-container class="scroll-container" *ngIf="imageViewModels && imageViewModels.length > 1">
238
+ <div *ngFor="let imageViewModel of imageViewModels; let index = index" class="carousel-thumb"
239
+ [class.active]="index === currentIndex">
240
+ <img [src]="imageViewModel.source" (click)="handleThumbClick(index)"/>
241
+ </div>
242
+ </co-scroll-container>
243
+ </div>
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>
267
267
  `,
268
268
  changeDetection: ChangeDetectionStrategy.OnPush,
269
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"]
@@ -285,4 +285,4 @@ ImageCarouselComponent.propDecorators = {
285
285
  gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
286
286
  resizing: [{ type: HostBinding, args: ['class.resizing',] }]
287
287
  };
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.bo';\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"]}
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":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,KAAK,EAEL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,UAAU,EAAC,MAAM,8CAA8C,CAAC;AACxE,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAC,mBAAmB,EAAC,MAAM,qCAAqC,CAAC;AAGxE,OAAO,EAAC,YAAY,EAAU,MAAM,2BAA2B,CAAC;AAGhE,MAAM,OAAO,cAAc;CAI1B;AA8DD,MAAM,OAAO,sBAAsB;IA6EjC,YACU,KAA8B,EAC9B,gBAAqC,EACrC,eAAkC,EAClC,aAA2B;QAH3B,UAAK,GAAL,KAAK,CAAyB;QAC9B,qBAAgB,GAAhB,gBAAgB,CAAqB;QACrC,oBAAe,GAAf,eAAe,CAAmB;QAClC,kBAAa,GAAb,aAAa,CAAc;QA7E9B,gBAAW,GAAG,KAAK,CAAC;QAYpB,gBAAW,GAAY,KAAK,CAAC;QAiD7B,aAAQ,GAAG,KAAK,CAAC;QAEjB,oBAAe,GAAqB,EAAE,CAAC;QACvC,eAAU,GAAY,KAAK,CAAC;QAG3B,kBAAa,GAAG,CAAC,CAAC;QAClB,YAAO,GAA4B,EAAE,CAAC;QACtC,UAAK,GAAmB,EAAE,CAAC;QAE3B,wBAAmB,GAAW,GAAG,CAAC;QAQxC,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;YACnD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;YACrC,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;YACvC,CAAC,EAAE,KAAK,CAAC,CAAC;QACZ,CAAC,CAAC,EACF,IAAI,CAAC,gBAAgB,CAAC,0BAA0B,CAAC,SAAS,CAAC,CAAC,KAAkB,EAAE,EAAE;YAChF,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE;gBACzB,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,UAAU,EAAE;oBACzC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;iBACpC;qBAAM;oBACL,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC;iBAChC;gBACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;YACD,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAlGD,eAAe;IAEf,KAAK;QACH,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAKD,IACW,MAAM,CAAC,KAA8B;QAC9C,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC7B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC9C,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;SACtC;IACH,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAGM,kBAAkB;QACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAGM,aAAa;QAClB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAGM,aAAa;QAClB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAEM,cAAc,CAAC,KAAa;QACjC,OAAO,IAAI,CAAC,YAAY,KAAK,KAAK,CAAC;IACrC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAW,YAAY,CAAC,KAAa;QACnC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IA6CD,WAAW;QACT,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IAC3C,CAAC;IAEM,gBAAgB,CAAC,KAAa;QACnC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;IAClD,CAAC;IAEM,eAAe,CAAC,cAA8B;QACnD,IAAI,cAAc,IAAI,cAAc,CAAC,cAAc,EAAE;YACnD,IAAI,CAAC,aAAa,GAAG,cAAc,CAAC;YACpC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;SACrC;IACH,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAEO,kBAAkB,CAAC,KAA8B;QACvD,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,EAAE,CAAC;SACX;QACD,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,GAAwB,EAAE,EAAE;YAC/C,MAAM,OAAO,GAAG,sCAAsC,CAAC;YACvD,OAAO,OAAO,GAAG,KAAK,QAAQ,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnF,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;QAChC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAsB,EAAE,EAAE;gBAC9C,IAAI,cAAc,GAAG,IAAI,cAAc,EAAE,CAAC;gBAC1C,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC;gBACzB,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,EAAE,+CAA+C;oBAC1E,IAAI,CAAC,wBAAwB,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;iBAClD;qBAAM;oBACL,IAAI,CAAC,CAAC,QAAQ,EAAE;wBACd,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;qBAC3D;yBAAM,IAAI,CAAC,CAAC,YAAY,EAAE;wBACzB,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC,qBAAqB,EAAE,cAAc,CAAC,CAAC;qBACxE;yBAAM;wBACL,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,OAAwB,EAAE,EAAE;4BACnF,IAAI,OAAO,EAAE;gCACX,CAAC,CAAC,YAAY,GAAG,OAAO,CAAC,eAAe,CAAC;gCACzC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC,qBAAqB,EAAE,cAAc,CAAC,CAAC;gCACvE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;6BACtC;wBACH,CAAC,CAAC,CAAC;qBACJ;iBACF;gBACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAC1C,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;YACvC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,wBAAwB,CAAC,MAAc,EAAE,cAA8B;QAC7E,MAAM,YAAY,GAAsB,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACzE,MAAM,GAAG,GAAG,YAAY,CAAC,UAAU,CAAC,IAAI,CAAE,CAAC;QAC3C,MAAM,GAAG,GAAqB,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC5D,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC;QAE9B,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;YAChB,GAAG,CAAC,qBAAqB,GAAG,IAAI,CAAC;YACjC,GAAG,CAAC,qBAAqB,GAAG,MAAM,CAAC;YAEnC,MAAM,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC;YACrB,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC;YACtB,MAAM,MAAM,GAAG,EAAE,GAAG,EAAE,CAAC;YAEvB,IAAI,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC;YACpC,IAAI,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC;YACpC,IAAI,EAAE,GAAG,EAAE,EAAE;gBACX,IAAI,GAAG,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;aAC1C;iBAAM;gBACL,IAAI,GAAG,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;aAC1C;YAED,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACtC,YAAY,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAEvC,+CAA+C;YAC/C,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC;YAE7D,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,KAAK,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC;YAElE,MAAM,IAAI,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,aAAa,GACjB,IAAI,KAAK,YAAY;gBACnB,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,4BAA4B;gBACzE,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAc,sBAAsB;YAEvE,cAAc,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,sBAAsB,CAAC,aAAa,CAAC,CAAC;YACjF,cAAc,CAAC,cAAc,GAAG,MAAM,CAAC;YACvC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC,CAAC;QAEF,GAAG,CAAC,GAAG,GAAG,MAAM,CAAC;IACnB,CAAC;IAEO,oBAAoB,CAAC,MAAc;QACzC,iBAAiB;QACjB,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;QAC9D,IAAI,CAAC,EAAE;YACL,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,WAAW,IAAI,CAAC,KAAK,YAAY,IAAI,CAAC,KAAK,YAAY;gBAAE,OAAO,CAAQ,CAAC;SACpF;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,EAAE,CAAC;QACnC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,WAAW,CAAC;QAC/C,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,YAAY,CAAC;QACjD,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,YAAY,CAAC;QAE3E,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,sBAAsB;QAC5B,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YACrE,MAAM,MAAM,GAAW,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC;YACnF,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE;gBAChD,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,GAAG,MAAM,CAAC;gBAChD,yCAAyC;gBACzC,kBAAkB;gBAClB,uBAAuB;gBACvB,MAAM;aACP;SACF;IACH,CAAC;;;YAhTF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsDT;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAEhD;;;YAxEO,uBAAuB;YACvB,mBAAmB;YAXzB,iBAAiB;YAcX,YAAY;;;uBAsEjB,SAAS,SAAC,UAAU,EAAE,EAAC,IAAI,EAAE,UAAU,EAAC;oBAOxC,YAAY,SAAC,yBAAyB;0BAOtC,KAAK;qBAGL,KAAK;iCAaL,YAAY,SAAC,eAAe;4BAU5B,YAAY,SAAC,WAAW;4BAKxB,YAAY,SAAC,YAAY;uBAkBzB,WAAW,SAAC,gBAAgB","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\nimport {ProductConnectorService} from '../../service/product-connector.service';\r\nimport {ProductEventService} from '../../service/product-event.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {IconEnum} from '../../enum/icon.enum';\r\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\r\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\r\n\r\nexport class ImageViewModel {\r\n  public image: CoDocument | string;\r\n  public source: SafeUrl;\r\n  public originalSource: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-image-carousel',\r\n  template: `\r\n      <div id=\"product_page_carousel\">\r\n          <div id=\"product_page_carousel_items\">\r\n              <co-loader [isShown]=\"true\" *ngIf=\"showLoader\"></co-loader>\r\n              <div #carousel class=\"inner-carousel\">\r\n                  <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\r\n                  <div *ngIf=\"imageViewModels[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\" (click)=\"handleShowImage(imageViewModels[0])\">\r\n                      <img [src]=\"imageViewModels[0].source\">\r\n                  </div>\r\n                  <div *ngFor=\"let imageViewModel of imageViewModels.slice(1); let index = index\" class=\"carousel-item\"\r\n                       [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\" (click)=\"handleShowImage(imageViewModel)\">\r\n                      <img [src]=\"imageViewModel.source\">\r\n                  </div>\r\n                  <div class=\"carousel-scroller-layer\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\r\n                      <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\r\n                      <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\r\n                  </div>\r\n              </div>\r\n              <!--\r\n                      <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\r\n              -->\r\n          </div>\r\n\r\n          <div id=\"product_page_carousel_thumbs\">\r\n              <co-scroll-container class=\"scroll-container\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\r\n                  <div *ngFor=\"let imageViewModel of imageViewModels; let index = index\" class=\"carousel-thumb\"\r\n                       [class.active]=\"index === currentIndex\">\r\n                      <img [src]=\"imageViewModel.source\" (click)=\"handleThumbClick(index)\"/>\r\n                  </div>\r\n              </co-scroll-container>\r\n          </div>\r\n      </div>\r\n      <!-- Modal (real popup) -->\r\n      <div\r\n        class=\"image-modal\"\r\n        *ngIf=\"isPopupOpen\"\r\n        (click)=\"closePopup()\"\r\n        role=\"dialog\"\r\n        aria-modal=\"true\"\r\n        aria-label=\"Image preview\"\r\n      >\r\n        <div class=\"image-modal__content\" (click)=\"$event.stopPropagation()\">\r\n          <button\r\n            class=\"image-modal__close\"\r\n            type=\"button\"\r\n            aria-label=\"Close\"\r\n            (click)=\"closePopup()\"\r\n          >\r\n            ×\r\n          </button>\r\n\r\n          <img [src]=\"selectedImage?.originalSource\" alt=\"Image preview\" />\r\n        </div>\r\n      </div>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  styleUrls: ['./image-carousel.component.scss']\r\n})\r\nexport class ImageCarouselComponent implements OnDestroy {\r\n  @ViewChild('carousel', {read: ElementRef})\r\n  public carousel: ElementRef;\r\n\r\n  public isPopupOpen = false;\r\n  public selectedImage?: ImageViewModel;\r\n\r\n  // Close on ESC\r\n  @HostListener('document:keydown.escape')\r\n  onEsc(): void {\r\n    if (this.isPopupOpen) {\r\n      this.closePopup();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public showRefresh: boolean = false;\r\n\r\n  @Input()\r\n  public set images(value: (CoDocument | string)[]) {\r\n    if (value && value.length > 0) {\r\n      this._images = this._filterValidImages(value);\r\n      this._loadAndRescaleImages();\r\n      this._changeDetector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public get images(): (CoDocument | string)[] {\r\n    return this._images;\r\n  }\r\n\r\n  @HostListener('window:resize')\r\n  public handleWindowResize(): void {\r\n    this.resizing = true;\r\n    this._scrollCarouselToIndex();\r\n    clearTimeout(this._resizeTimer);\r\n    this._resizeTimer = setTimeout(() => {\r\n      this.resizing = false;\r\n    }, 200);\r\n  }\r\n\r\n  @HostListener('swipeleft')\r\n  public gotoNextSlide(): void {\r\n    this.currentIndex++;\r\n  }\r\n\r\n  @HostListener('swiperight')\r\n  public gotoPrevSlide(): void {\r\n    this.currentIndex--;\r\n  }\r\n\r\n  public isCurrentIndex(index: number): boolean {\r\n    return this.currentIndex === index;\r\n  }\r\n\r\n  public get currentIndex(): number {\r\n    return this._currentIndex;\r\n  }\r\n\r\n  public set currentIndex(value: number) {\r\n    this._currentIndex = value;\r\n    this._scrollCarouselToIndex();\r\n  }\r\n\r\n  @HostBinding('class.resizing')\r\n  public resizing = false;\r\n\r\n  public imageViewModels: ImageViewModel[] = [];\r\n  public showLoader: boolean = false;\r\n\r\n  private _resizeTimer: any;\r\n  private _currentIndex = 0;\r\n  private _images: (CoDocument | string)[] = [];\r\n  private _subs: Subscription[] = [];\r\n\r\n  private _resizeCanvasHeight: number = 500;\r\n\r\n  constructor(\r\n    private _ione: ProductConnectorService,\r\n    private _appEventService: ProductEventService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _domSanitizer: DomSanitizer\r\n  ) {\r\n    this._subs.push(\r\n      this._appEventService.onRenderStarted.subscribe(() => {\r\n        this.showLoader = true;\r\n        this._changeDetector.detectChanges();\r\n        setTimeout(() => {\r\n          this.showLoader = false;\r\n          this._changeDetector.detectChanges();\r\n        }, 10000);\r\n      }),\r\n      this._appEventService.onDraftRenderImageReceived.subscribe((event: CustomEvent) => {\r\n        if (event && event.detail) {\r\n          if (this._images[0] instanceof CoDocument) {\r\n            this._images.unshift(event.detail);\r\n          } else {\r\n            this._images[0] = event.detail;\r\n          }\r\n          this._loadAndRescaleImages();\r\n        }\r\n        this.showLoader = false;\r\n        this._changeDetector.detectChanges();\r\n      })\r\n    );\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.carousel = undefined;\r\n    this._subs.forEach(s => s.unsubscribe());\r\n  }\r\n\r\n  public handleThumbClick(index: number): void {\r\n    this.currentIndex = index;\r\n  }\r\n\r\n  public onForceRenderImage(): void {\r\n    this._appEventService.onForceRenderImage.next();\r\n  }\r\n\r\n  public handleShowImage(imageViewModel: ImageViewModel): void {\r\n    if (imageViewModel && imageViewModel.originalSource) {\r\n      this.selectedImage = imageViewModel;\r\n      this.isPopupOpen = true;\r\n      this._changeDetector.markForCheck();\r\n    }\r\n  }\r\n\r\n  public closePopup(): void {\r\n    this.isPopupOpen = false;\r\n    this.selectedImage = undefined;\r\n    this._changeDetector.markForCheck();\r\n  }\r\n\r\n  private _filterValidImages(value: (CoDocument | string)[]): (CoDocument | string)[] {\r\n    if (!value) {\r\n      return [];\r\n    }\r\n    return value.filter((doc: CoDocument | string) => {\r\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\r\n      return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);\r\n    });\r\n  }\r\n\r\n  private _loadAndRescaleImages(): void {\r\n    this.imageViewModels.length = 0;\r\n    if (this._images) {\r\n      this._images.forEach((i: CoDocument | string) => {\r\n        let imageViewModel = new ImageViewModel();\r\n        imageViewModel.image = i;\r\n        if (typeof i === 'string') { // is a rendered image coming from configurator\r\n          this._resizeAndSanitizeSource(i, imageViewModel);\r\n        } else {\r\n          if (i.filePath) {\r\n            this._resizeAndSanitizeSource(i.filePath, imageViewModel);\r\n          } else if (i.documentBody) {\r\n            this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\r\n          } else {\r\n            this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\r\n              if (content) {\r\n                i.documentBody = content.documentContent;\r\n                this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\r\n                this._changeDetector.detectChanges();\r\n              }\r\n            });\r\n          }\r\n        }\r\n        this.imageViewModels.push(imageViewModel);\r\n        this._changeDetector.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  private _resizeAndSanitizeSource(source: string, imageViewModel: ImageViewModel): void {\r\n    const resizeCanvas: HTMLCanvasElement = document.createElement('canvas');\r\n    const ctx = resizeCanvas.getContext('2d')!;\r\n    const img: HTMLImageElement = document.createElement('img');\r\n    img.crossOrigin = 'anonymous';\r\n\r\n    img.onload = () => {\r\n      ctx.imageSmoothingEnabled = true;\r\n      ctx.imageSmoothingQuality = 'high';\r\n\r\n      const ow = img.width;\r\n      const oh = img.height;\r\n      const aspect = ow / oh;\r\n\r\n      let newW = this._resizeCanvasHeight;\r\n      let newH = this._resizeCanvasHeight;\r\n      if (ow > oh) {\r\n        newH = this._resizeCanvasHeight / aspect;\r\n      } else {\r\n        newW = this._resizeCanvasHeight * aspect;\r\n      }\r\n\r\n      resizeCanvas.width = Math.round(newW);\r\n      resizeCanvas.height = Math.round(newH);\r\n\r\n      // Ensure transparent background before drawing\r\n      ctx.clearRect(0, 0, resizeCanvas.width, resizeCanvas.height);\r\n\r\n      ctx.drawImage(img, 0, 0, resizeCanvas.width, resizeCanvas.height);\r\n\r\n      const mime = this._detectPreferredMime(source);\r\n      const resizedSource =\r\n        mime === 'image/jpeg'\r\n          ? resizeCanvas.toDataURL('image/jpeg', 0.92) // only if original was JPEG\r\n          : resizeCanvas.toDataURL(mime);              // PNG/WebP keep alpha\r\n\r\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\r\n      imageViewModel.originalSource = source;\r\n      this._changeDetector.detectChanges();\r\n    };\r\n\r\n    img.src = source;\r\n  }\r\n\r\n  private _detectPreferredMime(source: string): 'image/png' | 'image/webp' | 'image/jpeg' {\r\n    // Data URI check\r\n    const m = source.match(/^data:(image\\/[a-zA-Z+.-]+);base64,/);\r\n    if (m) {\r\n      const t = m[1].toLowerCase();\r\n      if (t === 'image/png' || t === 'image/webp' || t === 'image/jpeg') return t as any;\r\n    }\r\n\r\n    const lower = source.toLowerCase();\r\n    if (lower.endsWith('.png')) return 'image/png';\r\n    if (lower.endsWith('.webp')) return 'image/webp';\r\n    if (lower.endsWith('.jpg') || lower.endsWith('.jpeg')) return 'image/jpeg';\r\n\r\n    return 'image/png';\r\n  }\r\n\r\n  private _scrollCarouselToIndex(): void {\r\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\r\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\r\n      if (this.carousel && this.carousel.nativeElement) {\r\n        this.carousel.nativeElement.scrollLeft = movePx;\r\n        // this.carousel.nativeElement.scrollTo({\r\n        //   left: movePx,\r\n        //   behavior: 'smooth'\r\n        // });\r\n      }\r\n    }\r\n  }\r\n\r\n}\r\n"]}
@@ -38,13 +38,13 @@ export class ProductAdditionalDescriptionComponent {
38
38
  ProductAdditionalDescriptionComponent.decorators = [
39
39
  { type: Component, args: [{
40
40
  selector: 'app-product-additional-description',
41
- template: `
42
- <ng-container *ngIf="description !== ''">
43
- <div class="pd-additional-description">
44
- <p [innerHTML]="description"></p>
45
- <button class="pd-read-more-btn" [textContent]="'READ_MORE' | localize" (click)="onReadMore()"></button>
46
- </div>
47
- </ng-container>
41
+ template: `
42
+ <ng-container *ngIf="description !== ''">
43
+ <div class="pd-additional-description">
44
+ <p [innerHTML]="description"></p>
45
+ <button class="pd-read-more-btn" [textContent]="'READ_MORE' | localize" (click)="onReadMore()"></button>
46
+ </div>
47
+ </ng-container>
48
48
  `,
49
49
  styles: [":host{display:block;padding-top:0!important}:host *:focus{outline:0!important}:host .pd-additional-description{line-height:190%;color:#22313c;font-size:13px}:host .pd-read-more-btn{color:#2b60a7;border:none;background:transparent;cursor:pointer;text-decoration:underline;font-family:iOneMontserrat}:host .pd-read-more-btn:hover{color:#74b77f}@media screen and (max-width: 650px){:host .pd-additional-description{font-size:12px}}\n"]
50
50
  },] }
@@ -55,4 +55,4 @@ ProductAdditionalDescriptionComponent.ctorParameters = () => [
55
55
  ProductAdditionalDescriptionComponent.propDecorators = {
56
56
  article: [{ type: Input }]
57
57
  };
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24vcHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUd6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFjakQsTUFBTSxPQUFPLHFDQUFxQztJQW1CaEQsWUFDVSxnQkFBcUM7UUFBckMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFxQjtJQUM1QyxDQUFDO0lBbkJKLElBQ1csT0FBTyxDQUFDLEtBQXdCO1FBQ3pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMscUJBQXFCLENBQUM7WUFDdEQsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRUQsSUFBVyxPQUFPO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBVUQsUUFBUTtJQUNSLENBQUM7SUFFTSxVQUFVO1FBQ2YsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU8sbUJBQW1CO1FBRXpCLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBRXRCLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN2RCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFXLEVBQUUsRUFBRTtnQkFDekMsSUFBSSxRQUFRLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFO29CQUNoRCxJQUFJLENBQUMsV0FBVyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUM7aUJBQzlCO1lBQ0gsQ0FBQyxDQUFDLENBQUM7WUFFSCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQztZQUM5RCxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRTtnQkFDakMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDO2FBQzlEO1NBQ0Y7SUFFSCxDQUFDOzs7WUEzREYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQ0FBb0M7Z0JBQzlDLFFBQVEsRUFBRTs7Ozs7OztHQU9UOzthQUVGOzs7WUFkUSxtQkFBbUI7OztzQkFpQnpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFydGljbGVGdWxsT2JqZWN0IH0gZnJvbSAnQGNvbGlqbml0L2FydGljbGVhcGkvYnVpbGQvbW9kZWwvYXJ0aWNsZS1mdWxsLW9iamVjdCc7XG5pbXBvcnQgeyBDb1RleHQgfSBmcm9tICdAY29saWpuaXQvbWFpbmFwaS9idWlsZC9tb2RlbC9jby10ZXh0JztcbmltcG9ydCB7IFByb2R1Y3RFdmVudFNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlL3Byb2R1Y3QtZXZlbnQuc2VydmljZSc7XG5pbXBvcnQgeyBCaXRVdGlscyB9IGZyb20gJy4uLy4uL3V0aWxzL2JpdC11dGlscyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24nLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJkZXNjcmlwdGlvbiAhPT0gJydcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJwZC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uXCI+XG4gICAgICAgIDxwIFtpbm5lckhUTUxdPVwiZGVzY3JpcHRpb25cIj48L3A+XG4gICAgICAgIDxidXR0b24gY2xhc3M9XCJwZC1yZWFkLW1vcmUtYnRuXCIgW3RleHRDb250ZW50XT1cIidSRUFEX01PUkUnIHwgbG9jYWxpemVcIiAoY2xpY2spPVwib25SZWFkTW9yZSgpXCI+PC9idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vcHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgUHJvZHVjdEFkZGl0aW9uYWxEZXNjcmlwdGlvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHNldCBhcnRpY2xlKHZhbHVlOiBBcnRpY2xlRnVsbE9iamVjdCkge1xuICAgIHRoaXMuX2FydGljbGUgPSB2YWx1ZTtcbiAgICBpZiAodGhpcy5fYXJ0aWNsZSkge1xuICAgICAgdGhpcy5kZXNjcmlwdGlvbiA9IHRoaXMuYXJ0aWNsZS5hZGRpdGlvbmFsRGVzY3JpcHRpb247XG4gICAgICB0aGlzLl9wcmVwYXJlRGVzY3JpcHRpb24oKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0IGFydGljbGUoKTogQXJ0aWNsZUZ1bGxPYmplY3Qge1xuICAgIHJldHVybiB0aGlzLl9hcnRpY2xlO1xuICB9XG5cbiAgcHVibGljIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSBfYXJ0aWNsZTogQXJ0aWNsZUZ1bGxPYmplY3Q7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfYXBwRXZlbnRTZXJ2aWNlOiBQcm9kdWN0RXZlbnRTZXJ2aWNlXG4gICkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG4gIHB1YmxpYyBvblJlYWRNb3JlKCk6IHZvaWQge1xuICAgIHRoaXMuX2FwcEV2ZW50U2VydmljZS5vblVwZGF0ZVByb2R1Y3RJbmZvVGFiLm5leHQoMCk7XG4gIH1cblxuICBwcml2YXRlIF9wcmVwYXJlRGVzY3JpcHRpb24oKTogdm9pZCB7XG5cbiAgICB0aGlzLmRlc2NyaXB0aW9uID0gJyc7XG5cbiAgICBpZiAodGhpcy5hcnRpY2xlLnRleHRzICYmIHRoaXMuYXJ0aWNsZS50ZXh0cy5sZW5ndGggPiAwKSB7XG4gICAgICB0aGlzLmFydGljbGUudGV4dHMuZm9yRWFjaCgodHh0OiBDb1RleHQpID0+IHtcbiAgICAgICAgaWYgKEJpdFV0aWxzLklzU2hvcnREZXNjcmlwdGlvbih0eHQucHVibGljYXRpb24pKSB7XG4gICAgICAgICAgdGhpcy5kZXNjcmlwdGlvbiArPSB0eHQudGV4dDtcbiAgICAgICAgfVxuICAgICAgfSk7XG5cbiAgICAgIHRoaXMuZGVzY3JpcHRpb24gPSB0aGlzLmRlc2NyaXB0aW9uLnJlcGxhY2UoLzxbXj5dKj4/L2dtLCAnJyk7XG4gICAgICBpZiAodGhpcy5kZXNjcmlwdGlvbi5sZW5ndGggPiAyNTApIHtcbiAgICAgICAgdGhpcy5kZXNjcmlwdGlvbiA9IHRoaXMuZGVzY3JpcHRpb24uc3Vic3RyKDAsIDI1MCkgKyAnIFsuLl0nO1xuICAgICAgfVxuICAgIH1cblxuICB9XG5cbn1cbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24vcHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUd6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFjakQsTUFBTSxPQUFPLHFDQUFxQztJQW1CaEQsWUFDVSxnQkFBcUM7UUFBckMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFxQjtJQUM1QyxDQUFDO0lBbkJKLElBQ1csT0FBTyxDQUFDLEtBQXdCO1FBQ3pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMscUJBQXFCLENBQUM7WUFDdEQsSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRUQsSUFBVyxPQUFPO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBVUQsUUFBUTtJQUNSLENBQUM7SUFFTSxVQUFVO1FBQ2YsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU8sbUJBQW1CO1FBRXpCLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBRXRCLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN2RCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFXLEVBQUUsRUFBRTtnQkFDekMsSUFBSSxRQUFRLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFO29CQUNoRCxJQUFJLENBQUMsV0FBVyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUM7aUJBQzlCO1lBQ0gsQ0FBQyxDQUFDLENBQUM7WUFFSCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQztZQUM5RCxJQUFJLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRTtnQkFDakMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEdBQUcsT0FBTyxDQUFDO2FBQzlEO1NBQ0Y7SUFFSCxDQUFDOzs7WUEzREYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQ0FBb0M7Z0JBQzlDLFFBQVEsRUFBRTs7Ozs7OztHQU9UOzthQUVGOzs7WUFkUSxtQkFBbUI7OztzQkFpQnpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQXJ0aWNsZUZ1bGxPYmplY3QgfSBmcm9tICdAY29saWpuaXQvYXJ0aWNsZWFwaS9idWlsZC9tb2RlbC9hcnRpY2xlLWZ1bGwtb2JqZWN0JztcclxuaW1wb3J0IHsgQ29UZXh0IH0gZnJvbSAnQGNvbGlqbml0L21haW5hcGkvYnVpbGQvbW9kZWwvY28tdGV4dCc7XHJcbmltcG9ydCB7IFByb2R1Y3RFdmVudFNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlL3Byb2R1Y3QtZXZlbnQuc2VydmljZSc7XHJcbmltcG9ydCB7IEJpdFV0aWxzIH0gZnJvbSAnLi4vLi4vdXRpbHMvYml0LXV0aWxzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLXByb2R1Y3QtYWRkaXRpb25hbC1kZXNjcmlwdGlvbicsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJkZXNjcmlwdGlvbiAhPT0gJydcIj5cclxuICAgICAgPGRpdiBjbGFzcz1cInBkLWFkZGl0aW9uYWwtZGVzY3JpcHRpb25cIj5cclxuICAgICAgICA8cCBbaW5uZXJIVE1MXT1cImRlc2NyaXB0aW9uXCI+PC9wPlxyXG4gICAgICAgIDxidXR0b24gY2xhc3M9XCJwZC1yZWFkLW1vcmUtYnRuXCIgW3RleHRDb250ZW50XT1cIidSRUFEX01PUkUnIHwgbG9jYWxpemVcIiAoY2xpY2spPVwib25SZWFkTW9yZSgpXCI+PC9idXR0b24+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9uZy1jb250YWluZXI+XHJcbiAgYCxcclxuICBzdHlsZVVybHM6IFsnLi9wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24uY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZHVjdEFkZGl0aW9uYWxEZXNjcmlwdGlvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNldCBhcnRpY2xlKHZhbHVlOiBBcnRpY2xlRnVsbE9iamVjdCkge1xyXG4gICAgdGhpcy5fYXJ0aWNsZSA9IHZhbHVlO1xyXG4gICAgaWYgKHRoaXMuX2FydGljbGUpIHtcclxuICAgICAgdGhpcy5kZXNjcmlwdGlvbiA9IHRoaXMuYXJ0aWNsZS5hZGRpdGlvbmFsRGVzY3JpcHRpb247XHJcbiAgICAgIHRoaXMuX3ByZXBhcmVEZXNjcmlwdGlvbigpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBhcnRpY2xlKCk6IEFydGljbGVGdWxsT2JqZWN0IHtcclxuICAgIHJldHVybiB0aGlzLl9hcnRpY2xlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGRlc2NyaXB0aW9uOiBzdHJpbmc7XHJcblxyXG4gIHByaXZhdGUgX2FydGljbGU6IEFydGljbGVGdWxsT2JqZWN0O1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgX2FwcEV2ZW50U2VydmljZTogUHJvZHVjdEV2ZW50U2VydmljZVxyXG4gICkge31cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25SZWFkTW9yZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuX2FwcEV2ZW50U2VydmljZS5vblVwZGF0ZVByb2R1Y3RJbmZvVGFiLm5leHQoMCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9wcmVwYXJlRGVzY3JpcHRpb24oKTogdm9pZCB7XHJcblxyXG4gICAgdGhpcy5kZXNjcmlwdGlvbiA9ICcnO1xyXG5cclxuICAgIGlmICh0aGlzLmFydGljbGUudGV4dHMgJiYgdGhpcy5hcnRpY2xlLnRleHRzLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5hcnRpY2xlLnRleHRzLmZvckVhY2goKHR4dDogQ29UZXh0KSA9PiB7XHJcbiAgICAgICAgaWYgKEJpdFV0aWxzLklzU2hvcnREZXNjcmlwdGlvbih0eHQucHVibGljYXRpb24pKSB7XHJcbiAgICAgICAgICB0aGlzLmRlc2NyaXB0aW9uICs9IHR4dC50ZXh0O1xyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcblxyXG4gICAgICB0aGlzLmRlc2NyaXB0aW9uID0gdGhpcy5kZXNjcmlwdGlvbi5yZXBsYWNlKC88W14+XSo+Py9nbSwgJycpO1xyXG4gICAgICBpZiAodGhpcy5kZXNjcmlwdGlvbi5sZW5ndGggPiAyNTApIHtcclxuICAgICAgICB0aGlzLmRlc2NyaXB0aW9uID0gdGhpcy5kZXNjcmlwdGlvbi5zdWJzdHIoMCwgMjUwKSArICcgWy4uXSc7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgfVxyXG5cclxufVxyXG4iXX0=
@@ -87,11 +87,11 @@ export class ProductAdditionalInfoComponent {
87
87
  ProductAdditionalInfoComponent.decorators = [
88
88
  { type: Component, args: [{
89
89
  selector: 'app-product-additional-info',
90
- template: `
91
- <h3 *ngIf="showLabel" [textContent]="'ADDITIONAL_DATA' | localize"></h3>
92
- <ng-container *ngIf="textParts && textParts.length > 0">
93
- <div class="additional-info-parts" *ngFor="let text of textParts" [innerHTML]="text"></div>
94
- </ng-container>
90
+ template: `
91
+ <h3 *ngIf="showLabel" [textContent]="'ADDITIONAL_DATA' | localize"></h3>
92
+ <ng-container *ngIf="textParts && textParts.length > 0">
93
+ <div class="additional-info-parts" *ngFor="let text of textParts" [innerHTML]="text"></div>
94
+ </ng-container>
95
95
  `,
96
96
  styles: [":host{display:block}:host .additional-info-parts{margin-bottom:20px;line-height:190%;color:#22313c;font-size:13px}:host ::ng-deep p{line-height:190%;margin:15px 0}:host ::ng-deep font{font-family:\"iOneMontserrat\"}:host .additional-info-parts>*:first-child{margin-top:0}:host .additional-info-parts>*:last-child{margin-bottom:0}\n"]
97
97
  },] }
@@ -105,4 +105,4 @@ ProductAdditionalInfoComponent.propDecorators = {
105
105
  article: [{ type: Input }],
106
106
  showLabel: [{ type: Input }]
107
107
  };
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-additional-info.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-additional-info/product-additional-info.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit, SecurityContext } from '@angular/core';\nimport { CoText } from '@colijnit/mainapi/build/model/co-text';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport { SuperArticle } from '@colijnit/articleapi/build/model/super-article';\nimport { BitUtils } from '../../utils/bit-utils';\nimport {ProductConnectorService} from '../../service/product-connector.service';\n\n@Component({\n  selector: 'app-product-additional-info',\n  template: `\n    <h3 *ngIf=\"showLabel\" [textContent]=\"'ADDITIONAL_DATA' | localize\"></h3>\n    <ng-container *ngIf=\"textParts && textParts.length > 0\">\n      <div class=\"additional-info-parts\" *ngFor=\"let text of textParts\" [innerHTML]=\"text\"></div>\n    </ng-container>\n  `,\n  styleUrls: ['./product-additional-info.component.scss']\n})\nexport class ProductAdditionalInfoComponent implements OnInit {\n\n  @Input()\n  public set article(value: ArticleFullObject) {\n    if (value) {\n      this._article = value;\n      this._buildInfo().then(() => {\n        this._changeDetector.detectChanges();\n      });\n    }\n  }\n\n  public get article(): ArticleFullObject {\n    return this._article;\n  }\n\n  @Input()\n  public showLabel: boolean = false;\n\n  public textParts: SafeHtml[] = [];\n  public info: string;\n\n  private _article: ArticleFullObject;\n  private _superArticles: Map<string, SuperArticle> = new Map();\n\n  constructor(\n    private _sanitizer: DomSanitizer,\n    private _connectorService: ProductConnectorService,\n    private _changeDetector: ChangeDetectorRef\n  ) {\n  }\n\n  ngOnInit() {\n  }\n\n  private async _getTextsSuperArticle(): Promise<SafeHtml[]> {\n    return new Promise(async (resolve: Function, reject: Function) => {\n      const texts: SafeHtml[] = [];\n      if (this.article.superArticleNr) {\n        let mainArticle;\n        if (this._superArticles.has(this.article.superArticleNr)) {\n          mainArticle = this._superArticles.get(this.article.superArticleNr);\n        } else {\n          mainArticle = await this._connectorService.getSuperArticle(this.article.superArticleNr);\n          this._superArticles.set(this.article.superArticleNr, mainArticle);\n        }\n        mainArticle.texts.forEach((txt: CoText) => {\n          if (BitUtils.IsFullDescription(txt.publication)) {\n            const safeTxt: SafeHtml = this._sanitizer.sanitize(SecurityContext.HTML, txt.text);\n            texts.push(safeTxt);\n          }\n        });\n        resolve(texts);\n      } else {\n        resolve(texts);\n      }\n    });\n  }\n\n  private async _prepareArticleTexts(): Promise<void> {\n    const texts: SafeHtml[] = await this._getTextsSuperArticle();\n    if (texts.length > 0) {\n      this.textParts.push(...texts);\n    }\n    if (this.article.texts) {\n      this.article.texts.forEach((txt: CoText) => {\n        if (BitUtils.IsFullDescription(txt.publication)) {\n          const safeTxt: SafeHtml = this._sanitizer.sanitize(SecurityContext.HTML, txt.text);\n          this.textParts.push(safeTxt);\n        }\n      });\n    }\n  }\n\n  private async _buildInfo(): Promise<void> {\n    this.textParts.length = 0;\n    await this._prepareArticleTexts();\n    if (this.textParts.length === 0) {\n      if (this.article.additionalDescription) {\n        this.textParts.push(this.article.additionalDescription);\n      } else if (this.article.description) {\n        this.textParts.push(this.article.description);\n      }\n    }\n    return;\n  }\n\n}\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-additional-info.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-additional-info/product-additional-info.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit, SecurityContext } from '@angular/core';\r\nimport { CoText } from '@colijnit/mainapi/build/model/co-text';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\r\nimport { SuperArticle } from '@colijnit/articleapi/build/model/super-article';\r\nimport { BitUtils } from '../../utils/bit-utils';\r\nimport {ProductConnectorService} from '../../service/product-connector.service';\r\n\r\n@Component({\r\n  selector: 'app-product-additional-info',\r\n  template: `\r\n    <h3 *ngIf=\"showLabel\" [textContent]=\"'ADDITIONAL_DATA' | localize\"></h3>\r\n    <ng-container *ngIf=\"textParts && textParts.length > 0\">\r\n      <div class=\"additional-info-parts\" *ngFor=\"let text of textParts\" [innerHTML]=\"text\"></div>\r\n    </ng-container>\r\n  `,\r\n  styleUrls: ['./product-additional-info.component.scss']\r\n})\r\nexport class ProductAdditionalInfoComponent implements OnInit {\r\n\r\n  @Input()\r\n  public set article(value: ArticleFullObject) {\r\n    if (value) {\r\n      this._article = value;\r\n      this._buildInfo().then(() => {\r\n        this._changeDetector.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  public get article(): ArticleFullObject {\r\n    return this._article;\r\n  }\r\n\r\n  @Input()\r\n  public showLabel: boolean = false;\r\n\r\n  public textParts: SafeHtml[] = [];\r\n  public info: string;\r\n\r\n  private _article: ArticleFullObject;\r\n  private _superArticles: Map<string, SuperArticle> = new Map();\r\n\r\n  constructor(\r\n    private _sanitizer: DomSanitizer,\r\n    private _connectorService: ProductConnectorService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  private async _getTextsSuperArticle(): Promise<SafeHtml[]> {\r\n    return new Promise(async (resolve: Function, reject: Function) => {\r\n      const texts: SafeHtml[] = [];\r\n      if (this.article.superArticleNr) {\r\n        let mainArticle;\r\n        if (this._superArticles.has(this.article.superArticleNr)) {\r\n          mainArticle = this._superArticles.get(this.article.superArticleNr);\r\n        } else {\r\n          mainArticle = await this._connectorService.getSuperArticle(this.article.superArticleNr);\r\n          this._superArticles.set(this.article.superArticleNr, mainArticle);\r\n        }\r\n        mainArticle.texts.forEach((txt: CoText) => {\r\n          if (BitUtils.IsFullDescription(txt.publication)) {\r\n            const safeTxt: SafeHtml = this._sanitizer.sanitize(SecurityContext.HTML, txt.text);\r\n            texts.push(safeTxt);\r\n          }\r\n        });\r\n        resolve(texts);\r\n      } else {\r\n        resolve(texts);\r\n      }\r\n    });\r\n  }\r\n\r\n  private async _prepareArticleTexts(): Promise<void> {\r\n    const texts: SafeHtml[] = await this._getTextsSuperArticle();\r\n    if (texts.length > 0) {\r\n      this.textParts.push(...texts);\r\n    }\r\n    if (this.article.texts) {\r\n      this.article.texts.forEach((txt: CoText) => {\r\n        if (BitUtils.IsFullDescription(txt.publication)) {\r\n          const safeTxt: SafeHtml = this._sanitizer.sanitize(SecurityContext.HTML, txt.text);\r\n          this.textParts.push(safeTxt);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private async _buildInfo(): Promise<void> {\r\n    this.textParts.length = 0;\r\n    await this._prepareArticleTexts();\r\n    if (this.textParts.length === 0) {\r\n      if (this.article.additionalDescription) {\r\n        this.textParts.push(this.article.additionalDescription);\r\n      } else if (this.article.description) {\r\n        this.textParts.push(this.article.description);\r\n      }\r\n    }\r\n    return;\r\n  }\r\n\r\n}\r\n"]}
@@ -125,36 +125,36 @@ export class ProductAddtocartComponent {
125
125
  ProductAddtocartComponent.decorators = [
126
126
  { type: Component, args: [{
127
127
  selector: 'app-product-addtocart',
128
- template: `
129
- <div class="atc-wrapper">
130
- <ng-container *ngIf="isReturn">
131
- <co-number-picker *ngIf="!configurable && !configuring" class="quantity-select" [(model)]="quantity" [min]="-100" horizontal></co-number-picker>
132
- </ng-container>
133
-
134
- <ng-container *ngIf="!isReturn">
135
- <co-number-picker *ngIf="!configurable && !configuring" class="quantity-select" [(model)]="quantity" [min]="1" horizontal></co-number-picker>
136
- </ng-container>
137
-
138
- <div class="button-wrapper" *ngIf="configurable">
139
- <co-button class="configure-button"
140
- [iconData]="iconCache.getIcon(icon.MagicWand)"
141
- [label]="'CONFIGURE' | localize"
142
- (onClick)="startConfiguration.emit()"
143
- ></co-button>
144
- </div>
145
- <div class="button-wrapper" *ngIf="showAddToCart && !configurable">
146
- <co-button #addtocartbutton class="cart-button"
147
- [iconData]="iconCache.getIcon(icon.AddToCartDrop)"
148
- [label]="'SHOPPING_CART_IN' | localize"
149
- (onClick)="handleAddToCartClick(quantity)"
150
- ></co-button>
151
- <co-button class="cart-button quote" *ngIf="showQuoteButton"
152
- [iconData]="iconCache.getIcon(icon.Quote)"
153
- [label]="'QUOTATION' | localize"
154
- (onClick)="handleAddToQuoteClick(quantity)"
155
- ></co-button>
156
- </div>
157
- </div>
128
+ template: `
129
+ <div class="atc-wrapper">
130
+ <ng-container *ngIf="isReturn">
131
+ <co-number-picker *ngIf="!configurable && !configuring" class="quantity-select" [(model)]="quantity" [min]="-100" horizontal></co-number-picker>
132
+ </ng-container>
133
+
134
+ <ng-container *ngIf="!isReturn">
135
+ <co-number-picker *ngIf="!configurable && !configuring" class="quantity-select" [(model)]="quantity" [min]="1" horizontal></co-number-picker>
136
+ </ng-container>
137
+
138
+ <div class="button-wrapper" *ngIf="configurable">
139
+ <co-button class="configure-button"
140
+ [iconData]="iconCache.getIcon(icon.MagicWand)"
141
+ [label]="'CONFIGURE' | localize"
142
+ (onClick)="startConfiguration.emit()"
143
+ ></co-button>
144
+ </div>
145
+ <div class="button-wrapper" *ngIf="showAddToCart && !configurable">
146
+ <co-button #addtocartbutton class="cart-button"
147
+ [iconData]="iconCache.getIcon(icon.AddToCartDrop)"
148
+ [label]="'SHOPPING_CART_IN' | localize"
149
+ (onClick)="handleAddToCartClick(quantity)"
150
+ ></co-button>
151
+ <co-button class="cart-button quote" *ngIf="showQuoteButton"
152
+ [iconData]="iconCache.getIcon(icon.Quote)"
153
+ [label]="'QUOTATION' | localize"
154
+ (onClick)="handleAddToQuoteClick(quantity)"
155
+ ></co-button>
156
+ </div>
157
+ </div>
158
158
  `,
159
159
  styles: [":host{display:flex;flex-direction:column}:host *:not(:last-child){margin-bottom:5px}:host .atc-wrapper{display:flex;flex-direction:row;align-items:baseline}:host .atc-wrapper .quantity-select{margin-right:5px}:host.full-screen .cart-button{position:fixed;right:20px;bottom:20px;z-index:3}::ng-deep co-number-picker{max-width:100px;border:2px solid #f6f5f4;border-radius:5px}::ng-deep co-number-picker ::ng-deep co-input-text{height:50px!important;border:none!important;width:50px!important}::ng-deep co-number-picker ::ng-deep co-input-text:after{display:none}::ng-deep co-number-picker ::ng-deep co-input-text.focused{box-shadow:none!important;border:none!important;background:none!important}::ng-deep co-number-picker ::ng-deep co-input-text .clear-icon{display:none}::ng-deep co-number-picker ::ng-deep co-input-text input{width:100%;text-align:center}::ng-deep co-number-picker ::ng-deep co-button{justify-content:center;padding:0!important;margin:0!important;height:50px!important;background-color:transparent!important}::ng-deep co-number-picker ::ng-deep co-button ::ng-deep co-icon [fill]{fill:#22313c!important}.button-wrapper ::ng-deep co-button{height:50px;max-width:300px;justify-content:center;font-size:15px;border-radius:5px!important;cursor:pointer;padding:0 20px!important}.button-wrapper ::ng-deep co-button:hover{background:#74B77F}::ng-deep co-button.cart-button{border-radius:5px}::ng-deep co-button.cart-button.quote{background:#7292b6}\n"]
160
160
  },] }
@@ -182,4 +182,4 @@ ProductAddtocartComponent.propDecorators = {
182
182
  addToQuoteClick: [{ type: Output }],
183
183
  showRelatedPopup: [{ type: Output }]
184
184
  };
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 _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  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"]}
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';\r\nimport { IconCacheService } from '../../service/icon-cache.service';\r\nimport { IconEnum } from '../../enum/icon.enum';\r\nimport { ArticleQuantity } from '../../model/article-quantity.model';\r\nimport { ProductConnectorService } from '../../service/product-connector.service';\r\nimport { ProductEventService } from '../../service/product-event.service';\r\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\r\nimport {ConfiguratorStatisticsEnvironment} from '@colijnit/articleapi/build/model/configurator-statistics-environment';\r\nimport {ProductSettingsService} from '../../service/product-settings.service';\r\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\r\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\r\nimport {ProductConnectorAdapterService} from '../../service/product-connector-adapter.service';\r\n\r\n@Component({\r\n  selector: 'app-product-addtocart',\r\n  template: `\r\n    <div class=\"atc-wrapper\">\r\n      <ng-container *ngIf=\"isReturn\">\r\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"-100\" horizontal></co-number-picker>\r\n      </ng-container>\r\n\r\n      <ng-container *ngIf=\"!isReturn\">\r\n        <co-number-picker *ngIf=\"!configurable && !configuring\" class=\"quantity-select\" [(model)]=\"quantity\" [min]=\"1\" horizontal></co-number-picker>\r\n      </ng-container>\r\n\r\n      <div class=\"button-wrapper\" *ngIf=\"configurable\">\r\n        <co-button class=\"configure-button\"\r\n                   [iconData]=\"iconCache.getIcon(icon.MagicWand)\"\r\n                   [label]=\"'CONFIGURE' | localize\"\r\n                   (onClick)=\"startConfiguration.emit()\"\r\n        ></co-button>\r\n      </div>\r\n      <div class=\"button-wrapper\" *ngIf=\"showAddToCart && !configurable\">\r\n        <co-button #addtocartbutton class=\"cart-button\"\r\n                   [iconData]=\"iconCache.getIcon(icon.AddToCartDrop)\"\r\n                   [label]=\"'SHOPPING_CART_IN' | localize\"\r\n                   (onClick)=\"handleAddToCartClick(quantity)\"\r\n        ></co-button>\r\n        <co-button class=\"cart-button quote\" *ngIf=\"showQuoteButton\"\r\n                   [iconData]=\"iconCache.getIcon(icon.Quote)\"\r\n                   [label]=\"'QUOTATION' | localize\"\r\n                   (onClick)=\"handleAddToQuoteClick(quantity)\"\r\n        ></co-button>\r\n      </div>\r\n    </div>\r\n  `,\r\n  styleUrls: ['./product-addtocart.component.scss']\r\n})\r\nexport class ProductAddtocartComponent implements OnInit, OnDestroy {\r\n\r\n  public readonly icon: typeof IconEnum = IconEnum;\r\n\r\n  @ViewChild('addtocartbutton', { read: ElementRef })\r\n  public addToCartButton: ElementRef;\r\n\r\n  @Input()\r\n  public article: ArticleFullObject;\r\n\r\n  @Input()\r\n  public externalSource: ExternalSource;\r\n\r\n  @Input()\r\n  public createFrozenArticle: boolean = true;\r\n\r\n  @Input()\r\n  public configurable: boolean = false;\r\n\r\n  @Input()\r\n  public configuring: boolean = false;\r\n\r\n  @Input()\r\n  public showAddToCart: boolean = false;\r\n\r\n  @Input()\r\n  public isReturn: boolean = false;\r\n\r\n  @HostBinding('class.full-screen')\r\n  @Input()\r\n  public fullscreen: boolean = false;\r\n\r\n  @Input()\r\n  public set quantity(value: number) {\r\n    if (this.isReturn) {\r\n      if (this._quantity === 1) {\r\n        this._quantity = -1;\r\n      } else {\r\n        this._quantity = value\r\n      }\r\n    } else {\r\n      this._quantity = Math.max(1, value);\r\n    }\r\n  }\r\n\r\n  public get quantity(): number {\r\n    return this._quantity;\r\n  }\r\n\r\n  @Output()\r\n  public startConfiguration: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public addToCartClick: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @Output()\r\n  public addToQuoteClick: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @Output()\r\n  public showRelatedPopup: EventEmitter<boolean> = new EventEmitter<boolean>()\r\n\r\n  public showQuoteButton: boolean = false;\r\n\r\n  private _quantity = 1;\r\n\r\n  constructor(\r\n    public iconCache: IconCacheService,\r\n    private _ioneControllerService: ProductConnectorService,\r\n    private _appEventService: ProductEventService,\r\n    private _settingsService: ProductSettingsService,\r\n    private _productConnectorAdapterService: ProductConnectorAdapterService\r\n    ) { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.addToCartButton = undefined;\r\n  }\r\n\r\n  public async handleAddToCartClick(quantity: number): Promise<void> {\r\n    if (this.createFrozenArticle) {\r\n      if (this.article.goodType === 'B') {\r\n\r\n        if (this.article.isConfigurable) {\r\n          const article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\r\n          if (article) {\r\n            this._appEventService.onAddToCart.next({article: article, quantity: quantity});\r\n          }\r\n        } else {\r\n          await this._handleGeneratedArticleDirectly(quantity);\r\n        }\r\n      } else {\r\n        let article: ArticleListObjectExtended | string;\r\n        if (!!this.externalSource) {\r\n          article = await this._getJSONFromArticleObject({article: this.article, quantity: quantity});\r\n        } else {\r\n          article = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\r\n        }\r\n        if (article) {\r\n          this._appEventService.onAddToCart.next({article: article, quantity: quantity});\r\n        }\r\n      }\r\n    } else {\r\n      if (this.article.goodType === 'B') {\r\n        if (!this.article.isConfigurable) {\r\n          await this._handleGeneratedArticleDirectly(quantity);\r\n        }\r\n      } else {\r\n        const article: ArticleListObjectExtended = this._ioneControllerService.convertArticleFullObjectToArticleExtended(this.article);\r\n        this._appEventService.onAddToCart.next({ article: article, quantity: quantity });\r\n      }\r\n    }\r\n  }\r\n\r\n  public async handleAddToQuoteClick(quantity: number): Promise<void> {\r\n    this._appEventService.onAddToQuote.next(await this._getJSONFromArticleObject({article: this.article, quantity: quantity}));\r\n  }\r\n\r\n  private async _getJSONFromArticleObject(article: ArticleQuantity): Promise<string> {\r\n    const configuratorStatistics = new ConfiguratorStatisticsEnvironment();\r\n    configuratorStatistics.userType = 'iOneProductPage';\r\n    configuratorStatistics.transactionType = 'Sales';\r\n    configuratorStatistics.actionDomain = 'bundle';\r\n    configuratorStatistics.sessionId = this._settingsService.settings.session ? this._settingsService.settings.session.sessionId : 'unknown';\r\n    configuratorStatistics.webHost = window.location.host;\r\n    configuratorStatistics.bundleHost = window.location.host;\r\n    return await this._ioneControllerService.getJsonArticleFlatTree(\r\n        article.article.goodId, article.article.goodType, article.quantity, !!this.externalSource, true, configuratorStatistics);\r\n  }\r\n\r\n  private async _handleGeneratedArticleDirectly(quantity: number): Promise<void> {\r\n    const generatedGoodId: number = await this._getGeneratedArtDirectly(this.article.goodId);\r\n    if (generatedGoodId) {\r\n      const articleFull: ArticleFullObject = await this._productConnectorAdapterService.getArticleFullObject(generatedGoodId, true);\r\n      const article: ArticleListObjectExtended = this._ioneControllerService.convertArticleFullObjectToArticleExtended(articleFull);\r\n      this._appEventService.onAddToCart.next({article: article, quantity: quantity});\r\n    }\r\n  }\r\n\r\n  private async _getGeneratedArtDirectly(goodId: number): Promise<number> {\r\n    return await this._ioneControllerService.getGeneratedArtDirectly(goodId, true);\r\n  }\r\n}\r\n"]}
@@ -25,15 +25,15 @@ export class ProductDeliveryComponent {
25
25
  ProductDeliveryComponent.decorators = [
26
26
  { type: Component, args: [{
27
27
  selector: 'app-product-delivery',
28
- template: `
29
- <!--<app-header [label]="'DELIVERY_TIME_PERIOD' | localize"></app-header>-->
30
- <div class="product-delivery-wrapper">
31
- <co-icon class="delivery-icon" [iconData]="iconData"></co-icon>
32
- <div class="product-delivery-fields">
33
- <div class="pp-default-label" [textContent]="'DELIVERY_TIME_PERIOD' | localize"></div>
34
- <div class="pp-default-description" [textContent]="deliveryDescription | date:'dd MMMM yyyy'"></div>
35
- </div>
36
- </div>
28
+ template: `
29
+ <!--<app-header [label]="'DELIVERY_TIME_PERIOD' | localize"></app-header>-->
30
+ <div class="product-delivery-wrapper">
31
+ <co-icon class="delivery-icon" [iconData]="iconData"></co-icon>
32
+ <div class="product-delivery-fields">
33
+ <div class="pp-default-label" [textContent]="'DELIVERY_TIME_PERIOD' | localize"></div>
34
+ <div class="pp-default-description" [textContent]="deliveryDescription | date:'dd MMMM yyyy'"></div>
35
+ </div>
36
+ </div>
37
37
  `,
38
38
  styles: [":host{display:block}.product-delivery-wrapper{display:flex;flex-direction:row;align-items:center;border-bottom:1px solid #f6f5f4;padding:20px 15px}.product-delivery-wrapper .delivery-icon{margin:0 15px 0 0;width:40px;height:37px}.product-delivery-wrapper .product-delivery-fields{display:flex;flex-direction:column}.product-delivery-wrapper .product-delivery-fields .pp-default-label{font-size:14px;margin:0}@media screen and (max-width: 400px){.product-delivery-wrapper{padding:15px 0 15px 10px}.product-delivery-wrapper .delivery-icon{margin:0 15px 0 0;width:32px;height:28px}.product-delivery-wrapper .product-delivery-fields .pp-default-label{font-size:13px}}\n"]
39
39
  },] }
@@ -46,4 +46,4 @@ ProductDeliveryComponent.ctorParameters = () => [
46
46
  ProductDeliveryComponent.propDecorators = {
47
47
  stockAndDelivery: [{ type: Input }]
48
48
  };
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1kZWxpdmVyeS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvcHJvZHVjdC1kZWxpdmVyeS9wcm9kdWN0LWRlbGl2ZXJ5LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUVwRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBZ0J4RCxNQUFNLE9BQU8sd0JBQXdCO0lBaUJuQyxZQUNVLGFBQTJCLEVBQzNCLEtBQThCLEVBQzlCLFVBQTRCO1FBRjVCLGtCQUFhLEdBQWIsYUFBYSxDQUFjO1FBQzNCLFVBQUssR0FBTCxLQUFLLENBQXlCO1FBQzlCLGVBQVUsR0FBVixVQUFVLENBQWtCO1FBbEJ0QixTQUFJLEdBQW9CLFFBQVEsQ0FBQztRQW9CL0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFuQkQsSUFDVyxnQkFBZ0IsQ0FBQyxLQUF1QjtRQUNqRCxJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsbUJBQW1CLENBQUM7WUFDckQsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxFQUFFO2dCQUM5RSxJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQzthQUNoRjtTQUNGO0lBQ0gsQ0FBQztJQWFELFFBQVE7SUFDUixDQUFDOzs7WUF4Q0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxzQkFBc0I7Z0JBQ2hDLFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7O2FBRUY7OztZQWZRLFlBQVk7WUFMWix1QkFBdUI7WUFDdkIsZ0JBQWdCOzs7K0JBd0J0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcm9kdWN0Q29ubmVjdG9yU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2UvcHJvZHVjdC1jb25uZWN0b3Iuc2VydmljZSc7XG5pbXBvcnQgeyBJY29uQ2FjaGVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZS9pY29uLWNhY2hlLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7IEljb25FbnVtIH0gZnJvbSAnLi4vLi4vZW51bS9pY29uLmVudW0nO1xuaW1wb3J0IHsgU3RvY2tBbmREZWxpdmVyeSB9IGZyb20gJy4uLy4uL21vZGVsL3N0b2NrLWFuZC1kZWxpdmVyeSc7XG5pbXBvcnQgeyBMb2NhbGl6ZVBpcGUgfSBmcm9tICcuLi8uLi9waXBlL2xvY2FsaXplLnBpcGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtcHJvZHVjdC1kZWxpdmVyeScsXG4gIHRlbXBsYXRlOiBgXG4gICAgPCEtLTxhcHAtaGVhZGVyIFtsYWJlbF09XCInREVMSVZFUllfVElNRV9QRVJJT0QnIHwgbG9jYWxpemVcIj48L2FwcC1oZWFkZXI+LS0+XG4gICAgPGRpdiBjbGFzcz1cInByb2R1Y3QtZGVsaXZlcnktd3JhcHBlclwiPlxuICAgICAgPGNvLWljb24gY2xhc3M9XCJkZWxpdmVyeS1pY29uXCIgW2ljb25EYXRhXT1cImljb25EYXRhXCI+PC9jby1pY29uPlxuICAgICAgPGRpdiBjbGFzcz1cInByb2R1Y3QtZGVsaXZlcnktZmllbGRzXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJwcC1kZWZhdWx0LWxhYmVsXCIgW3RleHRDb250ZW50XT1cIidERUxJVkVSWV9USU1FX1BFUklPRCcgfCBsb2NhbGl6ZVwiPjwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwicHAtZGVmYXVsdC1kZXNjcmlwdGlvblwiIFt0ZXh0Q29udGVudF09XCJkZWxpdmVyeURlc2NyaXB0aW9uIHwgZGF0ZTonZGQgTU1NTSB5eXl5J1wiPjwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3Byb2R1Y3QtZGVsaXZlcnkuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0RGVsaXZlcnlDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIHB1YmxpYyByZWFkb25seSBpY29uOiB0eXBlb2YgSWNvbkVudW0gPSBJY29uRW51bTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IHN0b2NrQW5kRGVsaXZlcnkodmFsdWU6IFN0b2NrQW5kRGVsaXZlcnkpIHtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuZGVsaXZlcnlEZXNjcmlwdGlvbiA9IHZhbHVlLmRlbGl2ZXJ5RGVzY3JpcHRpb247XG4gICAgICBpZiAodGhpcy5kZWxpdmVyeURlc2NyaXB0aW9uLmxlbmd0aCA+IDAgJiYgdGhpcy5kZWxpdmVyeURlc2NyaXB0aW9uWzBdID09PSAnICcpIHtcbiAgICAgICAgdGhpcy5kZWxpdmVyeURlc2NyaXB0aW9uID0gdGhpcy5fbG9jYWxpemVQaXBlLnRyYW5zZm9ybSgnQVNLX0ZPUl9JTkZPUk1BVElPTicpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBkZWxpdmVyeURlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIHB1YmxpYyBpY29uRGF0YTogU2FmZUh0bWw7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfbG9jYWxpemVQaXBlOiBMb2NhbGl6ZVBpcGUsXG4gICAgcHJpdmF0ZSBfaU9uZTogUHJvZHVjdENvbm5lY3RvclNlcnZpY2UsXG4gICAgcHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlXG4gICkge1xuICAgIHRoaXMuaWNvbkRhdGEgPSB0aGlzLl9pY29uQ2FjaGUuZ2V0SWNvbih0aGlzLmljb24uVHJ1Y2spO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cbn1cbiJdfQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1kZWxpdmVyeS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvcHJvZHVjdC1kZWxpdmVyeS9wcm9kdWN0LWRlbGl2ZXJ5LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUVwRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBZ0J4RCxNQUFNLE9BQU8sd0JBQXdCO0lBaUJuQyxZQUNVLGFBQTJCLEVBQzNCLEtBQThCLEVBQzlCLFVBQTRCO1FBRjVCLGtCQUFhLEdBQWIsYUFBYSxDQUFjO1FBQzNCLFVBQUssR0FBTCxLQUFLLENBQXlCO1FBQzlCLGVBQVUsR0FBVixVQUFVLENBQWtCO1FBbEJ0QixTQUFJLEdBQW9CLFFBQVEsQ0FBQztRQW9CL0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFuQkQsSUFDVyxnQkFBZ0IsQ0FBQyxLQUF1QjtRQUNqRCxJQUFJLEtBQUssRUFBRTtZQUNULElBQUksQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsbUJBQW1CLENBQUM7WUFDckQsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxFQUFFO2dCQUM5RSxJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQzthQUNoRjtTQUNGO0lBQ0gsQ0FBQztJQWFELFFBQVE7SUFDUixDQUFDOzs7WUF4Q0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxzQkFBc0I7Z0JBQ2hDLFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7O2FBRUY7OztZQWZRLFlBQVk7WUFMWix1QkFBdUI7WUFDdkIsZ0JBQWdCOzs7K0JBd0J0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFByb2R1Y3RDb25uZWN0b3JTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZS9wcm9kdWN0LWNvbm5lY3Rvci5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSWNvbkNhY2hlU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuaW1wb3J0IHsgSWNvbkVudW0gfSBmcm9tICcuLi8uLi9lbnVtL2ljb24uZW51bSc7XHJcbmltcG9ydCB7IFN0b2NrQW5kRGVsaXZlcnkgfSBmcm9tICcuLi8uLi9tb2RlbC9zdG9jay1hbmQtZGVsaXZlcnknO1xyXG5pbXBvcnQgeyBMb2NhbGl6ZVBpcGUgfSBmcm9tICcuLi8uLi9waXBlL2xvY2FsaXplLnBpcGUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtcHJvZHVjdC1kZWxpdmVyeScsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgIDwhLS08YXBwLWhlYWRlciBbbGFiZWxdPVwiJ0RFTElWRVJZX1RJTUVfUEVSSU9EJyB8IGxvY2FsaXplXCI+PC9hcHAtaGVhZGVyPi0tPlxyXG4gICAgPGRpdiBjbGFzcz1cInByb2R1Y3QtZGVsaXZlcnktd3JhcHBlclwiPlxyXG4gICAgICA8Y28taWNvbiBjbGFzcz1cImRlbGl2ZXJ5LWljb25cIiBbaWNvbkRhdGFdPVwiaWNvbkRhdGFcIj48L2NvLWljb24+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJwcm9kdWN0LWRlbGl2ZXJ5LWZpZWxkc1wiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJwcC1kZWZhdWx0LWxhYmVsXCIgW3RleHRDb250ZW50XT1cIidERUxJVkVSWV9USU1FX1BFUklPRCcgfCBsb2NhbGl6ZVwiPjwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJwcC1kZWZhdWx0LWRlc2NyaXB0aW9uXCIgW3RleHRDb250ZW50XT1cImRlbGl2ZXJ5RGVzY3JpcHRpb24gfCBkYXRlOidkZCBNTU1NIHl5eXknXCI+PC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgYCxcclxuICBzdHlsZVVybHM6IFsnLi9wcm9kdWN0LWRlbGl2ZXJ5LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFByb2R1Y3REZWxpdmVyeUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIHB1YmxpYyByZWFkb25seSBpY29uOiB0eXBlb2YgSWNvbkVudW0gPSBJY29uRW51bTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2V0IHN0b2NrQW5kRGVsaXZlcnkodmFsdWU6IFN0b2NrQW5kRGVsaXZlcnkpIHtcclxuICAgIGlmICh2YWx1ZSkge1xyXG4gICAgICB0aGlzLmRlbGl2ZXJ5RGVzY3JpcHRpb24gPSB2YWx1ZS5kZWxpdmVyeURlc2NyaXB0aW9uO1xyXG4gICAgICBpZiAodGhpcy5kZWxpdmVyeURlc2NyaXB0aW9uLmxlbmd0aCA+IDAgJiYgdGhpcy5kZWxpdmVyeURlc2NyaXB0aW9uWzBdID09PSAnICcpIHtcclxuICAgICAgICB0aGlzLmRlbGl2ZXJ5RGVzY3JpcHRpb24gPSB0aGlzLl9sb2NhbGl6ZVBpcGUudHJhbnNmb3JtKCdBU0tfRk9SX0lORk9STUFUSU9OJyk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBkZWxpdmVyeURlc2NyaXB0aW9uOiBzdHJpbmc7XHJcbiAgcHVibGljIGljb25EYXRhOiBTYWZlSHRtbDtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIF9sb2NhbGl6ZVBpcGU6IExvY2FsaXplUGlwZSxcclxuICAgIHByaXZhdGUgX2lPbmU6IFByb2R1Y3RDb25uZWN0b3JTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlXHJcbiAgKSB7XHJcbiAgICB0aGlzLmljb25EYXRhID0gdGhpcy5faWNvbkNhY2hlLmdldEljb24odGhpcy5pY29uLlRydWNrKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gIH1cclxufVxyXG4iXX0=