ngx-wapp-components 2.1.11 → 2.1.12

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.
@@ -132,8 +132,13 @@ export class WMaterialServiceCardComponent {
132
132
  return this.wappingService.imageUrl;
133
133
  }
134
134
  else {
135
- this.isNoImage = true;
136
- return './../../../assets/wappIcons/image.svg';
135
+ if (this.defaultImage) {
136
+ return this.defaultImage;
137
+ }
138
+ else {
139
+ this.isNoImage = true;
140
+ return './../../../assets/wappIcons/image.svg';
141
+ }
137
142
  }
138
143
  }
139
144
  }
@@ -166,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
166
171
  }], onHoverImageTooltip: [{
167
172
  type: Input
168
173
  }] } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"w-material-service-card.component.js","sourceRoot":"","sources":["../../../../../../projects/wapp-components/src/lib/material/w-material-service-card/w-material-service-card.component.ts","../../../../../../projects/wapp-components/src/lib/material/w-material-service-card/w-material-service-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { CardStatus, SendingStatus, WappingServiceAppViewType } from '../shared/models/enums.model';\r\nimport { WappingService } from '../shared/models/wapping-service';\r\nimport { WappingServiceTranslations } from '../shared/models/wapping-service-translations.model';\r\nimport { Router } from '@angular/router';\r\nimport { WappingServiceItemView } from '../shared/models/wapping-service-item-view';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { WappingServiceTemplate } from '../shared/models/wapping-service-template.model';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { WImageCropperComponent } from '../../file/w-image-cropper/w-image-cropper.component';\r\nimport { WFileB64 } from '../../shared/models/w-file-b64.model';\r\nimport { WImageCropperData } from '../../shared/models/w-image-cropper-data.model';\r\n\r\n@Component({\r\n  selector: 'w-material-service-card',\r\n  templateUrl: './w-material-service-card.component.html',\r\n  styleUrls: ['./w-material-service-card.component.scss']\r\n})\r\nexport class WMaterialServiceCardComponent implements OnChanges {\r\n  @Input() isDevModeActive: boolean = false;\r\n  isSendGiftCard: boolean = false;\r\n  allowSelectSendGiftCard: boolean = true;\r\n  \r\n  enumSendingStatus: typeof SendingStatus =  SendingStatus;\r\n  ecardStatus: typeof CardStatus = CardStatus;\r\n\r\n  wappingServiceReady: boolean = false;\r\n  emptyTile: boolean = false;\r\n\r\n  private _wappingTranslations: WappingServiceTranslations = {\r\n    activedService: 'Activada',\r\n    disabledService: 'Desactivada',\r\n    scheduledLabel: 'Programada para enviar a {{name}}',\r\n    sendLabel: 'Enviada a {{name}}',\r\n    cardGenerated: 'Tu tarjeta estará disponible para el envío en breves instantes',\r\n    receivedLabel: \"Enviada por {{name}}\",\r\n    showMore: \"Mostrar más\",\r\n  };\r\n  \r\n  @Input() set wappingServicesTranslations(value: WappingServiceTranslations) {\r\n    if(value) this._wappingTranslations = value;\r\n  }\r\n  \r\n  get wappingTranslations() {\r\n    return this._wappingTranslations;\r\n  }\r\n\r\n  private _wappingService!: WappingService;\r\n\r\n  @Input() set wappingService(value: WappingService) {\r\n    this._wappingService = value;\r\n    if(value) this.getWappingServiceTitles(value);\r\n  }\r\n\r\n  get wappingService() {\r\n    return this._wappingService;\r\n  }\r\n\r\n  @Output('cardClicked') cardClicked = new EventEmitter<WappingService>();\r\n\r\n  @Input() defaultImage!: WFileB64 | string;\r\n  @Input() croppedImageConfiguration: WImageCropperData = {\r\n    roundedCropper: false, \r\n    configuredAspectRatio: 4/3, \r\n    viewPortHeihtPx: 600, \r\n    viewPortWidthPx: 800, \r\n    maxFileSize: 2000\r\n  };\r\n\r\n  @Input() croppedDialogTranslations: any;\r\n  @Output() onDefaultImageEvent = new EventEmitter<WFileB64>();\r\n  isNoImage: boolean = false;\r\n  @Input() onHoverImageTooltip: any = 'Upload image';\r\n  \r\n  constructor(\r\n    private route: Router,\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer, \r\n    private dialogService: DialogService\r\n  ) {\r\n    this.matIconRegistry.addSvgIcon(\"activated\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"assets/wappIcons/activated.svg\"));\r\n    this.matIconRegistry.addSvgIcon(\"deactivated\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"assets/wappIcons/deactivated.svg\"));\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes['wappingService'] && changes['wappingService'].currentValue){\r\n      this.wappingService = changes['wappingService'].currentValue\r\n    }\r\n\r\n    if(changes['defaultImage'] && changes['defaultImage'].currentValue){\r\n      this.defaultImage = changes['defaultImage'].currentValue;\r\n    }\r\n  }\r\n\r\n  getWappingServiceTitles(service: WappingService) {\r\n    if (service.wappingServiceTemplates != null) {\r\n      service.wappingServiceTemplates.forEach((wappingServiceTemplate: WappingServiceTemplate) => {\r\n        if (wappingServiceTemplate.summaryHeader && wappingServiceTemplate.summaryHeader.trim() !== ''){\r\n          service.tile1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTemplate.summaryHeader);\r\n        } else {\r\n          service.tile1 = '';\r\n        }\r\n\r\n        if (wappingServiceTemplate.summaryBody && wappingServiceTemplate.summaryBody.trim() !== ''){\r\n          service.tile3 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTemplate.summaryBody);\r\n        } else {\r\n          service.tile3 = '';\r\n        }\r\n\r\n      });\r\n      this.wappingServiceReady = true;\r\n    }\r\n  }\r\n\r\n  cardOnClick(service: WappingService) {\r\n    this.cardClicked.emit(service);\r\n  }\r\n\r\n  hasHtml(value: any): boolean {\r\n    return /<\\/?[a-z][\\s\\S]*>/i.test(value);\r\n  }\r\n\r\n  setImage(){\r\n    const ref: DynamicDialogRef = this.dialogService.open(WImageCropperComponent, {\r\n      header: this.croppedDialogTranslations?.modal.header,\r\n      width: '70rem',\r\n      contentStyle: {\"overflow\": \"auto\", \"height\": \"auto\", \"padding-bottom\": \"8px\"},\r\n      data: {dataModal: this.croppedImageConfiguration, translations: this.croppedDialogTranslations},\r\n      resizable: true\r\n    });\r\n\r\n    ref.onClose.subscribe((imageCropped: WFileB64) => {\r\n      if(imageCropped){\r\n        this.defaultImage = imageCropped;\r\n        this.onDefaultImageEvent.emit(this.defaultImage);\r\n      }\r\n    })\r\n  }\r\n\r\n  getImage(){\r\n    this.isNoImage = false;\r\n    if(this.isDevModeActive == true){\r\n      if(this.defaultImage){\r\n        if(this.isWFileImage(this.defaultImage)){\r\n          return (this.defaultImage as WFileB64).fileBase64;\r\n        }else{\r\n          return this.defaultImage;\r\n        }\r\n      }else{\r\n        this.isNoImage = true;\r\n        return './../../../assets/wappIcons/image.svg';\r\n      }\r\n    }else{\r\n      if(this.wappingService && this.wappingService.imageUrl){\r\n        this.onHoverImageTooltip = null;\r\n        return this.wappingService.imageUrl;\r\n      }else{\r\n        this.isNoImage = true;\r\n        return './../../../assets/wappIcons/image.svg';\r\n      }\r\n    }\r\n  }\r\n\r\n  isWFileImage(obj: WFileB64 | string){\r\n    return (obj as WFileB64).base64 !== undefined;\r\n  }\r\n}\r\n","<mat-card *ngIf=\"wappingServiceReady\" class=\"service-card\" (click)=\"isDevModeActive ? setImage() : cardOnClick(wappingService)\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n  <div fxLayout=\"column\" fxLayoutAlign=\"center center\">\r\n    <div class=\"service-card-image-title\"\r\n         fxLayout=\"row\" fxLayoutGap=\"5px\"\r\n         *ngIf=\"wappingService.tile1 && wappingService.tile1 != ''\">\r\n      <!--tile1-->\r\n      <div [ngClass]=\"{'tile-no-html': !hasHtml(wappingService.tile1)}\" class=\"service-card-tile1\"\r\n        [innerHtml]=\"wappingService.tile1\"></div>\r\n    </div>\r\n    <div class=\"service-card-image\">\r\n      <img mat-card-image  \r\n        [ngClass]=\"{'default-image' : isNoImage}\" \r\n        [src]=\"getImage()\">\r\n    </div>\r\n  </div>\r\n  <mat-card-header fxLayout=\"column\">\r\n    <div fxLayout=\"row\">\r\n      <div fxFlex></div>\r\n      <!--status-->\r\n      <div class=\"card-header-status-container\" *ngIf=\"wappingService.allowSelect && allowSelectSendGiftCard\" fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n        <div class=\"card-header-status\" *ngIf=\"wappingService.active\">\r\n          <mat-icon class=\"card-header-status-icon\" svgIcon=\"activated\"></mat-icon>\r\n          <span class=\"status\">{{ wappingTranslations.activedService }}</span>\r\n        </div>\r\n        <div class=\"card-header-status\" *ngIf=\"!wappingService.active\">\r\n          <mat-icon class=\"card-header-status-icon\" svgIcon=\"deactivated\"></mat-icon>\r\n          <span class=\"status\">{{ wappingTranslations.disabledService }}</span>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <!--tile3-->\r\n    <div *ngIf=\"wappingService.tile3\" class=\"card-header-description\">\r\n        <div [innerHtml]=\"wappingService.tile3\"></div>\r\n    </div>\r\n  </mat-card-header>\r\n</mat-card>"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"w-material-service-card.component.js","sourceRoot":"","sources":["../../../../../../projects/wapp-components/src/lib/material/w-material-service-card/w-material-service-card.component.ts","../../../../../../projects/wapp-components/src/lib/material/w-material-service-card/w-material-service-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { CardStatus, SendingStatus, WappingServiceAppViewType } from '../shared/models/enums.model';\r\nimport { WappingService } from '../shared/models/wapping-service';\r\nimport { WappingServiceTranslations } from '../shared/models/wapping-service-translations.model';\r\nimport { Router } from '@angular/router';\r\nimport { WappingServiceItemView } from '../shared/models/wapping-service-item-view';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { WappingServiceTemplate } from '../shared/models/wapping-service-template.model';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { WImageCropperComponent } from '../../file/w-image-cropper/w-image-cropper.component';\r\nimport { WFileB64 } from '../../shared/models/w-file-b64.model';\r\nimport { WImageCropperData } from '../../shared/models/w-image-cropper-data.model';\r\n\r\n@Component({\r\n  selector: 'w-material-service-card',\r\n  templateUrl: './w-material-service-card.component.html',\r\n  styleUrls: ['./w-material-service-card.component.scss']\r\n})\r\nexport class WMaterialServiceCardComponent implements OnChanges {\r\n  @Input() isDevModeActive: boolean = false;\r\n  isSendGiftCard: boolean = false;\r\n  allowSelectSendGiftCard: boolean = true;\r\n  \r\n  enumSendingStatus: typeof SendingStatus =  SendingStatus;\r\n  ecardStatus: typeof CardStatus = CardStatus;\r\n\r\n  wappingServiceReady: boolean = false;\r\n  emptyTile: boolean = false;\r\n\r\n  private _wappingTranslations: WappingServiceTranslations = {\r\n    activedService: 'Activada',\r\n    disabledService: 'Desactivada',\r\n    scheduledLabel: 'Programada para enviar a {{name}}',\r\n    sendLabel: 'Enviada a {{name}}',\r\n    cardGenerated: 'Tu tarjeta estará disponible para el envío en breves instantes',\r\n    receivedLabel: \"Enviada por {{name}}\",\r\n    showMore: \"Mostrar más\",\r\n  };\r\n  \r\n  @Input() set wappingServicesTranslations(value: WappingServiceTranslations) {\r\n    if(value) this._wappingTranslations = value;\r\n  }\r\n  \r\n  get wappingTranslations() {\r\n    return this._wappingTranslations;\r\n  }\r\n\r\n  private _wappingService!: WappingService;\r\n\r\n  @Input() set wappingService(value: WappingService) {\r\n    this._wappingService = value;\r\n    if(value) this.getWappingServiceTitles(value);\r\n  }\r\n\r\n  get wappingService() {\r\n    return this._wappingService;\r\n  }\r\n\r\n  @Output('cardClicked') cardClicked = new EventEmitter<WappingService>();\r\n\r\n  @Input() defaultImage!: WFileB64 | string;\r\n  @Input() croppedImageConfiguration: WImageCropperData = {\r\n    roundedCropper: false, \r\n    configuredAspectRatio: 4/3, \r\n    viewPortHeihtPx: 600, \r\n    viewPortWidthPx: 800, \r\n    maxFileSize: 2000\r\n  };\r\n\r\n  @Input() croppedDialogTranslations: any;\r\n  @Output() onDefaultImageEvent = new EventEmitter<WFileB64>();\r\n  isNoImage: boolean = false;\r\n  @Input() onHoverImageTooltip: any = 'Upload image';\r\n  \r\n  constructor(\r\n    private route: Router,\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer, \r\n    private dialogService: DialogService\r\n  ) {\r\n    this.matIconRegistry.addSvgIcon(\"activated\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"assets/wappIcons/activated.svg\"));\r\n    this.matIconRegistry.addSvgIcon(\"deactivated\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"assets/wappIcons/deactivated.svg\"));\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes['wappingService'] && changes['wappingService'].currentValue){\r\n      this.wappingService = changes['wappingService'].currentValue\r\n    }\r\n\r\n    if(changes['defaultImage'] && changes['defaultImage'].currentValue){\r\n      this.defaultImage = changes['defaultImage'].currentValue;\r\n    }\r\n  }\r\n\r\n  getWappingServiceTitles(service: WappingService) {\r\n    if (service.wappingServiceTemplates != null) {\r\n      service.wappingServiceTemplates.forEach((wappingServiceTemplate: WappingServiceTemplate) => {\r\n        if (wappingServiceTemplate.summaryHeader && wappingServiceTemplate.summaryHeader.trim() !== ''){\r\n          service.tile1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTemplate.summaryHeader);\r\n        } else {\r\n          service.tile1 = '';\r\n        }\r\n\r\n        if (wappingServiceTemplate.summaryBody && wappingServiceTemplate.summaryBody.trim() !== ''){\r\n          service.tile3 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTemplate.summaryBody);\r\n        } else {\r\n          service.tile3 = '';\r\n        }\r\n\r\n      });\r\n      this.wappingServiceReady = true;\r\n    }\r\n  }\r\n\r\n  cardOnClick(service: WappingService) {\r\n    this.cardClicked.emit(service);\r\n  }\r\n\r\n  hasHtml(value: any): boolean {\r\n    return /<\\/?[a-z][\\s\\S]*>/i.test(value);\r\n  }\r\n\r\n  setImage(){\r\n    const ref: DynamicDialogRef = this.dialogService.open(WImageCropperComponent, {\r\n      header: this.croppedDialogTranslations?.modal.header,\r\n      width: '70rem',\r\n      contentStyle: {\"overflow\": \"auto\", \"height\": \"auto\", \"padding-bottom\": \"8px\"},\r\n      data: {dataModal: this.croppedImageConfiguration, translations: this.croppedDialogTranslations},\r\n      resizable: true\r\n    });\r\n\r\n    ref.onClose.subscribe((imageCropped: WFileB64) => {\r\n      if(imageCropped){\r\n        this.defaultImage = imageCropped;\r\n        this.onDefaultImageEvent.emit(this.defaultImage);\r\n      }\r\n    })\r\n  }\r\n\r\n  getImage(){\r\n    this.isNoImage = false;\r\n    if(this.isDevModeActive == true){\r\n      if(this.defaultImage){\r\n        if(this.isWFileImage(this.defaultImage)){\r\n          return (this.defaultImage as WFileB64).fileBase64;\r\n        }else{\r\n          return this.defaultImage;\r\n        }\r\n      }else{\r\n        this.isNoImage = true;\r\n        return './../../../assets/wappIcons/image.svg';\r\n      }\r\n    }else{\r\n      if(this.wappingService && this.wappingService.imageUrl){\r\n        this.onHoverImageTooltip = null;\r\n        return this.wappingService.imageUrl;\r\n      }else{\r\n        if(this.defaultImage){\r\n          return this.defaultImage;\r\n        }else{\r\n          this.isNoImage = true;\r\n          return './../../../assets/wappIcons/image.svg';\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  isWFileImage(obj: WFileB64 | string){\r\n    return (obj as WFileB64).base64 !== undefined;\r\n  }\r\n}\r\n","<mat-card *ngIf=\"wappingServiceReady\" class=\"service-card\" (click)=\"isDevModeActive ? setImage() : cardOnClick(wappingService)\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n  <div fxLayout=\"column\" fxLayoutAlign=\"center center\">\r\n    <div class=\"service-card-image-title\"\r\n         fxLayout=\"row\" fxLayoutGap=\"5px\"\r\n         *ngIf=\"wappingService.tile1 && wappingService.tile1 != ''\">\r\n      <!--tile1-->\r\n      <div [ngClass]=\"{'tile-no-html': !hasHtml(wappingService.tile1)}\" class=\"service-card-tile1\"\r\n        [innerHtml]=\"wappingService.tile1\"></div>\r\n    </div>\r\n    <div class=\"service-card-image\">\r\n      <img mat-card-image  \r\n        [ngClass]=\"{'default-image' : isNoImage}\" \r\n        [src]=\"getImage()\">\r\n    </div>\r\n  </div>\r\n  <mat-card-header fxLayout=\"column\">\r\n    <div fxLayout=\"row\">\r\n      <div fxFlex></div>\r\n      <!--status-->\r\n      <div class=\"card-header-status-container\" *ngIf=\"wappingService.allowSelect && allowSelectSendGiftCard\" fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n        <div class=\"card-header-status\" *ngIf=\"wappingService.active\">\r\n          <mat-icon class=\"card-header-status-icon\" svgIcon=\"activated\"></mat-icon>\r\n          <span class=\"status\">{{ wappingTranslations.activedService }}</span>\r\n        </div>\r\n        <div class=\"card-header-status\" *ngIf=\"!wappingService.active\">\r\n          <mat-icon class=\"card-header-status-icon\" svgIcon=\"deactivated\"></mat-icon>\r\n          <span class=\"status\">{{ wappingTranslations.disabledService }}</span>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <!--tile3-->\r\n    <div *ngIf=\"wappingService.tile3\" class=\"card-header-description\">\r\n        <div [innerHtml]=\"wappingService.tile3\"></div>\r\n    </div>\r\n  </mat-card-header>\r\n</mat-card>"]}
