@colijnit/product 258.1.0 → 258.1.2

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/app/components/product-page/product-page.component.d.ts +1 -0
  2. package/app/components/product-selector-type/product-selector-type.component.d.ts +1 -0
  3. package/app/components/render-carousel/render-carousel.component.d.ts +40 -0
  4. package/app/components/render-carousel/render-carousel.module.d.ts +2 -0
  5. package/app/enum/icon.enum.d.ts +2 -0
  6. package/app/ione-product.component.d.ts +5 -11
  7. package/app/model/productSettings.d.ts +2 -14
  8. package/app/service/product-event.service.d.ts +2 -0
  9. package/bundles/colijnit-product.umd.js +553 -414
  10. package/bundles/colijnit-product.umd.js.map +1 -1
  11. package/colijnit-product-258.1.1.tgz +0 -0
  12. package/colijnit-product.d.ts +6 -4
  13. package/colijnit-product.metadata.json +1 -1
  14. package/esm2015/app/components/image-carousel/image-carousel.component.js +2 -1
  15. package/esm2015/app/components/product-page/product-page.component.js +8 -3
  16. package/esm2015/app/components/product-page/product-page.module.js +4 -2
  17. package/esm2015/app/components/product-selector-type/product-selector-type.component.js +10 -2
  18. package/esm2015/app/components/render-carousel/render-carousel.component.js +127 -0
  19. package/esm2015/app/components/render-carousel/render-carousel.module.js +25 -0
  20. package/esm2015/app/enum/icon.enum.js +3 -1
  21. package/esm2015/app/ione-product.component.js +26 -27
  22. package/esm2015/app/ione-product.module.js +3 -13
  23. package/esm2015/app/model/icon.js +3 -1
  24. package/esm2015/app/model/productSettings.js +4 -6
  25. package/esm2015/app/product-version.js +3 -3
  26. package/esm2015/app/service/product-event.service.js +3 -1
  27. package/esm2015/colijnit-product.js +7 -5
  28. package/fesm2015/colijnit-product.js +488 -333
  29. package/fesm2015/colijnit-product.js.map +1 -1
  30. package/package.json +1 -1
@@ -140,6 +140,7 @@ export class ImageCarouselComponent {
140
140
  const resizeCanvas = document.createElement('canvas');
141
141
  const resizeCanvasContext = resizeCanvas.getContext('2d');
142
142
  const resizeImage = document.createElement('img');
143
+ resizeImage.crossOrigin = 'anonymous';
143
144
  resizeImage.onload = () => __awaiter(this, void 0, void 0, function* () {
144
145
  resizeCanvasContext.imageSmoothingEnabled = true;
145
146
  resizeCanvasContext.imageSmoothingQuality = 'high';
@@ -238,4 +239,4 @@ ImageCarouselComponent.propDecorators = {
238
239
  gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
239
240
  resizing: [{ type: HostBinding, args: ['class.resizing',] }]
240
241
  };
241
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/image-carousel/image-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  ViewChild\n} from '@angular/core';\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {Subscription} from 'rxjs';\nimport {IconEnum} from '../../enum/icon.enum';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\n\nexport class ImageViewModel {\n  public image: CoDocument | string;\n  public source: SafeUrl;\n  public originalSource: string;\n}\n\n@Component({\n  selector: 'app-image-carousel',\n  template: `\n      <div id=\"product_page_carousel\">\n          <div id=\"product_page_carousel_items\">\n              <co-loader [isShown]=\"true\" *ngIf=\"showLoader\"></co-loader>\n              <div #carousel class=\"inner-carousel\">\n                  <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\n                  <div *ngIf=\"imageViewModels[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\" (click)=\"handleShowImage(imageViewModels[0])\">\n                      <img [src]=\"imageViewModels[0].source\">\n                  </div>\n                  <div *ngFor=\"let imageViewModel of imageViewModels.slice(1); let index = index\" class=\"carousel-item\"\n                       [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\" (click)=\"handleShowImage(imageViewModel)\">\n                      <img [src]=\"imageViewModel.source\">\n                  </div>\n                  <div class=\"carousel-scroller-layer\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                      <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\n                      <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\n                  </div>\n              </div>\n              <!--\n                      <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\n              -->\n          </div>\n\n          <div id=\"product_page_carousel_thumbs\">\n              <co-scroll-container class=\"scroll-container\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                  <div *ngFor=\"let imageViewModel of imageViewModels; let index = index\" class=\"carousel-thumb\"\n                       [class.active]=\"index === currentIndex\">\n                      <img [src]=\"imageViewModel.source\" (click)=\"handleThumbClick(index)\"/>\n                  </div>\n              </co-scroll-container>\n          </div>\n      </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['./image-carousel.component.scss']\n})\nexport class ImageCarouselComponent implements OnDestroy {\n  @ViewChild('carousel', {read: ElementRef})\n  public carousel: ElementRef;\n\n  @Input()\n  public showRefresh: boolean = false;\n\n  @Input()\n  public set images(value: (CoDocument | string)[]) {\n    if (value && value.length > 0) {\n      this._images = this._filterValidImages(value);\n      this._loadAndRescaleImages();\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  public get images(): (CoDocument | string)[] {\n    return this._images;\n  }\n\n  @HostListener('window:resize')\n  public handleWindowResize(): void {\n    this.resizing = true;\n    this._scrollCarouselToIndex();\n    clearTimeout(this._resizeTimer);\n    this._resizeTimer = setTimeout(() => {\n      this.resizing = false;\n    }, 200);\n  }\n\n  @HostListener('swipeleft')\n  public gotoNextSlide(): void {\n    this.currentIndex++;\n  }\n\n  @HostListener('swiperight')\n  public gotoPrevSlide(): void {\n    this.currentIndex--;\n  }\n\n  public isCurrentIndex(index: number): boolean {\n    return this.currentIndex === index;\n  }\n\n  public get currentIndex(): number {\n    return this._currentIndex;\n  }\n\n  public set currentIndex(value: number) {\n    this._currentIndex = value;\n    this._scrollCarouselToIndex();\n  }\n\n  @HostBinding('class.resizing')\n  public resizing = false;\n\n  public imageViewModels: ImageViewModel[] = [];\n  public showLoader: boolean = false;\n\n  private _resizeTimer: any;\n  private _currentIndex = 0;\n  private _images: (CoDocument | string)[] = [];\n  private _subs: Subscription[] = [];\n\n  private _resizeCanvasHeight: number = 500;\n\n  constructor(\n    private _ione: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _changeDetector: ChangeDetectorRef,\n    private _domSanitizer: DomSanitizer\n  ) {\n    this._subs.push(\n      this._appEventService.onRenderStarted.subscribe(() => {\n        this.showLoader = true;\n        this._changeDetector.detectChanges();\n        setTimeout(() => {\n          this.showLoader = false;\n          this._changeDetector.detectChanges();\n        }, 10000);\n      }),\n      this._appEventService.onDraftRenderImageReceived.subscribe((event: CustomEvent) => {\n        if (event && event.detail) {\n          if (this._images[0] instanceof CoDocument) {\n            this._images.unshift(event.detail);\n          } else {\n            this._images[0] = event.detail;\n          }\n          this._loadAndRescaleImages();\n        }\n        this.showLoader = false;\n        this._changeDetector.detectChanges();\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.carousel = undefined;\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  public handleThumbClick(index: number): void {\n    this.currentIndex = index;\n  }\n\n  public onForceRenderImage(): void {\n    this._appEventService.onForceRenderImage.next();\n  }\n\n  public handleShowImage(imageViewModel: ImageViewModel): void {\n    if (imageViewModel && imageViewModel.originalSource) {\n      let popupWindow: Window = window.open('', 'Image zoom', 'width=600,height=400');\n      // Set the content of the popup window\n      popupWindow.document.write('<html><head><title>Image zoom</title></head><body>');\n      popupWindow.document.write(`<img src=${imageViewModel.originalSource} alt=\"Image\" style=\"width:100%; height:auto;\">`);\n      popupWindow.document.write('</body></html>');\n      // Close the document to render the popup window\n      popupWindow.document.close();\n    }\n  }\n\n  private _filterValidImages(value: (CoDocument | string)[]): (CoDocument | string)[] {\n    if (!value) {\n      return [];\n    }\n    return value.filter((doc: CoDocument | string) => {\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\n      return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);\n    });\n  }\n\n  private _loadAndRescaleImages(): void {\n    this.imageViewModels.length = 0;\n    if (this._images) {\n      this._images.forEach((i: CoDocument | string) => {\n        let imageViewModel = new ImageViewModel();\n        imageViewModel.image = i;\n        if (typeof i === 'string') { // is a rendered image coming from configurator\n          this._resizeAndSanitizeSource(i, imageViewModel);\n        } else {\n          if (i.filePath) {\n            this._resizeAndSanitizeSource(i.filePath, imageViewModel);\n          } else if (i.documentBody) {\n            this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n          } else {\n            this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\n              if (content) {\n                i.documentBody = content.documentContent;\n                this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n                this._changeDetector.detectChanges();\n              }\n            });\n          }\n        }\n        this.imageViewModels.push(imageViewModel);\n        this._changeDetector.detectChanges();\n      });\n    }\n  }\n\n  private _resizeAndSanitizeSource(source: string, imageViewModel: ImageViewModel): void {\n    const resizeCanvas: HTMLCanvasElement = document.createElement('canvas');\n    const resizeCanvasContext: CanvasRenderingContext2D = resizeCanvas.getContext('2d');\n    const resizeImage: HTMLImageElement = document.createElement('img');\n    resizeImage.onload = async () => {\n      resizeCanvasContext.imageSmoothingEnabled = true;\n      resizeCanvasContext.imageSmoothingQuality = 'high';\n      // Get the original image dimensions\n      const originalWidth = resizeImage.width;\n      const originalHeight = resizeImage.height;\n\n      // Calculate the aspect ratio\n      const aspectRatio = originalWidth / originalHeight;\n\n      // Calculate the new width and height while maintaining the aspect ratio\n      let newWidth: number = this._resizeCanvasHeight;\n      let newHeight: number = this._resizeCanvasHeight;\n\n      if (originalWidth > originalHeight) {\n        newHeight = this._resizeCanvasHeight / aspectRatio;\n      } else {\n        newWidth = this._resizeCanvasHeight * aspectRatio;\n      }\n\n      // Set the canvas size to the new width and height\n      resizeCanvas.width = newWidth;\n      resizeCanvas.height = newHeight;\n\n      const imageWidth: number = this._resizeCanvasHeight * (resizeImage.height / resizeImage.width);\n      resizeCanvasContext.drawImage(resizeImage, 0, 0, newWidth, newHeight);\n      const resizedSource = resizeCanvas.toDataURL('image/jpeg');\n\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\n      imageViewModel.originalSource = source;\n      this._changeDetector.detectChanges();\n    };\n    // @ts-ignore\n    resizeImage.src = source;\n  }\n\n  private _scrollCarouselToIndex(): void {\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\n      if (this.carousel && this.carousel.nativeElement) {\n        this.carousel.nativeElement.scrollLeft = movePx;\n        // this.carousel.nativeElement.scrollTo({\n        //   left: movePx,\n        //   behavior: 'smooth'\n        // });\n      }\n    }\n  }\n\n}\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/image-carousel/image-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  ViewChild\n} from '@angular/core';\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {Subscription} from 'rxjs';\nimport {IconEnum} from '../../enum/icon.enum';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\n\nexport class ImageViewModel {\n  public image: CoDocument | string;\n  public source: SafeUrl;\n  public originalSource: string;\n}\n\n@Component({\n  selector: 'app-image-carousel',\n  template: `\n      <div id=\"product_page_carousel\">\n          <div id=\"product_page_carousel_items\">\n              <co-loader [isShown]=\"true\" *ngIf=\"showLoader\"></co-loader>\n              <div #carousel class=\"inner-carousel\">\n                  <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\n                  <div *ngIf=\"imageViewModels[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\" (click)=\"handleShowImage(imageViewModels[0])\">\n                      <img [src]=\"imageViewModels[0].source\">\n                  </div>\n                  <div *ngFor=\"let imageViewModel of imageViewModels.slice(1); let index = index\" class=\"carousel-item\"\n                       [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\" (click)=\"handleShowImage(imageViewModel)\">\n                      <img [src]=\"imageViewModel.source\">\n                  </div>\n                  <div class=\"carousel-scroller-layer\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                      <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\n                      <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\n                  </div>\n              </div>\n              <!--\n                      <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\n              -->\n          </div>\n\n          <div id=\"product_page_carousel_thumbs\">\n              <co-scroll-container class=\"scroll-container\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                  <div *ngFor=\"let imageViewModel of imageViewModels; let index = index\" class=\"carousel-thumb\"\n                       [class.active]=\"index === currentIndex\">\n                      <img [src]=\"imageViewModel.source\" (click)=\"handleThumbClick(index)\"/>\n                  </div>\n              </co-scroll-container>\n          </div>\n      </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['./image-carousel.component.scss']\n})\nexport class ImageCarouselComponent implements OnDestroy {\n  @ViewChild('carousel', {read: ElementRef})\n  public carousel: ElementRef;\n\n  @Input()\n  public showRefresh: boolean = false;\n\n  @Input()\n  public set images(value: (CoDocument | string)[]) {\n    if (value && value.length > 0) {\n      this._images = this._filterValidImages(value);\n      this._loadAndRescaleImages();\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  public get images(): (CoDocument | string)[] {\n    return this._images;\n  }\n\n  @HostListener('window:resize')\n  public handleWindowResize(): void {\n    this.resizing = true;\n    this._scrollCarouselToIndex();\n    clearTimeout(this._resizeTimer);\n    this._resizeTimer = setTimeout(() => {\n      this.resizing = false;\n    }, 200);\n  }\n\n  @HostListener('swipeleft')\n  public gotoNextSlide(): void {\n    this.currentIndex++;\n  }\n\n  @HostListener('swiperight')\n  public gotoPrevSlide(): void {\n    this.currentIndex--;\n  }\n\n  public isCurrentIndex(index: number): boolean {\n    return this.currentIndex === index;\n  }\n\n  public get currentIndex(): number {\n    return this._currentIndex;\n  }\n\n  public set currentIndex(value: number) {\n    this._currentIndex = value;\n    this._scrollCarouselToIndex();\n  }\n\n  @HostBinding('class.resizing')\n  public resizing = false;\n\n  public imageViewModels: ImageViewModel[] = [];\n  public showLoader: boolean = false;\n\n  private _resizeTimer: any;\n  private _currentIndex = 0;\n  private _images: (CoDocument | string)[] = [];\n  private _subs: Subscription[] = [];\n\n  private _resizeCanvasHeight: number = 500;\n\n  constructor(\n    private _ione: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _changeDetector: ChangeDetectorRef,\n    private _domSanitizer: DomSanitizer\n  ) {\n    this._subs.push(\n      this._appEventService.onRenderStarted.subscribe(() => {\n        this.showLoader = true;\n        this._changeDetector.detectChanges();\n        setTimeout(() => {\n          this.showLoader = false;\n          this._changeDetector.detectChanges();\n        }, 10000);\n      }),\n      this._appEventService.onDraftRenderImageReceived.subscribe((event: CustomEvent) => {\n        if (event && event.detail) {\n          if (this._images[0] instanceof CoDocument) {\n            this._images.unshift(event.detail);\n          } else {\n            this._images[0] = event.detail;\n          }\n          this._loadAndRescaleImages();\n        }\n        this.showLoader = false;\n        this._changeDetector.detectChanges();\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.carousel = undefined;\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  public handleThumbClick(index: number): void {\n    this.currentIndex = index;\n  }\n\n  public onForceRenderImage(): void {\n    this._appEventService.onForceRenderImage.next();\n  }\n\n  public handleShowImage(imageViewModel: ImageViewModel): void {\n    if (imageViewModel && imageViewModel.originalSource) {\n      let popupWindow: Window = window.open('', 'Image zoom', 'width=600,height=400');\n      // Set the content of the popup window\n      popupWindow.document.write('<html><head><title>Image zoom</title></head><body>');\n      popupWindow.document.write(`<img src=${imageViewModel.originalSource} alt=\"Image\" style=\"width:100%; height:auto;\">`);\n      popupWindow.document.write('</body></html>');\n      // Close the document to render the popup window\n      popupWindow.document.close();\n    }\n  }\n\n  private _filterValidImages(value: (CoDocument | string)[]): (CoDocument | string)[] {\n    if (!value) {\n      return [];\n    }\n    return value.filter((doc: CoDocument | string) => {\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\n      return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);\n    });\n  }\n\n  private _loadAndRescaleImages(): void {\n    this.imageViewModels.length = 0;\n    if (this._images) {\n      this._images.forEach((i: CoDocument | string) => {\n        let imageViewModel = new ImageViewModel();\n        imageViewModel.image = i;\n        if (typeof i === 'string') { // is a rendered image coming from configurator\n          this._resizeAndSanitizeSource(i, imageViewModel);\n        } else {\n          if (i.filePath) {\n            this._resizeAndSanitizeSource(i.filePath, imageViewModel);\n          } else if (i.documentBody) {\n            this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n          } else {\n            this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\n              if (content) {\n                i.documentBody = content.documentContent;\n                this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n                this._changeDetector.detectChanges();\n              }\n            });\n          }\n        }\n        this.imageViewModels.push(imageViewModel);\n        this._changeDetector.detectChanges();\n      });\n    }\n  }\n\n  private _resizeAndSanitizeSource(source: string, imageViewModel: ImageViewModel): void {\n    const resizeCanvas: HTMLCanvasElement = document.createElement('canvas');\n    const resizeCanvasContext: CanvasRenderingContext2D = resizeCanvas.getContext('2d');\n    const resizeImage: HTMLImageElement = document.createElement('img');\n    resizeImage.crossOrigin = 'anonymous';\n    resizeImage.onload = async () => {\n      resizeCanvasContext.imageSmoothingEnabled = true;\n      resizeCanvasContext.imageSmoothingQuality = 'high';\n      // Get the original image dimensions\n      const originalWidth = resizeImage.width;\n      const originalHeight = resizeImage.height;\n\n      // Calculate the aspect ratio\n      const aspectRatio = originalWidth / originalHeight;\n\n      // Calculate the new width and height while maintaining the aspect ratio\n      let newWidth: number = this._resizeCanvasHeight;\n      let newHeight: number = this._resizeCanvasHeight;\n\n      if (originalWidth > originalHeight) {\n        newHeight = this._resizeCanvasHeight / aspectRatio;\n      } else {\n        newWidth = this._resizeCanvasHeight * aspectRatio;\n      }\n\n      // Set the canvas size to the new width and height\n      resizeCanvas.width = newWidth;\n      resizeCanvas.height = newHeight;\n\n      const imageWidth: number = this._resizeCanvasHeight * (resizeImage.height / resizeImage.width);\n      resizeCanvasContext.drawImage(resizeImage, 0, 0, newWidth, newHeight);\n      const resizedSource = resizeCanvas.toDataURL('image/jpeg');\n\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\n      imageViewModel.originalSource = source;\n      this._changeDetector.detectChanges();\n    };\n    // @ts-ignore\n    resizeImage.src = source;\n  }\n\n  private _scrollCarouselToIndex(): void {\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\n      if (this.carousel && this.carousel.nativeElement) {\n        this.carousel.nativeElement.scrollLeft = movePx;\n        // this.carousel.nativeElement.scrollTo({\n        //   left: movePx,\n        //   behavior: 'smooth'\n        // });\n      }\n    }\n  }\n\n}\n"]}
@@ -44,6 +44,10 @@ export class ProductPageComponent {
44
44
  else {
45
45
  this.showAddToCart = true;
46
46
  }
47
+ }), this.appEventService.onGetRenderForRenderCarousel.subscribe((renderParameters) => {
48
+ if (this.selections.nativeElement) {
49
+ this.selections.nativeElement.getRenderForRenderCarousel(renderParameters);
50
+ }
47
51
  }));
