ngx-wapp-components 2.1.13 → 2.1.14

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.
@@ -121,7 +121,7 @@ export class WMaterialServiceCardComponent {
121
121
  }
122
122
  else {
123
123
  this.isNoImage = true;
124
- return './../../../assets/wappIcons/image.svg';
124
+ return './assets/wappIcons/image.svg';
125
125
  }
126
126
  }
127
127
  else {
@@ -135,7 +135,7 @@ export class WMaterialServiceCardComponent {
135
135
  }
136
136
  else {
137
137
  this.isNoImage = true;
138
- return './../../../assets/wappIcons/image.svg';
138
+ return './assets/wappIcons/image.svg';
139
139
  }
140
140
  }
141
141
  }
@@ -169,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
169
169
  }], onHoverImageTooltip: [{
170
170
  type: Input
171
171
  }] } });
172
- //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAiB,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,UAAU,EAAE,aAAa,EAA6B,MAAM,8BAA8B,CAAC;AASpG,OAAO,EAAE,sBAAsB,EAAE,MAAM,sDAAsD,CAAC;;;;;;;;;;AAS9F,MAAM,OAAO,6BAA6B;IAqBxC,IAAa,2BAA2B,CAAC,KAAiC;QACxE,IAAG,KAAK;YAAE,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;IAC9C,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAID,IAAa,cAAc,CAAC,KAAqB;QAC/C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAG,KAAK;YAAE,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAkBD,YACU,eAAgC,EAChC,YAA0B,EAC1B,aAA4B;QAF5B,oBAAe,GAAf,eAAe,CAAiB;QAChC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,kBAAa,GAAb,aAAa,CAAe;QA1D7B,oBAAe,GAAY,KAAK,CAAC;QAC1C,mBAAc,GAAY,KAAK,CAAC;QAChC,4BAAuB,GAAY,IAAI,CAAC;QAExC,sBAAiB,GAA0B,aAAa,CAAC;QACzD,gBAAW,GAAsB,UAAU,CAAC;QAE5C,wBAAmB,GAAY,KAAK,CAAC;QACrC,cAAS,GAAY,KAAK,CAAC;QAEnB,yBAAoB,GAA+B;YACzD,cAAc,EAAE,UAAU;YAC1B,eAAe,EAAE,aAAa;YAC9B,cAAc,EAAE,mCAAmC;YACnD,SAAS,EAAE,oBAAoB;YAC/B,aAAa,EAAE,gEAAgE;YAC/E,aAAa,EAAE,sBAAsB;YACrC,QAAQ,EAAE,aAAa;SACxB,CAAC;QAqBqB,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QAG/D,8BAAyB,GAAsB;YACtD,cAAc,EAAE,KAAK;YACrB,qBAAqB,EAAE,CAAC,GAAC,CAAC;YAC1B,eAAe,EAAE,GAAG;YACpB,eAAe,EAAE,GAAG;YACpB,WAAW,EAAE,IAAI;SAClB,CAAC;QAGQ,wBAAmB,GAAG,IAAI,YAAY,EAAY,CAAC;QAC7D,cAAS,GAAY,KAAK,CAAC;QAClB,wBAAmB,GAAQ,cAAc,CAAC;QAOjD,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,gCAAgC,CAAC,CAAC,CAAC;QACjI,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,kCAAkC,CAAC,CAAC,CAAC;IACvI,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAG,OAAO,CAAC,gBAAgB,CAAC,IAAI,OAAO,CAAC,gBAAgB,CAAC,CAAC,YAAY,EAAC;YACrE,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAA;SAC7D;QAED,IAAG,OAAO,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,EAAC;YACjE,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC;SAC1D;IACH,CAAC;IAED,uBAAuB,CAAC,OAAuB;QAC7C,IAAI,OAAO,CAAC,uBAAuB,IAAI,IAAI,EAAE;YAC3C,OAAO,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC,sBAA8C,EAAE,EAAE;gBACzF,IAAI,sBAAsB,CAAC,aAAa,IAAI,sBAAsB,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,EAAE,EAAC;oBAC7F,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,sBAAsB,CAAC,aAAa,CAAC,CAAC;iBACjG;qBAAM;oBACL,OAAO,CAAC,KAAK,GAAG,EAAE,CAAC;iBACpB;gBAED,IAAI,sBAAsB,CAAC,WAAW,IAAI,sBAAsB,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,EAAE,EAAC;oBACzF,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,sBAAsB,CAAC,WAAW,CAAC,CAAC;iBAC/F;qBAAM;oBACL,OAAO,CAAC,KAAK,GAAG,EAAE,CAAC;iBACpB;YAEH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;SACjC;IACH,CAAC;IAED,WAAW,CAAC,OAAuB;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,OAAO,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,QAAQ;QACN,MAAM,GAAG,GAAqB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,EAAE;YAC5E,MAAM,EAAE,IAAI,CAAC,yBAAyB,EAAE,KAAK,CAAC,MAAM;YACpD,KAAK,EAAE,OAAO;YACd,YAAY,EAAE,EAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAC;YAC7E,IAAI,EAAE,EAAC,SAAS,EAAE,IAAI,CAAC,yBAAyB,EAAE,YAAY,EAAE,IAAI,CAAC,yBAAyB,EAAC;YAC/F,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;QAEH,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,YAAsB,EAAE,EAAE;YAC/C,IAAG,YAAY,EAAC;gBACd,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;gBACjC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClD;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAG,IAAI,CAAC,eAAe,IAAI,IAAI,EAAC;YAC9B,IAAG,IAAI,CAAC,YAAY,EAAC;gBACnB,IAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,EAAC;oBACtC,OAAQ,IAAI,CAAC,YAAyB,CAAC,UAAU,CAAC;iBACnD;qBAAI;oBACH,OAAO,IAAI,CAAC,YAAY,CAAC;iBAC1B;aACF;iBAAI;gBACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gBACtB,OAAO,uCAAuC,CAAC;aAChD;SACF;aAAI;YACH,IAAG,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAC;gBACrD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;gBAChC,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;aACrC;iBAAI;gBACH,IAAG,IAAI,CAAC,YAAY,EAAC;oBACnB,OAAO,IAAI,CAAC,YAAY,CAAC;iBAC1B;qBAAI;oBACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBACtB,OAAO,uCAAuC,CAAC;iBAChD;aACF;SACF;IACH,CAAC;IAED,YAAY,CAAC,GAAsB;QACjC,OAAQ,GAAgB,CAAC,MAAM,KAAK,SAAS,CAAC;IAChD,CAAC;;2HAtJU,6BAA6B;+GAA7B,6BAA6B,ifCnB1C,imEAuCA;4FDpBa,6BAA6B;kBALzC,SAAS;+BACE,yBAAyB;6JAK1B,eAAe;sBAAvB,KAAK;gBAoBO,2BAA2B;sBAAvC,KAAK;gBAUO,cAAc;sBAA1B,KAAK;gBASiB,WAAW;sBAAjC,MAAM;uBAAC,aAAa;gBAEZ,YAAY;sBAApB,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBAQG,yBAAyB;sBAAjC,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBAEE,mBAAmB;sBAA3B,KAAK","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 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 class=\"service-card-header\" fxLayout=\"column\" fxLayoutAlign=\"center center\">\r\n    <!-- tile1 -->\r\n    <div *ngIf=\"!hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-image-title\">\r\n      <div class=\"tile-no-html\"\r\n        [innerHtml]=\"wappingService.tile1\"></div>\r\n    </div>\r\n    <div *ngIf=\"hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-card-image-title service-card-image-title-html\"\r\n         fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n      <div 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>\r\n"]}
172
+ //# 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 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 class=\"service-card-header\" fxLayout=\"column\" fxLayoutAlign=\"center center\">\r\n    <!-- tile1 -->\r\n    <div *ngIf=\"!hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-image-title\">\r\n      <div class=\"tile-no-html\"\r\n        [innerHtml]=\"wappingService.tile1\"></div>\r\n    </div>\r\n    <div *ngIf=\"hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-card-image-title service-card-image-title-html\"\r\n         fxLayout=\"row\" fxLayoutGap=\"5px\">\r\n      <div 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>\r\n"]}
@@ -72,7 +72,7 @@ export class WMaterialServiceViewComponent {
72
72
  if (changes['defaultImage'] && !changes['defaultImage'].currentValue) {
73
73
  if (this.isDevModeActive) {
74
74
  this.isNoImage = true;
75
- this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
75
+ this.wappingServiceImages = [{ path: './assets/wappIcons/image.svg' }];
76
76
  }
77
77
  }
78
78
  }
