@colijnit/product 257.1.6 → 257.1.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/app/ione-product.component.d.ts +3 -11
- package/app/model/productSettings.d.ts +2 -14
- package/bundles/colijnit-product.umd.js +59 -72
- package/bundles/colijnit-product.umd.js.map +1 -1
- package/colijnit-product.metadata.json +1 -1
- package/esm2015/app/components/image-carousel/image-carousel.component.js +2 -1
- package/esm2015/app/components/product-page/product-page.component.js +1 -1
- package/esm2015/app/ione-product.component.js +11 -19
- package/esm2015/app/ione-product.module.js +1 -11
- package/esm2015/app/model/productSettings.js +4 -6
- package/esm2015/app/product-version.js +3 -3
- package/fesm2015/colijnit-product.js +40 -55
- package/fesm2015/colijnit-product.js.map +1 -1
- package/package.json +1 -1
|
@@ -165,6 +165,7 @@ export class ImageCarouselComponent {
|
|
|
165
165
|
const resizedSource = resizeCanvas.toDataURL('image/jpeg');
|
|
166
166
|
imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);
|
|
167
167
|
imageViewModel.originalSource = source;
|
|
168
|
+
this._changeDetector.detectChanges();
|
|
168
169
|
});
|
|
169
170
|
// @ts-ignore
|
|
170
171
|
resizeImage.src = source;
|
|
@@ -237,4 +238,4 @@ ImageCarouselComponent.propDecorators = {
|
|
|
237
238
|
gotoPrevSlide: [{ type: HostListener, args: ['swiperight',] }],
|
|
238
239
|
resizing: [{ type: HostBinding, args: ['class.resizing',] }]
|
|
239
240
|
};
|
|
240
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-carousel.component.js","sourceRoot":"","sources":["../../../../../src/app/components/image-carousel/image-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  ViewChild\n} from '@angular/core';\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document';\nimport {ProductConnectorService} from '../../service/product-connector.service';\nimport {ProductEventService} from '../../service/product-event.service';\nimport {Subscription} from 'rxjs';\nimport {IconEnum} from '../../enum/icon.enum';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {DocumentContent} from '@colijnit/articleapi/build/model/document-content';\n\nexport class ImageViewModel {\n  public image: CoDocument | string;\n  public source: SafeUrl;\n  public originalSource: string;\n}\n\n@Component({\n  selector: 'app-image-carousel',\n  template: `\n      <div id=\"product_page_carousel\">\n          <div id=\"product_page_carousel_items\">\n              <co-loader [isShown]=\"true\" *ngIf=\"showLoader\"></co-loader>\n              <div #carousel class=\"inner-carousel\">\n                  <!-- This has been taken out of the for loop to prevent flashing images when updating. -->\n                  <div *ngIf=\"imageViewModels[0]\" class=\"carousel-item\" [id]=\"'slide-0'\" [class.active]=\"isCurrentIndex(0)\" (click)=\"handleShowImage(imageViewModels[0])\">\n                      <img [src]=\"imageViewModels[0].source\">\n                  </div>\n                  <div *ngFor=\"let imageViewModel of imageViewModels.slice(1); let index = index\" class=\"carousel-item\"\n                       [id]=\"'slide-' + (index + 1)\" [class.active]=\"isCurrentIndex((index + 1))\" (click)=\"handleShowImage(imageViewModel)\">\n                      <img [src]=\"imageViewModel.source\">\n                  </div>\n                  <div class=\"carousel-scroller-layer\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                      <div class=\"carousel-item-scroller prev\" (click)=\"gotoPrevSlide()\" *ngIf=\"currentIndex > 0\"></div>\n                      <div class=\"carousel-item-scroller next\" (click)=\"gotoNextSlide()\" *ngIf=\"currentIndex < images.length - 1\"></div>\n                  </div>\n              </div>\n              <!--\n                      <co-icon class=\"selector-type-icon refresh-button\" [iconData]=\"iconCache.getIcon(icons.Refresh)\" (click)=\"onForceRenderImage()\" [class.loading]=\"showLoader\" *ngIf=\"showRefresh\"></co-icon>\n              -->\n          </div>\n\n          <div id=\"product_page_carousel_thumbs\">\n              <co-scroll-container class=\"scroll-container\" *ngIf=\"imageViewModels && imageViewModels.length > 1\">\n                  <div *ngFor=\"let imageViewModel of imageViewModels; let index = index\" class=\"carousel-thumb\"\n                       [class.active]=\"index === currentIndex\">\n                      <img [src]=\"imageViewModel.source\" (click)=\"handleThumbClick(index)\"/>\n                  </div>\n              </co-scroll-container>\n          </div>\n      </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['./image-carousel.component.scss']\n})\nexport class ImageCarouselComponent implements OnDestroy {\n  @ViewChild('carousel', {read: ElementRef})\n  public carousel: ElementRef;\n\n  @Input()\n  public showRefresh: boolean = false;\n\n  @Input()\n  public set images(value: (CoDocument | string)[]) {\n    if (value && value.length > 0) {\n      this._images = this._filterValidImages(value);\n      this._loadAndRescaleImages();\n      this._changeDetector.detectChanges();\n    }\n  }\n\n  public get images(): (CoDocument | string)[] {\n    return this._images;\n  }\n\n  @HostListener('window:resize')\n  public handleWindowResize(): void {\n    this.resizing = true;\n    this._scrollCarouselToIndex();\n    clearTimeout(this._resizeTimer);\n    this._resizeTimer = setTimeout(() => {\n      this.resizing = false;\n    }, 200);\n  }\n\n  @HostListener('swipeleft')\n  public gotoNextSlide(): void {\n    this.currentIndex++;\n  }\n\n  @HostListener('swiperight')\n  public gotoPrevSlide(): void {\n    this.currentIndex--;\n  }\n\n  public isCurrentIndex(index: number): boolean {\n    return this.currentIndex === index;\n  }\n\n  public get currentIndex(): number {\n    return this._currentIndex;\n  }\n\n  public set currentIndex(value: number) {\n    this._currentIndex = value;\n    this._scrollCarouselToIndex();\n  }\n\n  @HostBinding('class.resizing')\n  public resizing = false;\n\n  public imageViewModels: ImageViewModel[] = [];\n  public showLoader: boolean = false;\n\n  private _resizeTimer: any;\n  private _currentIndex = 0;\n  private _images: (CoDocument | string)[] = [];\n  private _subs: Subscription[] = [];\n\n  private _resizeCanvasHeight: number = 500;\n\n  constructor(\n    private _ione: ProductConnectorService,\n    private _appEventService: ProductEventService,\n    private _changeDetector: ChangeDetectorRef,\n    private _domSanitizer: DomSanitizer\n  ) {\n    this._subs.push(\n      this._appEventService.onRenderStarted.subscribe(() => {\n        this.showLoader = true;\n        this._changeDetector.detectChanges();\n        setTimeout(() => {\n          this.showLoader = false;\n          this._changeDetector.detectChanges();\n        }, 10000);\n      }),\n      this._appEventService.onDraftRenderImageReceived.subscribe((event: CustomEvent) => {\n        if (event && event.detail) {\n          if (this._images[0] instanceof CoDocument) {\n            this._images.unshift(event.detail);\n          } else {\n            this._images[0] = event.detail;\n          }\n          this._loadAndRescaleImages();\n        }\n        this.showLoader = false;\n        this._changeDetector.detectChanges();\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.carousel = undefined;\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  public handleThumbClick(index: number): void {\n    this.currentIndex = index;\n  }\n\n  public onForceRenderImage(): void {\n    this._appEventService.onForceRenderImage.next();\n  }\n\n  public handleShowImage(imageViewModel: ImageViewModel): void {\n    if (imageViewModel && imageViewModel.originalSource) {\n      let popupWindow: Window = window.open('', 'Image zoom', 'width=600,height=400');\n      // Set the content of the popup window\n      popupWindow.document.write('<html><head><title>Image zoom</title></head><body>');\n      popupWindow.document.write(`<img src=${imageViewModel.originalSource} alt=\"Image\" style=\"width:100%; height:auto;\">`);\n      popupWindow.document.write('</body></html>');\n      // Close the document to render the popup window\n      popupWindow.document.close();\n    }\n  }\n\n  private _filterValidImages(value: (CoDocument | string)[]): (CoDocument | string)[] {\n    if (!value) {\n      return [];\n    }\n    return value.filter((doc: CoDocument | string) => {\n      const pattern = /\\.(jpg|jpeg|png|gif|bmp|tiff|webp)$/i;\n      return typeof doc === 'string' || (pattern.test(doc.fileName) || !!doc.filePath);\n    });\n  }\n\n  private _loadAndRescaleImages(): void {\n    this.imageViewModels.length = 0;\n    if (this._images) {\n      this._images.forEach((i: CoDocument | string) => {\n        let imageViewModel = new ImageViewModel();\n        imageViewModel.image = i;\n        if (typeof i === 'string') { // is a rendered image coming from configurator\n          this._resizeAndSanitizeSource(i, imageViewModel);\n        } else {\n          if (i.filePath) {\n            this._resizeAndSanitizeSource(i.filePath, imageViewModel);\n          } else if (i.documentBody) {\n            this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n          } else {\n            this._ione.getDocumentContent(i.documentId, false).then((content: DocumentContent) => {\n              if (content) {\n                i.documentBody = content.documentContent;\n                this._resizeAndSanitizeSource(i.documentBodyAsDataUri, imageViewModel);\n                this._changeDetector.detectChanges();\n              }\n            });\n          }\n        }\n        this.imageViewModels.push(imageViewModel);\n        this._changeDetector.detectChanges();\n      });\n    }\n  }\n\n  private _resizeAndSanitizeSource(source: string, imageViewModel: ImageViewModel): void {\n    const resizeCanvas: HTMLCanvasElement = document.createElement('canvas');\n    const resizeCanvasContext: CanvasRenderingContext2D = resizeCanvas.getContext('2d');\n    const resizeImage: HTMLImageElement = document.createElement('img');\n    resizeImage.onload = async () => {\n      resizeCanvasContext.imageSmoothingEnabled = true;\n      resizeCanvasContext.imageSmoothingQuality = 'high';\n      // Get the original image dimensions\n      const originalWidth = resizeImage.width;\n      const originalHeight = resizeImage.height;\n\n      // Calculate the aspect ratio\n      const aspectRatio = originalWidth / originalHeight;\n\n      // Calculate the new width and height while maintaining the aspect ratio\n      let newWidth: number = this._resizeCanvasHeight;\n      let newHeight: number = this._resizeCanvasHeight;\n\n      if (originalWidth > originalHeight) {\n        newHeight = this._resizeCanvasHeight / aspectRatio;\n      } else {\n        newWidth = this._resizeCanvasHeight * aspectRatio;\n      }\n\n      // Set the canvas size to the new width and height\n      resizeCanvas.width = newWidth;\n      resizeCanvas.height = newHeight;\n\n      const imageWidth: number = this._resizeCanvasHeight * (resizeImage.height / resizeImage.width);\n      resizeCanvasContext.drawImage(resizeImage, 0, 0, newWidth, newHeight);\n      const resizedSource = resizeCanvas.toDataURL('image/jpeg');\n\n      imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);\n      imageViewModel.originalSource = source;\n    };\n    // @ts-ignore\n    resizeImage.src = source;\n  }\n\n  private _scrollCarouselToIndex(): void {\n    if (this.currentIndex > -1 && this.currentIndex <= this.images.length) {\n      const movePx: number = this.currentIndex * this.carousel.nativeElement.clientWidth;\n      if (this.carousel && this.carousel.nativeElement) {\n        this.carousel.nativeElement.scrollLeft = movePx;\n        // this.carousel.nativeElement.scrollTo({\n        //   left: movePx,\n        //   behavior: 'smooth'\n        // });\n      }\n    }\n  }\n\n}\n"]}
|
|
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"]}
|
|
@@ -233,4 +233,4 @@ ProductPageComponent.propDecorators = {
|
|
|
233
233
|
showRelatedProductsPopup: [{ type: Input }],
|
|
234
234
|
openStockEvent: [{ type: Output }]
|
|
235
235
|
};
|
|
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"]}
|
|
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  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  @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  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"]}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import {
|
|
3
|
-
import { JsonUtilsService } from './utils/json-utils.service';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
4
3
|
import { ProductConnectorService } from './service/product-connector.service';
|
|
5
|
-
import { DictionaryService } from './service/dictionary.service';
|
|
6
4
|
import { ProductEventService } from './service/product-event.service';
|
|
7
5
|
import { ProductSettingsService } from './service/product-settings.service';
|
|
6
|
+
import { ProductConnectorAdapterService } from './service/product-connector-adapter.service';
|
|
8
7
|
export class IoneProductComponent {
|
|
9
|
-
constructor(
|
|
8
|
+
constructor(_appEventService, _settingsService) {
|
|
10
9
|
// this.sku = 'CF-HILL';
|
|
11
10
|
// this.sku = 'CF-ALMADA';
|
|
12
11
|
// this.sku = 'CF-39904ANT';
|
|
@@ -19,10 +18,6 @@ export class IoneProductComponent {
|
|
|
19
18
|
// this.sku = '104';
|
|
20
19
|
// this.sku = "70000107";
|
|
21
20
|
// this.sku = "grover";
|
|
22
|
-
this._dictionary = _dictionary;
|
|
23
|
-
this._jsonUtils = _jsonUtils;
|
|
24
|
-
this._ione = _ione;
|
|
25
|
-
this._changeDetector = _changeDetector;
|
|
26
21
|
this._appEventService = _appEventService;
|
|
27
22
|
this._settingsService = _settingsService;
|
|
28
23
|
this.handleAddArticleInternally = true;
|
|
@@ -38,9 +33,7 @@ export class IoneProductComponent {
|
|
|
38
33
|
this.settingsLoaded = false;
|
|
39
34
|
this.showHD = false;
|
|
40
35
|
this._subs = [];
|
|
41
|
-
this._subs.push(
|
|
42
|
-
// this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),
|
|
43
|
-
this._appEventService.onAddToCart.subscribe((data) => {
|
|
36
|
+
this._subs.push(this._appEventService.onAddToCart.subscribe((data) => {
|
|
44
37
|
this._handleAddToCart(data);
|
|
45
38
|
}), this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)), this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)), this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)), this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)), this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)), this._appEventService.onAnswersAvailable.subscribe(answers => this._handleAnswersAvailable(answers)), this._settingsService.settingsLoaded.subscribe(loaded => {
|
|
46
39
|
this.settingsLoaded = loaded;
|
|
@@ -67,9 +60,6 @@ export class IoneProductComponent {
|
|
|
67
60
|
}
|
|
68
61
|
});
|
|
69
62
|
}
|
|
70
|
-
ngOnChanges(changes) {
|
|
71
|
-
this._changeDetector.detectChanges();
|
|
72
|
-
}
|
|
73
63
|
ngOnDestroy() {
|
|
74
64
|
this._subs.forEach(s => s.unsubscribe());
|
|
75
65
|
}
|
|
@@ -102,15 +92,17 @@ IoneProductComponent.decorators = [
|
|
|
102
92
|
<!-- <co-button [label]="'click'" (click)="showHD = !showHD"></co-button>
|
|
103
93
|
<co-product-hd [sku]="'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'" *ngIf="showHD"></co-product-hd>-->
|
|
104
94
|
`,
|
|
95
|
+
providers: [
|
|
96
|
+
ProductSettingsService,
|
|
97
|
+
ProductConnectorService,
|
|
98
|
+
ProductEventService,
|
|
99
|
+
ProductConnectorAdapterService
|
|
100
|
+
],
|
|
105
101
|
encapsulation: ViewEncapsulation.Emulated,
|
|
106
102
|
styles: [""]
|
|
107
103
|
},] }
|
|
108
104
|
];
|
|
109
105
|
IoneProductComponent.ctorParameters = () => [
|
|
110
|
-
{ type: DictionaryService },
|
|
111
|
-
{ type: JsonUtilsService },
|
|
112
|
-
{ type: ProductConnectorService },
|
|
113
|
-
{ type: ChangeDetectorRef },
|
|
114
106
|
{ type: ProductEventService },
|
|
115
107
|
{ type: ProductSettingsService }
|
|
116
108
|
];
|
|
@@ -130,4 +122,4 @@ IoneProductComponent.propDecorators = {
|
|
|
130
122
|
openStockEvent: [{ type: Output }],
|
|
131
123
|
onAnswersAvailable: [{ type: Output }]
|
|
132
124
|
};
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"","sources":["../../../src/app/ione-product.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation\n} from '@angular/core';\nimport {JsonUtilsService} from './utils/json-utils.service';\nimport {ProductConnectorService} from './service/product-connector.service';\nimport {DictionaryService} from './service/dictionary.service';\nimport {Subscription} from 'rxjs';\nimport {ProductEventService} from './service/product-event.service';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductSettingsService} from './service/product-settings.service';\nimport {Selection} from '@colijnit/articleapi/build/model/selection';\nimport {ArticleQuickSel} from '@colijnit/articleapi/build/model/article-quick-sel';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\n\n@Component({\n  selector: 'app-ione-product',\n  template: `\n     <app-product-page *ngIf=\"settingsLoaded\"\n                        [createFrozenArticle]=\"handleAddArticleInternally\"\n                        [isReturn]=\"isReturn\"\n                        (openStockEvent)=\"openStock()\"\n                        [sku]=\"sku\"\n                        [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\n      ></app-product-page>\n    <!--  <co-button [label]=\"'click'\" (click)=\"showHD = !showHD\"></co-button>\n      <co-product-hd [sku]=\"'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'\" *ngIf=\"showHD\"></co-product-hd>-->\n  `,\n  encapsulation: ViewEncapsulation.Emulated,\n  styleUrls: ['./ione-product.component.css']\n})\nexport class IoneProductComponent implements OnInit, OnChanges, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public isReturn: boolean;\n\n  @Input()\n  public showRelatedProductsPopup: boolean;\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  public get settings(): any {\n    return this._settings;\n  }\n\n  @Input()\n  public handleAddArticleInternally: boolean = true;\n\n  @Output()\n  public onAddToCart: EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }>();\n\n  @Output()\n  public forceRenderImage: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAlternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\n\n  @Output()\n  public onArticleInfoReceived: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public onArticleReceived: EventEmitter<ArticleQuickSel> = new EventEmitter<ArticleQuickSel>();\n\n  @Output()\n  public onSelectionsReceived: EventEmitter<Selection[]> = new EventEmitter<Selection[]>();\n\n  @Output()\n  public onAddToQuote: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAnswersAvailable: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  public settingsLoaded: boolean = false;\n  public showHD: boolean = false;\n\n  private _settings: any;\n  private _subs: Subscription[] = [];\n\n  constructor (\n    private _dictionary: DictionaryService,\n    private _jsonUtils: JsonUtilsService,\n    private _ione: ProductConnectorService,\n    private _changeDetector: ChangeDetectorRef,\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService\n  ) {\n    // this.sku = 'CF-HILL';\n    // this.sku = 'CF-ALMADA';\n    // this.sku = 'CF-39904ANT';\n    // this.sku = 'CF-22346001';\n    // this.sku = '104';\n    // this.sku = '1000561986';\n    // this.sku = '1000567768';\n    // this.sku = '1000234793';\n    // this.sku = '1066';\n    // this.sku = '104';\n    // this.sku = \"70000107\";\n    // this.sku = \"grover\";\n\n    this._subs.push(\n      // this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),\n      this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\n        this._handleAddToCart(data);\n      }),\n      this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)),\n      this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)),\n      this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)),\n      this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)),\n      this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)),\n      this._appEventService.onAnswersAvailable.subscribe(answers => this._handleAnswersAvailable(answers)),\n      this._settingsService.settingsLoaded.subscribe(loaded => {\n        this.settingsLoaded = loaded;\n      }),\n    );\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this._settingsService.initializeSettings(this._settings === undefined);\n    if (this._settings) {\n      this._settingsService.createSettingsFromObject(this._settings);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this._changeDetector.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  private _handleAnswerInfoReceived(info: string): void {\n    this.onArticleInfoReceived.next(info);\n  }\n\n  private _handleAnswersAvailable(answers: boolean): void {\n    this.onAnswersAvailable.next(answers);\n  }\n\n  private async _handleAddToCart(data: { article: string | ArticleListObjectExtended, quantity: number }): Promise<void> {\n    this.onAddToCart.emit(data);\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ione-product.component.js","sourceRoot":"","sources":["../../../src/app/ione-product.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\nimport {ProductConnectorService} from './service/product-connector.service';\nimport {Subscription} from 'rxjs';\nimport {ProductEventService} from './service/product-event.service';\nimport {ArticleListObject} from '@colijnit/articleapi/build/model/article-list-object';\nimport {ProductSettingsService} from './service/product-settings.service';\nimport {Selection} from '@colijnit/articleapi/build/model/selection';\nimport {ArticleQuickSel} from '@colijnit/articleapi/build/model/article-quick-sel';\nimport {ArticleListObjectExtended} from '@colijnit/articleapi/build/model/article-list-object-extended.bo';\nimport {ProductConnectorAdapterService} from './service/product-connector-adapter.service';\n\n@Component({\n  selector: 'app-ione-product',\n  template: `\n     <app-product-page *ngIf=\"settingsLoaded\"\n                        [createFrozenArticle]=\"handleAddArticleInternally\"\n                        [isReturn]=\"isReturn\"\n                        (openStockEvent)=\"openStock()\"\n                        [sku]=\"sku\"\n                        [showRelatedProductsPopup]=\"showRelatedProductsPopup\"\n      ></app-product-page>\n    <!--  <co-button [label]=\"'click'\" (click)=\"showHD = !showHD\"></co-button>\n      <co-product-hd [sku]=\"'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'\" *ngIf=\"showHD\"></co-product-hd>-->\n  `,\n  providers: [\n    ProductSettingsService,\n    ProductConnectorService,\n    ProductEventService,\n    ProductConnectorAdapterService\n  ],\n  encapsulation: ViewEncapsulation.Emulated,\n  styleUrls: ['./ione-product.component.css']\n})\nexport class IoneProductComponent implements OnInit, OnDestroy {\n\n  @Input()\n  public sku: string;\n\n  @Input()\n  public isReturn: boolean;\n\n  @Input()\n  public showRelatedProductsPopup: boolean;\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  public get settings(): any {\n    return this._settings;\n  }\n\n  @Input()\n  public handleAddArticleInternally: boolean = true;\n\n  @Output()\n  public onAddToCart: EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }> = new EventEmitter<{ article: string | ArticleListObjectExtended, quantity: number }>();\n\n  @Output()\n  public forceRenderImage: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAlternativeClick: EventEmitter<ArticleListObject> = new EventEmitter<ArticleListObject>();\n\n  @Output()\n  public onArticleInfoReceived: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public onArticleReceived: EventEmitter<ArticleQuickSel> = new EventEmitter<ArticleQuickSel>();\n\n  @Output()\n  public onSelectionsReceived: EventEmitter<Selection[]> = new EventEmitter<Selection[]>();\n\n  @Output()\n  public onAddToQuote: EventEmitter<string> = new EventEmitter<string>();\n\n  @Output()\n  public openStockEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  public onAnswersAvailable: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n  public settingsLoaded: boolean = false;\n  public showHD: boolean = false;\n\n  private _settings: any;\n  private _subs: Subscription[] = [];\n\n  constructor (\n    private _appEventService: ProductEventService,\n    private _settingsService: ProductSettingsService\n  ) {\n    // this.sku = 'CF-HILL';\n    // this.sku = 'CF-ALMADA';\n    // this.sku = 'CF-39904ANT';\n    // this.sku = 'CF-22346001';\n    // this.sku = '104';\n    // this.sku = '1000561986';\n    // this.sku = '1000567768';\n    // this.sku = '1000234793';\n    // this.sku = '1066';\n    // this.sku = '104';\n    // this.sku = \"70000107\";\n    // this.sku = \"grover\";\n\n    this._subs.push(\n      this._appEventService.onAddToCart.subscribe((data: { article: string | ArticleListObjectExtended, quantity: number }) => {\n        this._handleAddToCart(data);\n      }),\n      this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)),\n      this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)),\n      this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)),\n      this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)),\n      this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)),\n      this._appEventService.onAnswersAvailable.subscribe(answers => this._handleAnswersAvailable(answers)),\n      this._settingsService.settingsLoaded.subscribe(loaded => {\n        this.settingsLoaded = loaded;\n      }),\n    );\n  }\n\n  async ngOnInit(): Promise<void> {\n    await this._settingsService.initializeSettings(this._settings === undefined);\n    if (this._settings) {\n      this._settingsService.createSettingsFromObject(this._settings);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subs.forEach(s => s.unsubscribe());\n  }\n\n  private _handleAnswerInfoReceived(info: string): void {\n    this.onArticleInfoReceived.next(info);\n  }\n\n  private _handleAnswersAvailable(answers: boolean): void {\n    this.onAnswersAvailable.next(answers);\n  }\n\n  private async _handleAddToCart(data: { article: string | ArticleListObjectExtended, quantity: number }): Promise<void> {\n    this.onAddToCart.emit(data);\n  }\n  public openStock() {\n    this.openStockEvent.emit();\n  }\n}\n"]}
|
|
@@ -3,10 +3,6 @@ import { IoneProductComponent } from './ione-product.component';
|
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
//import {BrowserAnimationsModule} from '@angular/platform-browser/animations';
|
|
5
5
|
import { ProductPageModule } from './components/product-page/product-page.module';
|
|
6
|
-
import { ProductSettingsService } from './service/product-settings.service';
|
|
7
|
-
import { ProductConnectorService } from './service/product-connector.service';
|
|
8
|
-
import { ProductConnectorAdapterService } from './service/product-connector-adapter.service';
|
|
9
|
-
import { ProductEventService } from './service/product-event.service';
|
|
10
6
|
import { ProductHdModule } from './components/product-hd/product-hd.module';
|
|
11
7
|
import { ProductExternalSourceModule } from './components/product-external-source/product-external-source.module';
|
|
12
8
|
import { ButtonModule } from '@colijnit/corecomponents_v12';
|
|
@@ -34,13 +30,7 @@ IoneProductModule.decorators = [
|
|
|
34
30
|
],
|
|
35
31
|
bootstrap: [
|
|
36
32
|
IoneProductComponent
|
|
37
|
-
],
|
|
38
|
-
providers: [
|
|
39
|
-
ProductSettingsService,
|
|
40
|
-
ProductConnectorService,
|
|
41
|
-
ProductEventService,
|
|
42
|
-
ProductConnectorAdapterService
|
|
43
33
|
]
|
|
44
34
|
},] }
|
|
45
35
|
];
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uZS1wcm9kdWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcHAvaW9uZS1wcm9kdWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QywrRUFBK0U7QUFDL0UsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDaEYsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQzFFLE9BQU8sRUFBQywyQkFBMkIsRUFBQyxNQUFNLHFFQUFxRSxDQUFDO0FBQ2hILE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQXlCMUQsTUFBTSxPQUFPLGlCQUFpQjs7O1lBdkI3QixRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLDBCQUEwQjtvQkFDMUIsWUFBWTtvQkFDWixpQkFBaUI7b0JBQ2pCLGVBQWU7b0JBQ2YsMkJBQTJCO29CQUMzQixZQUFZO2lCQUNiO2dCQUNDLFlBQVksRUFBRTtvQkFDVixvQkFBb0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDTCxvQkFBb0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDTCxzQkFBc0I7b0JBQ3RCLGdCQUFnQjtpQkFDbkI7Z0JBQ0QsU0FBUyxFQUFFO29CQUNQLG9CQUFvQjtpQkFDdkI7YUFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTmdNb2R1bGUsIE5PX0VSUk9SU19TQ0hFTUF9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtJb25lUHJvZHVjdENvbXBvbmVudH0gZnJvbSAnLi9pb25lLXByb2R1Y3QuY29tcG9uZW50JztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuLy9pbXBvcnQge0Jyb3dzZXJBbmltYXRpb25zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtQcm9kdWN0UGFnZU1vZHVsZX0gZnJvbSAnLi9jb21wb25lbnRzL3Byb2R1Y3QtcGFnZS9wcm9kdWN0LXBhZ2UubW9kdWxlJztcbmltcG9ydCB7UHJvZHVjdEhkTW9kdWxlfSBmcm9tICcuL2NvbXBvbmVudHMvcHJvZHVjdC1oZC9wcm9kdWN0LWhkLm1vZHVsZSc7XG5pbXBvcnQge1Byb2R1Y3RFeHRlcm5hbFNvdXJjZU1vZHVsZX0gZnJvbSAnLi9jb21wb25lbnRzL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlL3Byb2R1Y3QtZXh0ZXJuYWwtc291cmNlLm1vZHVsZSc7XG5pbXBvcnQge0J1dHRvbk1vZHVsZX0gZnJvbSAnQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMic7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICAvL0Jyb3dzZXJBbmltYXRpb25zTW9kdWxlLFxuICAgIENvbW1vbk1vZHVsZSxcbiAgICBQcm9kdWN0UGFnZU1vZHVsZSxcbiAgICBQcm9kdWN0SGRNb2R1bGUsXG4gICAgUHJvZHVjdEV4dGVybmFsU291cmNlTW9kdWxlLFxuICAgIEJ1dHRvbk1vZHVsZVxuICBdLFxuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBJb25lUHJvZHVjdENvbXBvbmVudFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBJb25lUHJvZHVjdENvbXBvbmVudFxuICAgIF0sXG4gICAgc2NoZW1hczogW1xuICAgICAgICBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLFxuICAgICAgICBOT19FUlJPUlNfU0NIRU1BXG4gICAgXSxcbiAgICBib290c3RyYXA6IFtcbiAgICAgICAgSW9uZVByb2R1Y3RDb21wb25lbnRcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIElvbmVQcm9kdWN0TW9kdWxlIHtcbn1cbiJdfQ==
|
|
@@ -1,16 +1,14 @@
|
|
|
1
1
|
import { SettingsOptions } from './settings-options';
|
|
2
2
|
import { RenderParameters } from './render-parameters';
|
|
3
|
-
|
|
3
|
+
import { Options } from '@colijnit/ioneconnector/build/model/options';
|
|
4
|
+
export class ProductSettings extends Options {
|
|
4
5
|
constructor() {
|
|
6
|
+
super(...arguments);
|
|
5
7
|
this.session = undefined;
|
|
6
|
-
this.useGroups = true;
|
|
7
|
-
this.useRenders = false;
|
|
8
|
-
this.useLoginEncryption = true;
|
|
9
8
|
this.createWebOrder = true;
|
|
10
|
-
this.useMatch = false;
|
|
11
9
|
this.currencySymbol = '€';
|
|
12
10
|
this.options = new SettingsOptions();
|
|
13
11
|
this.renderParameters = new RenderParameters();
|
|
14
12
|
}
|
|
15
13
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdFNldHRpbmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2RlbC9wcm9kdWN0U2V0dGluZ3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXZELE9BQU8sRUFBeUIsT0FBTyxFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFFNUYsTUFBTSxPQUFPLGVBQWdCLFNBQVEsT0FBTztJQUE1Qzs7UUFFUyxZQUFPLEdBQVEsU0FBUyxDQUFDO1FBQ3pCLG1CQUFjLEdBQVksSUFBSSxDQUFDO1FBRy9CLG1CQUFjLEdBQVcsR0FBRyxDQUFDO1FBTTdCLFlBQU8sR0FBb0IsSUFBSSxlQUFlLEVBQUUsQ0FBQztRQUNqRCxxQkFBZ0IsR0FBcUIsSUFBSSxnQkFBZ0IsRUFBRSxDQUFDO0lBQ3JFLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNldHRpbmdzT3B0aW9ucyB9IGZyb20gJy4vc2V0dGluZ3Mtb3B0aW9ucyc7XHJcbmltcG9ydCB7IFJlbmRlclBhcmFtZXRlcnMgfSBmcm9tICcuL3JlbmRlci1wYXJhbWV0ZXJzJztcclxuaW1wb3J0IHtMYW5ndWFnZUNvZGV9IGZyb20gJ0Bjb2xpam5pdC9pb25lY29ubmVjdG9yL2J1aWxkL2VudW0vbGFuZ3VhZ2UtY29kZS5lbnVtJztcclxuaW1wb3J0IHtHZXRBY2Nlc3NUb2tlbkZ1bmN0aW9uLCBPcHRpb25zfSBmcm9tICdAY29saWpuaXQvaW9uZWNvbm5lY3Rvci9idWlsZC9tb2RlbC9vcHRpb25zJztcclxuXHJcbmV4cG9ydCBjbGFzcyBQcm9kdWN0U2V0dGluZ3MgZXh0ZW5kcyBPcHRpb25zIHtcclxuICBwdWJsaWMgY3VycmVuY3k6IG51bWJlcjtcclxuICBwdWJsaWMgc2Vzc2lvbjogYW55ID0gdW5kZWZpbmVkO1xyXG4gIHB1YmxpYyBjcmVhdGVXZWJPcmRlcjogYm9vbGVhbiA9IHRydWU7XHJcbiAgcHVibGljIGFzc2V0UGF0aDogc3RyaW5nO1xyXG4gIHB1YmxpYyBhc3NldEluZGV4OiBzdHJpbmc7XHJcbiAgcHVibGljIGN1cnJlbmN5U3ltYm9sOiBzdHJpbmcgPSAn4oKsJztcclxuICBwdWJsaWMgdGhyZWVEQXNzZXRQYXRoOiBzdHJpbmc7XHJcbiAgcHVibGljIGxpZ2h0UHJlc2V0c0luZGV4OiBzdHJpbmc7XHJcbiAgcHVibGljIGFkZGl0aW9uYWxUcmFuc2xhdGlvbkZpbGU6IHN0cmluZztcclxuICBwdWJsaWMgZ3RtOiBzdHJpbmc7XHJcbiAgcHVibGljIGNsaWVudDogc3RyaW5nO1xyXG4gIHB1YmxpYyBvcHRpb25zOiBTZXR0aW5nc09wdGlvbnMgPSBuZXcgU2V0dGluZ3NPcHRpb25zKCk7XHJcbiAgcHVibGljIHJlbmRlclBhcmFtZXRlcnM6IFJlbmRlclBhcmFtZXRlcnMgPSBuZXcgUmVuZGVyUGFyYW1ldGVycygpO1xyXG59XHJcbiJdfQ==
|
|
@@ -3,8 +3,8 @@ export class Version {
|
|
|
3
3
|
constructor() {
|
|
4
4
|
this.name = "@colijnit/product";
|
|
5
5
|
this.description = "Product detail page project for iOne";
|
|
6
|
-
this.symVer = "257.1.
|
|
7
|
-
this.publishDate = "
|
|
6
|
+
this.symVer = "257.1.8";
|
|
7
|
+
this.publishDate = "27-5-2025 10:30:02";
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9wcm9kdWN0LXZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBQ1MsU0FBSSxHQUFHLG1CQUFtQixDQUFDO1FBQzNCLGdCQUFXLEdBQUcsc0NBQXNDLENBQUM7UUFDckQsV0FBTSxHQUFHLFNBQVMsQ0FBQztRQUNuQixnQkFBVyxHQUFHLG9CQUFvQixDQUFDO0lBQzVDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIHRoaXMgZmlsZSBpcyBkeW5hbWljYWxseSBjcmVhdGVkLCBkbyBub3QgY2hhbmdlIHRoaXNcbmV4cG9ydCBjbGFzcyBWZXJzaW9uIHtcbiAgcHVibGljIG5hbWUgPSBcIkBjb2xpam5pdC9wcm9kdWN0XCI7XG4gIHB1YmxpYyBkZXNjcmlwdGlvbiA9IFwiUHJvZHVjdCBkZXRhaWwgcGFnZSBwcm9qZWN0IGZvciBpT25lXCI7XG4gIHB1YmxpYyBzeW1WZXIgPSBcIjI1Ny4xLjhcIjtcbiAgcHVibGljIHB1Ymxpc2hEYXRlID0gXCIyNy01LTIwMjUgMTA6MzA6MDJcIjtcbn0iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { Directive, Injectable, EventEmitter, Component, ViewEncapsulation, Input, Output, Renderer2, ChangeDetectorRef, ViewChild, ElementRef, Pipe, NgModule, ChangeDetectionStrategy, HostListener, HostBinding, SecurityContext, CUSTOM_ELEMENTS_SCHEMA, Inject, PLATFORM_ID, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
3
3
|
import { __awaiter } from 'tslib';
|
|
4
4
|
import { Subject, BehaviorSubject } from 'rxjs';
|
|
5
5
|
import { Options } from '@colijnit/ioneconnector/build/model/options';
|
|
@@ -30,37 +30,11 @@ class Version {
|
|
|
30
30
|
constructor() {
|
|
31
31
|
this.name = "@colijnit/product";
|
|
32
32
|
this.description = "Product detail page project for iOne";
|
|
33
|
-
this.symVer = "257.1.
|
|
34
|
-
this.publishDate = "
|
|
33
|
+
this.symVer = "257.1.8";
|
|
34
|
+
this.publishDate = "27-5-2025 10:30:02";
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
|
|
38
|
-
class JsonUtilsService {
|
|
39
|
-
readJsonFile(filePath) {
|
|
40
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
try {
|
|
42
|
-
const response = yield fetch(filePath);
|
|
43
|
-
if (!response.ok) {
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
return response.json();
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
catch (e) {
|
|
51
|
-
console.error('Error getting file:', e.message);
|
|
52
|
-
return '';
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
JsonUtilsService.ɵprov = i0.ɵɵdefineInjectable({ factory: function JsonUtilsService_Factory() { return new JsonUtilsService(); }, token: JsonUtilsService, providedIn: "root" });
|
|
58
|
-
JsonUtilsService.decorators = [
|
|
59
|
-
{ type: Injectable, args: [{
|
|
60
|
-
providedIn: 'root'
|
|
61
|
-
},] }
|
|
62
|
-
];
|
|
63
|
-
|
|
64
38
|
class SettingsOptions {
|
|
65
39
|
constructor() {
|
|
66
40
|
this.showStockStatus = false;
|
|
@@ -90,14 +64,11 @@ class RenderParameters {
|
|
|
90
64
|
}
|
|
91
65
|
}
|
|
92
66
|
|
|
93
|
-
class ProductSettings {
|
|
67
|
+
class ProductSettings extends Options {
|
|
94
68
|
constructor() {
|
|
69
|
+
super(...arguments);
|
|
95
70
|
this.session = undefined;
|
|
96
|
-
this.useGroups = true;
|
|
97
|
-
this.useRenders = false;
|
|
98
|
-
this.useLoginEncryption = true;
|
|
99
71
|
this.createWebOrder = true;
|
|
100
|
-
this.useMatch = false;
|
|
101
72
|
this.currencySymbol = '€';
|
|
102
73
|
this.options = new SettingsOptions();
|
|
103
74
|
this.renderParameters = new RenderParameters();
|
|
@@ -293,6 +264,32 @@ ProductConnectorAdapterService.ctorParameters = () => [
|
|
|
293
264
|
{ type: ProductEventService }
|
|
294
265
|
];
|
|
295
266
|
|
|
267
|
+
class JsonUtilsService {
|
|
268
|
+
readJsonFile(filePath) {
|
|
269
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
270
|
+
try {
|
|
271
|
+
const response = yield fetch(filePath);
|
|
272
|
+
if (!response.ok) {
|
|
273
|
+
return null;
|
|
274
|
+
}
|
|
275
|
+
else {
|
|
276
|
+
return response.json();
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
catch (e) {
|
|
280
|
+
console.error('Error getting file:', e.message);
|
|
281
|
+
return '';
|
|
282
|
+
}
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
JsonUtilsService.ɵprov = i0.ɵɵdefineInjectable({ factory: function JsonUtilsService_Factory() { return new JsonUtilsService(); }, token: JsonUtilsService, providedIn: "root" });
|
|
287
|
+
JsonUtilsService.decorators = [
|
|
288
|
+
{ type: Injectable, args: [{
|
|
289
|
+
providedIn: 'root'
|
|
290
|
+
},] }
|
|
291
|
+
];
|
|
292
|
+
|
|
296
293
|
var LanguageCode;
|
|
297
294
|
(function (LanguageCode) {
|
|
298
295
|
LanguageCode["Dutch"] = "nl-NL";
|
|
@@ -667,7 +664,7 @@ ProductConnectorService.ctorParameters = () => [
|
|
|
667
664
|
];
|
|
668
665
|
|
|
669
666
|
class IoneProductComponent {
|
|
670
|
-
constructor(
|
|
667
|
+
constructor(_appEventService, _settingsService) {
|
|
671
668
|
// this.sku = 'CF-HILL';
|
|
672
669
|
// this.sku = 'CF-ALMADA';
|
|
673
670
|
// this.sku = 'CF-39904ANT';
|
|
@@ -680,10 +677,6 @@ class IoneProductComponent {
|
|
|
680
677
|
// this.sku = '104';
|
|
681
678
|
// this.sku = "70000107";
|
|
682
679
|
// this.sku = "grover";
|
|
683
|
-
this._dictionary = _dictionary;
|
|
684
|
-
this._jsonUtils = _jsonUtils;
|
|
685
|
-
this._ione = _ione;
|
|
686
|
-
this._changeDetector = _changeDetector;
|
|
687
680
|
this._appEventService = _appEventService;
|
|
688
681
|
this._settingsService = _settingsService;
|
|
689
682
|
this.handleAddArticleInternally = true;
|
|
@@ -699,9 +692,7 @@ class IoneProductComponent {
|
|
|
699
692
|
this.settingsLoaded = false;
|
|
700
693
|
this.showHD = false;
|
|
701
694
|
this._subs = [];
|
|
702
|
-
this._subs.push(
|
|
703
|
-
// this._dictionary.dictionaryLoaded.subscribe(d => this.upAndLoaded = true),
|
|
704
|
-
this._appEventService.onAddToCart.subscribe((data) => {
|
|
695
|
+
this._subs.push(this._appEventService.onAddToCart.subscribe((data) => {
|
|
705
696
|
this._handleAddToCart(data);
|
|
706
697
|
}), this._appEventService.onAddToQuote.subscribe(json => this.onAddToQuote.emit(json)), this._appEventService.onAlternativeClick.subscribe(article => this.onAlternativeClick.emit(article)), this._appEventService.onArticleInfoReceived.subscribe(info => this._handleAnswerInfoReceived(info)), this._appEventService.onArticleReceived.subscribe(article => this.onArticleReceived.emit(article)), this._appEventService.onSelectionsReceived.subscribe(selections => this.onSelectionsReceived.emit(selections)), this._appEventService.onAnswersAvailable.subscribe(answers => this._handleAnswersAvailable(answers)), this._settingsService.settingsLoaded.subscribe(loaded => {
|
|
707
698
|
this.settingsLoaded = loaded;
|
|
@@ -728,9 +719,6 @@ class IoneProductComponent {
|
|
|
728
719
|
}
|
|
729
720
|
});
|
|
730
721
|
}
|
|
731
|
-
ngOnChanges(changes) {
|
|
732
|
-
this._changeDetector.detectChanges();
|
|
733
|
-
}
|
|
734
722
|
ngOnDestroy() {
|
|
735
723
|
this._subs.forEach(s => s.unsubscribe());
|
|
736
724
|
}
|
|
@@ -763,15 +751,17 @@ IoneProductComponent.decorators = [
|
|
|
763
751
|
<!-- <co-button [label]="'click'" (click)="showHD = !showHD"></co-button>
|
|
764
752
|
<co-product-hd [sku]="'657946ca-e1e1-41fd-7ae0-08dbf7df0cef'" *ngIf="showHD"></co-product-hd>-->
|
|
765
753
|
`,
|
|
754
|
+
providers: [
|
|
755
|
+
ProductSettingsService,
|
|
756
|
+
ProductConnectorService,
|
|
757
|
+
ProductEventService,
|
|
758
|
+
ProductConnectorAdapterService
|
|
759
|
+
],
|
|
766
760
|
encapsulation: ViewEncapsulation.Emulated,
|
|
767
761
|
styles: [""]
|
|
768
762
|
},] }
|
|
769
763
|
];
|
|
770
764
|
IoneProductComponent.ctorParameters = () => [
|
|
771
|
-
{ type: DictionaryService },
|
|
772
|
-
{ type: JsonUtilsService },
|
|
773
|
-
{ type: ProductConnectorService },
|
|
774
|
-
{ type: ChangeDetectorRef },
|
|
775
765
|
{ type: ProductEventService },
|
|
776
766
|
{ type: ProductSettingsService }
|
|
777
767
|
];
|
|
@@ -1385,6 +1375,7 @@ class ImageCarouselComponent {
|
|
|
1385
1375
|
const resizedSource = resizeCanvas.toDataURL('image/jpeg');
|
|
1386
1376
|
imageViewModel.source = this._domSanitizer.bypassSecurityTrustUrl(resizedSource);
|
|
1387
1377
|
imageViewModel.originalSource = source;
|
|
1378
|
+
this._changeDetector.detectChanges();
|
|
1388
1379
|
});
|
|
1389
1380
|
// @ts-ignore
|
|
1390
1381
|
resizeImage.src = source;
|
|
@@ -3161,12 +3152,6 @@ IoneProductModule.decorators = [
|
|
|
3161
3152
|
],
|
|
3162
3153
|
bootstrap: [
|
|
3163
3154
|
IoneProductComponent
|
|
3164
|
-
],
|
|
3165
|
-
providers: [
|
|
3166
|
-
ProductSettingsService,
|
|
3167
|
-
ProductConnectorService,
|
|
3168
|
-
ProductEventService,
|
|
3169
|
-
ProductConnectorAdapterService
|
|
3170
3155
|
]
|
|
3171
3156
|
},] }
|
|
3172
3157
|
];
|