48
52
  }
49
53
  set sku(value) {
@@ -177,7 +181,7 @@ export class ProductPageComponent {
177
181
  ProductPageComponent.decorators = [
178
182
  { type: Component, args: [{
179
183
  selector: 'app-product-page',
180
- template: "<ng-container *ngIf=\"settingsLoaded\">\r\n <div class=\"page-wrapper\">\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <div class=\"product-image-container\">\r\n <div class=\"product-page-block-selector-type\">\r\n <app-product-selector-type class=\"default-padding\"\r\n [(currentType)]=\"currentView\"\r\n [show2D]=\"configurable\"\r\n [show3D]=\"threeD\"\r\n ></app-product-selector-type>\r\n </div>\r\n <div class=\"product-page-block-image default-padding\" [class.full]=\"fullScreen\">\r\n <app-image-carousel [@toggleVisibilityByState]=\"show2D ? 'show' : 'hide'\" [images]=\"article?.images\" [showRefresh]=\"configurable && threeD\"></app-image-carousel>\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-configurator #configurator class=\"threed-configurator\"\r\n [class.configurator-full-screen]=\"fullScreen\"\r\n [@toggleVisibilityByState]=\"show3D ? 'show' : 'hide'\"\r\n [@toggleFullScreen]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n ></threed-configurator>\r\n </ng-container>\r\n <co-icon #fullscreenbutton class=\"fullscreen-button\" *ngIf=\"show3D\"\r\n [@toggleTopLeft]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [iconData]=\"iconCache.getIcon(fullScreenIcon)\"\r\n (click)=\"showFullScreen()\"></co-icon>\r\n <co-icon class=\"threed-watermark\" *ngIf=\"show3D && fullScreen\"\r\n [iconData]=\"iconCache.getIcon(icon.Logo)\"></co-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-description\">\r\n <app-product-description class=\"default-padding\" [article]=\"article\"></app-product-description>\r\n </div>\r\n <div class=\"product-page-block-additional\">\r\n <div class=\"product-page-block-additional-description\">\r\n <app-product-additional-description class=\"default-padding\" [article]=\"article\"></app-product-additional-description>\r\n </div>\r\n <div class=\"product-page-block-price\" [class.full]=\"configuring\">\r\n <app-product-price class=\"s-padding\" *ngIf=\"!configuring\"\r\n [pricing]=\"article?.pricing\"\r\n [configurable]=\"configurable\"\r\n ></app-product-price>\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-selections #selections class=\"threed-selections\" [class.show-selections]=\"configuring\" [@toggleFullScreenRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [class.default-padding]=\"!fullScreen\"\r\n [class.show-full-screen]=\"fullScreen\"\r\n [class.mini-scrollbar]=\"fullScreen\"\r\n [sku]=\"sku\"\r\n [settings]=\"settings\"\r\n (onUserActionFromThreeD)=\"configuring = true\"\r\n (instanceSet)=\"setInstance($event)\"\r\n (onImageReceived)=\"appEventService.onImageReceived.next($event)\"\r\n (onRenderStarted)=\"appEventService.onRenderStarted.next()\"\r\n (onDraftRenderImageReceived)=\"appEventService.onDraftRenderImageReceived.next($event)\"\r\n (onArticleReceived)=\"appEventService.onArticleReceived.next($event.detail)\"\r\n (onSelectionsReceived)=\"appEventService.onSelectionsReceived.next($event.detail)\"\r\n (onArticleInfoReceived)=\"appEventService.onArticleInfoReceived.next($event.detail)\"\r\n (onAnswersAvailable)=\"appEventService.onAnswersAvailable.next($event.detail)\"\r\n ></threed-selections>\r\n </ng-container>\r\n </div>\r\n <div class=\"product-page-block-addtocart no-padding product-action-buttons\" *ngIf=\"!configuring\" [@toggleTopRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\">\r\n <app-product-addtocart\r\n [configurable]=\"configurable\"\r\n [createFrozenArticle]=\"createFrozenArticle\"\r\n [configuring]=\"configuring\"\r\n [showAddToCart]=\"showAddToCart\"\r\n [article]=\"article\"\r\n [externalSource]=\"externalSource\"\r\n [isReturn]=\"isReturn\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n (showRelatedPopup)=\"handlePopUpChange($event)\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"addtocart-reserved product-action-buttons\" *ngIf=\"configuring\" [class.full-screen]=\"fullScreen\">\r\n <app-product-addtocart class=\"default-padding\"\r\n [configurable]=\"false\"\r\n [fullscreen]=\"fullScreen\"\r\n [showAddToCart]=\"showAddToCart\"\r\n [configuring]=\"configuring\"\r\n [article]=\"article\"\r\n [externalSource]=\"externalSource\"\r\n [isReturn]=\"isReturn\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"product-page-block-variants\">\r\n <app-product-related class=\"no-padding\" *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\" [refType]=\"64\" [label]=\"'VARIANTS' | localize\"></app-product-related>\r\n </div>\r\n <div class=\"product-page-block-stock\">\r\n <app-product-stock class=\"no-padding\" [goodId]=\"article?.goodId\" (openStockEvent)=\"openStock()\"></app-product-stock>\r\n </div>\r\n <div class=\"product-page-block-delivery\">\r\n <app-product-delivery class=\"no-padding\" [stockAndDelivery]=\"stockAndDelivery\"></app-product-delivery>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <app-product-info-tabs class=\"no-padding\" [article]=\"article\"></app-product-info-tabs>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-related s-padding\">\r\n <app-product-related\r\n *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"1\"\r\n [label]=\"'RELATED_PRODUCTS' | localize\">\r\n </app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content no-top-margin\">\r\n <div class=\"page-wrapper-full\">\r\n <div class=\"product-page-block-alternatives s-padding\">\r\n <app-product-related\r\n *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"4\"\r\n [isSmallModus]=\"false\"\r\n [label]=\"'ALTERNATIVE_PRODUCTS' | localize\">\r\n </app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"showRelatedProductsPopup\">\r\n <co-product-dialog\r\n [mainArticle]=\"article\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"1\"\r\n (closeRelatedPopup)=\"handlePopUpChange($event)\"\r\n >\r\n </co-product-dialog>\r\n\r\n<!-- <app-product-related class=\"no-padding\" *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"-->\r\n<!-- [articles]=\"article?.relatedArticles\" [refType]=\"64\" [label]=\"'VARIANTS' | localize\"></app-product-related>-->\r\n </div>\r\n\r\n\r\n </div>\r\n</ng-container>\r\n",
184
+ template: "<ng-container *ngIf=\"settingsLoaded\">\r\n <div class=\"page-wrapper\">\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <div class=\"product-image-container\">\r\n <div class=\"product-page-block-selector-type\">\r\n <app-product-selector-type class=\"default-padding\"\r\n [(currentType)]=\"currentView\"\r\n [show2D]=\"configurable\"\r\n [show3D]=\"threeD\"\r\n ></app-product-selector-type>\r\n </div>\r\n <div class=\"product-page-block-image default-padding\" [class.full]=\"fullScreen\">\r\n\r\n <app-image-carousel\r\n *ngIf=\"!enableRenderCarousel\"\r\n [@toggleVisibilityByState]=\"show2D ? 'show' : 'hide'\"\r\n [images]=\"article?.images\"\r\n [showRefresh]=\"configurable && threeD\">\r\n </app-image-carousel>\r\n\r\n <app-render-carousel\r\n *ngIf=\"enableRenderCarousel\"\r\n [@toggleVisibilityByState]=\"show2D ? 'show' : 'hide'\"\r\n [article]=\"article\">\r\n </app-render-carousel>\r\n\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-configurator\r\n #configurator\r\n class=\"threed-configurator\"\r\n [class.configurator-full-screen]=\"fullScreen\"\r\n [@toggleVisibilityByState]=\"show3D ? 'show' : 'hide'\"\r\n [@toggleFullScreen]=\"fullScreen ? 'fullscreen' : 'halfscreen'\">\r\n </threed-configurator>\r\n </ng-container>\r\n\r\n <co-icon #fullscreenbutton class=\"fullscreen-button\" *ngIf=\"show3D\"\r\n [@toggleTopLeft]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [iconData]=\"iconCache.getIcon(fullScreenIcon)\"\r\n (click)=\"showFullScreen()\"></co-icon>\r\n <co-icon class=\"threed-watermark\" *ngIf=\"show3D && fullScreen\"\r\n [iconData]=\"iconCache.getIcon(icon.Logo)\"></co-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-description\">\r\n <app-product-description class=\"default-padding\" [article]=\"article\"></app-product-description>\r\n </div>\r\n <div class=\"product-page-block-additional\">\r\n <div class=\"product-page-block-additional-description\">\r\n <app-product-additional-description class=\"default-padding\" [article]=\"article\"></app-product-additional-description>\r\n </div>\r\n <div class=\"product-page-block-price\" [class.full]=\"configuring\">\r\n <app-product-price class=\"s-padding\" *ngIf=\"!configuring\"\r\n [pricing]=\"article?.pricing\"\r\n [configurable]=\"configurable\"\r\n ></app-product-price>\r\n <ng-container *ngIf=\"settingsLoaded\">\r\n <threed-selections #selections class=\"threed-selections\"\r\n [class.show-selections]=\"configuring\"\r\n [@toggleFullScreenRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\"\r\n [class.default-padding]=\"!fullScreen\"\r\n [class.show-full-screen]=\"fullScreen\"\r\n [class.mini-scrollbar]=\"fullScreen\"\r\n [sku]=\"sku\"\r\n [settings]=\"settings\"\r\n (onUserActionFromThreeD)=\"configuring = true\"\r\n (instanceSet)=\"setInstance($event)\"\r\n (onImageReceived)=\"appEventService.onImageReceived.next($event)\"\r\n (onRenderStarted)=\"appEventService.onRenderStarted.next()\"\r\n (onDraftRenderImageReceived)=\"appEventService.onDraftRenderImageReceived.next($event)\"\r\n (onArticleReceived)=\"appEventService.onArticleReceived.next($event.detail)\"\r\n (onSelectionsReceived)=\"appEventService.onSelectionsReceived.next($event.detail)\"\r\n (onArticleInfoReceived)=\"appEventService.onArticleInfoReceived.next($event.detail)\"\r\n (onAnswersAvailable)=\"appEventService.onAnswersAvailable.next($event.detail)\"\r\n (onReadyToRender)=\"appEventService.onReadyToRender.next($event.detail)\"\r\n (onRenderImageReceived)=\"appEventService.onRenderImageReceived.next($event.detail)\"\r\n ></threed-selections>\r\n </ng-container>\r\n </div>\r\n <div class=\"product-page-block-addtocart no-padding product-action-buttons\" *ngIf=\"!configuring\" [@toggleTopRight]=\"fullScreen ? 'fullscreen' : 'halfscreen'\">\r\n <app-product-addtocart\r\n [configurable]=\"configurable\"\r\n [createFrozenArticle]=\"createFrozenArticle\"\r\n [configuring]=\"configuring\"\r\n [showAddToCart]=\"showAddToCart\"\r\n [article]=\"article\"\r\n [externalSource]=\"externalSource\"\r\n [isReturn]=\"isReturn\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n (showRelatedPopup)=\"handlePopUpChange($event)\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"addtocart-reserved product-action-buttons\" *ngIf=\"configuring\" [class.full-screen]=\"fullScreen\">\r\n <app-product-addtocart class=\"default-padding\"\r\n [configurable]=\"false\"\r\n [fullscreen]=\"fullScreen\"\r\n [showAddToCart]=\"showAddToCart\"\r\n [configuring]=\"configuring\"\r\n [article]=\"article\"\r\n [externalSource]=\"externalSource\"\r\n [isReturn]=\"isReturn\"\r\n (startConfiguration)=\"handleStartConfiguration()\"\r\n ></app-product-addtocart>\r\n </div>\r\n <div class=\"product-page-block-variants\">\r\n <app-product-related class=\"no-padding\" *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\" [refType]=\"64\" [label]=\"'VARIANTS' | localize\"></app-product-related>\r\n </div>\r\n <div class=\"product-page-block-stock\">\r\n <app-product-stock class=\"no-padding\" [goodId]=\"article?.goodId\" (openStockEvent)=\"openStock()\"></app-product-stock>\r\n </div>\r\n <div class=\"product-page-block-delivery\">\r\n <app-product-delivery class=\"no-padding\" [stockAndDelivery]=\"stockAndDelivery\"></app-product-delivery>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content\">\r\n <div class=\"page-wrapper-left\">\r\n <app-product-info-tabs class=\"no-padding\" [article]=\"article\"></app-product-info-tabs>\r\n </div>\r\n <div class=\"page-wrapper-right\">\r\n <div class=\"product-page-block-related s-padding\">\r\n <app-product-related\r\n *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"1\"\r\n [label]=\"'RELATED_PRODUCTS' | localize\">\r\n </app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"page-wrapper-content no-top-margin\">\r\n <div class=\"page-wrapper-full\">\r\n <div class=\"product-page-block-alternatives s-padding\">\r\n <app-product-related\r\n *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"\r\n [externalSource]=\"externalSource\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"4\"\r\n [isSmallModus]=\"false\"\r\n [label]=\"'ALTERNATIVE_PRODUCTS' | localize\">\r\n </app-product-related>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div *ngIf=\"showRelatedProductsPopup\">\r\n <co-product-dialog\r\n [mainArticle]=\"article\"\r\n [articles]=\"article?.relatedArticles\"\r\n [refType]=\"1\"\r\n (closeRelatedPopup)=\"handlePopUpChange($event)\"\r\n >\r\n </co-product-dialog>\r\n\r\n <!-- <app-product-related class=\"no-padding\" *ngIf=\"article?.relatedArticles && article?.relatedArticles.length > 0\"-->\r\n <!-- [articles]=\"article?.relatedArticles\" [refType]=\"64\" [label]=\"'VARIANTS' | localize\"></app-product-related>-->\r\n </div>\r\n\r\n\r\n </div>\r\n</ng-container>\r\n",
181
185
  animations: [
182
186
  trigger('toggleFullScreen', [
183
187
  state('fullscreen', style({ 'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%' })),
@@ -210,7 +214,7 @@ ProductPageComponent.decorators = [
210
214
  transition('void => *', animate('200ms ease-in-out')),
211
215
  ])
212
216
  ],
213
- styles: [".page-wrapper{font-family:iOneMontserrat;font-size:12px;display:flex;flex-direction:column;max-width:1400px;padding:0 15px;margin:0 auto}.page-wrapper-content{display:flex;flex-direction:row;margin:40px 0}.page-wrapper-content:first-child{margin-top:0}.page-wrapper-content.no-top-margin{margin-top:0}.page-wrapper-left{display:flex;width:55%;flex-direction:column}.page-wrapper-right{display:flex;width:45%;flex-direction:column}.page-wrapper-full{display:flex;width:100%;flex-direction:column}.page-wrapper-66{display:flex;width:60%;flex-direction:column}.page-wrapper-33{display:flex;width:40%;flex-direction:column}.threed-selections{display:none}.threed-selections.show-selections{display:block}.threed-selections ::ng-deep .rp-lite-selector .rp-answers-slideout ::ng-deep co-slideout{width:480px;z-index:3}.threed-selections ::ng-deep .co-summary-line{cursor:pointer}.product-action-buttons{position:relative}.product-action-buttons.full-screen{z-index:10}.product-image-container{grid-column:1/7;grid-row:1/6;position:relative}.product-page-block-selector-type{width:auto;position:absolute;top:10px;right:10px;z-index:2}.product-page-block-image{box-sizing:border-box;width:100%;z-index:1;position:relative}.product-page-block-image .threed-configurator{border:1px solid #efefef}.product-page-block-image .threed-configurator .layer .viewer canvas{height:100%;width:100%}.product-page-block-image .threed-configurator ::ng-deep .rp-element-toolbar{top:30px}.product-page-block-image app-image-carousel.show-animated,.product-page-block-image threed-configurator.show-animated{opacity:1;z-index:0;transition:all .2s ease-in-out}.product-page-block-image .fullscreen-button{cursor:pointer;height:50px;width:50px;position:absolute;left:30px;z-index:100;top:30px}.product-page-block-image.full{grid-column:1/11;grid-row:2/span 10;z-index:3}.product-page-block-description{grid-column:7/12;grid-row:1/1}.product-page-block-additional{width:100%}.product-page-block-additional-description{width:100%}.product-page-block-price{grid-column:1/3;grid-row:2/2;align-self:center}.product-page-block-price.full{grid-column:1/5}.product-page-block-addtocart{grid-column:3/5;grid-row:2/2;align-self:center;padding-top:30px!important}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button:hover div.rippler{background:#f6f5f4}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button ::ng-deep co-icon{position:relative;z-index:2}.product-page-block-addtocart ::ng-deep co-button.cart-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-button.cart-button:hover{background:#74B77F}.addtocart-reserved{grid-column:1/3;grid-row:3/3}.product-page-block-stock{grid-column:1/3;grid-row:4/4}.product-page-block-delivery{grid-column:3/5;grid-row:4/4}::ng-deep co-scroll-container{overflow:hidden;position:relative}::ng-deep co-scroll-container .content-wrapper{padding:0}::ng-deep co-scroll-container .scroll-layer{left:0;top:0}::ng-deep co-scroll-container .scroll-layer .scroller{width:34px;height:34px;border-radius:36px;background:#fff;cursor:pointer;box-shadow:0 0 5px #0003}::ng-deep co-scroll-container .scroll-layer .scroller:hover{background:#f6f5f4}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll{left:5px}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll:before{border-width:0 3px 3px 0;padding:4px;margin-left:13px;margin-top:11px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll{right:5px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll:after{border-width:0 3px 3px 0;padding:4px;margin-left:9px;margin-top:11px}.product-page-block-variants{margin:20px 0 0}.product-page-block-variants ::ng-deep app-product-related>div{display:flex;grid-gap:15px;gap:15px;align-items:center;border-top:1px solid #f6f5f4;padding:5px 0 7px 15px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep app-header h3{font-size:14px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container{width:320px;max-width:100%;padding:0 16px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller{width:26px;height:26px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll{left:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll:before{border-width:0 2px 2px 0;margin-left:9px;margin-top:9px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll{right:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll:after{border-width:0 2px 2px 0;margin-left:6px;margin-top:9px}.product-page-block-variants ::ng-deep co-tile.small{min-width:50px!important;max-width:50px!important;border:1px solid #f6f5f4;margin:0 10px 0 0;border-radius:4px}.product-page-block-variants ::ng-deep co-tile.small:hover{border-color:#22313c}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper{padding:0}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-top{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image{height:40px!important;padding:5px;margin-bottom:10px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper .no-image{width:40px;height:40px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper span{display:none!important}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-bottom{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-extra-bottom{display:none}.product-page-block-alternatives ::ng-deep .article-wrapper{margin:0 20px 0 0}.product-page-block-alternatives ::ng-deep .article-wrapper:last-child{margin:0}.product-page-block-alternatives ::ng-deep co-tile{cursor:pointer;transition:all .14s ease-out;border:1px solid transparent;border-bottom-color:#f6f5f4;padding:15px 10px 0;width:319px;max-width:none;min-width:0;box-sizing:border-box}.product-page-block-alternatives ::ng-deep co-tile:hover{box-shadow:none;border-color:#f6f5f4}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper div.image co-image{transform:scale(1.05)}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper .tile-bottom{margin:0}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-extra-bottom .main .description{text-decoration:underline}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper{padding:0;position:relative;outline:none;overflow:hidden}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-top{position:absolute;left:0;top:0;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image{position:relative;padding:1px;display:flex;align-items:center;justify-content:center;overflow:hidden;max-width:250px;margin:0 auto 10px;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image:after{content:\"\";padding:100% 0 0;float:left;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image co-image{position:absolute;left:0;top:0;overflow:hidden;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;z-index:-1;transition:all .2s ease}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image .no-image-wrapper{position:absolute;display:flex;left:50%;top:50%;margin:-48px 0 0 -54px;flex-direction:column;align-items:center;opacity:.25}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom{transition:all .2s ease;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button{margin:0 0 5px!important;width:36px;height:36px;border:1px solid #22313C;cursor:pointer;border-radius:4px;padding:0!important;font-size:0}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button co-icon{width:32px;height:32px;margin:0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom{outline:none;padding:15px 0;background:transparent!important;min-height:60px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main{padding:0 10px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .description{font-size:15px;font-weight:bold;margin:0 0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .price{font-size:16px;margin:15px 0 0;font-weight:bold;color:#2b60a7}.product-page-block-additional-information{grid-column:1/6;grid-row:4/4}.product-page-block-properties{grid-column:7/10;grid-row:3/3}.product-page-block-related-articles{grid-column:2/6;grid-row:4/4}.product-page-block-alternative-articles{grid-column:6/10;grid-row:4/4}.product-page-block-documents{grid-column:2/6;grid-row:5/5}.product-page-block-symbols{grid-column:6/10;grid-row:5/5}@media screen and (max-width: 950px){.default-padding{padding-top:20px;padding-bottom:20px}.m-padding{padding-top:15px;padding-bottom:15px}.s-padding{padding-top:5px;padding-bottom:5px}.page-wrapper{max-width:650px}.page-wrapper .page-wrapper-content{flex-direction:column;margin:30px 0}.page-wrapper .page-wrapper-content .page-wrapper-left{width:100%}.page-wrapper .page-wrapper-content .page-wrapper-right{width:100%}.product-page-block-alternatives ::ng-deep co-tile{width:284px!important}}@media screen and (max-width: 650px){[class*=-padding]{padding-left:0!important;padding-right:0!important}.product-page-block-addtocart ::ng-deep co-number-picker co-button{height:38px!important}.product-page-block-addtocart ::ng-deep co-number-picker co-input-text{height:38px!important;width:36px!important}.product-page-block-addtocart ::ng-deep co-button.cart-button{height:40px;font-size:13px}}\n"]
217
+ styles: [".page-wrapper{font-family:iOneMontserrat;font-size:12px;display:flex;flex-direction:column;max-width:100%;padding:0 15px;margin:0 auto}.page-wrapper-content{display:flex;flex-direction:row;margin:40px 0}.page-wrapper-content:first-child{margin-top:0}.page-wrapper-content.no-top-margin{margin-top:0}.page-wrapper-left{display:flex;width:65%;flex-direction:column}.page-wrapper-right{display:flex;width:35%;flex-direction:column}.page-wrapper-full{display:flex;width:100%;flex-direction:column}.page-wrapper-66{display:flex;width:60%;flex-direction:column}.page-wrapper-33{display:flex;width:40%;flex-direction:column}.threed-selections{display:none}.threed-selections.show-selections{display:block}.threed-selections ::ng-deep .rp-lite-selector .rp-answers-slideout ::ng-deep co-slideout{width:480px;z-index:3}.threed-selections ::ng-deep .co-summary-line{cursor:pointer}.product-action-buttons{position:relative}.product-action-buttons.full-screen{z-index:10}.product-image-container{grid-column:1/7;grid-row:1/6;position:relative}.product-page-block-selector-type{width:auto;position:absolute;top:10px;right:10px;z-index:2}.product-page-block-image{box-sizing:border-box;width:100%;z-index:1;position:relative}.product-page-block-image .threed-configurator{border:none}.product-page-block-image .threed-configurator .layer .viewer canvas{height:100%;width:100%}.product-page-block-image .threed-configurator ::ng-deep .rp-element-toolbar{top:30px}.product-page-block-image app-image-carousel.show-animated,.product-page-block-image threed-configurator.show-animated{opacity:1;z-index:0;transition:all .2s ease-in-out}.product-page-block-image .fullscreen-button{cursor:pointer;height:50px;width:50px;position:absolute;left:30px;z-index:100;top:30px}.product-page-block-image.full{grid-column:1/11;grid-row:2/span 10;z-index:3}.product-page-block-description{grid-column:7/12;grid-row:1/1}.product-page-block-additional{width:100%}.product-page-block-additional-description{width:100%}.product-page-block-price{grid-column:1/3;grid-row:2/2;align-self:center}.product-page-block-price.full{grid-column:1/5}.product-page-block-addtocart{grid-column:3/5;grid-row:2/2;align-self:center;padding-top:30px!important}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button:hover div.rippler{background:#f6f5f4}.product-page-block-addtocart ::ng-deep co-number-picker ::ng-deep co-button ::ng-deep co-icon{position:relative;z-index:2}.product-page-block-addtocart ::ng-deep co-button.cart-button{cursor:pointer}.product-page-block-addtocart ::ng-deep co-button.cart-button:hover{background:#74B77F}.addtocart-reserved{grid-column:1/3;grid-row:3/3}.product-page-block-stock{grid-column:1/3;grid-row:4/4}.product-page-block-delivery{grid-column:3/5;grid-row:4/4}::ng-deep co-scroll-container{overflow:hidden;position:relative}::ng-deep co-scroll-container .content-wrapper{padding:0}::ng-deep co-scroll-container .scroll-layer{left:0;top:0}::ng-deep co-scroll-container .scroll-layer .scroller{width:34px;height:34px;border-radius:36px;background:#fff;cursor:pointer;box-shadow:0 0 5px #0003}::ng-deep co-scroll-container .scroll-layer .scroller:hover{background:#f6f5f4}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll{left:5px}::ng-deep co-scroll-container .scroll-layer .scroller.left-scroll:before{border-width:0 3px 3px 0;padding:4px;margin-left:13px;margin-top:11px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll{right:5px}::ng-deep co-scroll-container .scroll-layer .scroller.right-scroll:after{border-width:0 3px 3px 0;padding:4px;margin-left:9px;margin-top:11px}.product-page-block-variants{margin:20px 0 0}.product-page-block-variants ::ng-deep app-product-related>div{display:flex;grid-gap:15px;gap:15px;align-items:center;border-top:1px solid #f6f5f4;padding:5px 0 7px 15px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep app-header h3{font-size:14px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container{width:320px;max-width:100%;padding:0 16px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller{width:26px;height:26px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll{left:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.left-scroll:before{border-width:0 2px 2px 0;margin-left:9px;margin-top:9px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll{right:5px}.product-page-block-variants ::ng-deep app-product-related>div ::ng-deep co-scroll-container .scroller.right-scroll:after{border-width:0 2px 2px 0;margin-left:6px;margin-top:9px}.product-page-block-variants ::ng-deep co-tile.small{min-width:50px!important;max-width:50px!important;border:1px solid #f6f5f4;margin:0 10px 0 0;border-radius:4px}.product-page-block-variants ::ng-deep co-tile.small:hover{border-color:#22313c}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper{padding:0}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-top{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image{height:40px!important;padding:5px;margin-bottom:10px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper .no-image{width:40px;height:40px}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .image .no-image-wrapper span{display:none!important}.product-page-block-variants ::ng-deep co-tile.small .tile-wrapper .tile-bottom{display:none}.product-page-block-variants ::ng-deep co-tile.small .tile-extra-bottom{display:none}.product-page-block-alternatives ::ng-deep .article-wrapper{margin:0 20px 0 0}.product-page-block-alternatives ::ng-deep .article-wrapper:last-child{margin:0}.product-page-block-alternatives ::ng-deep co-tile{cursor:pointer;transition:all .14s ease-out;border:1px solid transparent;border-bottom-color:#f6f5f4;padding:15px 10px 0;width:319px;max-width:none;min-width:0;box-sizing:border-box}.product-page-block-alternatives ::ng-deep co-tile:hover{box-shadow:none;border-color:#f6f5f4}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper div.image co-image{transform:scale(1.05)}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-wrapper .tile-bottom{margin:0}.product-page-block-alternatives ::ng-deep co-tile:hover .tile-extra-bottom .main .description{text-decoration:underline}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper{padding:0;position:relative;outline:none;overflow:hidden}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-top{position:absolute;left:0;top:0;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image{position:relative;padding:1px;display:flex;align-items:center;justify-content:center;overflow:hidden;max-width:250px;margin:0 auto 10px;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image:after{content:\"\";padding:100% 0 0;float:left;width:100%}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image co-image{position:absolute;left:0;top:0;overflow:hidden;width:100%;height:100%;-o-object-fit:contain;object-fit:contain;z-index:-1;transition:all .2s ease}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper div.image .no-image-wrapper{position:absolute;display:flex;left:50%;top:50%;margin:-48px 0 0 -54px;flex-direction:column;align-items:center;opacity:.25}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom{transition:all .2s ease;height:auto}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button{margin:0 0 5px!important;width:36px;height:36px;border:1px solid #22313C;cursor:pointer;border-radius:4px;padding:0!important;font-size:0}.product-page-block-alternatives ::ng-deep co-tile .tile-wrapper .tile-bottom ::ng-deep co-button co-icon{width:32px;height:32px;margin:0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom{outline:none;padding:15px 0;background:transparent!important;min-height:60px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main{padding:0 10px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .description{font-size:15px;font-weight:bold;margin:0 0 2px}.product-page-block-alternatives ::ng-deep co-tile .tile-extra-bottom .main .price{font-size:16px;margin:15px 0 0;font-weight:bold;color:#2b60a7}.product-page-block-additional-information{grid-column:1/6;grid-row:4/4}.product-page-block-properties{grid-column:7/10;grid-row:3/3}.product-page-block-related-articles{grid-column:2/6;grid-row:4/4}.product-page-block-alternative-articles{grid-column:6/10;grid-row:4/4}.product-page-block-documents{grid-column:2/6;grid-row:5/5}.product-page-block-symbols{grid-column:6/10;grid-row:5/5}@media screen and (max-width: 950px){.default-padding{padding-top:20px;padding-bottom:20px}.m-padding{padding-top:15px;padding-bottom:15px}.s-padding{padding-top:5px;padding-bottom:5px}.page-wrapper{max-width:650px}.page-wrapper .page-wrapper-content{flex-direction:column;margin:30px 0}.page-wrapper .page-wrapper-content .page-wrapper-left{width:100%}.page-wrapper .page-wrapper-content .page-wrapper-right{width:100%}.product-page-block-alternatives ::ng-deep co-tile{width:284px!important}}@media screen and (max-width: 650px){[class*=-padding]{padding-left:0!important;padding-right:0!important}.product-page-block-addtocart ::ng-deep co-number-picker co-button{height:38px!important}.product-page-block-addtocart ::ng-deep co-number-picker co-input-text{height:38px!important;width:36px!important}.product-page-block-addtocart ::ng-deep co-button.cart-button{height:40px;font-size:13px}}\n"]
214
218
  },] }
215
219
  ];
216
220
  ProductPageComponent.ctorParameters = () => [
@@ -231,6 +235,7 @@ ProductPageComponent.propDecorators = {
231
235
  createFrozenArticle: [{ type: Input }],
232
236
  isReturn: [{ type: Input }],
233
237
  showRelatedProductsPopup: [{ type: Input }],
238
+ enableRenderCarousel: [{ type: Input }],
234
239
  openStockEvent: [{ type: Output }]
235
240
  };
236
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-page.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-page/product-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef, EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit, Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport { Subscription } from 'rxjs';\nimport { StockAndDelivery } from '../../model/stock-and-delivery';\nimport { SelectorType } from '../../enum/selector-type.enum';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { ProductSettingsService } from '../../service/product-settings.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport { DeliveryPrognosis } from '@colijnit/articleapi/build/model/delivery-prognosis';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\n\n@Component({\n  selector: 'app-product-page',\n  templateUrl: './product-page.component.html',\n  styleUrls: ['./product-page.component.scss'],\n  animations: [\n    trigger('toggleFullScreen', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'left': '*', 'width': '*', 'height': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopLeft', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0'})),\n      state('halfscreen', style({'position': 'absolute', 'top': '*', 'left': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopRight', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleFullScreenRight', [\n      state('fullscreen', style({'position': 'fixed', 'width': '400px', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'width': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleVisibilityByState', [\n      state('hide', style({'opacity': '0', 'display': 'none'})),\n      state('show', style({'display': 'block', 'opacity': '1'})),\n      transition('hide <=> show', animate('200ms 100ms ease-in-out')),\n    ]),\n    trigger('toggleVisibility', [\n      state('void', style({'opacity': '0'})),\n      state('*', style({'opacity': '1'})),\n      transition('void => *', animate('200ms ease-in-out')),\n    ])\n  ],\n\n})\nexport class ProductPageComponent implements OnInit, OnDestroy, AfterViewInit {\n\n  public readonly icon: typeof IconEnum = IconEnum;\n  @ViewChild('configurator', { read: ElementRef })\n  public configurator: ElementRef;\n\n  @ViewChild('selections', { read: ElementRef })\n  public selections: ElementRef;\n\n  @ViewChild('fullscreenbutton', { read: ElementRef })\n  public fullscreenbutton: ElementRef;\n\n  @Input()\n  public set sku(value: string) {\n    if (value) {\n      if (this.configuring) {\n        this.show3D = false;\n        this.fullScreen = false;\n        this.configuring = false;\n        this._changeDetector.detectChanges();\n      }\n      this._sku = value;\n      this._getArticle();\n    }\n  }\n\n  public get sku(): string {\n    return this._sku;\n  }\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      if (typeof value === 'string') {\n        this._settings = JSON.parse(value);\n      } else {\n        this._settings = value;\n      }\n    }\n  }\n\n  @Input()\n  public externalSource: ExternalSource;\n\n  @Input()\n  public createFrozenArticle: boolean = true;\n\n  @Input()\n  public isReturn: boolean = false;\n\n  @Input()\n  public showRelatedProductsPopup: boolean = false;\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n  public get settings(): any {\n    return this._settings;\n  }\n\n  public set fullScreen(value: boolean) {\n    this._fullScreen = value;\n    this.fullscreenAnimationEnd = true;\n    this._changeDetector.detectChanges();\n    // setTimeout(() => {\n    //   this.fullscreenAnimationEnd = true;\n    // }, 400)\n  }\n\n  public get fullScreen(): boolean {\n    return this._fullScreen;\n  }\n\n  public get fullScreenIcon(): IconEnum {\n    return this.fullScreen ? this.icon.NormalScreen : this.icon.FullScreen;\n  }\n\n  public set currentView(value: SelectorType) {\n    this._currentView = value;\n    this.show2D = this._currentView === SelectorType.TwoD;\n    this.show3D = this._currentView === SelectorType.ThreeD;\n    this._changeDetector.detectChanges();\n  }\n\n  public get currentView(): SelectorType {\n    return this._currentView;\n  }\n\n  public article: ArticleFullObject;\n  public stockAndDelivery: StockAndDelivery;\n  public configurable = false;\n  public threeD = false;\n  public selectorType: SelectorType;\n  public show2D = true;\n  public show3D = false;\n  public configuring: boolean = false;\n  public showAddToCart: boolean = false;\n  public fullscreenAnimationEnd: boolean = false;\n  public settingsLoaded: boolean = false;\n  private _sku: string;\n  private _initializedSub: Subscription;\n  private _fullScreen: boolean = false;\n  private _currentView: SelectorType;\n  private _subs: Subscription[] = [];\n  private _settings: any;\n\n  constructor(private _ione: ProductConnectorService,\n              private _renderer: Renderer2,\n              private _changeDetector: ChangeDetectorRef,\n              public iconCache: IconCacheService,\n              public settingsService: ProductSettingsService,\n              public appEventService: ProductEventService\n  ) {\n    this._subs.push(\n      this.appEventService.onForceRenderImage.subscribe((x) => {\n        if (this.selections.nativeElement) {\n          this.selections.nativeElement.forceRenderImage();\n        }\n      }),\n        this.settingsService.settingsLoaded.subscribe(loaded => this._handleSettingsLoaded(loaded)),\n        this._ione.controllerInitialized.subscribe((initialized: boolean) => {\n        this.settingsLoaded = initialized;\n      }),\n      this.appEventService.onAnswersAvailable.subscribe((answers) => {\n        if (answers && this.configurable) {\n          this.showAddToCart = false;\n        } else {\n          this.showAddToCart = true;\n        }\n      })\n    );\n\n  }\n\n  ngOnInit() {\n    if (this._settings) {\n      this.settingsService.settings = undefined;\n      this.settingsService.createSettingsFromObject(this._settings);\n    } else {\n      this._settings = this.settingsService.settings;\n    }\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this.configurator = undefined;\n    this.selections = undefined;\n    this.fullscreenbutton = undefined;\n  }\n\n  public setInstance(event: CustomEvent): void {\n    if (event.detail) {\n      this._ione.setInstance(event.detail);\n    }\n  }\n\n  public handleStartConfiguration(): void {\n    this.configuring = true;\n    this._changeDetector.detectChanges();\n  }\n\n  public showFullScreen(): void {\n    this.fullScreen = !this.fullScreen;\n  }\n\n  private _handleSettingsLoaded(loaded: boolean): void {\n    if (loaded) {\n      this._ione.initConnection();\n    }\n  }\n\n  private async _getArticle(): Promise<void> {\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this._initializedSub = this._ione.controllerInitialized.subscribe(async (init: boolean) => {\n      if (init) {\n        this._ione.getFullArticle(this._sku).then((article: ArticleFullObject) => {\n          this.article = article;\n          if (this.article) {\n            this.configurable = this.article.goodType === 'B';\n            if (this.configurable) {\n              this.showAddToCart = false;\n              this.currentView = SelectorType.TwoD;\n            } else {\n              this.showAddToCart = true;\n            }\n            this.threeD = this.article.is3D;\n            this.selectorType = this.article.selectorTypeCustomer;\n            this._ione.getDeliveryPrognosis(this.article.goodId).then((stockInfo: DeliveryPrognosis) => {\n              const stockAndDelivery: DeliveryPrognosis = stockInfo;\n              this.stockAndDelivery = new StockAndDelivery(0, stockAndDelivery.returnValue ? stockAndDelivery.returnValue : ' ');\n              this._changeDetector.detectChanges();\n            });\n            this._changeDetector.detectChanges();\n          }\n        });\n      }\n    });\n    this.showRelatedProductsPopup = false;\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n\n  public handlePopUpChange(event: boolean){\n    this.showRelatedProductsPopup = event;\n  }\n}\n"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-page.component.js","sourceRoot":"","sources":["../../../../../src/app/components/product-page/product-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef, EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit, Output,\n  Renderer2,\n  ViewChild\n} from '@angular/core';\nimport { ProductConnectorService } from '../../service/product-connector.service';\nimport { ArticleFullObject } from '@colijnit/articleapi/build/model/article-full-object';\nimport { Subscription } from 'rxjs';\nimport { StockAndDelivery } from '../../model/stock-and-delivery';\nimport { SelectorType } from '../../enum/selector-type.enum';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { IconEnum } from '../../enum/icon.enum';\nimport { IconCacheService } from '../../service/icon-cache.service';\nimport { ProductSettingsService } from '../../service/product-settings.service';\nimport { ProductEventService } from '../../service/product-event.service';\nimport { DeliveryPrognosis } from '@colijnit/articleapi/build/model/delivery-prognosis';\nimport {ExternalSource} from '@colijnit/articleapi/build/model/external-source.bo';\n\n@Component({\n  selector: 'app-product-page',\n  templateUrl: './product-page.component.html',\n  styleUrls: ['./product-page.component.scss'],\n  animations: [\n    trigger('toggleFullScreen', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0', 'width': '100%', 'height': '100%'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'left': '*', 'width': '*', 'height': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopLeft', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'left': '0'})),\n      state('halfscreen', style({'position': 'absolute', 'top': '*', 'left': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleTopRight', [\n      state('fullscreen', style({'position': 'fixed', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleFullScreenRight', [\n      state('fullscreen', style({'position': 'fixed', 'width': '400px', 'top': '0', 'right': '0'})),\n      state('halfscreen', style({'position': '*', 'width': '*', 'top': '*', 'right': '*'})),\n      transition('halfscreen <=> fullscreen', animate('200ms ease-in-out')),\n    ]),\n    trigger('toggleVisibilityByState', [\n      state('hide', style({'opacity': '0', 'display': 'none'})),\n      state('show', style({'display': 'block', 'opacity': '1'})),\n      transition('hide <=> show', animate('200ms 100ms ease-in-out')),\n    ]),\n    trigger('toggleVisibility', [\n      state('void', style({'opacity': '0'})),\n      state('*', style({'opacity': '1'})),\n      transition('void => *', animate('200ms ease-in-out')),\n    ])\n  ],\n\n})\nexport class ProductPageComponent implements OnInit, OnDestroy, AfterViewInit {\n  public readonly icon: typeof IconEnum = IconEnum;\n\n  @ViewChild('configurator', { read: ElementRef })\n  public configurator: ElementRef;\n\n  @ViewChild('selections', { read: ElementRef })\n  public selections: ElementRef;\n\n  @ViewChild('fullscreenbutton', { read: ElementRef })\n  public fullscreenbutton: ElementRef;\n\n  @Input()\n  public set sku(value: string) {\n    if (value) {\n      if (this.configuring) {\n        this.show3D = false;\n        this.fullScreen = false;\n        this.configuring = false;\n        this._changeDetector.detectChanges();\n      }\n      this._sku = value;\n      this._getArticle();\n    }\n  }\n\n  public get sku(): string {\n    return this._sku;\n  }\n\n  @Input()\n  public set settings(value: any) {\n    if (value) {\n      if (typeof value === 'string') {\n        this._settings = JSON.parse(value);\n      } else {\n        this._settings = value;\n      }\n    }\n  }\n\n  @Input()\n  public externalSource: ExternalSource;\n\n  @Input()\n  public createFrozenArticle: boolean = true;\n\n  @Input()\n  public isReturn: boolean = false;\n\n  @Input()\n  public showRelatedProductsPopup: boolean = false;\n\n  @Input()\n  public enableRenderCarousel: boolean;\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  public get settings(): any {\n    return this._settings;\n  }\n\n  public set fullScreen(value: boolean) {\n    this._fullScreen = value;\n    this.fullscreenAnimationEnd = true;\n    this._changeDetector.detectChanges();\n    // setTimeout(() => {\n    //   this.fullscreenAnimationEnd = true;\n    // }, 400)\n  }\n\n  public get fullScreen(): boolean {\n    return this._fullScreen;\n  }\n\n  public get fullScreenIcon(): IconEnum {\n    return this.fullScreen ? this.icon.NormalScreen : this.icon.FullScreen;\n  }\n\n  public set currentView(value: SelectorType) {\n    this._currentView = value;\n    this.show2D = this._currentView === SelectorType.TwoD;\n    this.show3D = this._currentView === SelectorType.ThreeD;\n    this._changeDetector.detectChanges();\n  }\n\n  public get currentView(): SelectorType {\n    return this._currentView;\n  }\n\n\n\n  public article: ArticleFullObject;\n  public stockAndDelivery: StockAndDelivery;\n  public configurable = false;\n  public threeD = false;\n  public selectorType: SelectorType;\n  public show2D = true;\n  public show3D = false;\n  public configuring: boolean = false;\n  public showAddToCart: boolean = false;\n  public fullscreenAnimationEnd: boolean = false;\n  public settingsLoaded: boolean = false;\n  private _sku: string;\n  private _initializedSub: Subscription;\n  private _fullScreen: boolean = false;\n  private _currentView: SelectorType;\n  private _subs: Subscription[] = [];\n  private _settings: any;\n\n  constructor(private _ione: ProductConnectorService,\n              private _renderer: Renderer2,\n              private _changeDetector: ChangeDetectorRef,\n              public iconCache: IconCacheService,\n              public settingsService: ProductSettingsService,\n              public appEventService: ProductEventService\n  ) {\n    this._subs.push(\n      this.appEventService.onForceRenderImage.subscribe((x) => {\n        if (this.selections.nativeElement) {\n          this.selections.nativeElement.forceRenderImage();\n        }\n      }),\n      this.settingsService.settingsLoaded.subscribe(loaded => this._handleSettingsLoaded(loaded)),\n      this._ione.controllerInitialized.subscribe((initialized: boolean) => {\n        this.settingsLoaded = initialized;\n      }),\n      this.appEventService.onAnswersAvailable.subscribe((answers) => {\n        if (answers && this.configurable) {\n          this.showAddToCart = false;\n        } else {\n          this.showAddToCart = true;\n        }\n      }),\n      this.appEventService.onGetRenderForRenderCarousel.subscribe((renderParameters: any) => {\n        if (this.selections.nativeElement) {\n          this.selections.nativeElement.getRenderForRenderCarousel(renderParameters);\n        }\n      })\n    );\n\n  }\n\n  ngOnInit() {\n    if (this._settings) {\n      this.settingsService.settings = undefined;\n      this.settingsService.createSettingsFromObject(this._settings);\n    } else {\n      this._settings = this.settingsService.settings;\n    }\n  }\n\n  ngAfterViewInit(): void {\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this.configurator = undefined;\n    this.selections = undefined;\n    this.fullscreenbutton = undefined;\n  }\n\n  public setInstance(event: CustomEvent): void {\n    if (event.detail) {\n      this._ione.setInstance(event.detail);\n    }\n  }\n\n  public handleStartConfiguration(): void {\n    this.configuring = true;\n    this._changeDetector.detectChanges();\n  }\n\n  public showFullScreen(): void {\n    this.fullScreen = !this.fullScreen;\n  }\n\n  private _handleSettingsLoaded(loaded: boolean): void {\n    if (loaded) {\n      this._ione.initConnection();\n    }\n  }\n\n  private async _getArticle(): Promise<void> {\n    if (this._initializedSub) {\n      this._initializedSub.unsubscribe();\n    }\n    this._initializedSub = this._ione.controllerInitialized.subscribe(async (init: boolean) => {\n      if (init) {\n        this._ione.getFullArticle(this._sku).then((article: ArticleFullObject) => {\n          this.article = article;\n          if (this.article) {\n            this.configurable = this.article.goodType === 'B';\n            if (this.configurable) {\n              this.showAddToCart = false;\n              this.currentView = SelectorType.TwoD;\n            } else {\n              this.showAddToCart = true;\n            }\n            this.threeD = this.article.is3D;\n            this.selectorType = this.article.selectorTypeCustomer;\n            this._ione.getDeliveryPrognosis(this.article.goodId).then((stockInfo: DeliveryPrognosis) => {\n              const stockAndDelivery: DeliveryPrognosis = stockInfo;\n              this.stockAndDelivery = new StockAndDelivery(0, stockAndDelivery.returnValue ? stockAndDelivery.returnValue : ' ');\n              this._changeDetector.detectChanges();\n            });\n            this._changeDetector.detectChanges();\n          }\n        });\n      }\n    });\n    this.showRelatedProductsPopup = false;\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n\n  public handlePopUpChange(event: boolean){\n    this.showRelatedProductsPopup = event;\n  }\n}\n"]}
@@ -15,6 +15,7 @@ import { ProductInfoTabsModule } from '../product-info-tabs/product-info-tabs.mo
15
15
  import { PipeModule } from '../../pipe/pipe.module';
16
16
  import { ProductDialogModule } from "../product-dialog/product-dialog.module";
17
17
  import { LoaderModule } from "@colijnit/corecomponents_v12";
18
+ import { RenderCarouselModule } from "../render-carousel/render-carousel.module";
18
19
  export class ProductPageModule {
19
20
  }
20
21
  ProductPageModule.decorators = [
@@ -34,7 +35,8 @@ ProductPageModule.decorators = [
34
35
  ProductInfoTabsModule,
35
36
  PipeModule,
36
37
  ProductDialogModule,
37
- LoaderModule
38
+ LoaderModule,
39
+ RenderCarouselModule
38
40
  ],
39
41
  schemas: [CUSTOM_ELEMENTS_SCHEMA],
40
42
  declarations: [
@@ -45,4 +47,4 @@ ProductPageModule.decorators = [
45
47
  ]
46
48
  },] }
