UNPKG

@spartacus/cdc

Version:

Customer Data Cloud Integration library for Spartacus

151 lines 18.1 kB
import { isPlatformBrowser } from '@angular/common'; import { Inject, Injectable, PLATFORM_ID, } from '@angular/core'; import { combineLatest, ReplaySubject, Subscription } from 'rxjs'; import { take } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "../config/cdc-config"; import * as i2 from "@spartacus/core"; import * as i3 from "../facade/cdc-auth.facade"; import * as i4 from "@spartacus/user/profile/root"; export class CdcJsService { constructor(cdcConfig, baseSiteService, languageService, scriptLoader, winRef, cdcAuth, auth, zone, userProfileFacade, platform) { this.cdcConfig = cdcConfig; this.baseSiteService = baseSiteService; this.languageService = languageService; this.scriptLoader = scriptLoader; this.winRef = winRef; this.cdcAuth = cdcAuth; this.auth = auth; this.zone = zone; this.userProfileFacade = userProfileFacade; this.platform = platform; this.loaded$ = new ReplaySubject(1); this.errorLoading$ = new ReplaySubject(1); this.subscription = new Subscription(); } /** * Initialize CDC script */ initialize() { this.loadCdcJavascript(); } /** * Returns observable with the information if CDC script is loaded. */ didLoad() { return this.loaded$.asObservable(); } /** * Returns observable with the information if CDC script failed to load. */ didScriptFailToLoad() { return this.errorLoading$.asObservable(); } /** * Method which loads the CDC Script */ loadCdcJavascript() { // Only load the script on client side (no SSR) if (isPlatformBrowser(this.platform)) { this.subscription.add(combineLatest([ this.baseSiteService.getActive(), this.languageService.getActive(), ]) .pipe(take(1)) .subscribe(([baseSite, language]) => { var _a; const scriptForBaseSite = this.getJavascriptUrlForCurrentSite(baseSite); if (scriptForBaseSite) { const javascriptUrl = `${scriptForBaseSite}&lang=${language}`; this.scriptLoader.embedScript({ src: javascriptUrl, params: undefined, attributes: { type: 'text/javascript' }, callback: () => { this.registerEventListeners(baseSite); this.loaded$.next(true); }, errorCallback: () => { this.errorLoading$.next(true); }, }); if (((_a = this.winRef) === null || _a === void 0 ? void 0 : _a.nativeWindow) !== undefined) { this.winRef.nativeWindow['__gigyaConf'] = { include: 'id_token', }; } } })); } } getJavascriptUrlForCurrentSite(baseSite) { var _a; const filteredConfigs = ((_a = this.cdcConfig.cdc) !== null && _a !== void 0 ? _a : []).filter((conf) => conf.baseSite === baseSite); if (filteredConfigs && filteredConfigs.length > 0) { return filteredConfigs[0].javascriptUrl; } return ''; } /** * Register login event listeners for CDC login * * @param baseSite */ registerEventListeners(baseSite) { this.addCdcEventHandlers(baseSite); } /** * Method to register CDC event handlers * * @param baseSite */ addCdcEventHandlers(baseSite) { 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.addEventHandlers({ onLogin: (...params) => { this.zone.run(() => this.onLoginEventHandler(baseSite, ...params)); }, }); } /** * Trigger login to Commerce once an onLogin event is triggered by CDC Screen Set. * * @param baseSite * @param response */ onLoginEventHandler(baseSite, response) { if (response) { this.cdcAuth.loginWithCustomCdcFlow(response.UID, response.UIDSignature, response.signatureTimestamp, response.id_token !== undefined ? response.id_token : '', baseSite); } } /** * Updates user details using the existing User API * * @param response */ onProfileUpdateEventHandler(response) { if (response) { const userDetails = {}; userDetails.firstName = response.profile.firstName; userDetails.lastName = response.profile.lastName; this.userProfileFacade.update(userDetails); } } ngOnDestroy() { if (this.subscription) { this.subscription.unsubscribe(); } } } CdcJsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CdcJsService, deps: [{ token: i1.CdcConfig }, { token: i2.BaseSiteService }, { token: i2.LanguageService }, { token: i2.ScriptLoader }, { token: i2.WindowRef }, { token: i3.CdcAuthFacade }, { token: i2.AuthService }, { token: i0.NgZone }, { token: i4.UserProfileFacade }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable }); CdcJsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CdcJsService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CdcJsService, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.CdcConfig }, { type: i2.BaseSiteService }, { type: i2.LanguageService }, { type: i2.ScriptLoader }, { type: i2.WindowRef }, { type: i3.CdcAuthFacade }, { type: i2.AuthService }, { type: i0.NgZone }, { type: i4.UserProfileFacade }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdc-js.service.js","sourceRoot":"","sources":["../../../../../integration-libs/cdc/root/service/cdc-js.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n  Inject,\n  Injectable,\n  NgZone,\n  OnDestroy,\n  PLATFORM_ID,\n} from '@angular/core';\nimport {\n  AuthService,\n  BaseSiteService,\n  LanguageService,\n  ScriptLoader,\n  User,\n  WindowRef,\n} from '@spartacus/core';\nimport { combineLatest, Observable, ReplaySubject, Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\nimport { UserProfileFacade } from '@spartacus/user/profile/root';\nimport { CdcConfig } from '../config/cdc-config';\nimport { CdcAuthFacade } from '../facade/cdc-auth.facade';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class CdcJsService implements OnDestroy {\n  protected loaded$ = new ReplaySubject<boolean>(1);\n  protected errorLoading$ = new ReplaySubject<boolean>(1);\n  protected subscription: Subscription = new Subscription();\n\n  constructor(\n    protected cdcConfig: CdcConfig,\n    protected baseSiteService: BaseSiteService,\n    protected languageService: LanguageService,\n    protected scriptLoader: ScriptLoader,\n    protected winRef: WindowRef,\n    protected cdcAuth: CdcAuthFacade,\n    protected auth: AuthService,\n    protected zone: NgZone,\n    protected userProfileFacade: UserProfileFacade,\n    @Inject(PLATFORM_ID) protected platform: any\n  ) {}\n\n  /**\n   * Initialize CDC script\n   */\n  initialize(): void {\n    this.loadCdcJavascript();\n  }\n\n  /**\n   * Returns observable with the information if CDC script is loaded.\n   */\n  didLoad(): Observable<boolean> {\n    return this.loaded$.asObservable();\n  }\n\n  /**\n   * Returns observable with the information if CDC script failed to load.\n   */\n  didScriptFailToLoad(): Observable<boolean> {\n    return this.errorLoading$.asObservable();\n  }\n\n  /**\n   * Method which loads the CDC Script\n   */\n  loadCdcJavascript(): void {\n    // Only load the script on client side (no SSR)\n    if (isPlatformBrowser(this.platform)) {\n      this.subscription.add(\n        combineLatest([\n          this.baseSiteService.getActive(),\n          this.languageService.getActive(),\n        ])\n          .pipe(take(1))\n          .subscribe(([baseSite, language]) => {\n            const scriptForBaseSite =\n              this.getJavascriptUrlForCurrentSite(baseSite);\n            if (scriptForBaseSite) {\n              const javascriptUrl = `${scriptForBaseSite}&lang=${language}`;\n              this.scriptLoader.embedScript({\n                src: javascriptUrl,\n                params: undefined,\n                attributes: { type: 'text/javascript' },\n                callback: () => {\n                  this.registerEventListeners(baseSite);\n                  this.loaded$.next(true);\n                },\n                errorCallback: () => {\n                  this.errorLoading$.next(true);\n                },\n              });\n              if (this.winRef?.nativeWindow !== undefined) {\n                (this.winRef.nativeWindow as { [key: string]: any })[\n                  '__gigyaConf'\n                ] = {\n                  include: 'id_token',\n                };\n              }\n            }\n          })\n      );\n    }\n  }\n\n  private getJavascriptUrlForCurrentSite(baseSite: string): string {\n    const filteredConfigs = (this.cdcConfig.cdc ?? []).filter(\n      (conf) => conf.baseSite === baseSite\n    );\n    if (filteredConfigs && filteredConfigs.length > 0) {\n      return filteredConfigs[0].javascriptUrl;\n    }\n    return '';\n  }\n\n  /**\n   * Register login event listeners for CDC login\n   *\n   * @param baseSite\n   */\n  protected registerEventListeners(baseSite: string): void {\n    this.addCdcEventHandlers(baseSite);\n  }\n\n  /**\n   * Method to register CDC event handlers\n   *\n   * @param baseSite\n   */\n  protected addCdcEventHandlers(baseSite: string): void {\n    (this.winRef.nativeWindow as { [key: string]: any })?.[\n      'gigya'\n    ]?.accounts?.addEventHandlers({\n      onLogin: (...params: any[]) => {\n        this.zone.run(() => this.onLoginEventHandler(baseSite, ...params));\n      },\n    });\n  }\n\n  /**\n   * Trigger login to Commerce once an onLogin event is triggered by CDC Screen Set.\n   *\n   * @param baseSite\n   * @param response\n   */\n  onLoginEventHandler(baseSite: string, response?: any) {\n    if (response) {\n      this.cdcAuth.loginWithCustomCdcFlow(\n        response.UID,\n        response.UIDSignature,\n        response.signatureTimestamp,\n        response.id_token !== undefined ? response.id_token : '',\n        baseSite\n      );\n    }\n  }\n\n  /**\n   * Updates user details using the existing User API\n   *\n   * @param response\n   */\n  onProfileUpdateEventHandler(response?: any) {\n    if (response) {\n      const userDetails: User = {};\n      userDetails.firstName = response.profile.firstName;\n      userDetails.lastName = response.profile.lastName;\n      this.userProfileFacade.update(userDetails);\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n}\n"]}