UNPKG

@spartacus/cdc

Version:

Customer Data Cloud Integration library for Spartacus

104 lines 16.8 kB
import { ChangeDetectionStrategy, Component, ViewEncapsulation, } from '@angular/core'; import { distinctUntilChanged, take, tap } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@spartacus/storefront"; import * as i2 from "@spartacus/core"; import * as i3 from "@spartacus/cdc/root"; import * as i4 from "@angular/common"; export class GigyaRaasComponent { constructor(component, baseSiteService, languageService, cdcConfig, winRef, cdcJSService, zone) { this.component = component; this.baseSiteService = baseSiteService; this.languageService = languageService; this.cdcConfig = cdcConfig; this.winRef = winRef; this.cdcJSService = cdcJSService; this.zone = zone; this.renderScreenSet = true; } ngOnInit() { this.jsLoaded$ = this.cdcJSService.didLoad(); this.jsError$ = this.cdcJSService.didScriptFailToLoad(); this.language$ = this.languageService.getActive().pipe(distinctUntilChanged(), // On language change we want to rerender CDC screen with proper translations tap(() => (this.renderScreenSet = true))); } /** * Display screen set in embed mode * * @param data - GigyaRaasComponentData * @param lang - language */ displayScreenSet(data, lang) { if (this.renderScreenSet) { this.showScreenSet(data, lang); } this.renderScreenSet = false; } /** * Show screen set * * @param data - GigyaRaasComponentData * @param lang - language */ showScreenSet(data, lang) { var _a, _b, _c; (_c = (_b = (_a = this.winRef.nativeWindow) === null || _a === void 0 ? void 0 : _a['gigya']) === null || _b === void 0 ? void 0 : _b.accounts) === null || _c === void 0 ? void 0 : _c.showScreenSet(Object.assign(Object.assign({ screenSet: data.screenSet, startScreen: data.startScreen, lang }, (this.displayInEmbedMode(data) ? { containerID: data.containerID } : {})), (this.isLoginScreenSet(data) ? { sessionExpiration: this.getSessionExpirationValue() } : { onAfterSubmit: (...params) => { this.zone.run(() => this.cdcJSService.onProfileUpdateEventHandler(...params)); }, }))); } isLoginScreenSet(data) { const profileEditScreen = data.profileEdit === 'true' ? true : false; return !profileEditScreen; } getSessionExpirationValue() { var _a; if (((_a = this.cdcConfig) === null || _a === void 0 ? void 0 : _a.cdc) !== undefined) { const filteredConfigs = this.cdcConfig.cdc.filter((conf) => conf.baseSite === this.getCurrentBaseSite()); if (filteredConfigs && filteredConfigs.length > 0) { return filteredConfigs[0].sessionExpiration; } } // Return a default value return 3600; } getCurrentBaseSite() { let baseSite = ''; this.baseSiteService .getActive() .pipe(take(1)) .subscribe((data) => (baseSite = data)); return baseSite; } /** * Check if the component should be displayed in embed mode * * @param data - GigyaRaasComponentData */ displayInEmbedMode(data) { const embedValue = data.embed === 'true' ? true : false; if (embedValue && data.containerID && data.containerID.length > 0) { return true; } return false; } } GigyaRaasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: GigyaRaasComponent, deps: [{ token: i1.CmsComponentData }, { token: i2.BaseSiteService }, { token: i2.LanguageService }, { token: i3.CdcConfig }, { token: i2.WindowRef }, { token: i3.CdcJsService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); GigyaRaasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: GigyaRaasComponent, selector: "cx-gigya-raas", ngImport: i0, template: "<div *ngIf=\"component.data$ | async as data\">\n <div *ngIf=\"jsLoaded$ | async\">\n <div *ngIf=\"language$ | async as lang\">\n <div\n *ngIf=\"displayInEmbedMode(data); else popupLink\"\n [attr.id]=\"data.containerID\"\n >\n {{ displayScreenSet(data, lang) }}\n </div>\n <ng-template #popupLink>\n <a\n class=\"popup-link\"\n [attr.data-cdc-id]=\"data.uid\"\n [attr.data-profile-edit]=\"data.profileEdit\"\n (click)=\"showScreenSet(data, lang)\"\n >{{ data.linkText }}</a\n >\n </ng-template>\n </div>\n </div>\n <div *ngIf=\"jsError$ | async\" class=\"js-error\">\n {{ 'errorHandlers.scriptFailedToLoad' | cxTranslate }}\n {{ 'errorHandlers.refreshThePage' | cxTranslate }}\n </div>\n</div>\n", styles: ["cx-gigya-raas .popup-link{cursor:pointer;color:var(--cx-color-primary)}cx-gigya-raas .js-error{text-align:center;padding:4rem}"], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i4.AsyncPipe, "cxTranslate": i2.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: GigyaRaasComponent, decorators: [{ type: Component, args: [{ selector: 'cx-gigya-raas', templateUrl: './gigya-raas.component.html', styleUrls: ['./gigya-raas.component.scss'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: function () { return [{ type: i1.CmsComponentData }, { type: i2.BaseSiteService }, { type: i2.LanguageService }, { type: i3.CdcConfig }, { type: i2.WindowRef }, { type: i3.CdcJsService }, { type: i0.NgZone }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gigya-raas.component.js","sourceRoot":"","sources":["../../../../../integration-libs/cdc/components/gigya-raas/gigya-raas.component.ts","../../../../../integration-libs/cdc/components/gigya-raas/gigya-raas.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  NgZone,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { GigyaRaasComponentData } from '@spartacus/cdc/core';\nimport { CdcConfig, CdcJsService } from '@spartacus/cdc/root';\nimport { BaseSiteService, LanguageService, WindowRef } from '@spartacus/core';\nimport { CmsComponentData } from '@spartacus/storefront';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, take, tap } from 'rxjs/operators';\n\n@Component({\n  selector: 'cx-gigya-raas',\n  templateUrl: './gigya-raas.component.html',\n  styleUrls: ['./gigya-raas.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class GigyaRaasComponent implements OnInit {\n  protected renderScreenSet = true;\n  language$: Observable<string>;\n  jsError$: Observable<boolean>;\n  jsLoaded$: Observable<boolean>;\n\n  public constructor(\n    public component: CmsComponentData<GigyaRaasComponentData>,\n    private baseSiteService: BaseSiteService,\n    private languageService: LanguageService,\n    private cdcConfig: CdcConfig,\n    private winRef: WindowRef,\n    private cdcJSService: CdcJsService,\n    private zone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    this.jsLoaded$ = this.cdcJSService.didLoad();\n    this.jsError$ = this.cdcJSService.didScriptFailToLoad();\n    this.language$ = this.languageService.getActive().pipe(\n      distinctUntilChanged(),\n      // On language change we want to rerender CDC screen with proper translations\n      tap(() => (this.renderScreenSet = true))\n    );\n  }\n\n  /**\n   * Display screen set in embed mode\n   *\n   * @param data - GigyaRaasComponentData\n   * @param lang - language\n   */\n  displayScreenSet(data: GigyaRaasComponentData, lang: string): void {\n    if (this.renderScreenSet) {\n      this.showScreenSet(data, lang);\n    }\n    this.renderScreenSet = false;\n  }\n\n  /**\n   * Show screen set\n   *\n   * @param data - GigyaRaasComponentData\n   * @param lang - language\n   */\n  showScreenSet(data: GigyaRaasComponentData, lang: string) {\n    (this.winRef.nativeWindow as { [key: string]: any })?.[\n      'gigya'\n    ]?.accounts?.showScreenSet({\n      screenSet: data.screenSet,\n      startScreen: data.startScreen,\n      lang,\n      ...(this.displayInEmbedMode(data)\n        ? { containerID: data.containerID }\n        : {}),\n      ...(this.isLoginScreenSet(data)\n        ? { sessionExpiration: this.getSessionExpirationValue() }\n        : {\n            onAfterSubmit: (...params: any[]) => {\n              this.zone.run(() =>\n                this.cdcJSService.onProfileUpdateEventHandler(...params)\n              );\n            },\n          }),\n    });\n  }\n\n  protected isLoginScreenSet(data: GigyaRaasComponentData): boolean {\n    const profileEditScreen: boolean =\n      data.profileEdit === 'true' ? true : false;\n\n    return !profileEditScreen;\n  }\n\n  protected getSessionExpirationValue(): number {\n    if (this.cdcConfig?.cdc !== undefined) {\n      const filteredConfigs: any = this.cdcConfig.cdc.filter(\n        (conf) => conf.baseSite === this.getCurrentBaseSite()\n      );\n      if (filteredConfigs && filteredConfigs.length > 0) {\n        return filteredConfigs[0].sessionExpiration;\n      }\n    }\n    // Return a default value\n    return 3600;\n  }\n\n  private getCurrentBaseSite(): string {\n    let baseSite: string = '';\n    this.baseSiteService\n      .getActive()\n      .pipe(take(1))\n      .subscribe((data) => (baseSite = data));\n    return baseSite;\n  }\n\n  /**\n   * Check if the component should be displayed in embed mode\n   *\n   * @param data - GigyaRaasComponentData\n   */\n  displayInEmbedMode(data: GigyaRaasComponentData): boolean {\n    const embedValue: boolean = data.embed === 'true' ? true : false;\n    if (embedValue && data.containerID && data.containerID.length > 0) {\n      return true;\n    }\n    return false;\n  }\n}\n","<div *ngIf=\"component.data$ | async as data\">\n  <div *ngIf=\"jsLoaded$ | async\">\n    <div *ngIf=\"language$ | async as lang\">\n      <div\n        *ngIf=\"displayInEmbedMode(data); else popupLink\"\n        [attr.id]=\"data.containerID\"\n      >\n        {{ displayScreenSet(data, lang) }}\n      </div>\n      <ng-template #popupLink>\n        <a\n          class=\"popup-link\"\n          [attr.data-cdc-id]=\"data.uid\"\n          [attr.data-profile-edit]=\"data.profileEdit\"\n          (click)=\"showScreenSet(data, lang)\"\n          >{{ data.linkText }}</a\n        >\n      </ng-template>\n    </div>\n  </div>\n  <div *ngIf=\"jsError$ | async\" class=\"js-error\">\n    {{ 'errorHandlers.scriptFailedToLoad' | cxTranslate }}\n    {{ 'errorHandlers.refreshThePage' | cxTranslate }}\n  </div>\n</div>\n"]}