47
49
  ];
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1wYWdlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LXBhZ2UvcHJvZHVjdC1wYWdlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSx1REFBdUQsQ0FBQztBQUNoRyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDcEQsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDM0YsT0FBTyxFQUFDLGtDQUFrQyxFQUFDLE1BQU0seUVBQXlFLENBQUM7QUFDM0gsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDckYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDbEYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDcEYsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQTRCMUQsTUFBTSxPQUFPLGlCQUFpQjs7O1lBMUI3QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1oseUJBQXlCO29CQUN6QixtQkFBbUI7b0JBQ25CLFVBQVU7b0JBQ1Ysd0JBQXdCO29CQUN4QixrQ0FBa0M7b0JBQ2xDLGtCQUFrQjtvQkFDbEIsc0JBQXNCO29CQUN0QixvQkFBb0I7b0JBQ3BCLGtCQUFrQjtvQkFDbEIscUJBQXFCO29CQUNyQixxQkFBcUI7b0JBQ3JCLFVBQVU7b0JBQ1YsbUJBQW1CO29CQUNuQixZQUFZO2lCQUNiO2dCQUNDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2dCQUNqQyxZQUFZLEVBQUU7b0JBQ1Ysb0JBQW9CO2lCQUN2QjtnQkFDRCxPQUFPLEVBQUU7b0JBQ0wsb0JBQW9CO2lCQUN2QjthQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDVVNUT01fRUxFTUVOVFNfU0NIRU1BLCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1Byb2R1Y3RQYWdlQ29tcG9uZW50fSBmcm9tICcuL3Byb2R1Y3QtcGFnZS5jb21wb25lbnQnO1xyXG5pbXBvcnQge1Byb2R1Y3RTZWxlY3RvclR5cGVNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3Qtc2VsZWN0b3ItdHlwZS9wcm9kdWN0LXNlbGVjdG9yLXR5cGUubW9kdWxlJztcclxuaW1wb3J0IHtJbWFnZUNhcm91c2VsTW9kdWxlfSBmcm9tICcuLi9pbWFnZS1jYXJvdXNlbC9pbWFnZS1jYXJvdXNlbC5tb2R1bGUnO1xyXG5pbXBvcnQge0ljb25Nb2R1bGV9IGZyb20gJ0Bjb2xpam5pdC9jb3JlY29tcG9uZW50cyc7XHJcbmltcG9ydCB7UHJvZHVjdERlc2NyaXB0aW9uTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LWRlc2NyaXB0aW9uL3Byb2R1Y3QtZGVzY3JpcHRpb24ubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0QWRkaXRpb25hbERlc2NyaXB0aW9uTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24vcHJvZHVjdC1hZGRpdGlvbmFsLWRlc2NyaXB0aW9uLm1vZHVsZSc7XHJcbmltcG9ydCB7UHJvZHVjdFByaWNlTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LXByaWNlL3Byb2R1Y3QtcHJpY2UubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0QWRkdG9jYXJ0TW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LWFkZHRvY2FydC9wcm9kdWN0LWFkZHRvY2FydC5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3RSZWxhdGVkTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LXJlbGF0ZWQvcHJvZHVjdC1yZWxhdGVkLm1vZHVsZSc7XHJcbmltcG9ydCB7UHJvZHVjdFN0b2NrTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LXN0b2NrL3Byb2R1Y3Qtc3RvY2subW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0RGVsaXZlcnlNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtZGVsaXZlcnkvcHJvZHVjdC1kZWxpdmVyeS5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3RJbmZvVGFic01vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1pbmZvLXRhYnMvcHJvZHVjdC1pbmZvLXRhYnMubW9kdWxlJztcclxuaW1wb3J0IHtQaXBlTW9kdWxlfSBmcm9tICcuLi8uLi9waXBlL3BpcGUubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0RGlhbG9nTW9kdWxlfSBmcm9tIFwiLi4vcHJvZHVjdC1kaWFsb2cvcHJvZHVjdC1kaWFsb2cubW9kdWxlXCI7XHJcbmltcG9ydCB7TG9hZGVyTW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0U2VsZWN0b3JUeXBlTW9kdWxlLFxyXG4gICAgSW1hZ2VDYXJvdXNlbE1vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0RGVzY3JpcHRpb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0QWRkaXRpb25hbERlc2NyaXB0aW9uTW9kdWxlLFxyXG4gICAgUHJvZHVjdFByaWNlTW9kdWxlLFxyXG4gICAgUHJvZHVjdEFkZHRvY2FydE1vZHVsZSxcclxuICAgIFByb2R1Y3RSZWxhdGVkTW9kdWxlLFxyXG4gICAgUHJvZHVjdFN0b2NrTW9kdWxlLFxyXG4gICAgUHJvZHVjdERlbGl2ZXJ5TW9kdWxlLFxyXG4gICAgUHJvZHVjdEluZm9UYWJzTW9kdWxlLFxyXG4gICAgUGlwZU1vZHVsZSxcclxuICAgIFByb2R1Y3REaWFsb2dNb2R1bGUsXHJcbiAgICBMb2FkZXJNb2R1bGVcclxuICBdLFxyXG4gICAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgUHJvZHVjdFBhZ2VDb21wb25lbnRcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgUHJvZHVjdFBhZ2VDb21wb25lbnRcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFByb2R1Y3RQYWdlTW9kdWxlIHtcclxufVxyXG4iXX0=
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1wYWdlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LXBhZ2UvcHJvZHVjdC1wYWdlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSx1REFBdUQsQ0FBQztBQUNoRyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUM1RSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDcEQsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDM0YsT0FBTyxFQUFDLGtDQUFrQyxFQUFDLE1BQU0seUVBQXlFLENBQUM7QUFDM0gsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDckYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDL0UsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDekUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDbEYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDcEYsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzVFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQTZCL0UsTUFBTSxPQUFPLGlCQUFpQjs7O1lBM0I3QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1oseUJBQXlCO29CQUN6QixtQkFBbUI7b0JBQ25CLFVBQVU7b0JBQ1Ysd0JBQXdCO29CQUN4QixrQ0FBa0M7b0JBQ2xDLGtCQUFrQjtvQkFDbEIsc0JBQXNCO29CQUN0QixvQkFBb0I7b0JBQ3BCLGtCQUFrQjtvQkFDbEIscUJBQXFCO29CQUNyQixxQkFBcUI7b0JBQ3JCLFVBQVU7b0JBQ1YsbUJBQW1CO29CQUNuQixZQUFZO29CQUNaLG9CQUFvQjtpQkFDckI7Z0JBQ0MsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ2pDLFlBQVksRUFBRTtvQkFDVixvQkFBb0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDTCxvQkFBb0I7aUJBQ3ZCO2FBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7UHJvZHVjdFBhZ2VDb21wb25lbnR9IGZyb20gJy4vcHJvZHVjdC1wYWdlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7UHJvZHVjdFNlbGVjdG9yVHlwZU1vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1zZWxlY3Rvci10eXBlL3Byb2R1Y3Qtc2VsZWN0b3ItdHlwZS5tb2R1bGUnO1xyXG5pbXBvcnQge0ltYWdlQ2Fyb3VzZWxNb2R1bGV9IGZyb20gJy4uL2ltYWdlLWNhcm91c2VsL2ltYWdlLWNhcm91c2VsLm1vZHVsZSc7XHJcbmltcG9ydCB7SWNvbk1vZHVsZX0gZnJvbSAnQGNvbGlqbml0L2NvcmVjb21wb25lbnRzJztcclxuaW1wb3J0IHtQcm9kdWN0RGVzY3JpcHRpb25Nb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtZGVzY3JpcHRpb24vcHJvZHVjdC1kZXNjcmlwdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3RBZGRpdGlvbmFsRGVzY3JpcHRpb25Nb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtYWRkaXRpb25hbC1kZXNjcmlwdGlvbi9wcm9kdWN0LWFkZGl0aW9uYWwtZGVzY3JpcHRpb24ubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0UHJpY2VNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtcHJpY2UvcHJvZHVjdC1wcmljZS5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3RBZGR0b2NhcnRNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtYWRkdG9jYXJ0L3Byb2R1Y3QtYWRkdG9jYXJ0Lm1vZHVsZSc7XHJcbmltcG9ydCB7UHJvZHVjdFJlbGF0ZWRNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3QtcmVsYXRlZC9wcm9kdWN0LXJlbGF0ZWQubW9kdWxlJztcclxuaW1wb3J0IHtQcm9kdWN0U3RvY2tNb2R1bGV9IGZyb20gJy4uL3Byb2R1Y3Qtc3RvY2svcHJvZHVjdC1zdG9jay5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3REZWxpdmVyeU1vZHVsZX0gZnJvbSAnLi4vcHJvZHVjdC1kZWxpdmVyeS9wcm9kdWN0LWRlbGl2ZXJ5Lm1vZHVsZSc7XHJcbmltcG9ydCB7UHJvZHVjdEluZm9UYWJzTW9kdWxlfSBmcm9tICcuLi9wcm9kdWN0LWluZm8tdGFicy9wcm9kdWN0LWluZm8tdGFicy5tb2R1bGUnO1xyXG5pbXBvcnQge1BpcGVNb2R1bGV9IGZyb20gJy4uLy4uL3BpcGUvcGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQge1Byb2R1Y3REaWFsb2dNb2R1bGV9IGZyb20gXCIuLi9wcm9kdWN0LWRpYWxvZy9wcm9kdWN0LWRpYWxvZy5tb2R1bGVcIjtcclxuaW1wb3J0IHtMb2FkZXJNb2R1bGV9IGZyb20gXCJAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyXCI7XHJcbmltcG9ydCB7UmVuZGVyQ2Fyb3VzZWxNb2R1bGV9IGZyb20gXCIuLi9yZW5kZXItY2Fyb3VzZWwvcmVuZGVyLWNhcm91c2VsLm1vZHVsZVwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0U2VsZWN0b3JUeXBlTW9kdWxlLFxyXG4gICAgSW1hZ2VDYXJvdXNlbE1vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0RGVzY3JpcHRpb25Nb2R1bGUsXHJcbiAgICBQcm9kdWN0QWRkaXRpb25hbERlc2NyaXB0aW9uTW9kdWxlLFxyXG4gICAgUHJvZHVjdFByaWNlTW9kdWxlLFxyXG4gICAgUHJvZHVjdEFkZHRvY2FydE1vZHVsZSxcclxuICAgIFByb2R1Y3RSZWxhdGVkTW9kdWxlLFxyXG4gICAgUHJvZHVjdFN0b2NrTW9kdWxlLFxyXG4gICAgUHJvZHVjdERlbGl2ZXJ5TW9kdWxlLFxyXG4gICAgUHJvZHVjdEluZm9UYWJzTW9kdWxlLFxyXG4gICAgUGlwZU1vZHVsZSxcclxuICAgIFByb2R1Y3REaWFsb2dNb2R1bGUsXHJcbiAgICBMb2FkZXJNb2R1bGUsXHJcbiAgICBSZW5kZXJDYXJvdXNlbE1vZHVsZVxyXG4gIF0sXHJcbiAgICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgICBQcm9kdWN0UGFnZUNvbXBvbmVudFxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBQcm9kdWN0UGFnZUNvbXBvbmVudFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUHJvZHVjdFBhZ2VNb2R1bGUge1xyXG59XHJcbiJdfQ==
@@ -27,11 +27,18 @@ ProductSelectorTypeComponent.decorators = [
27
27
  selector: 'app-product-selector-type',
28
28
  template: `
29
29
  <div *ngIf="show2D || show3D" class="show-in" [textContent]="'SHOW_IN' | localize"></div>
30
- <co-icon *ngIf="show2D" class="selector-type-icon"
30
+ <co-icon *ngIf="show2D && !showRenderCarousel" class="selector-type-icon"
31
31
  [class.active]="currentType === type.TwoD"
32
32
  [iconData]="twoDIcon"
33
33
  (click)="handleIconClick(type.TwoD)"
34
34
  ></co-icon>
35
+
36
+ <co-icon *ngIf="show2D && showRenderCarousel" class="selector-type-icon"
37
+ [class.active]="currentType === type.TwoD"
38
+ [iconData]="twoDIcon"
39
+ (click)="handleIconClick(type.TwoD)"
40
+ ></co-icon>
41
+
35
42
  <co-icon *ngIf="show3D" class="selector-type-icon"
36
43
  [class.active]="currentType === type.ThreeD"
37
44
  [iconData]="threeDIcon"
@@ -48,8 +55,9 @@ ProductSelectorTypeComponent.ctorParameters = () => [
48
55
  ProductSelectorTypeComponent.propDecorators = {
49
56
  show2D: [{ type: Input }],
50
57
  show3D: [{ type: Input }],
58
+ showRenderCarousel: [{ type: Input }],
51
59
  currentType: [{ type: Input }],
52
60
  onIconClick: [{ type: Output }],
53
61
  currentTypeChange: [{ type: Output }]
54
62
  };
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1zZWxlY3Rvci10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LXNlbGVjdG9yLXR5cGUvcHJvZHVjdC1zZWxlY3Rvci10eXBlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWhHLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xFLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFtQjNELE1BQU0sT0FBTyw0QkFBNEI7SUF1QnJDLFlBQ1ksVUFBNEIsRUFDNUIsZUFBa0M7UUFEbEMsZUFBVSxHQUFWLFVBQVUsQ0FBa0I7UUFDNUIsb0JBQWUsR0FBZixlQUFlLENBQW1CO1FBdkI5QixTQUFJLEdBQXdCLFlBQVksQ0FBQztRQUN6QyxVQUFLLEdBQW9CLFFBQVEsQ0FBQztRQVkzQyxnQkFBVyxHQUErQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRzdELHNCQUFpQixHQUErQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBU3RFLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakUsQ0FBQztJQUVELFFBQVE7SUFDUixDQUFDO0lBRU0sZUFBZSxDQUFDLElBQWtCO1FBQ3JDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pDLENBQUM7OztZQXhESixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLDJCQUEyQjtnQkFDckMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7R0FZWDs7YUFFRjs7O1lBcEJPLGdCQUFnQjtZQUZoQixpQkFBaUI7OztxQkE0QnBCLEtBQUs7cUJBR0wsS0FBSzswQkFHTCxLQUFLOzBCQUdMLE1BQU07Z0NBR04sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTYWZlSHRtbH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcbmltcG9ydCB7SWNvbkVudW19IGZyb20gJy4uLy4uL2VudW0vaWNvbi5lbnVtJztcbmltcG9ydCB7U2VsZWN0b3JUeXBlfSBmcm9tICcuLi8uLi9lbnVtL3NlbGVjdG9yLXR5cGUuZW51bSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYXBwLXByb2R1Y3Qtc2VsZWN0b3ItdHlwZScsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGRpdiAqbmdJZj1cInNob3cyRCB8fCBzaG93M0RcIiBjbGFzcz1cInNob3ctaW5cIiBbdGV4dENvbnRlbnRdPVwiJ1NIT1dfSU4nIHwgbG9jYWxpemVcIj48L2Rpdj5cbiAgICAgICAgPGNvLWljb24gKm5nSWY9XCJzaG93MkRcIiBjbGFzcz1cInNlbGVjdG9yLXR5cGUtaWNvblwiXG4gICAgICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwiY3VycmVudFR5cGUgPT09IHR5cGUuVHdvRFwiXG4gICAgICAgICAgICAgICAgIFtpY29uRGF0YV09XCJ0d29ESWNvblwiXG4gICAgICAgICAgICAgICAgIChjbGljayk9XCJoYW5kbGVJY29uQ2xpY2sodHlwZS5Ud29EKVwiXG4gICAgICAgID48L2NvLWljb24+XG4gICAgICAgIDxjby1pY29uICpuZ0lmPVwic2hvdzNEXCIgY2xhc3M9XCJzZWxlY3Rvci10eXBlLWljb25cIlxuICAgICAgICAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cImN1cnJlbnRUeXBlID09PSB0eXBlLlRocmVlRFwiXG4gICAgICAgICAgICAgICAgIFtpY29uRGF0YV09XCJ0aHJlZURJY29uXCJcbiAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImhhbmRsZUljb25DbGljayh0eXBlLlRocmVlRClcIlxuICAgICAgICA+PC9jby1pY29uPlxuICBgLFxuICAgIHN0eWxlVXJsczogWycuL3Byb2R1Y3Qtc2VsZWN0b3ItdHlwZS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFByb2R1Y3RTZWxlY3RvclR5cGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHR5cGU6IHR5cGVvZiBTZWxlY3RvclR5cGUgPSBTZWxlY3RvclR5cGU7XG4gICAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbkVudW0gPSBJY29uRW51bTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNob3cyRDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNob3czRDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGN1cnJlbnRUeXBlOiBTZWxlY3RvclR5cGU7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgb25JY29uQ2xpY2s6IEV2ZW50RW1pdHRlcjxTZWxlY3RvclR5cGU+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIGN1cnJlbnRUeXBlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8U2VsZWN0b3JUeXBlPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIHB1YmxpYyB0d29ESWNvbjogU2FmZUh0bWwgfCBudWxsO1xuICAgIHB1YmxpYyB0aHJlZURJY29uOiBTYWZlSHRtbCB8IG51bGw7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIF9jaGFuZ2VEZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWZcbiAgICApIHtcbiAgICAgICAgdGhpcy50d29ESWNvbiA9IHRoaXMuX2ljb25DYWNoZS5nZXRJY29uKHRoaXMuaWNvbnMuVHdvRCk7XG4gICAgICAgIHRoaXMudGhyZWVESWNvbiA9IHRoaXMuX2ljb25DYWNoZS5nZXRJY29uKHRoaXMuaWNvbnMuVGhyZWVEKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICB9XG5cbiAgICBwdWJsaWMgaGFuZGxlSWNvbkNsaWNrKHR5cGU6IFNlbGVjdG9yVHlwZSk6IHZvaWQge1xuICAgICAgICB0aGlzLmN1cnJlbnRUeXBlID0gdHlwZTtcbiAgICAgICAgdGhpcy5jdXJyZW50VHlwZUNoYW5nZS5uZXh0KHRoaXMuY3VycmVudFR5cGUpO1xuICAgICAgICB0aGlzLm9uSWNvbkNsaWNrLm5leHQodGhpcy5jdXJyZW50VHlwZSk7XG4gICAgICAgIHRoaXMuX2NoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG5cbn1cbiJdfQ==
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1zZWxlY3Rvci10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9wcm9kdWN0LXNlbGVjdG9yLXR5cGUvcHJvZHVjdC1zZWxlY3Rvci10eXBlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWhHLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xFLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUEwQjNELE1BQU0sT0FBTyw0QkFBNEI7SUEwQnJDLFlBQ1ksVUFBNEIsRUFDNUIsZUFBa0M7UUFEbEMsZUFBVSxHQUFWLFVBQVUsQ0FBa0I7UUFDNUIsb0JBQWUsR0FBZixlQUFlLENBQW1CO1FBMUI5QixTQUFJLEdBQXdCLFlBQVksQ0FBQztRQUN6QyxVQUFLLEdBQW9CLFFBQVEsQ0FBQztRQWUzQyxnQkFBVyxHQUErQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRzdELHNCQUFpQixHQUErQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBU3RFLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakUsQ0FBQztJQUVELFFBQVE7SUFDUixDQUFDO0lBRU0sZUFBZSxDQUFDLElBQWtCO1FBQ3JDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN4QyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pDLENBQUM7OztZQWxFSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLDJCQUEyQjtnQkFDckMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJYOzthQUVGOzs7WUEzQk8sZ0JBQWdCO1lBRmhCLGlCQUFpQjs7O3FCQW1DcEIsS0FBSztxQkFHTCxLQUFLO2lDQUdMLEtBQUs7MEJBR0wsS0FBSzswQkFHTCxNQUFNO2dDQUdOLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U2FmZUh0bWx9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHtJY29uQ2FjaGVTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlL2ljb24tY2FjaGUuc2VydmljZSc7XG5pbXBvcnQge0ljb25FbnVtfSBmcm9tICcuLi8uLi9lbnVtL2ljb24uZW51bSc7XG5pbXBvcnQge1NlbGVjdG9yVHlwZX0gZnJvbSAnLi4vLi4vZW51bS9zZWxlY3Rvci10eXBlLmVudW0nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FwcC1wcm9kdWN0LXNlbGVjdG9yLXR5cGUnLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxkaXYgKm5nSWY9XCJzaG93MkQgfHwgc2hvdzNEXCIgY2xhc3M9XCJzaG93LWluXCIgW3RleHRDb250ZW50XT1cIidTSE9XX0lOJyB8IGxvY2FsaXplXCI+PC9kaXY+XG4gICAgICAgIDxjby1pY29uICpuZ0lmPVwic2hvdzJEICYmICFzaG93UmVuZGVyQ2Fyb3VzZWxcIiBjbGFzcz1cInNlbGVjdG9yLXR5cGUtaWNvblwiXG4gICAgICAgICAgICAgICAgIFtjbGFzcy5hY3RpdmVdPVwiY3VycmVudFR5cGUgPT09IHR5cGUuVHdvRFwiXG4gICAgICAgICAgICAgICAgIFtpY29uRGF0YV09XCJ0d29ESWNvblwiXG4gICAgICAgICAgICAgICAgIChjbGljayk9XCJoYW5kbGVJY29uQ2xpY2sodHlwZS5Ud29EKVwiXG4gICAgICAgID48L2NvLWljb24+XG5cbiAgICAgICAgPGNvLWljb24gKm5nSWY9XCJzaG93MkQgJiYgc2hvd1JlbmRlckNhcm91c2VsXCIgY2xhc3M9XCJzZWxlY3Rvci10eXBlLWljb25cIlxuICAgICAgICAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cImN1cnJlbnRUeXBlID09PSB0eXBlLlR3b0RcIlxuICAgICAgICAgICAgICAgICBbaWNvbkRhdGFdPVwidHdvREljb25cIlxuICAgICAgICAgICAgICAgICAoY2xpY2spPVwiaGFuZGxlSWNvbkNsaWNrKHR5cGUuVHdvRClcIlxuICAgICAgICA+PC9jby1pY29uPlxuXG4gICAgICAgIDxjby1pY29uICpuZ0lmPVwic2hvdzNEXCIgY2xhc3M9XCJzZWxlY3Rvci10eXBlLWljb25cIlxuICAgICAgICAgICAgICAgICBbY2xhc3MuYWN0aXZlXT1cImN1cnJlbnRUeXBlID09PSB0eXBlLlRocmVlRFwiXG4gICAgICAgICAgICAgICAgIFtpY29uRGF0YV09XCJ0aHJlZURJY29uXCJcbiAgICAgICAgICAgICAgICAgKGNsaWNrKT1cImhhbmRsZUljb25DbGljayh0eXBlLlRocmVlRClcIlxuICAgICAgICA+PC9jby1pY29uPlxuICBgLFxuICAgIHN0eWxlVXJsczogWycuL3Byb2R1Y3Qtc2VsZWN0b3ItdHlwZS5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIFByb2R1Y3RTZWxlY3RvclR5cGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHR5cGU6IHR5cGVvZiBTZWxlY3RvclR5cGUgPSBTZWxlY3RvclR5cGU7XG4gICAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbkVudW0gPSBJY29uRW51bTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNob3cyRDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNob3czRDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNob3dSZW5kZXJDYXJvdXNlbDogYm9vbGVhbjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGN1cnJlbnRUeXBlOiBTZWxlY3RvclR5cGU7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgb25JY29uQ2xpY2s6IEV2ZW50RW1pdHRlcjxTZWxlY3RvclR5cGU+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIGN1cnJlbnRUeXBlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8U2VsZWN0b3JUeXBlPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIHB1YmxpYyB0d29ESWNvbjogU2FmZUh0bWwgfCBudWxsO1xuICAgIHB1YmxpYyB0aHJlZURJY29uOiBTYWZlSHRtbCB8IG51bGw7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBfaWNvbkNhY2hlOiBJY29uQ2FjaGVTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIF9jaGFuZ2VEZXRlY3RvcjogQ2hhbmdlRGV0ZWN0b3JSZWZcbiAgICApIHtcbiAgICAgICAgdGhpcy50d29ESWNvbiA9IHRoaXMuX2ljb25DYWNoZS5nZXRJY29uKHRoaXMuaWNvbnMuVHdvRCk7XG4gICAgICAgIHRoaXMudGhyZWVESWNvbiA9IHRoaXMuX2ljb25DYWNoZS5nZXRJY29uKHRoaXMuaWNvbnMuVGhyZWVEKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICB9XG5cbiAgICBwdWJsaWMgaGFuZGxlSWNvbkNsaWNrKHR5cGU6IFNlbGVjdG9yVHlwZSk6IHZvaWQge1xuICAgICAgICB0aGlzLmN1cnJlbnRUeXBlID0gdHlwZTtcbiAgICAgICAgdGhpcy5jdXJyZW50VHlwZUNoYW5nZS5uZXh0KHRoaXMuY3VycmVudFR5cGUpO1xuICAgICAgICB0aGlzLm9uSWNvbkNsaWNrLm5leHQodGhpcy5jdXJyZW50VHlwZSk7XG4gICAgICAgIHRoaXMuX2NoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG5cbn1cbiJdfQ==
@@ -0,0 +1,127 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, ViewChild } from '@angular/core';
2
+ import { ProductEventService } from '../../service/product-event.service';
3
+ import { IconCacheService } from "../../service/icon-cache.service";
4
+ import { IconEnum } from "../../enum/icon.enum";
5
+ export class VectorObject {
6
+ }
7
+ export class RenderParameters {
8
+ }
9
+ export class RenderCarouselComponent {
10
+ constructor(iconCache, _appEventService, _changeDetector) {
11
+ this.iconCache = iconCache;
12
+ this._appEventService = _appEventService;
13
+ this._changeDetector = _changeDetector;
14
+ this.showRefresh = false;
15
+ this.resizing = false;
16
+ this.showLoader = true;
17
+ this.renderedImageLoaded = false;
18
+ // For now we will just use mock data
19
+ this.renderAngles = [0, -45, -90, -135, -180, -225, -270, -315];
20
+ this.currentRenderAngleIndex = 0;
21
+ this.icon = IconEnum;
22
+ this._subs = [];
23
+ this._subs.push(this._appEventService.onReadyToRender.subscribe((readyToRender) => {
24
+ if (readyToRender) {
25
+ this.showLoader = true;
26
+ this._createNewRender();
27
+ }
28
+ }), this._appEventService.onRenderStarted.subscribe(() => {
29
+ this.showLoader = true;
30
+ this._changeDetector.detectChanges();
31
+ }), this._appEventService.onRenderImageReceived.subscribe((image) => {
32
+ this.renderedImage = image;
33
+ this.showLoader = false;
34
+ this._changeDetector.detectChanges();
35
+ }));
36
+ }
37
+ handleWindowResize() {
38
+ this.resizing = true;
39
+ clearTimeout(this._resizeTimer);
40
+ this._resizeTimer = setTimeout(() => {
41
+ this.resizing = false;
42
+ }, 200);
43
+ }
44
+ gotoNextSlide() {
45
+ this.showLoader = true;
46
+ this.currentRenderAngleIndex = (this.currentRenderAngleIndex + 1) % this.renderAngles.length;
47
+ this._createNewRender();
48
+ }
49
+ gotoPrevSlide() {
50
+ this.showLoader = true;
51
+ this.currentRenderAngleIndex = (this.currentRenderAngleIndex - 1 + this.renderAngles.length) % this.renderAngles.length;
52
+ this._createNewRender();
53
+ }
54
+ ngOnDestroy() {
55
+ this.carousel = undefined;
56
+ this._subs.forEach(s => s.unsubscribe());
57
+ }
58
+ ngOnChanges() {
59
+ this.renderedImageLoaded = false;
60
+ }
61
+ onRenderLoaded() {
62
+ this.renderedImageLoaded = true;
63
+ }
64
+ _getRenderSettings() {
65
+ const settings = new RenderParameters();
66
+ const rotation = new VectorObject();
67
+ rotation.x = 0;
68
+ rotation.y = this.renderAngles[this.currentRenderAngleIndex];
69
+ rotation.z = 0;
70
+ settings.objectRotation = rotation;
71
+ settings.margin = 15;
72
+ return settings;
73
+ }
74
+ _createNewRender() {
75
+ this.showLoader = true;
76
+ this.renderedImageLoaded = false;
77
+ const renderParams = this._getRenderSettings();
78
+ this._appEventService.onGetRenderForRenderCarousel.next(renderParams);
79
+ }
80
+ }
81
+ RenderCarouselComponent.decorators = [
82
+ { type: Component, args: [{
83
+ selector: 'app-render-carousel',
84
+ template: `
85
+ <div id="product_page_carousel">
86
+ <div id="product_page_carousel_render_items">
87
+ <co-loader [isShown]="showLoader"></co-loader>
88
+ <div #carousel class="inner-carousel">
89
+ <div class="inner-carousel-render">
90
+ <img
91
+ [src]="renderedImage"
92
+ [class.loaded]="renderedImageLoaded"
93
+ (load)="onRenderLoaded()"
94
+ class="fade-image"
95
+ alt="">
96
+ </div>
97
+ <div class="carousel-scroller-layer">
98
+ <div class="carousel-item-scroller prev" (click)="gotoPrevSlide()">
99
+ <co-icon [iconData]="iconCache.getIcon(icon.ArrowPointLeft)"></co-icon>
100
+ </div>
101
+ <div class="carousel-item-scroller next" (click)="gotoNextSlide()">
102
+ <co-icon [iconData]="iconCache.getIcon(icon.ArrowPointRight)"></co-icon>
103
+ </div>
104
+ </div>
105
+ </div>
106
+ </div>
107
+ </div>
108
+ `,
109
+ changeDetection: ChangeDetectionStrategy.OnPush,
110
+ 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_render_items{position:relative;margin-bottom:10px;min-height:400px}#product_page_carousel #product_page_carousel_render_items ::ng-deep co-loader{position:absolute}#product_page_carousel .inner-carousel{display:flex;flex-direction:row;align-items:center;overflow:hidden;max-height:700px}#product_page_carousel .inner-carousel .inner-carousel-render img{width:100%;height:auto;-o-object-fit:contain;object-fit:contain}#product_page_carousel .carousel-scroller-layer{height:100%;width:100%;position:absolute;top:0;left:0;z-index:100}#product_page_carousel .carousel-scroller-layer .carousel-item-scroller{opacity:0;position:absolute;border-radius:50%;z-index:100;background:rgba(255,255,255,.4);color:#fff;width:30px;height:30px;top:calc(50% - 15px);cursor:pointer;transition:opacity .3s}#product_page_carousel .carousel-scroller-layer .carousel-item-scroller co-icon{color:#fff}#product_page_carousel .carousel-scroller-layer .prev{left:15px}#product_page_carousel .carousel-scroller-layer .next{right:15px}#product_page_carousel .carousel-scroller-layer:hover .carousel-item-scroller{opacity:1}#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}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-image{opacity:0;transition:opacity 1.5s ease-in-out}.fade-image.loaded{opacity:1}\n"]
111
+ },] }
112
+ ];
113
+ RenderCarouselComponent.ctorParameters = () => [
114
+ { type: IconCacheService },
115
+ { type: ProductEventService },
116
+ { type: ChangeDetectorRef }
117
+ ];
118
+ RenderCarouselComponent.propDecorators = {
119
+ carousel: [{ type: ViewChild, args: ['carousel', { read: ElementRef },] }],
120
+ showRefresh: [{ type: Input }],
121
+ article: [{ type: Input }],
122
+ handleWindowResize: [{ type: HostListener, args: ['window:resize',] }],
123
+ gotoNextSlide: [{ type: HostListener, args: ['swipeleft',] }],
124
+ gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
125
+ resizing: [{ type: HostBinding, args: ['class.resizing',] }]
126
+ };
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/render-carousel/render-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnChanges,\r\n  OnDestroy,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {ProductEventService} from '../../service/product-event.service';\r\nimport {Subscription} from 'rxjs';\r\nimport {ArticleFullObject} from \"@colijnit/articleapi/build/model/article-full-object\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {IconEnum} from \"../../enum/icon.enum\";\r\n\r\nexport class VectorObject {\r\n  public x: number;\r\n  public y: number;\r\n  public z: number;\r\n}\r\n\r\nexport class RenderParameters {\r\n  public objectRotation: VectorObject;\r\n  public margin: number;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-render-carousel',\r\n  template: `\r\n    <div id=\"product_page_carousel\">\r\n      <div id=\"product_page_carousel_render_items\">\r\n        <co-loader [isShown]=\"showLoader\"></co-loader>\r\n        <div #carousel class=\"inner-carousel\">\r\n          <div class=\"inner-carousel-render\">\r\n            <img\r\n              [src]=\"renderedImage\"\r\n              [class.loaded]=\"renderedImageLoaded\"\r\n              (load)=\"onRenderLoaded()\"\r\n              class=\"fade-image\"\r\n              alt=\"\">\r\n          </div>\r\n          <div class=\"carousel-scroller-layer\">\r\n            <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\">\r\n              <co-icon [iconData]=\"iconCache.getIcon(icon.ArrowPointLeft)\"></co-icon>\r\n            </div>\r\n            <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\">\r\n              <co-icon [iconData]=\"iconCache.getIcon(icon.ArrowPointRight)\"></co-icon>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  styleUrls: ['./render-carousel.component.scss']\r\n})\r\nexport class RenderCarouselComponent implements OnDestroy, OnChanges {\r\n  @ViewChild('carousel', {read: ElementRef})\r\n  public carousel: ElementRef;\r\n\r\n  @Input()\r\n  public showRefresh: boolean = false;\r\n\r\n  @Input()\r\n  public article: ArticleFullObject;\r\n\r\n  @HostListener('window:resize')\r\n  public handleWindowResize(): void {\r\n    this.resizing = true;\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.showLoader = true;\r\n    this.currentRenderAngleIndex = (this.currentRenderAngleIndex + 1) % this.renderAngles.length;\r\n    this._createNewRender();\r\n  }\r\n\r\n  @HostListener('swiperight')\r\n  public gotoPrevSlide(): void {\r\n    this.showLoader = true;\r\n    this.currentRenderAngleIndex = ( this.currentRenderAngleIndex - 1 + this.renderAngles.length) % this.renderAngles.length;\r\n    this._createNewRender();\r\n  }\r\n\r\n  @HostBinding('class.resizing')\r\n  public resizing = false;\r\n\r\n  public showLoader: boolean = true;\r\n  public renderedImage: string;\r\n  public renderedImageLoaded: boolean = false;\r\n\r\n  // For now we will just use mock data\r\n  public renderAngles: any = [0, -45, -90, -135, -180, -225, -270, -315];\r\n  public currentRenderAngleIndex: number = 0;\r\n  public readonly icon: typeof IconEnum = IconEnum;\r\n  private _resizeTimer: any;\r\n  private _subs: Subscription[] = [];\r\n\r\n  constructor(\r\n    public iconCache: IconCacheService,\r\n    private _appEventService: ProductEventService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n  ) {\r\n    this._subs.push(\r\n      this._appEventService.onReadyToRender.subscribe((readyToRender: boolean) => {\r\n        if (readyToRender) {\r\n          this.showLoader = true;\r\n          this._createNewRender();\r\n        }\r\n      }),\r\n      this._appEventService.onRenderStarted.subscribe(()=> {\r\n        this.showLoader = true;\r\n        this._changeDetector.detectChanges();\r\n      }),\r\n      this._appEventService.onRenderImageReceived.subscribe((image: string) => {\r\n        this.renderedImage = image;\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  ngOnChanges(): void {\r\n    this.renderedImageLoaded = false;\r\n  }\r\n\r\n  public onRenderLoaded(): void {\r\n    this.renderedImageLoaded = true;\r\n  }\r\n\r\n  private _getRenderSettings(): RenderParameters {\r\n    const settings: RenderParameters = new RenderParameters();\r\n    const rotation: VectorObject = new VectorObject();\r\n    rotation.x = 0;\r\n    rotation.y = this.renderAngles[this.currentRenderAngleIndex];\r\n    rotation.z = 0\r\n    settings.objectRotation = rotation;\r\n    settings.margin = 15;\r\n    return settings\r\n  }\r\n\r\n  private _createNewRender(): void {\r\n    this.showLoader = true;\r\n    this.renderedImageLoaded = false;\r\n    const renderParams: RenderParameters = this._getRenderSettings();\r\n    this._appEventService.onGetRenderForRenderCarousel.next(renderParams);\r\n  }\r\n}\r\n"]}