UNPKG

@spartacus/storefront

Version:

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

57 lines 19.2 kB
import { Component } from '@angular/core'; import { BehaviorSubject, Subscription } from 'rxjs'; import { take } from 'rxjs/operators'; import { ViewModes } from '../product-view/product-view.component'; import * as i0 from "@angular/core"; import * as i1 from "../../../../cms-structure/page/index"; import * as i2 from "./product-list-component.service"; import * as i3 from "../../../../shared/config/view-config"; import * as i4 from "../../../../shared/components/list-navigation/sorting/sorting.component"; import * as i5 from "../../../../shared/components/list-navigation/pagination/pagination.component"; import * as i6 from "../product-view/product-view.component"; import * as i7 from "../product-grid-item/product-grid-item.component"; import * as i8 from "../product-list-item/product-list-item.component"; import * as i9 from "./product-scroll/product-scroll.component"; import * as i10 from "@angular/common"; import * as i11 from "@spartacus/core"; export class ProductListComponent { constructor(pageLayoutService, productListComponentService, scrollConfig) { this.pageLayoutService = pageLayoutService; this.productListComponentService = productListComponentService; this.scrollConfig = scrollConfig; this.subscription = new Subscription(); this.model$ = this.productListComponentService.model$; this.viewMode$ = new BehaviorSubject(ViewModes.Grid); this.ViewModes = ViewModes; } ngOnInit() { var _a, _b; this.isInfiniteScroll = (_b = (_a = this.scrollConfig.view) === null || _a === void 0 ? void 0 : _a.infiniteScroll) === null || _b === void 0 ? void 0 : _b.active; this.subscription.add(this.pageLayoutService.templateName$ .pipe(take(1)) .subscribe((template) => { this.viewMode$.next(template === 'ProductGridPageTemplate' ? ViewModes.Grid : ViewModes.List); })); } sortList(sortCode) { this.productListComponentService.sort(sortCode); } setViewMode(mode) { this.viewMode$.next(mode); } ngOnDestroy() { this.subscription.unsubscribe(); } } ProductListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ProductListComponent, deps: [{ token: i1.PageLayoutService }, { token: i2.ProductListComponentService }, { token: i3.ViewConfig }], target: i0.ɵɵFactoryTarget.Component }); ProductListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: ProductListComponent, selector: "cx-product-list", ngImport: i0, template: "<div class=\"cx-page\" *ngIf=\"model$ | async as model\">\n <section class=\"cx-page-section\">\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-12 col-lg-12\" *ngIf=\"viewMode$ | async as viewMode\">\n <div class=\"cx-sorting top\">\n <div class=\"row\">\n <label\n class=\"form-group cx-sort-dropdown col-12 col-lg-4 mr-auto\"\n >\n <span>{{ 'productList.sortBy' | cxTranslate }}</span>\n <cx-sorting\n [sortOptions]=\"model.sorts\"\n (sortListEvent)=\"sortList($event)\"\n [selectedOption]=\"model.pagination.sort\"\n placeholder=\"{{ 'productList.sortBy' | cxTranslate }}\"\n ></cx-sorting>\n </label>\n <div *ngIf=\"!isInfiniteScroll\" class=\"col-auto\">\n <div\n class=\"cx-pagination\"\n [attr.aria-label]=\"\n 'productList.productSearchPagination' | cxTranslate\n \"\n >\n <cx-pagination\n [pagination]=\"model.pagination\"\n queryParam=\"currentPage\"\n [defaultPage]=\"0\"\n ></cx-pagination>\n </div>\n </div>\n <div class=\"col-auto ml-auto ml-lg-0\">\n <cx-product-view\n (modeChange)=\"setViewMode($event)\"\n [mode]=\"viewMode\"\n ></cx-product-view>\n </div>\n </div>\n </div>\n <div class=\"cx-product-container\">\n <!-- Product list when using pagination -->\n <ng-container *ngIf=\"!isInfiniteScroll; else infiniteScroll\">\n <ng-container *ngIf=\"viewMode === ViewModes.Grid\">\n <div class=\"row\">\n <cx-product-grid-item\n *ngFor=\"let product of model?.products\"\n [product]=\"product\"\n class=\"col-12 col-sm-6 col-md-4\"\n ></cx-product-grid-item>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"viewMode === ViewModes.List\">\n <cx-product-list-item\n *ngFor=\"let product of model?.products\"\n [product]=\"product\"\n class=\"cx-product-search-list\"\n ></cx-product-list-item>\n </ng-container>\n </ng-container>\n\n <!-- Product list when using infinite scroll -->\n <ng-template #infiniteScroll>\n <cx-product-scroll\n [scrollConfig]=\"scrollConfig\"\n [model]=\"model\"\n [inputViewMode]=\"viewMode\"\n ></cx-product-scroll>\n </ng-template>\n </div>\n <div class=\"cx-sorting bottom\">\n <div class=\"row\">\n <label\n class=\"form-group cx-sort-dropdown col-12 col-lg-4 mr-auto\"\n >\n <span>{{ 'productList.sortBy' | cxTranslate }}</span>\n <cx-sorting\n [sortOptions]=\"model.sorts\"\n (sortListEvent)=\"sortList($event)\"\n [selectedOption]=\"model.pagination.sort\"\n placeholder=\"{{ 'productList.sortBy' | cxTranslate }}\"\n ></cx-sorting>\n </label>\n <div\n *ngIf=\"!isInfiniteScroll\"\n class=\"col-auto\"\n [attr.aria-label]=\"\n 'productList.productSearchPagination' | cxTranslate\n \"\n >\n <div class=\"cx-pagination\">\n <cx-pagination\n [pagination]=\"model.pagination\"\n queryParam=\"currentPage\"\n [defaultPage]=\"0\"\n ></cx-pagination>\n </div>\n </div>\n <div class=\"col-auto ml-auto ml-lg-0\">\n <cx-product-view\n (modeChange)=\"setViewMode($event)\"\n [mode]=\"viewMode\"\n ></cx-product-view>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </section>\n</div>\n", components: [{ type: i4.SortingComponent, selector: "cx-sorting", inputs: ["sortOptions", "selectedOption", "placeholder", "sortLabels"], outputs: ["sortListEvent"] }, { type: i5.PaginationComponent, selector: "cx-pagination", inputs: ["pageRoute", "queryParam", "defaultPage", "pagination"], outputs: ["viewPageEvent"] }, { type: i6.ProductViewComponent, selector: "cx-product-view", inputs: ["mode"], outputs: ["modeChange"] }, { type: i7.ProductGridItemComponent, selector: "cx-product-grid-item", inputs: ["product"] }, { type: i8.ProductListItemComponent, selector: "cx-product-list-item", inputs: ["product"] }, { type: i9.ProductScrollComponent, selector: "cx-product-scroll", inputs: ["scrollConfig", "model", "inputViewMode"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i10.AsyncPipe, "cxTranslate": i11.TranslatePipe } }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ProductListComponent, decorators: [{ type: Component, args: [{ selector: 'cx-product-list', templateUrl: './product-list.component.html', }] }], ctorParameters: function () { return [{ type: i1.PageLayoutService }, { type: i2.ProductListComponentService }, { type: i3.ViewConfig }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/storefrontlib/cms-components/product/product-list/container/product-list.component.ts","../../../../../../../projects/storefrontlib/cms-components/product/product-list/container/product-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,eAAe,EAAc,YAAY,EAAE,MAAM,MAAM,CAAC;AACjE,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAGtC,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAC;;;;;;;;;;;;;AAOnE,MAAM,OAAO,oBAAoB;IAW/B,YACU,iBAAoC,EACpC,2BAAwD,EACzD,YAAwB;QAFvB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,gCAA2B,GAA3B,2BAA2B,CAA6B;QACzD,iBAAY,GAAZ,YAAY,CAAY;QAbzB,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAI1C,WAAM,GACJ,IAAI,CAAC,2BAA2B,CAAC,MAAM,CAAC;QAE1C,cAAS,GAAG,IAAI,eAAe,CAAY,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3D,cAAS,GAAG,SAAS,CAAC;IAMnB,CAAC;IAEJ,QAAQ;;QACN,IAAI,CAAC,gBAAgB,GAAG,MAAA,MAAA,IAAI,CAAC,YAAY,CAAC,IAAI,0CAAE,cAAc,0CAAE,MAAM,CAAC;QAEvE,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,iBAAiB,CAAC,aAAa;aACjC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACtB,IAAI,CAAC,SAAS,CAAC,IAAI,CACjB,QAAQ,KAAK,yBAAyB;gBACpC,CAAC,CAAC,SAAS,CAAC,IAAI;gBAChB,CAAC,CAAC,SAAS,CAAC,IAAI,CACnB,CAAC;QACJ,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,QAAgB;QACvB,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAClD,CAAC;IAED,WAAW,CAAC,IAAe;QACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;;iHA3CU,oBAAoB;qGAApB,oBAAoB,uDCbjC,k3IAgHA;2FDnGa,oBAAoB;kBAJhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,WAAW,EAAE,+BAA+B;iBAC7C","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { ProductSearchPage } from '@spartacus/core';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\nimport { PageLayoutService } from '../../../../cms-structure/page/index';\nimport { ViewConfig } from '../../../../shared/config/view-config';\nimport { ViewModes } from '../product-view/product-view.component';\nimport { ProductListComponentService } from './product-list-component.service';\n\n@Component({\n  selector: 'cx-product-list',\n  templateUrl: './product-list.component.html',\n})\nexport class ProductListComponent implements OnInit, OnDestroy {\n  private subscription = new Subscription();\n\n  isInfiniteScroll: boolean;\n\n  model$: Observable<ProductSearchPage> =\n    this.productListComponentService.model$;\n\n  viewMode$ = new BehaviorSubject<ViewModes>(ViewModes.Grid);\n  ViewModes = ViewModes;\n\n  constructor(\n    private pageLayoutService: PageLayoutService,\n    private productListComponentService: ProductListComponentService,\n    public scrollConfig: ViewConfig\n  ) {}\n\n  ngOnInit(): void {\n    this.isInfiniteScroll = this.scrollConfig.view?.infiniteScroll?.active;\n\n    this.subscription.add(\n      this.pageLayoutService.templateName$\n        .pipe(take(1))\n        .subscribe((template) => {\n          this.viewMode$.next(\n            template === 'ProductGridPageTemplate'\n              ? ViewModes.Grid\n              : ViewModes.List\n          );\n        })\n    );\n  }\n\n  sortList(sortCode: string): void {\n    this.productListComponentService.sort(sortCode);\n  }\n\n  setViewMode(mode: ViewModes): void {\n    this.viewMode$.next(mode);\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n}\n","<div class=\"cx-page\" *ngIf=\"model$ | async as model\">\n  <section class=\"cx-page-section\">\n    <div class=\"container\">\n      <div class=\"row\">\n        <div class=\"col-12 col-lg-12\" *ngIf=\"viewMode$ | async as viewMode\">\n          <div class=\"cx-sorting top\">\n            <div class=\"row\">\n              <label\n                class=\"form-group cx-sort-dropdown col-12 col-lg-4 mr-auto\"\n              >\n                <span>{{ 'productList.sortBy' | cxTranslate }}</span>\n                <cx-sorting\n                  [sortOptions]=\"model.sorts\"\n                  (sortListEvent)=\"sortList($event)\"\n                  [selectedOption]=\"model.pagination.sort\"\n                  placeholder=\"{{ 'productList.sortBy' | cxTranslate }}\"\n                ></cx-sorting>\n              </label>\n              <div *ngIf=\"!isInfiniteScroll\" class=\"col-auto\">\n                <div\n                  class=\"cx-pagination\"\n                  [attr.aria-label]=\"\n                    'productList.productSearchPagination' | cxTranslate\n                  \"\n                >\n                  <cx-pagination\n                    [pagination]=\"model.pagination\"\n                    queryParam=\"currentPage\"\n                    [defaultPage]=\"0\"\n                  ></cx-pagination>\n                </div>\n              </div>\n              <div class=\"col-auto ml-auto ml-lg-0\">\n                <cx-product-view\n                  (modeChange)=\"setViewMode($event)\"\n                  [mode]=\"viewMode\"\n                ></cx-product-view>\n              </div>\n            </div>\n          </div>\n          <div class=\"cx-product-container\">\n            <!-- Product list when using pagination -->\n            <ng-container *ngIf=\"!isInfiniteScroll; else infiniteScroll\">\n              <ng-container *ngIf=\"viewMode === ViewModes.Grid\">\n                <div class=\"row\">\n                  <cx-product-grid-item\n                    *ngFor=\"let product of model?.products\"\n                    [product]=\"product\"\n                    class=\"col-12 col-sm-6 col-md-4\"\n                  ></cx-product-grid-item>\n                </div>\n              </ng-container>\n\n              <ng-container *ngIf=\"viewMode === ViewModes.List\">\n                <cx-product-list-item\n                  *ngFor=\"let product of model?.products\"\n                  [product]=\"product\"\n                  class=\"cx-product-search-list\"\n                ></cx-product-list-item>\n              </ng-container>\n            </ng-container>\n\n            <!-- Product list when using infinite scroll -->\n            <ng-template #infiniteScroll>\n              <cx-product-scroll\n                [scrollConfig]=\"scrollConfig\"\n                [model]=\"model\"\n                [inputViewMode]=\"viewMode\"\n              ></cx-product-scroll>\n            </ng-template>\n          </div>\n          <div class=\"cx-sorting bottom\">\n            <div class=\"row\">\n              <label\n                class=\"form-group cx-sort-dropdown col-12 col-lg-4 mr-auto\"\n              >\n                <span>{{ 'productList.sortBy' | cxTranslate }}</span>\n                <cx-sorting\n                  [sortOptions]=\"model.sorts\"\n                  (sortListEvent)=\"sortList($event)\"\n                  [selectedOption]=\"model.pagination.sort\"\n                  placeholder=\"{{ 'productList.sortBy' | cxTranslate }}\"\n                ></cx-sorting>\n              </label>\n              <div\n                *ngIf=\"!isInfiniteScroll\"\n                class=\"col-auto\"\n                [attr.aria-label]=\"\n                  'productList.productSearchPagination' | cxTranslate\n                \"\n              >\n                <div class=\"cx-pagination\">\n                  <cx-pagination\n                    [pagination]=\"model.pagination\"\n                    queryParam=\"currentPage\"\n                    [defaultPage]=\"0\"\n                  ></cx-pagination>\n                </div>\n              </div>\n              <div class=\"col-auto ml-auto ml-lg-0\">\n                <cx-product-view\n                  (modeChange)=\"setViewMode($event)\"\n                  [mode]=\"viewMode\"\n                ></cx-product-view>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </section>\n</div>\n"]}