@@ -62,21 +62,12 @@ export class WMaterialServiceViewComponent {
62
62
  this.matIconRegistry.addSvgIcon("calendar", this.domSanitizer.bypassSecurityTrustResourceUrl("/assets/wappIcons/mat-calendar.svg"));
63
63
  }
64
64
  ngOnInit() {
65
+ this.getImage();
65
66
  }
66
67
  ngOnChanges(changes) {
67
68
  if (changes['defaultImage'] && changes['defaultImage'].currentValue) {
68
69
  this.defaultImage = changes['defaultImage'].currentValue;
69
- this.isNoImage = false;
70
- if (this.isDevModeActive == true) {
71
- if (this.defaultImage) {
72
- if (this.isWFileImage(this.defaultImage)) {
73
- this.wappingServiceImages = [{ path: this.defaultImage.fileBase64 }];
74
- }
75
- else {
76
- this.wappingServiceImages = [{ path: this.defaultImage }];
77
- }
78
- }
79
- }
70
+ this.getImage();
80
71
  }
81
72
  if (changes['defaultImage'] && !changes['defaultImage'].currentValue) {
82
73
  if (this.isDevModeActive) {
@@ -135,20 +126,7 @@ export class WMaterialServiceViewComponent {
135
126
  }
136
127
  }
137
128
  getWappingServiceImages() {
138
- this.wappingServiceImages = this.wappingService.wappingServiceImages;
139
- if (this.wappingServiceImages.length == 0) {
140
- let wappingServiceImage = {
141
- path: this.wappingService.imageUrl,
142
- };
143
- this.wappingServiceImages.unshift(wappingServiceImage);
144
- }
145
- // To Do implementar slideshow
146
- // if (this.wappingServiceImages.length > 1) {
147
- // this.showSlideshowArrows = true;
148
- // this.showSlideshowDots = true;
149
- // }
150
- // if (!this.isDesktop)
151
- // this.showSlideshowArrows = false;
129
+ this.getImage();
152
130
  }
153
131
  selectWappingService() {
154
132
  this.disabledToggle = true;
@@ -187,24 +165,36 @@ export class WMaterialServiceViewComponent {
187
165
  if (this.isDevModeActive == true) {
188
166
  if (this.defaultImage) {
189
167
  if (this.isWFileImage(this.defaultImage)) {
190
- return [{ path: this.defaultImage.fileBase64 }];
168
+ this.wappingServiceImages = [{ path: this.defaultImage.fileBase64 }];
191
169
  }
192
170
  else {
193
- return [{ path: this.defaultImage }];
171
+ this.wappingServiceImages = [{ path: this.defaultImage }];
194
172
  }
195
173
  }
196
174
  else {
197
175
  this.isNoImage = true;
198
- return [{ path: './../../../assets/wappIcons/image.svg' }];
176
+ this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
199
177
  }
200
178
  }
201
179
  else {
202
- if (this.wappingServiceImages.length > 0) {
203
- return this.wappingServiceImages;
204
- }
205
- else {
206
- this.isNoImage = true;
207
- return [{ path: './../../../assets/wappIcons/image.svg' }];
180
+ if (this.wappingService) {
181
+ if (this.wappingService.wappingServiceImages.length > 0) {
182
+ this.wappingServiceImages = this.wappingService.wappingServiceImages;
183
+ }
184
+ else if (this.wappingService.wappingServiceImages.length == 0 && this.wappingService.imageUrl) {
185
+ this.wappingServiceImages = [];
186
+ let wappingServiceImage = {
187
+ path: this.wappingService.imageUrl,
188
+ };
189
+ this.wappingServiceImages.unshift(wappingServiceImage);
190
+ }
191
+ else if (this.defaultImage) {
192
+ this.wappingServiceImages = [{ path: this.defaultImage }];
193
+ }
194
+ else {
195
+ this.isNoImage = true;
196
+ this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
197
+ }
208
198
  }
209
199
  }
210
200
  }
@@ -254,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
254
244
  }], onHoverImageTooltip: [{
255
245
  type: Input
256
246
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"w-material-service-view.component.js","sourceRoot":"","sources":["../../../../../../projects/wapp-components/src/lib/material/w-material-service-view/w-material-service-view.component.ts","../../../../../../projects/wapp-components/src/lib/material/w-material-service-view/w-material-service-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { WappingService } from '../shared/models/wapping-service';\r\nimport { WappingServiceImage } from '../shared/models/wapping-service-image';\r\nimport { CardStatus, SendingStatus, WappingServiceType } from '../shared/models/enums.model';\r\nimport { WappingServiceTranslations } from '../shared/models/wapping-service-translations.model';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { WappingServiceTemplate } from '../shared/models/wapping-service-template.model';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { WFileB64 } from '../../shared/models/w-file-b64.model';\r\nimport { WImageCropperData } from '../../shared/models/w-image-cropper-data.model';\r\nimport { WImageCropperComponent } from '../../file/w-image-cropper/w-image-cropper.component';\r\n\r\n@Component({\r\n  selector: 'w-material-service-view',\r\n  templateUrl: './w-material-service-view.component.html',\r\n  styleUrls: ['./w-material-service-view.component.scss']\r\n})\r\nexport class WMaterialServiceViewComponent implements OnInit, OnChanges {\r\n\r\n  serviceId!: number;\r\n  wappingServiceImages!: WappingServiceImage[];\r\n  serviceStatus!: string;\r\n  isSendGiftCard: boolean = false;\r\n  disabledToggle: boolean = false;\r\n  allowSelectSendGiftCard: boolean = true;\r\n  enumSendingStatus: typeof SendingStatus = SendingStatus;\r\n  ecardStatus: typeof CardStatus = CardStatus\r\n  translations: any;\r\n  \r\n  @Input() forceMobile = false;\r\n\r\n  @Input('wappingServicesTranslations') wappingServicesTranslations: WappingServiceTranslations = {\r\n    activedService: 'Activada',\r\n    disabledService: 'Desactivada',\r\n    scheduledLabel: 'Programada para enviar a {{name}}',\r\n    sendLabel: 'Enviada a {{name}}',\r\n    cardGenerated: 'Tu tarjeta estará disponible para el envío en breves instantes',\r\n    receivedLabel: \"Enviada por {{name}}\",\r\n    showMore: \"Mostrar más\",\r\n    buttonService: \"Participar\"\r\n  };\r\n  \r\n  @Input('disabledButtonService') disabledButtonService: boolean = false;\r\n  @Input('showButtonService') showButtonService: boolean = false;\r\n  @Input('showToggle') showToggle: boolean = true;\r\n\r\n  private _wappingService!: WappingService;\r\n\r\n  @Input() set wappingService(value: WappingService) {\r\n    this._wappingService = value;\r\n    if(value) this.getWappingService(value);\r\n  }\r\n\r\n  get wappingService() {\r\n    return this._wappingService;\r\n  }\r\n\r\n  @Output('wappingServiceSelected') wappingServiceSelected = new EventEmitter<boolean>();\r\n  @Output('triggerButtonService') triggerButtonService = new EventEmitter<void>();\r\n\r\n  @Input() isDevModeActive: boolean = false;\r\n  @Input() defaultImage!: WFileB64 | string;\r\n\r\n  @Input() croppedImageConfiguration: WImageCropperData = {\r\n    roundedCropper: false, \r\n    configuredAspectRatio: 4/3, \r\n    viewPortHeihtPx: 600, \r\n    viewPortWidthPx: 800, \r\n    maxFileSize: 2000\r\n  };\r\n  \r\n  @Input() croppedDialogTranslations: any;\r\n  images: any[] = [];\r\n  @Output() onDefaultImageEvent = new EventEmitter<WFileB64>();\r\n  @Input() isNoImage: boolean = false;\r\n  @Input() onHoverImageTooltip: string = 'Upload image';\r\n\r\n  constructor(\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer, \r\n    private dialogService: DialogService) {\r\n    this.matIconRegistry.addSvgIcon(\"calendar\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"/assets/wappIcons/mat-calendar.svg\"));\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes['defaultImage'] && changes['defaultImage'].currentValue){\r\n      this.defaultImage = changes['defaultImage'].currentValue;\r\n\r\n      this.isNoImage = false;\r\n      if(this.isDevModeActive == true){\r\n        if(this.defaultImage){\r\n          if(this.isWFileImage(this.defaultImage)){\r\n            this.wappingServiceImages = [{ path: (this.defaultImage as WFileB64).fileBase64 }];\r\n          }else{\r\n            this.wappingServiceImages = [{ path: (this.defaultImage as string)}];\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    if(changes['defaultImage'] && !changes['defaultImage'].currentValue){\r\n      if(this.isDevModeActive){\r\n        this.isNoImage = true;\r\n        this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }]\r\n      }\r\n    }\r\n  }\r\n\r\n  getWappingService(wappService: WappingService) {\r\n    this.isSendGiftCard = false\r\n    if (wappService.active)\r\n      this.serviceStatus = this.wappingServicesTranslations.activedService.toUpperCase();\r\n    else\r\n      this.serviceStatus = this.wappingServicesTranslations.disabledService.toUpperCase();\r\n    if (wappService.dataReqToSendCard && wappService.dataReqToSendCard.dataReqToSendCardId != 0) {\r\n      this.isSendGiftCard = true\r\n      if (wappService.enumTypeStatusECardID == this.ecardStatus.sent) {\r\n        this.allowSelectSendGiftCard = false;\r\n      }\r\n    }\r\n    if (wappService.enumTypeStatusECardID == this.ecardStatus.generated)\r\n      this.allowSelectSendGiftCard = false;\r\n\r\n\r\n    this.getWappingServiceTiles(this.wappingService);\r\n\r\n    if(this.isDevModeActive == false){\r\n      this.getWappingServiceImages();\r\n    }\r\n  }\r\n\r\n  getWappingServiceTiles(service: WappingService) {\r\n    if (service.wappingServiceTemplates != null) {\r\n      service.wappingServiceTemplates.forEach((wappingServiceTile: WappingServiceTemplate) => {\r\n        if(wappingServiceTile.detailTitle){\r\n          this.wappingService.tile3 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailTitle);\r\n        } else {\r\n          this.wappingService.tile3 = '';\r\n        }\r\n        if(wappingServiceTile.detailHeader){\r\n          this.wappingService.tile1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailHeader);\r\n        } else {\r\n          this.wappingService.tile1 = '';\r\n        }\r\n        if(wappingServiceTile.detailFoot){\r\n          this.wappingService.tile2 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailFoot);\r\n        } else {\r\n          this.wappingService.tile2 = '';\r\n        }\r\n        if(wappingServiceTile.detailBody){\r\n          this.wappingService.tileDetail1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailBody);\r\n        } else {\r\n          this.wappingService.tileDetail1 = '';\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  getWappingServiceImages() {\r\n    this.wappingServiceImages = this.wappingService.wappingServiceImages;\r\n\r\n    if (this.wappingServiceImages.length == 0) {\r\n      let wappingServiceImage: WappingServiceImage = {\r\n        path: this.wappingService.imageUrl!,\r\n      };\r\n      this.wappingServiceImages.unshift(wappingServiceImage);\r\n    }\r\n\r\n    // To Do implementar slideshow\r\n    \r\n    // if (this.wappingServiceImages.length > 1) {\r\n    //   this.showSlideshowArrows = true;\r\n    //   this.showSlideshowDots = true;\r\n    // }\r\n\r\n    // if (!this.isDesktop)\r\n    //   this.showSlideshowArrows = false;\r\n  }\r\n\r\n  selectWappingService() {\r\n    this.disabledToggle = true;\r\n    this.wappingServiceSelected.emit(this.wappingService.active);\r\n    if (this.wappingService.active)\r\n      this.serviceStatus = this.wappingServicesTranslations.activedService.toUpperCase();\r\n    else\r\n      this.serviceStatus = this.wappingServicesTranslations.disabledService.toUpperCase();\r\n\r\n    this.disabledToggle = false\r\n    this.getWappingService(this.wappingService);\r\n  }\r\n\r\n  hasHtml(value: any): boolean {\r\n    return /<\\/?[a-z][\\s\\S]*>/i.test(value);\r\n  }\r\n\r\n  pressButtonService(){\r\n    this.triggerButtonService.emit()\r\n  }\r\n\r\n  setImage(){\r\n    const ref: DynamicDialogRef = this.dialogService.open(WImageCropperComponent, {\r\n      header: this.croppedDialogTranslations?.modal.header,\r\n      width: '70rem',\r\n      contentStyle: {\"overflow\": \"auto\", \"height\": \"auto\", \"padding-bottom\": \"8px\"},\r\n      data: {dataModal: this.croppedImageConfiguration, translations: this.croppedDialogTranslations},\r\n      resizable: true\r\n    });\r\n    \r\n    ref.onClose.subscribe((imageCropped: WFileB64) => {\r\n      if(imageCropped){\r\n        this.defaultImage = imageCropped;\r\n        this.images.push({path: this.defaultImage.fileBase64});\r\n        this.onDefaultImageEvent.emit(this.defaultImage);\r\n      }\r\n    })\r\n  }\r\n\r\n  getImage(){\r\n    this.isNoImage = false;\r\n    if(this.isDevModeActive == true){\r\n      if(this.defaultImage){\r\n        if(this.isWFileImage(this.defaultImage)){\r\n          return [{ path: (this.defaultImage as WFileB64).fileBase64 }];\r\n        }else{\r\n          return [{ path: this.defaultImage}];\r\n        }\r\n      }else{\r\n        this.isNoImage = true;\r\n        return [{ path: './../../../assets/wappIcons/image.svg' }];\r\n      }\r\n    }else{\r\n      if(this.wappingServiceImages.length > 0){\r\n        return this.wappingServiceImages;\r\n      }else{\r\n        this.isNoImage = true;\r\n        return [{ path: './../../../assets/wappIcons/image.svg' }];\r\n      }\r\n    }\r\n  }\r\n\r\n  isWFileImage(obj: WFileB64 | string){\r\n    return (obj as WFileB64).base64 !== undefined;\r\n  }\r\n}\r\n","<wapp-main-title [title]=\"wappingService.tile3\" *ngIf=\"wappingService && (!forceMobile)\" fxHide.xs></wapp-main-title>\r\n<div class=\"service-detail-center\" *ngIf=\"wappingService\"\r\n        [ngClass]=\"{'force-mobile': forceMobile}\"\r\n        [fxLayout]=\"forceMobile ? 'column' : 'row'\"\r\n        [fxLayout.xs]=\"'column'\"\r\n        [fxLayout.sm]=\"'column'\">\r\n    <!--service image-->\r\n    <div [ngClass]=\"{'service-view-no-margin': forceMobile, 'service-view': !forceMobile}\" fxLayout=\"column\">\r\n        <!--tile 1-->\r\n        <div *ngIf=\"wappingService.tile1 && wappingService.tile1 != ''\"\r\n            [ngClass]=\"{'service-image-tile' : !hasHtml(wappingService.tile1),\r\n                        'template-service-image-tile' : hasHtml(wappingService.tile1)}\"\r\n            fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n            <div [ngClass]=\"{'tile-view-no-html': !hasHtml(wappingService.tile1)}\" class=\"service-view-tile1\" \r\n                [innerHtml]=\"wappingService.tile1\"></div>\r\n        </div>\r\n        <!--slideshow-->\r\n        <wapp-carousel [isDevModeActive]=\"isDevModeActive\" [forceMobile]=\"forceMobile\" [images]=\"wappingServiceImages\" [isNoImage]=\"isNoImage\" (onSetImageEvent)=\"setImage()\" [onHoverImageTooltip]=\"onHoverImageTooltip\"></wapp-carousel>\r\n        <!--tile 2-->\r\n        <div fxFlex fxLayout=\"row\"\r\n            fxLayoutAlign=\"center center\"\r\n            fxLayoutGap=\"5px\"\r\n            [ngClass]=\"{'service-tile-border-bottom-radius': !wappingService.tile4,\r\n                'template-service-tile': hasHtml(wappingService.tile2),\r\n                'service-tile' : !hasHtml(wappingService.tile2)}\"\r\n            [ngStyle]=\"!hasHtml(wappingService.tile2) ? { 'background-color': '#0e0c0c', 'color': '#fff' } : {'background-color': 'transparent !important', 'color': 'transparent !important'}\"\r\n            *ngIf=\"wappingService.tile2\">\r\n            <div [innerHtml]=\"wappingService.tile2\"></div>\r\n        </div>\r\n        <!--activate toggle-->\r\n        <mat-slide-toggle class=\"service-select-toggle\" color=\"accent\"\r\n                        *ngIf=\"wappingService.allowSelect && allowSelectSendGiftCard && !showButtonService && showToggle\"\r\n                        [disabled]=\"disabledToggle\"\r\n                        [(ngModel)]=\"wappingService.active\"\r\n                        (change)=\"selectWappingService()\">{{ serviceStatus }}</mat-slide-toggle>\r\n        <button mat-flat-button *ngIf=\"showButtonService\"\r\n                class=\"service-select-toggle\"\r\n                color=\"accent\"\r\n                [disabled]=\"disabledButtonService\"\r\n                (click)=\"pressButtonService()\">\r\n            <span>{{ wappingServicesTranslations?.buttonService }}</span>\r\n        </button>\r\n        \r\n    </div>\r\n    <!--service info-->\r\n    <div class=\"service-info-container\" [ngClass]=\"{'service-info-container-padding': forceMobile}\" fxLayout=\"column\">\r\n        <div class=\"service-tile-detail-container\" fxLayout=\"column\">\r\n        <!--tile 3-->\r\n        <div *ngIf=\"!forceMobile\"\r\n             [innerHtml]=\"wappingService.tile3\" fxHide fxShow.xs\r\n             class=\"service-name mat-title\">\r\n        </div>\r\n        <div *ngIf=\"forceMobile\"\r\n             [innerHtml]=\"wappingService.tile3\"\r\n             class=\"service-name mat-title\">\r\n        </div>\r\n        <!--tileDetail 1-->\r\n        <div class=\"service-tile-detail\" fxLayout=\"row\">\r\n            <span [innerHtml]=\"wappingService.tileDetail1\"></span>\r\n        </div>\r\n        </div>\r\n        <!--link-->\r\n        <div class=\"service-link-container\" *ngIf=\"wappingService.titleLinkUrl && wappingService.linkUrl\">\r\n        <a class=\"service-link\" href=\"{{wappingService.linkUrl}}\" target=\"_blank\">\r\n            <mat-icon class=\"service-link-icon\" svgIcon=\"share_square\"></mat-icon><span>{{wappingService.titleLinkUrl}}</span>\r\n        </a>\r\n        </div>\r\n    </div>\r\n</div>"]}
247
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"w-material-service-view.component.js","sourceRoot":"","sources":["../../../../../../projects/wapp-components/src/lib/material/w-material-service-view/w-material-service-view.component.ts","../../../../../../projects/wapp-components/src/lib/material/w-material-service-view/w-material-service-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { WappingService } from '../shared/models/wapping-service';\r\nimport { WappingServiceImage } from '../shared/models/wapping-service-image';\r\nimport { CardStatus, SendingStatus, WappingServiceType } from '../shared/models/enums.model';\r\nimport { WappingServiceTranslations } from '../shared/models/wapping-service-translations.model';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { WappingServiceTemplate } from '../shared/models/wapping-service-template.model';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { WFileB64 } from '../../shared/models/w-file-b64.model';\r\nimport { WImageCropperData } from '../../shared/models/w-image-cropper-data.model';\r\nimport { WImageCropperComponent } from '../../file/w-image-cropper/w-image-cropper.component';\r\n\r\n@Component({\r\n  selector: 'w-material-service-view',\r\n  templateUrl: './w-material-service-view.component.html',\r\n  styleUrls: ['./w-material-service-view.component.scss']\r\n})\r\nexport class WMaterialServiceViewComponent implements OnInit, OnChanges {\r\n\r\n  serviceId!: number;\r\n  wappingServiceImages!: WappingServiceImage[];\r\n  serviceStatus!: string;\r\n  isSendGiftCard: boolean = false;\r\n  disabledToggle: boolean = false;\r\n  allowSelectSendGiftCard: boolean = true;\r\n  enumSendingStatus: typeof SendingStatus = SendingStatus;\r\n  ecardStatus: typeof CardStatus = CardStatus\r\n  translations: any;\r\n  \r\n  @Input() forceMobile = false;\r\n\r\n  @Input('wappingServicesTranslations') wappingServicesTranslations: WappingServiceTranslations = {\r\n    activedService: 'Activada',\r\n    disabledService: 'Desactivada',\r\n    scheduledLabel: 'Programada para enviar a {{name}}',\r\n    sendLabel: 'Enviada a {{name}}',\r\n    cardGenerated: 'Tu tarjeta estará disponible para el envío en breves instantes',\r\n    receivedLabel: \"Enviada por {{name}}\",\r\n    showMore: \"Mostrar más\",\r\n    buttonService: \"Participar\"\r\n  };\r\n  \r\n  @Input('disabledButtonService') disabledButtonService: boolean = false;\r\n  @Input('showButtonService') showButtonService: boolean = false;\r\n  @Input('showToggle') showToggle: boolean = true;\r\n\r\n  private _wappingService!: WappingService;\r\n\r\n  @Input() set wappingService(value: WappingService) {\r\n    this._wappingService = value;\r\n    if(value) this.getWappingService(value);\r\n  }\r\n\r\n  get wappingService() {\r\n    return this._wappingService;\r\n  }\r\n\r\n  @Output('wappingServiceSelected') wappingServiceSelected = new EventEmitter<boolean>();\r\n  @Output('triggerButtonService') triggerButtonService = new EventEmitter<void>();\r\n\r\n  @Input() isDevModeActive: boolean = false;\r\n  @Input() defaultImage!: WFileB64 | string;\r\n\r\n  @Input() croppedImageConfiguration: WImageCropperData = {\r\n    roundedCropper: false, \r\n    configuredAspectRatio: 4/3, \r\n    viewPortHeihtPx: 600, \r\n    viewPortWidthPx: 800, \r\n    maxFileSize: 2000\r\n  };\r\n  \r\n  @Input() croppedDialogTranslations: any;\r\n  images: any[] = [];\r\n  @Output() onDefaultImageEvent = new EventEmitter<WFileB64>();\r\n  @Input() isNoImage: boolean = false;\r\n  @Input() onHoverImageTooltip: string = 'Upload image';\r\n\r\n  constructor(\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer, \r\n    private dialogService: DialogService) {\r\n    this.matIconRegistry.addSvgIcon(\"calendar\", this.domSanitizer.bypassSecurityTrustResourceUrl(\"/assets/wappIcons/mat-calendar.svg\"));\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.getImage();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes['defaultImage'] && changes['defaultImage'].currentValue){\r\n      this.defaultImage = changes['defaultImage'].currentValue;\r\n      this.getImage();\r\n    }\r\n\r\n    if(changes['defaultImage'] && !changes['defaultImage'].currentValue){\r\n      if(this.isDevModeActive){\r\n        this.isNoImage = true;\r\n        this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }]\r\n      }\r\n    }\r\n  }\r\n\r\n  getWappingService(wappService: WappingService) {\r\n    this.isSendGiftCard = false\r\n    if (wappService.active)\r\n      this.serviceStatus = this.wappingServicesTranslations.activedService.toUpperCase();\r\n    else\r\n      this.serviceStatus = this.wappingServicesTranslations.disabledService.toUpperCase();\r\n    if (wappService.dataReqToSendCard && wappService.dataReqToSendCard.dataReqToSendCardId != 0) {\r\n      this.isSendGiftCard = true\r\n      if (wappService.enumTypeStatusECardID == this.ecardStatus.sent) {\r\n        this.allowSelectSendGiftCard = false;\r\n      }\r\n    }\r\n    if (wappService.enumTypeStatusECardID == this.ecardStatus.generated)\r\n      this.allowSelectSendGiftCard = false;\r\n\r\n\r\n    this.getWappingServiceTiles(this.wappingService);\r\n\r\n    if(this.isDevModeActive == false){\r\n      this.getWappingServiceImages();\r\n    }\r\n  }\r\n\r\n  getWappingServiceTiles(service: WappingService) {\r\n    if (service.wappingServiceTemplates != null) {\r\n      service.wappingServiceTemplates.forEach((wappingServiceTile: WappingServiceTemplate) => {\r\n        if(wappingServiceTile.detailTitle){\r\n          this.wappingService.tile3 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailTitle);\r\n        } else {\r\n          this.wappingService.tile3 = '';\r\n        }\r\n        if(wappingServiceTile.detailHeader){\r\n          this.wappingService.tile1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailHeader);\r\n        } else {\r\n          this.wappingService.tile1 = '';\r\n        }\r\n        if(wappingServiceTile.detailFoot){\r\n          this.wappingService.tile2 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailFoot);\r\n        } else {\r\n          this.wappingService.tile2 = '';\r\n        }\r\n        if(wappingServiceTile.detailBody){\r\n          this.wappingService.tileDetail1 = this.domSanitizer.bypassSecurityTrustHtml(wappingServiceTile.detailBody);\r\n        } else {\r\n          this.wappingService.tileDetail1 = '';\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  getWappingServiceImages() {\r\n    this.getImage();\r\n  }\r\n\r\n  selectWappingService() {\r\n    this.disabledToggle = true;\r\n    this.wappingServiceSelected.emit(this.wappingService.active);\r\n    if (this.wappingService.active)\r\n      this.serviceStatus = this.wappingServicesTranslations.activedService.toUpperCase();\r\n    else\r\n      this.serviceStatus = this.wappingServicesTranslations.disabledService.toUpperCase();\r\n\r\n    this.disabledToggle = false\r\n    this.getWappingService(this.wappingService);\r\n  }\r\n\r\n  hasHtml(value: any): boolean {\r\n    return /<\\/?[a-z][\\s\\S]*>/i.test(value);\r\n  }\r\n\r\n  pressButtonService(){\r\n    this.triggerButtonService.emit()\r\n  }\r\n\r\n  setImage(){\r\n    const ref: DynamicDialogRef = this.dialogService.open(WImageCropperComponent, {\r\n      header: this.croppedDialogTranslations?.modal.header,\r\n      width: '70rem',\r\n      contentStyle: {\"overflow\": \"auto\", \"height\": \"auto\", \"padding-bottom\": \"8px\"},\r\n      data: {dataModal: this.croppedImageConfiguration, translations: this.croppedDialogTranslations},\r\n      resizable: true\r\n    });\r\n    \r\n    ref.onClose.subscribe((imageCropped: WFileB64) => {\r\n      if(imageCropped){\r\n        this.defaultImage = imageCropped;\r\n        this.images.push({path: this.defaultImage.fileBase64});\r\n        this.onDefaultImageEvent.emit(this.defaultImage);\r\n      }\r\n    })\r\n  }\r\n\r\n  getImage() {\r\n    this.isNoImage = false;\r\n    if (this.isDevModeActive == true) {\r\n      if (this.defaultImage) {\r\n        if (this.isWFileImage(this.defaultImage)) {\r\n          this.wappingServiceImages = [{ path: (this.defaultImage as WFileB64).fileBase64 }];\r\n        } else {\r\n          this.wappingServiceImages = [{ path: (this.defaultImage as string) }];\r\n        }\r\n      }else{\r\n        this.isNoImage = true; \r\n        this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];\r\n      }\r\n    }else{\r\n      if(this.wappingService){\r\n        if(this.wappingService.wappingServiceImages.length > 0){\r\n          this.wappingServiceImages = this.wappingService.wappingServiceImages;\r\n        }else if(this.wappingService.wappingServiceImages.length == 0 && this.wappingService.imageUrl){\r\n          this.wappingServiceImages = [];\r\n          let wappingServiceImage: WappingServiceImage = {\r\n            path: this.wappingService.imageUrl!,\r\n          };\r\n          this.wappingServiceImages.unshift(wappingServiceImage);\r\n        }else if(this.defaultImage){\r\n          this.wappingServiceImages = [{ path: (this.defaultImage as string) }];\r\n        }else{\r\n          this.isNoImage = true; \r\n          this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  isWFileImage(obj: WFileB64 | string){\r\n    return (obj as WFileB64).base64 !== undefined;\r\n  }\r\n}\r\n","<wapp-main-title [title]=\"wappingService.tile3\" *ngIf=\"wappingService && (!forceMobile)\" fxHide.xs></wapp-main-title>\r\n<div class=\"service-detail-center\" *ngIf=\"wappingService\"\r\n        [ngClass]=\"{'force-mobile': forceMobile}\"\r\n        [fxLayout]=\"forceMobile ? 'column' : 'row'\"\r\n        [fxLayout.xs]=\"'column'\"\r\n        [fxLayout.sm]=\"'column'\">\r\n    <!--service image-->\r\n    <div [ngClass]=\"{'service-view-no-margin': forceMobile, 'service-view': !forceMobile}\" fxLayout=\"column\">\r\n        <!--tile 1-->\r\n        <div *ngIf=\"wappingService.tile1 && wappingService.tile1 != ''\"\r\n            [ngClass]=\"{'service-image-tile' : !hasHtml(wappingService.tile1),\r\n                        'template-service-image-tile' : hasHtml(wappingService.tile1)}\"\r\n            fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n            <div [ngClass]=\"{'tile-view-no-html': !hasHtml(wappingService.tile1)}\" class=\"service-view-tile1\" \r\n                [innerHtml]=\"wappingService.tile1\"></div>\r\n        </div>\r\n        <!--slideshow-->\r\n        <wapp-carousel [isDevModeActive]=\"isDevModeActive\" [forceMobile]=\"forceMobile\" [images]=\"wappingServiceImages\" [isNoImage]=\"isNoImage\" (onSetImageEvent)=\"setImage()\" [onHoverImageTooltip]=\"onHoverImageTooltip\"></wapp-carousel>\r\n        <!--tile 2-->\r\n        <div fxFlex fxLayout=\"row\"\r\n            fxLayoutAlign=\"center center\"\r\n            fxLayoutGap=\"5px\"\r\n            [ngClass]=\"{'service-tile-border-bottom-radius': !wappingService.tile4,\r\n                'template-service-tile': hasHtml(wappingService.tile2),\r\n                'service-tile' : !hasHtml(wappingService.tile2)}\"\r\n            [ngStyle]=\"!hasHtml(wappingService.tile2) ? { 'background-color': '#0e0c0c', 'color': '#fff' } : {'background-color': 'transparent !important', 'color': 'transparent !important'}\"\r\n            *ngIf=\"wappingService.tile2\">\r\n            <div [innerHtml]=\"wappingService.tile2\"></div>\r\n        </div>\r\n        <!--activate toggle-->\r\n        <mat-slide-toggle class=\"service-select-toggle\" color=\"accent\"\r\n                        *ngIf=\"wappingService.allowSelect && allowSelectSendGiftCard && !showButtonService && showToggle\"\r\n                        [disabled]=\"disabledToggle\"\r\n                        [(ngModel)]=\"wappingService.active\"\r\n                        (change)=\"selectWappingService()\">{{ serviceStatus }}</mat-slide-toggle>\r\n        <button mat-flat-button *ngIf=\"showButtonService\"\r\n                class=\"service-select-toggle\"\r\n                color=\"accent\"\r\n                [disabled]=\"disabledButtonService\"\r\n                (click)=\"pressButtonService()\">\r\n            <span>{{ wappingServicesTranslations?.buttonService }}</span>\r\n        </button>\r\n        \r\n    </div>\r\n    <!--service info-->\r\n    <div class=\"service-info-container\" [ngClass]=\"{'service-info-container-padding': forceMobile}\" fxLayout=\"column\">\r\n        <div class=\"service-tile-detail-container\" fxLayout=\"column\">\r\n        <!--tile 3-->\r\n        <div *ngIf=\"!forceMobile\"\r\n             [innerHtml]=\"wappingService.tile3\" fxHide fxShow.xs\r\n             class=\"service-name mat-title\">\r\n        </div>\r\n        <div *ngIf=\"forceMobile\"\r\n             [innerHtml]=\"wappingService.tile3\"\r\n             class=\"service-name mat-title\">\r\n        </div>\r\n        <!--tileDetail 1-->\r\n        <div class=\"service-tile-detail\" fxLayout=\"row\">\r\n            <span [innerHtml]=\"wappingService.tileDetail1\"></span>\r\n        </div>\r\n        </div>\r\n        <!--link-->\r\n        <div class=\"service-link-container\" *ngIf=\"wappingService.titleLinkUrl && wappingService.linkUrl\">\r\n        <a class=\"service-link\" href=\"{{wappingService.linkUrl}}\" target=\"_blank\">\r\n            <mat-icon class=\"service-link-icon\" svgIcon=\"share_square\"></mat-icon><span>{{wappingService.titleLinkUrl}}</span>\r\n        </a>\r\n        </div>\r\n    </div>\r\n</div>"]}
@@ -126,6 +126,9 @@ export class CarouselComponent {
126
126
  }
127
127
  }
128
128
  ngOnChanges(changes) {
129
+ if (changes['images'] && changes['images'].currentValue) {
130
+ this.images = changes['images'].currentValue;
131
+ }
129
132
  }
130
133
  ngOnDestroy() {
131
134
  if (this.allowThumbnail) {
@@ -214,7 +217,7 @@ export class CarouselComponent {
214
217
  }
215
218
  }
216
219
  CarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CarouselComponent, deps: [{ token: i1.DeviceDetectorService }], target: i0.ɵɵFactoryTarget.Component });
