@spartacus/order
Version:
Order feature library for Spartacus
85 lines • 29.6 kB
JavaScript
import { ChangeDetectionStrategy, Component } from '@angular/core';
import { isNotUndefined, } from '@spartacus/core';
import { combineLatest } from 'rxjs';
import { filter, map, take, tap } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@spartacus/core";
import * as i2 from "@spartacus/order/root";
import * as i3 from "@spartacus/storefront";
import * as i4 from "@angular/common";
import * as i5 from "@angular/router";
export class OrderHistoryComponent {
constructor(routing, userOrderService, translation, userReplenishmentOrderService) {
this.routing = routing;
this.userOrderService = userOrderService;
this.translation = translation;
this.userReplenishmentOrderService = userReplenishmentOrderService;
this.PAGE_SIZE = 5;
this.orders$ = this.userOrderService
.getOrderHistoryList(this.PAGE_SIZE)
.pipe(tap((orders) => {
var _a;
if ((_a = orders === null || orders === void 0 ? void 0 : orders.pagination) === null || _a === void 0 ? void 0 : _a.sort) {
this.sortType = orders.pagination.sort;
}
}));
this.hasReplenishmentOrder$ = this.userReplenishmentOrderService
.getReplenishmentOrderDetails()
.pipe(map((order) => order && Object.keys(order).length !== 0));
this.isLoaded$ = this.userOrderService.getOrderHistoryListLoaded();
/**
* When "Order Return" feature is enabled, this component becomes one tab in
* TabParagraphContainerComponent. This can be read from TabParagraphContainer.
*/
this.tabTitleParam$ = this.orders$.pipe(map((order) => { var _a; return (_a = order === null || order === void 0 ? void 0 : order.pagination) === null || _a === void 0 ? void 0 : _a.totalResults; }), filter(isNotUndefined), take(1));
}
ngOnDestroy() {
this.userOrderService.clearOrderList();
}
changeSortCode(sortCode) {
const event = {
sortCode,
currentPage: 0,
};
this.sortType = sortCode;
this.fetchOrders(event);
}
pageChange(page) {
const event = {
sortCode: this.sortType,
currentPage: page,
};
this.fetchOrders(event);
}
goToOrderDetail(order) {
this.routing.go({
cxRoute: 'orderDetails',
params: order,
});
}
getSortLabels() {
return combineLatest([
this.translation.translate('sorting.date'),
this.translation.translate('sorting.orderNumber'),
]).pipe(map(([textByDate, textByOrderNumber]) => {
return {
byDate: textByDate,
byOrderNumber: textByOrderNumber,
};
}));
}
fetchOrders(event) {
this.userOrderService.loadOrderList(this.PAGE_SIZE, event.currentPage, event.sortCode);
}
}
OrderHistoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OrderHistoryComponent, deps: [{ token: i1.RoutingService }, { token: i2.OrderFacade }, { token: i1.TranslationService }, { token: i2.ReplenishmentOrderFacade }], target: i0.ɵɵFactoryTarget.Component });
OrderHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: OrderHistoryComponent, selector: "cx-order-history", ngImport: i0, template: "<ng-container\n *ngIf=\"{\n orderHistory: orders$ | async,\n replenishmentOrder: hasReplenishmentOrder$ | async\n } as type\"\n>\n <ng-container *ngIf=\"type.orderHistory\">\n <div [ngClass]=\"type.replenishmentOrder ? '' : 'container'\">\n <!-- HEADER -->\n <div\n [ngClass]=\"\n type.replenishmentOrder\n ? 'cx-replenishment-details-order-history-header'\n : 'cx-order-history-header'\n \"\n >\n <h4 *ngIf=\"type.replenishmentOrder\">\n {{ 'orderHistory.replenishmentHistory' | cxTranslate }}\n </h4>\n <h3 *ngIf=\"!type.replenishmentOrder\">\n {{ 'orderHistory.orderHistory' | cxTranslate }}\n </h3>\n </div>\n\n <!-- BODY -->\n <div class=\"cx-order-history-body\">\n <ng-container\n *ngIf=\"type.orderHistory.pagination.totalResults > 0; else noOrder\"\n >\n <!-- Select Form and Pagination Top -->\n <div class=\"cx-order-history-sort top row\">\n <label\n class=\"\n cx-order-history-form-group\n form-group\n col-sm-12 col-md-4 col-lg-4\n \"\n ><span>\n {{ 'orderHistory.sortBy' | cxTranslate }}\n </span>\n <cx-sorting\n [sortOptions]=\"type.orderHistory.sorts\"\n [sortLabels]=\"getSortLabels() | async\"\n (sortListEvent)=\"changeSortCode($event)\"\n [selectedOption]=\"type.orderHistory.pagination.sort\"\n placeholder=\"{{ 'orderHistory.sortBy' | cxTranslate }}\"\n ></cx-sorting>\n </label>\n <div\n *ngIf=\"type.orderHistory.pagination.totalPages > 1\"\n class=\"cx-order-history-pagination\"\n >\n <cx-pagination\n [pagination]=\"type.orderHistory.pagination\"\n (viewPageEvent)=\"pageChange($event)\"\n ></cx-pagination>\n </div>\n </div>\n <!-- TABLE -->\n <table class=\"table cx-order-history-table\">\n <thead class=\"cx-order-history-thead-mobile\">\n <th scope=\"col\">\n {{ 'orderHistory.orderId' | cxTranslate }}\n </th>\n <th scope=\"col\">{{ 'orderHistory.date' | cxTranslate }}</th>\n <th scope=\"col\">\n {{ 'orderHistory.status' | cxTranslate }}\n </th>\n <th scope=\"col\">{{ 'orderHistory.total' | cxTranslate }}</th>\n </thead>\n <tbody>\n <tr\n *ngFor=\"let order of type.orderHistory.orders\"\n (click)=\"goToOrderDetail(order)\"\n >\n <td class=\"cx-order-history-code\">\n <div class=\"d-md-none cx-order-history-label\">\n {{ 'orderHistory.orderId' | cxTranslate }}\n </div>\n <a\n [routerLink]=\"\n {\n cxRoute: 'orderDetails',\n params: order\n } | cxUrl\n \"\n class=\"cx-order-history-value\"\n >\n {{ order?.code }}</a\n >\n </td>\n <td class=\"cx-order-history-placed\">\n <div class=\"d-md-none cx-order-history-label\">\n {{ 'orderHistory.date' | cxTranslate }}\n </div>\n <a\n [routerLink]=\"\n {\n cxRoute: 'orderDetails',\n params: order\n } | cxUrl\n \"\n class=\"cx-order-history-value\"\n >{{ order?.placed | cxDate: 'longDate' }}</a\n >\n </td>\n <td class=\"cx-order-history-status\">\n <div class=\"d-md-none cx-order-history-label\">\n {{ 'orderHistory.status' | cxTranslate }}\n </div>\n <a\n [routerLink]=\"\n {\n cxRoute: 'orderDetails',\n params: order\n } | cxUrl\n \"\n class=\"cx-order-history-value\"\n >\n {{\n 'orderDetails.statusDisplay_' + order?.statusDisplay\n | cxTranslate\n }}</a\n >\n </td>\n <td class=\"cx-order-history-total\">\n <div class=\"d-md-none cx-order-history-label\">\n {{ 'orderHistory.total' | cxTranslate }}\n </div>\n <a\n [routerLink]=\"\n {\n cxRoute: 'orderDetails',\n params: order\n } | cxUrl\n \"\n class=\"cx-order-history-value\"\n >\n {{ order?.total.formattedValue }}</a\n >\n </td>\n </tr>\n </tbody>\n </table>\n <!-- Select Form and Pagination Bottom -->\n <div class=\"cx-order-history-sort bottom row\">\n <div\n *ngIf=\"type.orderHistory.pagination.totalPages > 1\"\n class=\"cx-order-history-pagination\"\n >\n <cx-pagination\n [pagination]=\"type.orderHistory.pagination\"\n (viewPageEvent)=\"pageChange($event)\"\n ></cx-pagination>\n </div>\n </div>\n </ng-container>\n\n <!-- NO ORDER CONTAINER -->\n <ng-template #noOrder>\n <div\n *ngIf=\"isLoaded$ | async\"\n [ngClass]=\"\n type.replenishmentOrder\n ? 'cx-replenishment-details-order-history-no-order row'\n : 'cx-order-history-no-order row'\n \"\n >\n <div\n [ngClass]=\"\n type.replenishmentOrder ? '' : 'col-sm-12 col-md-6 col-lg-4'\n \"\n >\n <ng-container *ngIf=\"type.replenishmentOrder; else otherOrder\">\n <div>{{ 'orderHistory.notFound' | cxTranslate }}</div>\n </ng-container>\n\n <ng-template #otherOrder>\n <div>{{ 'orderHistory.noOrders' | cxTranslate }}</div>\n <a\n [routerLink]=\"{ cxRoute: 'home' } | cxUrl\"\n routerLinkActive=\"active\"\n class=\"btn btn-primary btn-block\"\n >{{ 'orderHistory.startShopping' | cxTranslate }}</a\n >\n </ng-template>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </ng-container>\n</ng-container>\n", components: [{ type: i3.SortingComponent, selector: "cx-sorting", inputs: ["sortOptions", "selectedOption", "placeholder", "sortLabels"], outputs: ["sortListEvent"] }, { type: i3.PaginationComponent, selector: "cx-pagination", inputs: ["pageRoute", "queryParam", "defaultPage", "pagination"], outputs: ["viewPageEvent"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i5.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], exportAs: ["routerLinkActive"] }], pipes: { "async": i4.AsyncPipe, "cxTranslate": i1.TranslatePipe, "cxUrl": i1.UrlPipe, "cxDate": i1.CxDatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OrderHistoryComponent, decorators: [{
type: Component,
args: [{
selector: 'cx-order-history',
templateUrl: './order-history.component.html',
changeDetection: ChangeDetectionStrategy.OnPush,
}]
}], ctorParameters: function () { return [{ type: i1.RoutingService }, { type: i2.OrderFacade }, { type: i1.TranslationService }, { type: i2.ReplenishmentOrderFacade }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-history.component.js","sourceRoot":"","sources":["../../../../../feature-libs/order/components/order-history/order-history.component.ts","../../../../../feature-libs/order/components/order-history/order-history.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnDestroy } from '@angular/core';\nimport {\n  isNotUndefined,\n  Order,\n  OrderHistoryList,\n  RoutingService,\n  TranslationService,\n} from '@spartacus/core';\nimport { OrderFacade, ReplenishmentOrderFacade } from '@spartacus/order/root';\nimport { combineLatest, Observable } from 'rxjs';\nimport { filter, map, take, tap } from 'rxjs/operators';\n\n@Component({\n  selector: 'cx-order-history',\n  templateUrl: './order-history.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OrderHistoryComponent implements OnDestroy {\n  constructor(\n    protected routing: RoutingService,\n    protected userOrderService: OrderFacade,\n    protected translation: TranslationService,\n    protected userReplenishmentOrderService: ReplenishmentOrderFacade\n  ) {}\n\n  private PAGE_SIZE = 5;\n  sortType: string;\n\n  orders$: Observable<OrderHistoryList | undefined> = this.userOrderService\n    .getOrderHistoryList(this.PAGE_SIZE)\n    .pipe(\n      tap((orders: OrderHistoryList | undefined) => {\n        if (orders?.pagination?.sort) {\n          this.sortType = orders.pagination.sort;\n        }\n      })\n    );\n\n  hasReplenishmentOrder$: Observable<boolean> =\n    this.userReplenishmentOrderService\n      .getReplenishmentOrderDetails()\n      .pipe(map((order) => order && Object.keys(order).length !== 0));\n\n  isLoaded$: Observable<boolean> =\n    this.userOrderService.getOrderHistoryListLoaded();\n\n  /**\n   * When \"Order Return\" feature is enabled, this component becomes one tab in\n   * TabParagraphContainerComponent. This can be read from TabParagraphContainer.\n   */\n  tabTitleParam$: Observable<number> = this.orders$.pipe(\n    map((order) => order?.pagination?.totalResults),\n    filter(isNotUndefined),\n    take(1)\n  );\n\n  ngOnDestroy(): void {\n    this.userOrderService.clearOrderList();\n  }\n\n  changeSortCode(sortCode: string): void {\n    const event: { sortCode: string; currentPage: number } = {\n      sortCode,\n      currentPage: 0,\n    };\n    this.sortType = sortCode;\n    this.fetchOrders(event);\n  }\n\n  pageChange(page: number): void {\n    const event: { sortCode: string; currentPage: number } = {\n      sortCode: this.sortType,\n      currentPage: page,\n    };\n    this.fetchOrders(event);\n  }\n\n  goToOrderDetail(order: Order): void {\n    this.routing.go({\n      cxRoute: 'orderDetails',\n      params: order,\n    });\n  }\n\n  getSortLabels(): Observable<{ byDate: string; byOrderNumber: string }> {\n    return combineLatest([\n      this.translation.translate('sorting.date'),\n      this.translation.translate('sorting.orderNumber'),\n    ]).pipe(\n      map(([textByDate, textByOrderNumber]) => {\n        return {\n          byDate: textByDate,\n          byOrderNumber: textByOrderNumber,\n        };\n      })\n    );\n  }\n\n  private fetchOrders(event: { sortCode: string; currentPage: number }): void {\n    this.userOrderService.loadOrderList(\n      this.PAGE_SIZE,\n      event.currentPage,\n      event.sortCode\n    );\n  }\n}\n","<ng-container\n  *ngIf=\"{\n    orderHistory: orders$ | async,\n    replenishmentOrder: hasReplenishmentOrder$ | async\n  } as type\"\n>\n  <ng-container *ngIf=\"type.orderHistory\">\n    <div [ngClass]=\"type.replenishmentOrder ? '' : 'container'\">\n      <!-- HEADER -->\n      <div\n        [ngClass]=\"\n          type.replenishmentOrder\n            ? 'cx-replenishment-details-order-history-header'\n            : 'cx-order-history-header'\n        \"\n      >\n        <h4 *ngIf=\"type.replenishmentOrder\">\n          {{ 'orderHistory.replenishmentHistory' | cxTranslate }}\n        </h4>\n        <h3 *ngIf=\"!type.replenishmentOrder\">\n          {{ 'orderHistory.orderHistory' | cxTranslate }}\n        </h3>\n      </div>\n\n      <!-- BODY -->\n      <div class=\"cx-order-history-body\">\n        <ng-container\n          *ngIf=\"type.orderHistory.pagination.totalResults > 0; else noOrder\"\n        >\n          <!-- Select Form and Pagination Top -->\n          <div class=\"cx-order-history-sort top row\">\n            <label\n              class=\"\n                cx-order-history-form-group\n                form-group\n                col-sm-12 col-md-4 col-lg-4\n              \"\n              ><span>\n                {{ 'orderHistory.sortBy' | cxTranslate }}\n              </span>\n              <cx-sorting\n                [sortOptions]=\"type.orderHistory.sorts\"\n                [sortLabels]=\"getSortLabels() | async\"\n                (sortListEvent)=\"changeSortCode($event)\"\n                [selectedOption]=\"type.orderHistory.pagination.sort\"\n                placeholder=\"{{ 'orderHistory.sortBy' | cxTranslate }}\"\n              ></cx-sorting>\n            </label>\n            <div\n              *ngIf=\"type.orderHistory.pagination.totalPages > 1\"\n              class=\"cx-order-history-pagination\"\n            >\n              <cx-pagination\n                [pagination]=\"type.orderHistory.pagination\"\n                (viewPageEvent)=\"pageChange($event)\"\n              ></cx-pagination>\n            </div>\n          </div>\n          <!-- TABLE -->\n          <table class=\"table cx-order-history-table\">\n            <thead class=\"cx-order-history-thead-mobile\">\n              <th scope=\"col\">\n                {{ 'orderHistory.orderId' | cxTranslate }}\n              </th>\n              <th scope=\"col\">{{ 'orderHistory.date' | cxTranslate }}</th>\n              <th scope=\"col\">\n                {{ 'orderHistory.status' | cxTranslate }}\n              </th>\n              <th scope=\"col\">{{ 'orderHistory.total' | cxTranslate }}</th>\n            </thead>\n            <tbody>\n              <tr\n                *ngFor=\"let order of type.orderHistory.orders\"\n                (click)=\"goToOrderDetail(order)\"\n              >\n                <td class=\"cx-order-history-code\">\n                  <div class=\"d-md-none cx-order-history-label\">\n                    {{ 'orderHistory.orderId' | cxTranslate }}\n                  </div>\n                  <a\n                    [routerLink]=\"\n                      {\n                        cxRoute: 'orderDetails',\n                        params: order\n                      } | cxUrl\n                    \"\n                    class=\"cx-order-history-value\"\n                  >\n                    {{ order?.code }}</a\n                  >\n                </td>\n                <td class=\"cx-order-history-placed\">\n                  <div class=\"d-md-none cx-order-history-label\">\n                    {{ 'orderHistory.date' | cxTranslate }}\n                  </div>\n                  <a\n                    [routerLink]=\"\n                      {\n                        cxRoute: 'orderDetails',\n                        params: order\n                      } | cxUrl\n                    \"\n                    class=\"cx-order-history-value\"\n                    >{{ order?.placed | cxDate: 'longDate' }}</a\n                  >\n                </td>\n                <td class=\"cx-order-history-status\">\n                  <div class=\"d-md-none cx-order-history-label\">\n                    {{ 'orderHistory.status' | cxTranslate }}\n                  </div>\n                  <a\n                    [routerLink]=\"\n                      {\n                        cxRoute: 'orderDetails',\n                        params: order\n                      } | cxUrl\n                    \"\n                    class=\"cx-order-history-value\"\n                  >\n                    {{\n                      'orderDetails.statusDisplay_' + order?.statusDisplay\n                        | cxTranslate\n                    }}</a\n                  >\n                </td>\n                <td class=\"cx-order-history-total\">\n                  <div class=\"d-md-none cx-order-history-label\">\n                    {{ 'orderHistory.total' | cxTranslate }}\n                  </div>\n                  <a\n                    [routerLink]=\"\n                      {\n                        cxRoute: 'orderDetails',\n                        params: order\n                      } | cxUrl\n                    \"\n                    class=\"cx-order-history-value\"\n                  >\n                    {{ order?.total.formattedValue }}</a\n                  >\n                </td>\n              </tr>\n            </tbody>\n          </table>\n          <!-- Select Form and Pagination Bottom -->\n          <div class=\"cx-order-history-sort bottom row\">\n            <div\n              *ngIf=\"type.orderHistory.pagination.totalPages > 1\"\n              class=\"cx-order-history-pagination\"\n            >\n              <cx-pagination\n                [pagination]=\"type.orderHistory.pagination\"\n                (viewPageEvent)=\"pageChange($event)\"\n              ></cx-pagination>\n            </div>\n          </div>\n        </ng-container>\n\n        <!-- NO ORDER CONTAINER -->\n        <ng-template #noOrder>\n          <div\n            *ngIf=\"isLoaded$ | async\"\n            [ngClass]=\"\n              type.replenishmentOrder\n                ? 'cx-replenishment-details-order-history-no-order row'\n                : 'cx-order-history-no-order row'\n            \"\n          >\n            <div\n              [ngClass]=\"\n                type.replenishmentOrder ? '' : 'col-sm-12 col-md-6 col-lg-4'\n              \"\n            >\n              <ng-container *ngIf=\"type.replenishmentOrder; else otherOrder\">\n                <div>{{ 'orderHistory.notFound' | cxTranslate }}</div>\n              </ng-container>\n\n              <ng-template #otherOrder>\n                <div>{{ 'orderHistory.noOrders' | cxTranslate }}</div>\n                <a\n                  [routerLink]=\"{ cxRoute: 'home' } | cxUrl\"\n                  routerLinkActive=\"active\"\n                  class=\"btn btn-primary btn-block\"\n                  >{{ 'orderHistory.startShopping' | cxTranslate }}</a\n                >\n              </ng-template>\n            </div>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </ng-container>\n</ng-container>\n"]}