@@ -173,7 +173,7 @@ export class WMaterialServiceViewComponent {
173
173
  }
174
174
  else {
175
175
  this.isNoImage = true;
176
- this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
176
+ this.wappingServiceImages = [{ path: './assets/wappIcons/image.svg' }];
177
177
  }
178
178
  }
179
179
  else {
@@ -244,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
244
244
  }], onHoverImageTooltip: [{
245
245
  type: Input
246
246
  }] } });
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=\"!hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-image-title\">\r\n            <div class=\"service-view-tile1-no-html\" [innerHTML]=\"wappingService.tile1\"></div>\r\n        </div>\r\n        <div *ngIf=\"hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"template-service-image-tile service-card-image-title\">\r\n            <div class=\"service-view-tile1\" [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]=\"{'template-service-tile': hasHtml(wappingService.tile2),\r\n                'service-tile' : !hasHtml(wappingService.tile2)}\"\r\n            *ngIf=\"wappingService.tile2\">\r\n            <div class=\"service-view-tile2\" [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=\"!hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"service-image-title\">\r\n            <div class=\"service-view-tile1-no-html\" [innerHTML]=\"wappingService.tile1\"></div>\r\n        </div>\r\n        <div *ngIf=\"hasHtml(wappingService.tile1) && wappingService.tile1 && wappingService.tile1 != ''\" class=\"template-service-image-tile service-card-image-title\">\r\n            <div class=\"service-view-tile1\" [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]=\"{'template-service-tile': hasHtml(wappingService.tile2),\r\n                'service-tile' : !hasHtml(wappingService.tile2)}\"\r\n            *ngIf=\"wappingService.tile2\">\r\n            <div class=\"service-view-tile2\" [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>"]}
@@ -10169,7 +10169,7 @@ class WMaterialServiceCardComponent {
10169
10169
  }