217
- CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CarouselComponent, selector: "wapp-carousel", inputs: { images: "images", allowThumbnail: "allowThumbnail", infiniteCarousel: "infiniteCarousel", forceMobile: "forceMobile", height: "height", isDevModeActive: "isDevModeActive", isNoImage: "isNoImage", onHoverImageTooltip: "onHoverImageTooltip" }, outputs: { onSetImageEvent: "onSetImageEvent" }, viewQueries: [{ propertyName: "thumbnail", first: true, predicate: ["thumbnail"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"carousel-container\"\r\n [style.height.px]=\"height?height:null\"\r\n [style.margin-bottom]=\"height?'.25rem':null\"\r\n (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n <!--carousel image container-->\r\n <div class=\"carousel-image-container\"\r\n [ngClass]=\"height ? 'fixed-height' : null\"\r\n *ngFor=\"let img of images; let i = index; let first = first\"\r\n [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n <!--carousel image-->\r\n <img #slide (load)=\"first && onLoad(slide)\" \r\n [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n [src]=\"img.path\"/>\r\n </div>\r\n <!--previous button-->\r\n <button type=\"button\"\r\n class=\"carousel-previous-button\"\r\n (click)=\"change('right')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-previous-icon\"></span>\r\n </button>\r\n <!--next button-->\r\n <button type=\"button\"\r\n class=\"carousel-next-button\"\r\n (click)=\"change('left')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-next-icon\"></span>\r\n </button>\r\n <!--button indicators-->\r\n <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n <div class=\"carousel-indicator-buttons\">\r\n <button *ngFor=\"let img of images; let i = index\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (click)=\"setIndex(i)\"></button>\r\n </div>\r\n </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n <div class=\"carousel-thumbnails\"\r\n [@animationThumbnail]=\"{\r\n value: thumbnailAnimation,\r\n params: { margin: thumbnailMargin + 'px' }}\">\r\n <img *ngFor=\"let img of images; let i = index\"\r\n [style.width.px]=\"thumbnailWidth\"\r\n [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (load)=\"onLoadThumbnail()\"\r\n (click)=\"setIndex(i)\"\r\n [src]=\"img.path\" />\r\n </div>\r\n</div>\r\n", styles: [".carousel-container{position:relative;display:flex;overflow:hidden;margin-left:auto;margin-right:auto;align-items:center;width:450px}.carousel-top-left-icon{position:absolute;top:15px;left:15px;cursor:pointer;z-index:10}.carousel-image-container{width:100%;position:relative}.carousel-image-container img{width:450px}@media (min-width:600px) and (max-width: 959px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}@media (max-width: 599px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}.carousel-image-container img.fixed-height{position:absolute;inset:-100% 0;margin:auto}.carousel-container:after{display:block;clear:both;content:\"\"}.carousel-container div{float:left;margin-right:-100%;font-size:0}.carousel-previous-button:hover,.carousel-next-button:hover,.carousel-previous-button:focus,.carousel-next-button:focus{opacity:.9}.carousel-previous-button,.carousel-next-button{position:absolute;top:0;bottom:0;width:15%;display:flex;align-items:center;justify-content:center;background-color:transparent;border:0;color:#fff;opacity:.5;transition:opacity .15s ease;cursor:pointer}.carousel-next-button{right:0}.carousel-next-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>\")}.carousel-previous-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-chevron-left' viewBox='0 0 16 16'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>\")}.carousel-next-icon,.carousel-previous-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-indicator-container{width:100%;overflow:hidden}.carousel-indicator-buttons{display:flex;position:absolute;right:0;bottom:0;left:0;z-index:2;justify-content:center;padding:0;margin-right:15%!important;margin-bottom:1rem;margin-left:15%;list-style:none}.carousel-indicator-buttons button{box-sizing:content-box;flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent}.carousel-indicator-buttons button:hover{opacity:1!important}.carousel-thumbnail-container{width:100%;overflow:hidden}.carousel-thumbnails{display:flex}.carousel-thumbnails img{cursor:pointer}.carousel-thumbnails img:hover{opacity:1!important}.default-image{padding:68px}.edit-image{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }], animations: [
220
+ CarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CarouselComponent, selector: "wapp-carousel", inputs: { images: "images", allowThumbnail: "allowThumbnail", infiniteCarousel: "infiniteCarousel", forceMobile: "forceMobile", height: "height", isDevModeActive: "isDevModeActive", isNoImage: "isNoImage", onHoverImageTooltip: "onHoverImageTooltip" }, outputs: { onSetImageEvent: "onSetImageEvent" }, viewQueries: [{ propertyName: "thumbnail", first: true, predicate: ["thumbnail"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"carousel-container\"\r\n [style.height.px]=\"height?height:null\"\r\n [style.margin-bottom]=\"height?'.25rem':null\"\r\n (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n <!--carousel image container-->\r\n <div class=\"carousel-image-container\"\r\n [ngClass]=\"height ? 'fixed-height' : null\"\r\n *ngFor=\"let img of images; let i = index; let first = first\"\r\n [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n <!--carousel image-->\r\n <img #slide (load)=\"first && onLoad(slide)\" \r\n [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n [src]=\"img.path\"/>\r\n </div>\r\n <!--previous button-->\r\n <button type=\"button\"\r\n class=\"carousel-previous-button\"\r\n (click)=\"change('right')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-previous-icon\"></span>\r\n </button>\r\n <!--next button-->\r\n <button type=\"button\"\r\n class=\"carousel-next-button\"\r\n (click)=\"change('left')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-next-icon\"></span>\r\n </button>\r\n <!--button indicators-->\r\n <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n <div class=\"carousel-indicator-buttons\">\r\n <button *ngFor=\"let img of images; let i = index\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (click)=\"setIndex(i)\"></button>\r\n </div>\r\n </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n <div class=\"carousel-thumbnails\"\r\n [@animationThumbnail]=\"{\r\n value: thumbnailAnimation,\r\n params: { margin: thumbnailMargin + 'px' }}\">\r\n <img *ngFor=\"let img of images; let i = index\"\r\n [style.width.px]=\"thumbnailWidth\"\r\n [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (load)=\"onLoadThumbnail()\"\r\n (click)=\"setIndex(i)\"\r\n [src]=\"img.path\" />\r\n </div>\r\n</div>\r\n", styles: [".carousel-container{position:relative;display:flex;overflow:hidden;margin-left:auto;margin-right:auto;align-items:center;width:450px}.carousel-top-left-icon{position:absolute;top:15px;left:15px;cursor:pointer;z-index:10}.carousel-image-container{width:100%;position:relative}.carousel-image-container img{max-width:450px;width:-webkit-fill-available;width:-moz-available;width:stretch}@media (min-width:600px) and (max-width: 959px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}@media (max-width: 599px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}.carousel-image-container img.fixed-height{position:absolute;inset:-100% 0;margin:auto}.carousel-container:after{display:block;clear:both;content:\"\"}.carousel-container div{float:left;margin-right:-100%;font-size:0}.carousel-previous-button:hover,.carousel-next-button:hover,.carousel-previous-button:focus,.carousel-next-button:focus{opacity:.9}.carousel-previous-button,.carousel-next-button{position:absolute;top:0;bottom:0;width:15%;display:flex;align-items:center;justify-content:center;background-color:transparent;border:0;color:#fff;opacity:.5;transition:opacity .15s ease;cursor:pointer}.carousel-next-button{right:0}.carousel-next-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>\")}.carousel-previous-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-chevron-left' viewBox='0 0 16 16'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>\")}.carousel-next-icon,.carousel-previous-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-indicator-container{width:100%;overflow:hidden}.carousel-indicator-buttons{display:flex;position:absolute;right:0;bottom:0;left:0;z-index:2;justify-content:center;padding:0;margin-right:15%!important;margin-bottom:1rem;margin-left:15%;list-style:none}.carousel-indicator-buttons button{box-sizing:content-box;flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent}.carousel-indicator-buttons button:hover{opacity:1!important}.carousel-thumbnail-container{width:100%;overflow:hidden}.carousel-thumbnails{display:flex}.carousel-thumbnails img{cursor:pointer}.carousel-thumbnails img:hover{opacity:1!important}.default-image{padding:68px}.edit-image{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i4.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }], animations: [
218
221
  trigger('animImageSlider', animationCarouselFade),
219
222
  trigger('animationThumbnail', animationThumbnail),
220
223
  ] });
@@ -223,7 +226,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
223
226
  args: [{ selector: 'wapp-carousel', animations: [
224
227
  trigger('animImageSlider', animationCarouselFade),
225
228
  trigger('animationThumbnail', animationThumbnail),
226
- ], template: "<div class=\"carousel-container\"\r\n [style.height.px]=\"height?height:null\"\r\n [style.margin-bottom]=\"height?'.25rem':null\"\r\n (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n <!--carousel image container-->\r\n <div class=\"carousel-image-container\"\r\n [ngClass]=\"height ? 'fixed-height' : null\"\r\n *ngFor=\"let img of images; let i = index; let first = first\"\r\n [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n <!--carousel image-->\r\n <img #slide (load)=\"first && onLoad(slide)\" \r\n [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n [src]=\"img.path\"/>\r\n </div>\r\n <!--previous button-->\r\n <button type=\"button\"\r\n class=\"carousel-previous-button\"\r\n (click)=\"change('right')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-previous-icon\"></span>\r\n </button>\r\n <!--next button-->\r\n <button type=\"button\"\r\n class=\"carousel-next-button\"\r\n (click)=\"change('left')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-next-icon\"></span>\r\n </button>\r\n <!--button indicators-->\r\n <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n <div class=\"carousel-indicator-buttons\">\r\n <button *ngFor=\"let img of images; let i = index\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (click)=\"setIndex(i)\"></button>\r\n </div>\r\n </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n <div class=\"carousel-thumbnails\"\r\n [@animationThumbnail]=\"{\r\n value: thumbnailAnimation,\r\n params: { margin: thumbnailMargin + 'px' }}\">\r\n <img *ngFor=\"let img of images; let i = index\"\r\n [style.width.px]=\"thumbnailWidth\"\r\n [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (load)=\"onLoadThumbnail()\"\r\n (click)=\"setIndex(i)\"\r\n [src]=\"img.path\" />\r\n </div>\r\n</div>\r\n", styles: [".carousel-container{position:relative;display:flex;overflow:hidden;margin-left:auto;margin-right:auto;align-items:center;width:450px}.carousel-top-left-icon{position:absolute;top:15px;left:15px;cursor:pointer;z-index:10}.carousel-image-container{width:100%;position:relative}.carousel-image-container img{width:450px}@media (min-width:600px) and (max-width: 959px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}@media (max-width: 599px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}.carousel-image-container img.fixed-height{position:absolute;inset:-100% 0;margin:auto}.carousel-container:after{display:block;clear:both;content:\"\"}.carousel-container div{float:left;margin-right:-100%;font-size:0}.carousel-previous-button:hover,.carousel-next-button:hover,.carousel-previous-button:focus,.carousel-next-button:focus{opacity:.9}.carousel-previous-button,.carousel-next-button{position:absolute;top:0;bottom:0;width:15%;display:flex;align-items:center;justify-content:center;background-color:transparent;border:0;color:#fff;opacity:.5;transition:opacity .15s ease;cursor:pointer}.carousel-next-button{right:0}.carousel-next-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>\")}.carousel-previous-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-chevron-left' viewBox='0 0 16 16'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>\")}.carousel-next-icon,.carousel-previous-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-indicator-container{width:100%;overflow:hidden}.carousel-indicator-buttons{display:flex;position:absolute;right:0;bottom:0;left:0;z-index:2;justify-content:center;padding:0;margin-right:15%!important;margin-bottom:1rem;margin-left:15%;list-style:none}.carousel-indicator-buttons button{box-sizing:content-box;flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent}.carousel-indicator-buttons button:hover{opacity:1!important}.carousel-thumbnail-container{width:100%;overflow:hidden}.carousel-thumbnails{display:flex}.carousel-thumbnails img{cursor:pointer}.carousel-thumbnails img:hover{opacity:1!important}.default-image{padding:68px}.edit-image{cursor:pointer}\n"] }]
229
+ ], template: "<div class=\"carousel-container\"\r\n [style.height.px]=\"height?height:null\"\r\n [style.margin-bottom]=\"height?'.25rem':null\"\r\n (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n <!--carousel image container-->\r\n <div class=\"carousel-image-container\"\r\n [ngClass]=\"height ? 'fixed-height' : null\"\r\n *ngFor=\"let img of images; let i = index; let first = first\"\r\n [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n <!--carousel image-->\r\n <img #slide (load)=\"first && onLoad(slide)\" \r\n [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n [src]=\"img.path\"/>\r\n </div>\r\n <!--previous button-->\r\n <button type=\"button\"\r\n class=\"carousel-previous-button\"\r\n (click)=\"change('right')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-previous-icon\"></span>\r\n </button>\r\n <!--next button-->\r\n <button type=\"button\"\r\n class=\"carousel-next-button\"\r\n (click)=\"change('left')\"\r\n *ngIf=\"showNavigation\">\r\n <span class=\"carousel-next-icon\"></span>\r\n </button>\r\n <!--button indicators-->\r\n <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n <div class=\"carousel-indicator-buttons\">\r\n <button *ngFor=\"let img of images; let i = index\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (click)=\"setIndex(i)\"></button>\r\n </div>\r\n </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n <div class=\"carousel-thumbnails\"\r\n [@animationThumbnail]=\"{\r\n value: thumbnailAnimation,\r\n params: { margin: thumbnailMargin + 'px' }}\">\r\n <img *ngFor=\"let img of images; let i = index\"\r\n [style.width.px]=\"thumbnailWidth\"\r\n [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n (load)=\"onLoadThumbnail()\"\r\n (click)=\"setIndex(i)\"\r\n [src]=\"img.path\" />\r\n </div>\r\n</div>\r\n", styles: [".carousel-container{position:relative;display:flex;overflow:hidden;margin-left:auto;margin-right:auto;align-items:center;width:450px}.carousel-top-left-icon{position:absolute;top:15px;left:15px;cursor:pointer;z-index:10}.carousel-image-container{width:100%;position:relative}.carousel-image-container img{max-width:450px;width:-webkit-fill-available;width:-moz-available;width:stretch}@media (min-width:600px) and (max-width: 959px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}@media (max-width: 599px){.carousel-image-container img{width:100%}.carousel-container{width:unset}}.carousel-image-container img.fixed-height{position:absolute;inset:-100% 0;margin:auto}.carousel-container:after{display:block;clear:both;content:\"\"}.carousel-container div{float:left;margin-right:-100%;font-size:0}.carousel-previous-button:hover,.carousel-next-button:hover,.carousel-previous-button:focus,.carousel-next-button:focus{opacity:.9}.carousel-previous-button,.carousel-next-button{position:absolute;top:0;bottom:0;width:15%;display:flex;align-items:center;justify-content:center;background-color:transparent;border:0;color:#fff;opacity:.5;transition:opacity .15s ease;cursor:pointer}.carousel-next-button{right:0}.carousel-next-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' viewBox='0 0 16 16'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>\")}.carousel-previous-icon{background-image:url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-chevron-left' viewBox='0 0 16 16'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>\")}.carousel-next-icon,.carousel-previous-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-indicator-container{width:100%;overflow:hidden}.carousel-indicator-buttons{display:flex;position:absolute;right:0;bottom:0;left:0;z-index:2;justify-content:center;padding:0;margin-right:15%!important;margin-bottom:1rem;margin-left:15%;list-style:none}.carousel-indicator-buttons button{box-sizing:content-box;flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent}.carousel-indicator-buttons button:hover{opacity:1!important}.carousel-thumbnail-container{width:100%;overflow:hidden}.carousel-thumbnails{display:flex}.carousel-thumbnails img{cursor:pointer}.carousel-thumbnails img:hover{opacity:1!important}.default-image{padding:68px}.edit-image{cursor:pointer}\n"] }]
227
230
  }], ctorParameters: function () { return [{ type: i1.DeviceDetectorService }]; }, propDecorators: { thumbnail: [{
228
231
  type: ViewChild,
229
232
  args: ['thumbnail', { static: true }]
@@ -249,4 +252,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
249
252
  }], onHoverImageTooltip: [{
250
253
  type: Input
251
254
  }] } });
