UNPKG

@spartacus/storefront

Version:

Spartacus Storefront is a package that you can include in your application, which allows you to add default storefront features.

112 lines 24.3 kB
import { ChangeDetectionStrategy, Component, } from '@angular/core'; import { GlobalMessageType, isNotNullable, NotificationType, OCC_USER_ID_ANONYMOUS, } from '@spartacus/core'; import { combineLatest, Subscription } from 'rxjs'; import { filter, first, map, tap } from 'rxjs/operators'; import { StockNotificationDialogComponent } from './stock-notification-dialog/stock-notification-dialog.component'; import * as i0 from "@angular/core"; import * as i1 from "../current-product.service"; import * as i2 from "@spartacus/core"; import * as i3 from "../../../shared/components/modal/modal.service"; import * as i4 from "../../../shared/components/spinner/spinner.component"; import * as i5 from "@angular/common"; import * as i6 from "@angular/router"; export class StockNotificationComponent { constructor(currentProductService, globalMessageService, translationService, interestsService, modalService, notificationPrefService, userIdService) { this.currentProductService = currentProductService; this.globalMessageService = globalMessageService; this.translationService = translationService; this.interestsService = interestsService; this.modalService = modalService; this.notificationPrefService = notificationPrefService; this.userIdService = userIdService; this.anonymous = true; this.enabledPrefs = []; this.subscriptions = new Subscription(); } ngOnInit() { this.outOfStock$ = combineLatest([ this.currentProductService.getProduct().pipe(filter(isNotNullable)), this.userIdService.getUserId(), ]).pipe(tap(([product, userId]) => { this.productCode = product.code; if (userId !== OCC_USER_ID_ANONYMOUS) { this.anonymous = false; this.notificationPrefService.loadPreferences(); this.interestsService.loadProductInterests(null, null, null, product.code, NotificationType.BACK_IN_STOCK); } }), map(([product]) => !!product.stock && product.stock.stockLevelStatus === 'outOfStock')); this.hasProductInterests$ = this.interestsService .getProductInterests() .pipe(map((interests) => !!interests.results && interests.results.length === 1)); this.subscribeSuccess$ = this.interestsService.getAddProductInterestSuccess(); this.isRemoveInterestLoading$ = this.interestsService.getRemoveProdutInterestLoading(); this.prefsEnabled$ = this.notificationPrefService .getEnabledPreferences() .pipe(tap((prefs) => (this.enabledPrefs = prefs)), map((prefs) => prefs.length > 0)); this.subscriptions.add(this.interestsService.getAddProductInterestError().subscribe((error) => { if (error) { this.onInterestAddingError(); } })); this.subscriptions.add(this.interestsService .getRemoveProdutInterestSuccess() .subscribe((success) => { if (success) { this.onInterestRemovingSuccess(); } })); } subscribe() { this.openDialog(); this.interestsService.addProductInterest(this.productCode, NotificationType.BACK_IN_STOCK); } unsubscribe() { this.interestsService.removeProdutInterest({ product: { code: this.productCode, }, productInterestEntry: [ { interestType: NotificationType.BACK_IN_STOCK, }, ], }, true); } onInterestRemovingSuccess() { this.subscriptions.add(this.translationService .translate('stockNotification.unsubscribeSuccess') .pipe(first()) .subscribe((text) => this.globalMessageService.add(text, GlobalMessageType.MSG_TYPE_INFO))); this.interestsService.resetRemoveInterestState(); } onInterestAddingError() { this.modalService.dismissActiveModal(); this.interestsService.resetAddInterestState(); } openDialog() { const modalInstance = this.modalService.open(StockNotificationDialogComponent, { centered: true, size: 'lg', }).componentInstance; modalInstance.subscribeSuccess$ = this.subscribeSuccess$; modalInstance.enabledPrefs = this.enabledPrefs; } ngOnDestroy() { this.subscriptions.unsubscribe(); this.interestsService.clearProductInterests(); this.notificationPrefService.clearPreferences(); } } StockNotificationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: StockNotificationComponent, deps: [{ token: i1.CurrentProductService }, { token: i2.GlobalMessageService }, { token: i2.TranslationService }, { token: i2.UserInterestsService }, { token: i3.ModalService }, { token: i2.UserNotificationPreferenceService }, { token: i2.UserIdService }], target: i0.ɵɵFactoryTarget.Component }); StockNotificationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: StockNotificationComponent, selector: "cx-stock-notification", ngImport: i0, template: "<ng-container *ngIf=\"outOfStock$ | async\">\n <ng-container *ngIf=\"!(hasProductInterests$ | async); else stopNotify\">\n <ng-container *ngIf=\"prefsEnabled$ | async; else disableNotify\">\n <div class=\"stock-notification-notes\">\n <p>{{ 'stockNotification.getNotified' | cxTranslate }}</p>\n </div>\n <button\n class=\"btn btn-primary btn-block btn-notify\"\n type=\"button\"\n (click)=\"subscribe()\"\n >\n {{ 'stockNotification.notifyMe' | cxTranslate }}\n </button>\n </ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template #disableNotify>\n <div class=\"stock-notification-notes\" id=\"outOfStockMessage\">\n <p>\n <ng-container *ngIf=\"anonymous; else loggedIn\">\n <a [routerLink]=\"{ cxRoute: 'login' } | cxUrl\">\n {{ 'miniLogin.signInRegister' | cxTranslate }}</a\n >\n {{ 'stockNotification.getNotifySuffix' | cxTranslate }}<br />\n </ng-container>\n <ng-template #loggedIn>\n {{ 'stockNotification.getNotify' | cxTranslate }}<br />\n {{ 'stockNotification.activateChannelsPrefix' | cxTranslate\n }}<a [routerLink]=\"['/my-account/notification-preference']\">{{\n 'stockNotification.channelsLink' | cxTranslate\n }}</a\n >{{ 'stockNotification.activateChannelsSuffix' | cxTranslate }}\n </ng-template>\n </p>\n </div>\n <button\n class=\"btn btn-primary btn-block btn-notify\"\n type=\"button\"\n disabled=\"true\"\n aria-describedby=\"outOfStockMessage\"\n >\n {{ 'stockNotification.notifyMe' | cxTranslate }}\n </button>\n</ng-template>\n\n<ng-template #stopNotify>\n <ng-container *ngIf=\"!(isRemoveInterestLoading$ | async); else loading\">\n <div class=\"stock-notification-notes\">\n <p>{{ 'stockNotification.notified' | cxTranslate }}</p>\n </div>\n <button\n class=\"btn btn-primary btn-block btn-stop-notify\"\n type=\"button\"\n (click)=\"unsubscribe()\"\n >\n {{ 'stockNotification.stopNotify' | cxTranslate }}\n </button>\n </ng-container>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"cx-dialog-body modal-body\">\n <div class=\"cx-dialog-row\">\n <div class=\"col-sm-12\">\n <cx-spinner></cx-spinner>\n </div>\n </div>\n </div>\n</ng-template>\n", components: [{ type: i4.SpinnerComponent, selector: "cx-spinner" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }], pipes: { "async": i5.AsyncPipe, "cxTranslate": i2.TranslatePipe, "cxUrl": i2.UrlPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: StockNotificationComponent, decorators: [{ type: Component, args: [{ selector: 'cx-stock-notification', templateUrl: './stock-notification.component.html', changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: function () { return [{ type: i1.CurrentProductService }, { type: i2.GlobalMessageService }, { type: i2.TranslationService }, { type: i2.UserInterestsService }, { type: i3.ModalService }, { type: i2.UserNotificationPreferenceService }, { type: i2.UserIdService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stock-notification.component.js","sourceRoot":"","sources":["../../../../../../projects/storefrontlib/cms-components/product/stock-notification/stock-notification.component.ts","../../../../../../projects/storefrontlib/cms-components/product/stock-notification/stock-notification.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,GAGV,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,iBAAiB,EACjB,aAAa,EAEb,gBAAgB,EAChB,qBAAqB,GAMtB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,aAAa,EAAc,YAAY,EAAE,MAAM,MAAM,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAGzD,OAAO,EAAE,gCAAgC,EAAE,MAAM,iEAAiE,CAAC;;;;;;;;AAOnH,MAAM,OAAO,0BAA0B;IAYrC,YACU,qBAA4C,EAC5C,oBAA0C,EAC1C,kBAAsC,EACtC,gBAAsC,EACtC,YAA0B,EAC1B,uBAA0D,EAC1D,aAA4B;QAN5B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB,CAAsB;QACtC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,4BAAuB,GAAvB,uBAAuB,CAAmC;QAC1D,kBAAa,GAAb,aAAa,CAAe;QAdtC,cAAS,GAAG,IAAI,CAAC;QAET,iBAAY,GAA6B,EAAE,CAAC;QAG5C,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAUxC,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC;YAC/B,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YACnE,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE;SAC/B,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,EAAE;YACxB,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;YAChC,IAAI,MAAM,KAAK,qBAAqB,EAAE;gBACpC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,IAAI,CAAC,uBAAuB,CAAC,eAAe,EAAE,CAAC;gBAC/C,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CACxC,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,OAAO,CAAC,IAAI,EACZ,gBAAgB,CAAC,aAAa,CAC/B,CAAC;aACH;QACH,CAAC,CAAC,EACF,GAAG,CACD,CAAC,CAAC,OAAO,CAAoB,EAAE,EAAE,CAC/B,CAAC,CAAC,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,gBAAgB,KAAK,YAAY,CACrE,CACF,CAAC;QAEF,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,gBAAgB;aAC9C,mBAAmB,EAAE;aACrB,IAAI,CACH,GAAG,CACD,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,CACrE,CACF,CAAC;QACJ,IAAI,CAAC,iBAAiB;YACpB,IAAI,CAAC,gBAAgB,CAAC,4BAA4B,EAAE,CAAC;QACvD,IAAI,CAAC,wBAAwB;YAC3B,IAAI,CAAC,gBAAgB,CAAC,8BAA8B,EAAE,CAAC;QACzD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,uBAAuB;aAC9C,qBAAqB,EAAE;aACvB,IAAI,CACH,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,CAAC,EAC3C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CACjC,CAAC;QAEJ,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,gBAAgB,CAAC,0BAA0B,EAAE,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACrE,IAAI,KAAK,EAAE;gBACT,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;QACH,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,gBAAgB;aAClB,8BAA8B,EAAE;aAChC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACrB,IAAI,OAAO,EAAE;gBACX,IAAI,CAAC,yBAAyB,EAAE,CAAC;aAClC;QACH,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAED,SAAS;QACP,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CACtC,IAAI,CAAC,WAAW,EAChB,gBAAgB,CAAC,aAAa,CAC/B,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CACxC;YACE,OAAO,EAAE;gBACP,IAAI,EAAE,IAAI,CAAC,WAAW;aACvB;YACD,oBAAoB,EAAE;gBACpB;oBACE,YAAY,EAAE,gBAAgB,CAAC,aAAa;iBAC7C;aACF;SACF,EACD,IAAI,CACL,CAAC;IACJ,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,kBAAkB;aACpB,SAAS,CAAC,sCAAsC,CAAC;aACjD,IAAI,CAAC,KAAK,EAAE,CAAC;aACb,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAClB,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,IAAI,EAAE,iBAAiB,CAAC,aAAa,CAAC,CACrE,CACJ,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,wBAAwB,EAAE,CAAC;IACnD,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE,CAAC;QACvC,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,EAAE,CAAC;IAChD,CAAC;IAEO,UAAU;QAChB,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAC1C,gCAAgC,EAChC;YACE,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;SACX,CACF,CAAC,iBAAiB,CAAC;QACpB,aAAa,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;QACzD,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;IACjD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,EAAE,CAAC;QAC9C,IAAI,CAAC,uBAAuB,CAAC,gBAAgB,EAAE,CAAC;IAClD,CAAC;;uHA5IU,0BAA0B;2GAA1B,0BAA0B,6DC9BvC,gzEAsEA;2FDxCa,0BAA0B;kBALtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,WAAW,EAAE,qCAAqC;oBAClD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport {\n  GlobalMessageService,\n  GlobalMessageType,\n  isNotNullable,\n  NotificationPreference,\n  NotificationType,\n  OCC_USER_ID_ANONYMOUS,\n  Product,\n  TranslationService,\n  UserIdService,\n  UserInterestsService,\n  UserNotificationPreferenceService,\n} from '@spartacus/core';\nimport { combineLatest, Observable, Subscription } from 'rxjs';\nimport { filter, first, map, tap } from 'rxjs/operators';\nimport { ModalService } from '../../../shared/components/modal/modal.service';\nimport { CurrentProductService } from '../current-product.service';\nimport { StockNotificationDialogComponent } from './stock-notification-dialog/stock-notification-dialog.component';\n\n@Component({\n  selector: 'cx-stock-notification',\n  templateUrl: './stock-notification.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class StockNotificationComponent implements OnInit, OnDestroy {\n  hasProductInterests$: Observable<boolean>;\n  prefsEnabled$: Observable<boolean>;\n  outOfStock$: Observable<boolean>;\n  isRemoveInterestLoading$: Observable<boolean>;\n  anonymous = true;\n\n  private enabledPrefs: NotificationPreference[] = [];\n  private productCode: string;\n  private subscribeSuccess$: Observable<boolean>;\n  private subscriptions = new Subscription();\n\n  constructor(\n    private currentProductService: CurrentProductService,\n    private globalMessageService: GlobalMessageService,\n    private translationService: TranslationService,\n    private interestsService: UserInterestsService,\n    private modalService: ModalService,\n    private notificationPrefService: UserNotificationPreferenceService,\n    private userIdService: UserIdService\n  ) {}\n\n  ngOnInit() {\n    this.outOfStock$ = combineLatest([\n      this.currentProductService.getProduct().pipe(filter(isNotNullable)),\n      this.userIdService.getUserId(),\n    ]).pipe(\n      tap(([product, userId]) => {\n        this.productCode = product.code;\n        if (userId !== OCC_USER_ID_ANONYMOUS) {\n          this.anonymous = false;\n          this.notificationPrefService.loadPreferences();\n          this.interestsService.loadProductInterests(\n            null,\n            null,\n            null,\n            product.code,\n            NotificationType.BACK_IN_STOCK\n          );\n        }\n      }),\n      map(\n        ([product]: [Product, String]) =>\n          !!product.stock && product.stock.stockLevelStatus === 'outOfStock'\n      )\n    );\n\n    this.hasProductInterests$ = this.interestsService\n      .getProductInterests()\n      .pipe(\n        map(\n          (interests) => !!interests.results && interests.results.length === 1\n        )\n      );\n    this.subscribeSuccess$ =\n      this.interestsService.getAddProductInterestSuccess();\n    this.isRemoveInterestLoading$ =\n      this.interestsService.getRemoveProdutInterestLoading();\n    this.prefsEnabled$ = this.notificationPrefService\n      .getEnabledPreferences()\n      .pipe(\n        tap((prefs) => (this.enabledPrefs = prefs)),\n        map((prefs) => prefs.length > 0)\n      );\n\n    this.subscriptions.add(\n      this.interestsService.getAddProductInterestError().subscribe((error) => {\n        if (error) {\n          this.onInterestAddingError();\n        }\n      })\n    );\n    this.subscriptions.add(\n      this.interestsService\n        .getRemoveProdutInterestSuccess()\n        .subscribe((success) => {\n          if (success) {\n            this.onInterestRemovingSuccess();\n          }\n        })\n    );\n  }\n\n  subscribe() {\n    this.openDialog();\n    this.interestsService.addProductInterest(\n      this.productCode,\n      NotificationType.BACK_IN_STOCK\n    );\n  }\n\n  unsubscribe() {\n    this.interestsService.removeProdutInterest(\n      {\n        product: {\n          code: this.productCode,\n        },\n        productInterestEntry: [\n          {\n            interestType: NotificationType.BACK_IN_STOCK,\n          },\n        ],\n      },\n      true\n    );\n  }\n\n  private onInterestRemovingSuccess() {\n    this.subscriptions.add(\n      this.translationService\n        .translate('stockNotification.unsubscribeSuccess')\n        .pipe(first())\n        .subscribe((text) =>\n          this.globalMessageService.add(text, GlobalMessageType.MSG_TYPE_INFO)\n        )\n    );\n    this.interestsService.resetRemoveInterestState();\n  }\n\n  private onInterestAddingError() {\n    this.modalService.dismissActiveModal();\n    this.interestsService.resetAddInterestState();\n  }\n\n  private openDialog() {\n    const modalInstance = this.modalService.open(\n      StockNotificationDialogComponent,\n      {\n        centered: true,\n        size: 'lg',\n      }\n    ).componentInstance;\n    modalInstance.subscribeSuccess$ = this.subscribeSuccess$;\n    modalInstance.enabledPrefs = this.enabledPrefs;\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n    this.interestsService.clearProductInterests();\n    this.notificationPrefService.clearPreferences();\n  }\n}\n","<ng-container *ngIf=\"outOfStock$ | async\">\n  <ng-container *ngIf=\"!(hasProductInterests$ | async); else stopNotify\">\n    <ng-container *ngIf=\"prefsEnabled$ | async; else disableNotify\">\n      <div class=\"stock-notification-notes\">\n        <p>{{ 'stockNotification.getNotified' | cxTranslate }}</p>\n      </div>\n      <button\n        class=\"btn btn-primary btn-block btn-notify\"\n        type=\"button\"\n        (click)=\"subscribe()\"\n      >\n        {{ 'stockNotification.notifyMe' | cxTranslate }}\n      </button>\n    </ng-container>\n  </ng-container>\n</ng-container>\n\n<ng-template #disableNotify>\n  <div class=\"stock-notification-notes\" id=\"outOfStockMessage\">\n    <p>\n      <ng-container *ngIf=\"anonymous; else loggedIn\">\n        <a [routerLink]=\"{ cxRoute: 'login' } | cxUrl\">\n          {{ 'miniLogin.signInRegister' | cxTranslate }}</a\n        >\n        {{ 'stockNotification.getNotifySuffix' | cxTranslate }}<br />\n      </ng-container>\n      <ng-template #loggedIn>\n        {{ 'stockNotification.getNotify' | cxTranslate }}<br />\n        {{ 'stockNotification.activateChannelsPrefix' | cxTranslate\n        }}<a [routerLink]=\"['/my-account/notification-preference']\">{{\n          'stockNotification.channelsLink' | cxTranslate\n        }}</a\n        >{{ 'stockNotification.activateChannelsSuffix' | cxTranslate }}\n      </ng-template>\n    </p>\n  </div>\n  <button\n    class=\"btn btn-primary btn-block btn-notify\"\n    type=\"button\"\n    disabled=\"true\"\n    aria-describedby=\"outOfStockMessage\"\n  >\n    {{ 'stockNotification.notifyMe' | cxTranslate }}\n  </button>\n</ng-template>\n\n<ng-template #stopNotify>\n  <ng-container *ngIf=\"!(isRemoveInterestLoading$ | async); else loading\">\n    <div class=\"stock-notification-notes\">\n      <p>{{ 'stockNotification.notified' | cxTranslate }}</p>\n    </div>\n    <button\n      class=\"btn btn-primary btn-block btn-stop-notify\"\n      type=\"button\"\n      (click)=\"unsubscribe()\"\n    >\n      {{ 'stockNotification.stopNotify' | cxTranslate }}\n    </button>\n  </ng-container>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"cx-dialog-body modal-body\">\n    <div class=\"cx-dialog-row\">\n      <div class=\"col-sm-12\">\n        <cx-spinner></cx-spinner>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}