10170
10170
  else {
10171
10171
  this.isNoImage = true;
10172
- return './../../../assets/wappIcons/image.svg';
10172
+ return './assets/wappIcons/image.svg';
10173
10173
  }
10174
10174
  }
10175
10175
  else {
@@ -10183,7 +10183,7 @@ class WMaterialServiceCardComponent {
10183
10183
  }
10184
10184
  else {
10185
10185
  this.isNoImage = true;
10186
- return './../../../assets/wappIcons/image.svg';
10186
+ return './assets/wappIcons/image.svg';
10187
10187
  }
10188
10188
  }
10189
10189
  }
@@ -10374,7 +10374,7 @@ class WMaterialServiceViewComponent {
10374
10374
  if (changes['defaultImage'] && !changes['defaultImage'].currentValue) {
10375
10375
  if (this.isDevModeActive) {
10376
10376
  this.isNoImage = true;
10377
- this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
10377
+ this.wappingServiceImages = [{ path: './assets/wappIcons/image.svg' }];
10378
10378
  }
10379
10379
  }
10380
10380
  }
@@ -10476,7 +10476,7 @@ class WMaterialServiceViewComponent {
10476
10476
  }
10477
10477
  else {
10478
10478
  this.isNoImage = true;
10479
- this.wappingServiceImages = [{ path: './../../../assets/wappIcons/image.svg' }];
10479
+ this.wappingServiceImages = [{ path: './assets/wappIcons/image.svg' }];
10480
10480
  }
10481
10481
  }
10482
10482
  else {