UNPKG

@spartacus/core

Version:

Spartacus - the core framework

78 lines 12.3 kB
import { Injectable } from '@angular/core'; import { filter, map, pairwise } from 'rxjs/operators'; import { createFrom } from '../../util/create-from'; import { FacetChangedEvent } from './product.events'; import * as i0 from "@angular/core"; import * as i1 from "../../event/event.service"; import * as i2 from "../facade/product-search.service"; export class ProductEventBuilder { constructor(eventService, productSearchService) { this.eventService = eventService; this.productSearchService = productSearchService; this.register(); } register() { this.eventService.register(FacetChangedEvent, this.buildFacetChangedEvent()); } /** * To get the changed facet, we need to compare the product search results * got before and after toggling the facet value. These 2 product searches must * have the same search queries except one different solr filter term. That means * these 2 searches must have the same 'freeTextSearch'; and if they are category * searches, they must have the same root (in the same category or brand). */ buildFacetChangedEvent() { return this.productSearchService.getResults().pipe(pairwise(), filter(([prev, curr]) => this.compareSearchResults(prev, curr)), map(([prev, curr]) => { const toggled = this.getToggledBreadcrumb(curr.breadcrumbs, prev.breadcrumbs) || this.getToggledBreadcrumb(prev.breadcrumbs, curr.breadcrumbs); if (toggled) { return createFrom(FacetChangedEvent, { code: toggled.facetCode, name: toggled.facetName, valueCode: toggled.facetValueCode, valueName: toggled.facetValueName, selected: curr.breadcrumbs.length > prev.breadcrumbs.length, }); } })); } /** * The 2 product searches (before and after facet changed) must have the same * search queries; and if they are category searches, they also must have the * same root (in the same category or brand). */ compareSearchResults(prev, curr) { var _a, _b, _c; if (prev && Object.keys(prev).length !== 0) { // for text searches, they must have the same freeTextSearch const sameFreeTextSearch = prev.freeTextSearch !== '' && prev.freeTextSearch === curr.freeTextSearch; // for category searches, they must have the same root const sameCategoryRoot = ((_a = curr.breadcrumbs[0]) === null || _a === void 0 ? void 0 : _a.facetCode) === 'allCategories' && ((_b = prev.breadcrumbs[0]) === null || _b === void 0 ? void 0 : _b.facetCode) === ((_c = curr.breadcrumbs[0]) === null || _c === void 0 ? void 0 : _c.facetCode) && // same category or brand prev.breadcrumbs[0].facetValueCode === curr.breadcrumbs[0].facetValueCode; return sameFreeTextSearch || sameCategoryRoot; } } /** * Get the toggled breadcrumb. The 2 breadcrumb lists got from the 2 search results * only can have one different solr filter term. */ getToggledBreadcrumb(bc1, bc2) { if (bc1.length - bc2.length === 1) { return bc1.find((x) => !bc2.find((y) => y.facetCode === x.facetCode && y.facetValueCode === x.facetValueCode)); } } } ProductEventBuilder.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ProductEventBuilder, deps: [{ token: i1.EventService }, { token: i2.ProductSearchService }], target: i0.ɵɵFactoryTarget.Injectable }); ProductEventBuilder.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ProductEventBuilder, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ProductEventBuilder, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.EventService }, { type: i2.ProductSearchService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-event.builder.js","sourceRoot":"","sources":["../../../../../../projects/core/src/product/event/product-event.builder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAMvD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;;;;AAKrD,MAAM,OAAO,mBAAmB;IAC9B,YACY,YAA0B,EAC1B,oBAA0C;QAD1C,iBAAY,GAAZ,YAAY,CAAc;QAC1B,yBAAoB,GAApB,oBAAoB,CAAsB;QAEpD,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAES,QAAQ;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,CACxB,iBAAiB,EACjB,IAAI,CAAC,sBAAsB,EAAE,CAC9B,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACO,sBAAsB;QAC9B,OAAO,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC,IAAI,CAChD,QAAQ,EAAE,EACV,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,EAC/D,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE;YACnB,MAAM,OAAO,GACX,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;gBAC7D,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YAChE,IAAI,OAAO,EAAE;gBACX,OAAO,UAAU,CAAC,iBAAiB,EAAE;oBACnC,IAAI,EAAE,OAAO,CAAC,SAAS;oBACvB,IAAI,EAAE,OAAO,CAAC,SAAS;oBACvB,SAAS,EAAE,OAAO,CAAC,cAAc;oBACjC,SAAS,EAAE,OAAO,CAAC,cAAc;oBACjC,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM;iBAC5D,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACK,oBAAoB,CAC1B,IAAuB,EACvB,IAAuB;;QAEvB,IAAI,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YAC1C,4DAA4D;YAC5D,MAAM,kBAAkB,GACtB,IAAI,CAAC,cAAc,KAAK,EAAE;gBAC1B,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,cAAc,CAAC;YAE9C,sDAAsD;YACtD,MAAM,gBAAgB,GACpB,CAAA,MAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,0CAAE,SAAS,MAAK,eAAe;gBAClD,CAAA,MAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,0CAAE,SAAS,OAAK,MAAA,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,0CAAE,SAAS,CAAA;gBACjE,yBAAyB;gBACzB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,cAAc;oBAChC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;YAEvC,OAAO,kBAAkB,IAAI,gBAAgB,CAAC;SAC/C;IACH,CAAC;IAED;;;OAGG;IACK,oBAAoB,CAC1B,GAAiB,EACjB,GAAiB;QAEjB,IAAI,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;YACjC,OAAO,GAAG,CAAC,IAAI,CACb,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,GAAG,CAAC,IAAI,CACP,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,SAAS;gBAC3B,CAAC,CAAC,cAAc,KAAK,CAAC,CAAC,cAAc,CACxC,CACJ,CAAC;SACH;IACH,CAAC;;gHAxFU,mBAAmB;oHAAnB,mBAAmB,cAFlB,MAAM;2FAEP,mBAAmB;kBAH/B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { filter, map, pairwise } from 'rxjs/operators';\nimport { EventService } from '../../event/event.service';\nimport {\n  Breadcrumb,\n  ProductSearchPage,\n} from '../../model/product-search.model';\nimport { createFrom } from '../../util/create-from';\nimport { ProductSearchService } from '../facade/product-search.service';\nimport { FacetChangedEvent } from './product.events';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ProductEventBuilder {\n  constructor(\n    protected eventService: EventService,\n    protected productSearchService: ProductSearchService\n  ) {\n    this.register();\n  }\n\n  protected register(): void {\n    this.eventService.register(\n      FacetChangedEvent,\n      this.buildFacetChangedEvent()\n    );\n  }\n\n  /**\n   * To get the changed facet, we need to compare the product search results\n   * got before and after toggling the facet value. These 2 product searches must\n   * have the same search queries except one different solr filter term. That means\n   * these 2 searches must have the same 'freeTextSearch'; and if they are category\n   * searches, they must have the same root (in the same category or brand).\n   */\n  protected buildFacetChangedEvent(): Observable<FacetChangedEvent> {\n    return this.productSearchService.getResults().pipe(\n      pairwise(),\n      filter(([prev, curr]) => this.compareSearchResults(prev, curr)),\n      map(([prev, curr]) => {\n        const toggled =\n          this.getToggledBreadcrumb(curr.breadcrumbs, prev.breadcrumbs) ||\n          this.getToggledBreadcrumb(prev.breadcrumbs, curr.breadcrumbs);\n        if (toggled) {\n          return createFrom(FacetChangedEvent, {\n            code: toggled.facetCode,\n            name: toggled.facetName,\n            valueCode: toggled.facetValueCode,\n            valueName: toggled.facetValueName,\n            selected: curr.breadcrumbs.length > prev.breadcrumbs.length,\n          });\n        }\n      })\n    );\n  }\n\n  /**\n   * The 2 product searches (before and after facet changed) must have the same\n   * search queries; and if they are category searches, they also must have the\n   * same root (in the same category or brand).\n   */\n  private compareSearchResults(\n    prev: ProductSearchPage,\n    curr: ProductSearchPage\n  ): boolean {\n    if (prev && Object.keys(prev).length !== 0) {\n      // for text searches, they must have the same freeTextSearch\n      const sameFreeTextSearch =\n        prev.freeTextSearch !== '' &&\n        prev.freeTextSearch === curr.freeTextSearch;\n\n      // for category searches, they must have the same root\n      const sameCategoryRoot =\n        curr.breadcrumbs[0]?.facetCode === 'allCategories' &&\n        prev.breadcrumbs[0]?.facetCode === curr.breadcrumbs[0]?.facetCode &&\n        // same category or brand\n        prev.breadcrumbs[0].facetValueCode ===\n          curr.breadcrumbs[0].facetValueCode;\n\n      return sameFreeTextSearch || sameCategoryRoot;\n    }\n  }\n\n  /**\n   * Get the toggled breadcrumb. The 2 breadcrumb lists got from the 2 search results\n   * only can have one different solr filter term.\n   */\n  private getToggledBreadcrumb(\n    bc1: Breadcrumb[],\n    bc2: Breadcrumb[]\n  ): Breadcrumb {\n    if (bc1.length - bc2.length === 1) {\n      return bc1.find(\n        (x) =>\n          !bc2.find(\n            (y) =>\n              y.facetCode === x.facetCode &&\n              y.facetValueCode === x.facetValueCode\n          )\n      );\n    }\n  }\n}\n"]}