@spartacus/cdc
Version:
Customer Data Cloud Integration library for Spartacus
151 lines • 18.1 kB
JavaScript
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"]}