252
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../projects/wapp-components/src/lib/material/wapp-material-service-view/carousel/carousel.component.ts","../../../../../../../projects/wapp-components/src/lib/material/wapp-material-service-view/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport {\r\n  animation,\r\n  trigger,\r\n  transition,\r\n  query,\r\n  style,\r\n  animate,\r\n  group,\r\n  state,\r\n} from '@angular/animations';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\n\r\nconst animationCarousel = [\r\n  state('outright', style({ transform: `translateX(100%)` })),\r\n  state('outleft', style({ transform: `translateX(-100%)` })),\r\n  transition('void=>inleft', [style({ transform: `translateX(0)` })]),\r\n  transition('void=>outleft', [style({ transform: `translateX(-100%)` })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ transform: `translateX(-100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateX(0)` })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ transform: `translateX(100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateX(0)` })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('260ms ease-in', style({ transform: `translateX(-100%)` })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('260ms ease-in', style({ transform: `translateX(100%)` })),\r\n  ]),\r\n];\r\n\r\nconst animationCarouselTranslateY = [\r\n  state('outright', style({ transform: `translateY(100%)` })),\r\n  state('outleft', style({ transform: `translateY(-100%)` })),\r\n  transition('void=>inleft', [style({ transform: `translateY(0)` })]),\r\n  transition('void=>outleft', [style({ transform: `translateY(-100%)` })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ transform: `translateY(-100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateY(0)` })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ transform: `translateY(100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateY(0)` })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('260ms ease-in', style({ transform: `translateY(-100%)` })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('260ms ease-in', style({ transform: `translateY(100%)` })),\r\n  ]),\r\n];\r\n\r\nconst animationCarouselFade = [\r\n  state('outright', style({ opacity: 0 })),\r\n  state('outleft', style({ opacity: 0 })),\r\n  transition('void=>inleft', [style({ opacity: 1 })]),\r\n  transition('void=>outleft', [style({ opacity: 0 })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ opacity: 0 }),\r\n    animate('160ms ease-in', style({ opacity: 1 })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ opacity: 0 }),\r\n    animate('160ms ease-in', style({ opacity: 1 })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('160ms ease-in', style({ opacity: 0 })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('160ms ease-in', style({ opacity: 0 })),\r\n  ]),\r\n];\r\n\r\nconst animationThumbnail = [\r\n  state('true', style({ transform: `translateX({{margin}})` }), {\r\n    params: { margin: 0 },\r\n  }),\r\n  state('false', style({ transform: `translateX({{margin}})` }), {\r\n    params: { margin: 0 },\r\n  }),\r\n  transition('true<=>false', [animate('260ms ease-in')]),\r\n];\r\n\r\n@Component({\r\n  selector: 'wapp-carousel',\r\n  templateUrl: './carousel.component.html',\r\n  styleUrls: ['./carousel.component.css'],\r\n  animations: [\r\n    trigger('animImageSlider', animationCarouselFade),\r\n    trigger('animationThumbnail', animationThumbnail),\r\n  ],\r\n})\r\nexport class CarouselComponent implements OnInit, OnChanges {\r\n@ViewChild('thumbnail', { static: true }) thumbnail!: ElementRef;\r\n  @Input() set images(value) {\r\n    this._images = value;\r\n    this.slideControl = value.map((x:any, index:any) => (index ? 'outleft' : 'inleft'));\r\n  }\r\n  // TODO properly implement allow thumbnail functionality\r\n  @Input(\"allowThumbnail\") allowThumbnail: boolean = false;\r\n  @Input(\"infiniteCarousel\") infiniteCarousel: boolean = false;\r\n  @Input(\"forceMobile\") forceMobile: boolean = false;\r\n\r\n  get images() {\r\n    return this._images\r\n  }\r\n\r\n  @Input() height = 0;\r\n  counter: number = 0;\r\n  _images: any;\r\n  slideControl!: any[];\r\n  width: number = 0;\r\n  counterThumb: number = 0;\r\n  thumbnailMargin: number = 0;\r\n  thumbnailMarginRigth: number = 2;\r\n  thumbnailWidth: number = 60;\r\n  thumbnailAnimation: boolean | null = null;\r\n\r\n  resizeSub!: Subscription;\r\n  posIni: any;\r\n  showNavigation: boolean = false;\r\n  showIndicators: boolean = false;\r\n  isDesktop: boolean = false;\r\n  hasMultipleImages: boolean = false;\r\n\r\n  @Input() isDevModeActive: boolean = false; \r\n  @Input() isNoImage: boolean = false;\r\n  @Output() onSetImageEvent = new EventEmitter<boolean>();\r\n  @Input() onHoverImageTooltip!: any;\r\n\r\n  constructor(private deviceDetector: DeviceDetectorService,) { }\r\n\r\n  ngOnInit() {\r\n    if (this.deviceDetector.isDesktop() != null)\r\n      this.isDesktop = this.deviceDetector.isDesktop();\r\n\r\n    if (this.allowThumbnail) {\r\n      this.resizeSub = fromEvent(window, 'resize')\r\n        .pipe(debounceTime(200))\r\n        .subscribe((_) => this.posThumbnail(this.counter));\r\n    }\r\n\r\n    if (this.images.length > 1) {\r\n      this.showNavigation = true;\r\n      this.showIndicators = true;\r\n      this.hasMultipleImages = true;\r\n    }\r\n\r\n    if (this.isDesktop == false)\r\n      this.showNavigation = false;\r\n\r\n    if(this.isDevModeActive == false){\r\n      this.onHoverImageTooltip = null;\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.allowThumbnail) {\r\n      this.resizeSub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  move(pos: any) {\r\n    if (this.hasMultipleImages) {\r\n      const offset = this.posIni - pos;\r\n      if (offset < -100) this.change('right');\r\n\r\n      if (offset > 100) this.change('left');\r\n    }\r\n  }\r\n\r\n  // call this instead of onNext/onPrevious for infinite carousel\r\n  change(direction: string) {\r\n    const incr = direction == 'right' ? -1 : +1;\r\n    const prev = this.counter;\r\n    this.counter = (this.counter + this.images.length + incr) % this.images.length;\r\n    this.onSlide(this.counter, prev, direction);\r\n    this.slideControl[prev] = 'out' + direction\r\n  }\r\n\r\n  setIndex(index: number) {\r\n    if (index != this.counter) {\r\n      const prev = this.counter;\r\n      this.counter = index;\r\n      const direction = prev > index ? 'right' : 'left';\r\n      this.onSlide(this.counter, prev, direction);\r\n    }\r\n  }\r\n\r\n  onLoad(el: any) {\r\n    this.width = el.getBoundingClientRect().width;\r\n  }\r\n\r\n  onNext() {\r\n    if (this.counter != this.images.length - 1) {\r\n      this.counter++;\r\n      this.onSlide(this.counter, this.counter - 1, 'left')\r\n    }\r\n  }\r\n\r\n  onPrevious() {\r\n    if (this.counter > 0) {\r\n      this.counter--;\r\n      this.onSlide(this.counter, this.counter + 1, 'right')\r\n    }\r\n  }\r\n\r\n  onSlide(current: any, prev: any, direction: any) {\r\n    if (this.hasMultipleImages) {\r\n      this.slideControl[current] = 'in' + direction;\r\n      this.slideControl[prev] = 'out' + direction;\r\n\r\n      if (this.allowThumbnail) {\r\n        this.posThumbnail(current);\r\n      }\r\n    }\r\n  }\r\n\r\n  // TODO old method\r\n  onSlideOld(current: any, prev: any, direction: any) {\r\n    this.slideControl = this.slideControl.map((x, index) => {\r\n      return (index == current) ? 'in' + direction :\r\n        (index == prev) ? 'out' + direction : x\r\n    })\r\n  }\r\n\r\n  onLoadThumbnail() {\r\n    this.counterThumb++;\r\n    if (this.counterThumb == this.images.length) this.posThumbnail(0);\r\n  }\r\n\r\n  posThumbnail(current: number) {\r\n    const width = this.thumbnailWidth + this.thumbnailMarginRigth;\r\n    const widthWrapper =\r\n      this.thumbnail.nativeElement.getBoundingClientRect().width;\r\n\r\n    let newMargin: number = 0;\r\n    if (widthWrapper > width * this.images.length)\r\n      newMargin = (widthWrapper - width * this.images.length) / 2;\r\n    else {\r\n      const middle = widthWrapper / 2 - width * current;\r\n      const min = widthWrapper - width * this.images.length;\r\n\r\n      newMargin = Math.floor(middle > 0 ? 0 : middle < min ? min : middle);\r\n    }\r\n    if (newMargin != this.thumbnailMargin) {\r\n      this.thumbnailMargin = newMargin;\r\n      this.thumbnailAnimation = !this.thumbnailAnimation;\r\n    }\r\n  }\r\n\r\n  onSetImage(){\r\n    this.onSetImageEvent.emit(true);\r\n  }\r\n}\r\n","<div class=\"carousel-container\"\r\n     [style.height.px]=\"height?height:null\"\r\n     [style.margin-bottom]=\"height?'.25rem':null\"\r\n     (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n     (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n  <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n    <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n      <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n    </svg>\r\n  </div>\r\n  <!--carousel image container-->\r\n  <div class=\"carousel-image-container\"\r\n       [ngClass]=\"height ? 'fixed-height' : null\"\r\n       *ngFor=\"let img of images; let i = index; let first = first\"\r\n       [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n    <!--carousel image-->\r\n    <img #slide (load)=\"first && onLoad(slide)\" \r\n      [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n      [src]=\"img.path\"/>\r\n  </div>\r\n  <!--previous button-->\r\n  <button type=\"button\"\r\n          class=\"carousel-previous-button\"\r\n          (click)=\"change('right')\"\r\n          *ngIf=\"showNavigation\">\r\n    <span class=\"carousel-previous-icon\"></span>\r\n  </button>\r\n  <!--next button-->\r\n  <button type=\"button\"\r\n          class=\"carousel-next-button\"\r\n          (click)=\"change('left')\"\r\n          *ngIf=\"showNavigation\">\r\n    <span class=\"carousel-next-icon\"></span>\r\n  </button>\r\n  <!--button indicators-->\r\n  <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n    <div class=\"carousel-indicator-buttons\">\r\n      <button *ngFor=\"let img of images; let i = index\"\r\n              [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n              (click)=\"setIndex(i)\"></button>\r\n    </div>\r\n  </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n  <div class=\"carousel-thumbnails\"\r\n       [@animationThumbnail]=\"{\r\n        value: thumbnailAnimation,\r\n        params: { margin: thumbnailMargin + 'px' }}\">\r\n    <img *ngFor=\"let img of images; let i = index\"\r\n         [style.width.px]=\"thumbnailWidth\"\r\n         [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n         [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n         (load)=\"onLoadThumbnail()\"\r\n         (click)=\"setIndex(i)\"\r\n         [src]=\"img.path\" />\r\n  </div>\r\n</div>\r\n"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../projects/wapp-components/src/lib/material/wapp-material-service-view/carousel/carousel.component.ts","../../../../../../../projects/wapp-components/src/lib/material/wapp-material-service-view/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport {\r\n  animation,\r\n  trigger,\r\n  transition,\r\n  query,\r\n  style,\r\n  animate,\r\n  group,\r\n  state,\r\n} from '@angular/animations';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\n\r\nconst animationCarousel = [\r\n  state('outright', style({ transform: `translateX(100%)` })),\r\n  state('outleft', style({ transform: `translateX(-100%)` })),\r\n  transition('void=>inleft', [style({ transform: `translateX(0)` })]),\r\n  transition('void=>outleft', [style({ transform: `translateX(-100%)` })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ transform: `translateX(-100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateX(0)` })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ transform: `translateX(100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateX(0)` })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('260ms ease-in', style({ transform: `translateX(-100%)` })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('260ms ease-in', style({ transform: `translateX(100%)` })),\r\n  ]),\r\n];\r\n\r\nconst animationCarouselTranslateY = [\r\n  state('outright', style({ transform: `translateY(100%)` })),\r\n  state('outleft', style({ transform: `translateY(-100%)` })),\r\n  transition('void=>inleft', [style({ transform: `translateY(0)` })]),\r\n  transition('void=>outleft', [style({ transform: `translateY(-100%)` })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ transform: `translateY(-100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateY(0)` })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ transform: `translateY(100%)` }),\r\n    animate('260ms ease-in', style({ transform: `translateY(0)` })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('260ms ease-in', style({ transform: `translateY(-100%)` })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('260ms ease-in', style({ transform: `translateY(100%)` })),\r\n  ]),\r\n];\r\n\r\nconst animationCarouselFade = [\r\n  state('outright', style({ opacity: 0 })),\r\n  state('outleft', style({ opacity: 0 })),\r\n  transition('void=>inleft', [style({ opacity: 1 })]),\r\n  transition('void=>outleft', [style({ opacity: 0 })]),\r\n\r\n  transition('*=>inright', [\r\n    style({ opacity: 0 }),\r\n    animate('160ms ease-in', style({ opacity: 1 })),\r\n  ]),\r\n  transition('*=>inleft', [\r\n    style({ opacity: 0 }),\r\n    animate('160ms ease-in', style({ opacity: 1 })),\r\n  ]),\r\n  transition('*=>outleft', [\r\n    animate('160ms ease-in', style({ opacity: 0 })),\r\n  ]),\r\n  transition('*=>outright', [\r\n    animate('160ms ease-in', style({ opacity: 0 })),\r\n  ]),\r\n];\r\n\r\nconst animationThumbnail = [\r\n  state('true', style({ transform: `translateX({{margin}})` }), {\r\n    params: { margin: 0 },\r\n  }),\r\n  state('false', style({ transform: `translateX({{margin}})` }), {\r\n    params: { margin: 0 },\r\n  }),\r\n  transition('true<=>false', [animate('260ms ease-in')]),\r\n];\r\n\r\n@Component({\r\n  selector: 'wapp-carousel',\r\n  templateUrl: './carousel.component.html',\r\n  styleUrls: ['./carousel.component.css'],\r\n  animations: [\r\n    trigger('animImageSlider', animationCarouselFade),\r\n    trigger('animationThumbnail', animationThumbnail),\r\n  ],\r\n})\r\nexport class CarouselComponent implements OnInit, OnChanges {\r\n@ViewChild('thumbnail', { static: true }) thumbnail!: ElementRef;\r\n  @Input() set images(value) {\r\n    this._images = value;\r\n    this.slideControl = value.map((x:any, index:any) => (index ? 'outleft' : 'inleft'));\r\n  }\r\n  // TODO properly implement allow thumbnail functionality\r\n  @Input(\"allowThumbnail\") allowThumbnail: boolean = false;\r\n  @Input(\"infiniteCarousel\") infiniteCarousel: boolean = false;\r\n  @Input(\"forceMobile\") forceMobile: boolean = false;\r\n\r\n  get images() {\r\n    return this._images\r\n  }\r\n\r\n  @Input() height = 0;\r\n  counter: number = 0;\r\n  _images: any;\r\n  slideControl!: any[];\r\n  width: number = 0;\r\n  counterThumb: number = 0;\r\n  thumbnailMargin: number = 0;\r\n  thumbnailMarginRigth: number = 2;\r\n  thumbnailWidth: number = 60;\r\n  thumbnailAnimation: boolean | null = null;\r\n\r\n  resizeSub!: Subscription;\r\n  posIni: any;\r\n  showNavigation: boolean = false;\r\n  showIndicators: boolean = false;\r\n  isDesktop: boolean = false;\r\n  hasMultipleImages: boolean = false;\r\n\r\n  @Input() isDevModeActive: boolean = false; \r\n  @Input() isNoImage: boolean = false;\r\n  @Output() onSetImageEvent = new EventEmitter<boolean>();\r\n  @Input() onHoverImageTooltip!: any;\r\n\r\n  constructor(private deviceDetector: DeviceDetectorService,) { }\r\n\r\n  ngOnInit() {\r\n    if (this.deviceDetector.isDesktop() != null)\r\n      this.isDesktop = this.deviceDetector.isDesktop();\r\n\r\n    if (this.allowThumbnail) {\r\n      this.resizeSub = fromEvent(window, 'resize')\r\n        .pipe(debounceTime(200))\r\n        .subscribe((_) => this.posThumbnail(this.counter));\r\n    }\r\n\r\n    if (this.images.length > 1) {\r\n      this.showNavigation = true;\r\n      this.showIndicators = true;\r\n      this.hasMultipleImages = true;\r\n    }\r\n\r\n    if (this.isDesktop == false)\r\n      this.showNavigation = false;\r\n\r\n    if(this.isDevModeActive == false){\r\n      this.onHoverImageTooltip = null;\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void { \r\n    if(changes['images'] && changes['images'].currentValue){\r\n      this.images = changes['images'].currentValue;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.allowThumbnail) {\r\n      this.resizeSub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  move(pos: any) {\r\n    if (this.hasMultipleImages) {\r\n      const offset = this.posIni - pos;\r\n      if (offset < -100) this.change('right');\r\n\r\n      if (offset > 100) this.change('left');\r\n    }\r\n  }\r\n\r\n  // call this instead of onNext/onPrevious for infinite carousel\r\n  change(direction: string) {\r\n    const incr = direction == 'right' ? -1 : +1;\r\n    const prev = this.counter;\r\n    this.counter = (this.counter + this.images.length + incr) % this.images.length;\r\n    this.onSlide(this.counter, prev, direction);\r\n    this.slideControl[prev] = 'out' + direction\r\n  }\r\n\r\n  setIndex(index: number) {\r\n    if (index != this.counter) {\r\n      const prev = this.counter;\r\n      this.counter = index;\r\n      const direction = prev > index ? 'right' : 'left';\r\n      this.onSlide(this.counter, prev, direction);\r\n    }\r\n  }\r\n\r\n  onLoad(el: any) {\r\n    this.width = el.getBoundingClientRect().width;\r\n  }\r\n\r\n  onNext() {\r\n    if (this.counter != this.images.length - 1) {\r\n      this.counter++;\r\n      this.onSlide(this.counter, this.counter - 1, 'left')\r\n    }\r\n  }\r\n\r\n  onPrevious() {\r\n    if (this.counter > 0) {\r\n      this.counter--;\r\n      this.onSlide(this.counter, this.counter + 1, 'right')\r\n    }\r\n  }\r\n\r\n  onSlide(current: any, prev: any, direction: any) {\r\n    if (this.hasMultipleImages) {\r\n      this.slideControl[current] = 'in' + direction;\r\n      this.slideControl[prev] = 'out' + direction;\r\n\r\n      if (this.allowThumbnail) {\r\n        this.posThumbnail(current);\r\n      }\r\n    }\r\n  }\r\n\r\n  // TODO old method\r\n  onSlideOld(current: any, prev: any, direction: any) {\r\n    this.slideControl = this.slideControl.map((x, index) => {\r\n      return (index == current) ? 'in' + direction :\r\n        (index == prev) ? 'out' + direction : x\r\n    })\r\n  }\r\n\r\n  onLoadThumbnail() {\r\n    this.counterThumb++;\r\n    if (this.counterThumb == this.images.length) this.posThumbnail(0);\r\n  }\r\n\r\n  posThumbnail(current: number) {\r\n    const width = this.thumbnailWidth + this.thumbnailMarginRigth;\r\n    const widthWrapper =\r\n      this.thumbnail.nativeElement.getBoundingClientRect().width;\r\n\r\n    let newMargin: number = 0;\r\n    if (widthWrapper > width * this.images.length)\r\n      newMargin = (widthWrapper - width * this.images.length) / 2;\r\n    else {\r\n      const middle = widthWrapper / 2 - width * current;\r\n      const min = widthWrapper - width * this.images.length;\r\n\r\n      newMargin = Math.floor(middle > 0 ? 0 : middle < min ? min : middle);\r\n    }\r\n    if (newMargin != this.thumbnailMargin) {\r\n      this.thumbnailMargin = newMargin;\r\n      this.thumbnailAnimation = !this.thumbnailAnimation;\r\n    }\r\n  }\r\n\r\n  onSetImage(){\r\n    this.onSetImageEvent.emit(true);\r\n  }\r\n}\r\n","<div class=\"carousel-container\"\r\n     [style.height.px]=\"height?height:null\"\r\n     [style.margin-bottom]=\"height?'.25rem':null\"\r\n     (touchstart)=\"posIni = $event.changedTouches[0].pageX\"\r\n     (touchend)=\"move($event.changedTouches[0].pageX)\">\r\n  <div *ngIf=\"forceMobile\" class=\"carousel-top-left-icon\">\r\n    <svg width=\"30\" height=\"30\" viewBox=\"0 0 30 30\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n      <rect width=\"30\" height=\"30\" rx=\"15\" fill=\"white\" fill-opacity=\"0.63\"/>\r\n      <path d=\"M20.8337 15H9.16699\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n      <path d=\"M13.2503 19.0807L9.16699 14.9974L13.2503 10.9141\" stroke=\"#1F2224\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n    </svg>\r\n  </div>\r\n  <!--carousel image container-->\r\n  <div class=\"carousel-image-container\"\r\n       [ngClass]=\"height ? 'fixed-height' : null\"\r\n       *ngFor=\"let img of images; let i = index; let first = first\"\r\n       [@animImageSlider]=\"slideControl[i]\" (click)=\"isDevModeActive ? onSetImage() : ''\" [pTooltip]=\"onHoverImageTooltip\" tooltipPosition=\"top\">\r\n    <!--carousel image-->\r\n    <img #slide (load)=\"first && onLoad(slide)\" \r\n      [ngClass]=\"{'default-image' : isNoImage, 'edit-image' : isDevModeActive}\"\r\n      [src]=\"img.path\"/>\r\n  </div>\r\n  <!--previous button-->\r\n  <button type=\"button\"\r\n          class=\"carousel-previous-button\"\r\n          (click)=\"change('right')\"\r\n          *ngIf=\"showNavigation\">\r\n    <span class=\"carousel-previous-icon\"></span>\r\n  </button>\r\n  <!--next button-->\r\n  <button type=\"button\"\r\n          class=\"carousel-next-button\"\r\n          (click)=\"change('left')\"\r\n          *ngIf=\"showNavigation\">\r\n    <span class=\"carousel-next-icon\"></span>\r\n  </button>\r\n  <!--button indicators-->\r\n  <div class=\"carousel-indicator-container\" *ngIf=\"showIndicators\">\r\n    <div class=\"carousel-indicator-buttons\">\r\n      <button *ngFor=\"let img of images; let i = index\"\r\n              [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n              (click)=\"setIndex(i)\"></button>\r\n    </div>\r\n  </div>\r\n</div>\r\n<!--thumbnail indicators-->\r\n<div #thumbnail class=\"carousel-thumbnail-container\" *ngIf=\"allowThumbnail\">\r\n  <div class=\"carousel-thumbnails\"\r\n       [@animationThumbnail]=\"{\r\n        value: thumbnailAnimation,\r\n        params: { margin: thumbnailMargin + 'px' }}\">\r\n    <img *ngFor=\"let img of images; let i = index\"\r\n         [style.width.px]=\"thumbnailWidth\"\r\n         [style.margin-right.px]=\"thumbnailMarginRigth\"\r\n         [style.opacity]=\"i == counter ? 1 : 0.5\"\r\n         (load)=\"onLoadThumbnail()\"\r\n         (click)=\"setIndex(i)\"\r\n         [src]=\"img.path\" />\r\n  </div>\r\n</div>\r\n"]}