UNPKG

@spartacus/storefront

Version:

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

171 lines 34 kB
import { ChangeDetectionStrategy, Component, Input } from '@angular/core'; import { combineLatest } from 'rxjs'; import { filter, map } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@spartacus/core"; import * as i2 from "../card/card.component"; import * as i3 from "@angular/common"; export class OrderOverviewComponent { constructor(translation) { this.translation = translation; } set setOrder(order) { this.order = order; } getReplenishmentCodeCardContent(orderCode) { return this.translation.translate('orderDetails.replenishmentId').pipe(filter(() => Boolean(orderCode)), map((textTitle) => ({ title: textTitle, text: [orderCode], }))); } getReplenishmentActiveCardContent(active) { return combineLatest([ this.translation.translate('orderDetails.status'), this.translation.translate('orderDetails.active'), this.translation.translate('orderDetails.cancelled'), ]).pipe(map(([textTitle, textActive, textCancelled]) => ({ title: textTitle, text: [active ? textActive : textCancelled], }))); } getReplenishmentStartOnCardContent(isoDate) { return this.translation.translate('orderDetails.startOn').pipe(filter(() => Boolean(isoDate)), map((textTitle) => { return { title: textTitle, text: [isoDate], }; })); } getReplenishmentFrequencyCardContent(frequency) { return this.translation.translate('orderDetails.frequency').pipe(filter(() => Boolean(frequency)), map((textTitle) => ({ title: textTitle, text: [frequency], }))); } getReplenishmentNextDateCardContent(isoDate) { return this.translation.translate('orderDetails.nextOrderDate').pipe(filter(() => Boolean(isoDate)), map((textTitle) => { return { title: textTitle, text: [isoDate], }; })); } getOrderCodeCardContent(orderCode) { return this.translation.translate('orderDetails.orderNumber').pipe(filter(() => Boolean(orderCode)), map((textTitle) => ({ title: textTitle, text: [orderCode], }))); } getOrderCurrentDateCardContent(isoDate) { return this.translation.translate('orderDetails.placedOn').pipe(filter(() => Boolean(isoDate)), map((textTitle) => { return { title: textTitle, text: [isoDate], }; })); } getOrderStatusCardContent(status) { return combineLatest([ this.translation.translate('orderDetails.status'), this.translation.translate('orderDetails.statusDisplay_' + status), ]).pipe(map(([textTitle, textStatus]) => ({ title: textTitle, text: [textStatus], }))); } getPurchaseOrderNumber(poNumber) { return combineLatest([ this.translation.translate('orderDetails.purchaseOrderNumber'), this.translation.translate('orderDetails.emptyPurchaseOrderId'), ]).pipe(map(([textTitle, noneTextTitle]) => ({ title: textTitle, text: [poNumber ? poNumber : noneTextTitle], }))); } getMethodOfPaymentCardContent(hasPaymentInfo) { return combineLatest([ this.translation.translate('orderDetails.methodOfPayment'), this.translation.translate('paymentTypes.paymentType_ACCOUNT'), this.translation.translate('paymentTypes.paymentType_CARD'), ]).pipe(map(([textTitle, textAccount, textCard]) => ({ title: textTitle, text: [Boolean(hasPaymentInfo) ? textCard : textAccount], }))); } getCostCenterCardContent(costCenter) { return this.translation.translate('orderDetails.costCenter').pipe(filter(() => Boolean(costCenter)), map((textTitle) => { var _a; return ({ title: textTitle, textBold: costCenter === null || costCenter === void 0 ? void 0 : costCenter.name, text: ['(' + ((_a = costCenter === null || costCenter === void 0 ? void 0 : costCenter.unit) === null || _a === void 0 ? void 0 : _a.name) + ')'], }); })); } getAddressCardContent(deliveryAddress) { return this.translation.translate('addressCard.shipTo').pipe(filter(() => Boolean(deliveryAddress)), map((textTitle) => { const formattedAddress = this.normalizeFormattedAddress(deliveryAddress.formattedAddress); return { title: textTitle, textBold: `${deliveryAddress.firstName} ${deliveryAddress.lastName}`, text: [formattedAddress, deliveryAddress.country.name], }; })); } getDeliveryModeCardContent(deliveryMode) { return this.translation.translate('orderDetails.shippingMethod').pipe(filter(() => Boolean(deliveryMode)), map((textTitle) => { var _a, _b; return ({ title: textTitle, textBold: deliveryMode.name, text: [ deliveryMode.description, ((_a = deliveryMode.deliveryCost) === null || _a === void 0 ? void 0 : _a.formattedValue) ? (_b = deliveryMode.deliveryCost) === null || _b === void 0 ? void 0 : _b.formattedValue : '', ], }); })); } getPaymentInfoCardContent(payment) { return combineLatest([ this.translation.translate('paymentForm.payment'), this.translation.translate('paymentCard.expires', { month: Boolean(payment) ? payment.expiryMonth : '', year: Boolean(payment) ? payment.expiryYear : '', }), ]).pipe(filter(() => Boolean(payment)), map(([textTitle, textExpires]) => ({ title: textTitle, textBold: payment.accountHolderName, text: [payment.cardNumber, textExpires], }))); } getBillingAddressCardContent(billingAddress) { return this.translation.translate('paymentForm.billingAddress').pipe(filter(() => Boolean(billingAddress)), map((textTitle) => ({ title: textTitle, textBold: `${billingAddress.firstName} ${billingAddress.lastName}`, text: [billingAddress.formattedAddress, billingAddress.country.name], }))); } normalizeFormattedAddress(formattedAddress) { const addresses = formattedAddress .split(',') .map((address) => address.trim()); const newFormattedAddress = addresses.filter(Boolean).join(', '); return newFormattedAddress; } } OrderOverviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OrderOverviewComponent, deps: [{ token: i1.TranslationService }], target: i0.ɵɵFactoryTarget.Component }); OrderOverviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: OrderOverviewComponent, selector: "cx-order-overview", inputs: { setOrder: ["order", "setOrder"] }, ngImport: i0, template: "<div class=\"cx-order-summary\">\n <div class=\"container\">\n <ng-container *ngIf=\"order.replenishmentOrderCode; else otherOrder\">\n <div class=\"cx-summary-card\">\n <cx-card\n [content]=\"\n getReplenishmentCodeCardContent(order?.replenishmentOrderCode)\n | async\n \"\n ></cx-card>\n\n <cx-card\n [content]=\"getReplenishmentActiveCardContent(order?.active) | async\"\n ></cx-card>\n </div>\n\n <div class=\"cx-summary-card\">\n <cx-card\n [content]=\"\n getReplenishmentStartOnCardContent(order?.firstDate | cxDate)\n | async\n \"\n ></cx-card>\n\n <cx-card\n [content]=\"\n getReplenishmentFrequencyCardContent(\n order?.trigger?.displayTimeTable\n ) | async\n \"\n ></cx-card>\n\n <cx-card\n [content]=\"\n getReplenishmentNextDateCardContent(\n order?.trigger?.activationTime | cxDate\n ) | async\n \"\n ></cx-card>\n </div>\n </ng-container>\n\n <ng-template #otherOrder>\n <div class=\"cx-summary-card\">\n <cx-card\n [content]=\"getOrderCodeCardContent(order?.code) | async\"\n ></cx-card>\n\n <cx-card\n [content]=\"\n getOrderCurrentDateCardContent(order?.created | cxDate) | async\n \"\n ></cx-card>\n\n <cx-card\n [content]=\"getOrderStatusCardContent(order.statusDisplay) | async\"\n ></cx-card>\n </div>\n </ng-template>\n\n <ng-container\n *ngIf=\"order.purchaseOrderNumber || order.purchaseOrderNumber === ''\"\n >\n <div class=\"cx-summary-card\">\n <cx-card\n [content]=\"getPurchaseOrderNumber(order?.purchaseOrderNumber) | async\"\n ></cx-card>\n\n <cx-card\n [content]=\"getMethodOfPaymentCardContent(order.paymentInfo) | async\"\n ></cx-card>\n\n <ng-container *ngIf=\"order.costCenter\">\n <cx-card\n [content]=\"getCostCenterCardContent(order?.costCenter) | async\"\n ></cx-card>\n </ng-container>\n </div>\n </ng-container>\n\n <div class=\"cx-summary-card\">\n <ng-container *ngIf=\"order.deliveryAddress\">\n <cx-card\n [content]=\"getAddressCardContent(order?.deliveryAddress) | async\"\n ></cx-card>\n </ng-container>\n\n <ng-container *ngIf=\"order.deliveryMode\">\n <cx-card\n [content]=\"getDeliveryModeCardContent(order?.deliveryMode) | async\"\n ></cx-card>\n </ng-container>\n </div>\n\n <ng-container *ngIf=\"order.paymentInfo\">\n <div class=\"cx-summary-card\">\n <cx-card\n [content]=\"getPaymentInfoCardContent(order?.paymentInfo) | async\"\n ></cx-card>\n\n <cx-card\n [content]=\"\n getBillingAddressCardContent(order?.paymentInfo?.billingAddress)\n | async\n \"\n ></cx-card>\n </div>\n </ng-container>\n </div>\n</div>\n", components: [{ type: i2.CardComponent, selector: "cx-card", inputs: ["border", "editMode", "isDefault", "content", "fitToContainer", "truncateText", "charactersLimit"], outputs: ["deleteCard", "setDefaultCard", "sendCard", "editCard", "cancelCard"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i3.AsyncPipe, "cxDate": i1.CxDatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OrderOverviewComponent, decorators: [{ type: Component, args: [{ selector: 'cx-order-overview', templateUrl: './order-overview.component.html', changeDetection: ChangeDetectionStrategy.OnPush, }] }], ctorParameters: function () { return [{ type: i1.TranslationService }]; }, propDecorators: { setOrder: [{ type: Input, args: ['order'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-overview.component.js","sourceRoot":"","sources":["../../../../../../projects/storefrontlib/shared/components/order-overview/order-overview.component.ts","../../../../../../projects/storefrontlib/shared/components/order-overview/order-overview.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAQ1E,OAAO,EAAE,aAAa,EAAc,MAAM,MAAM,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;AAQ7C,MAAM,OAAO,sBAAsB;IAQjC,YAAsB,WAA+B;QAA/B,gBAAW,GAAX,WAAW,CAAoB;IAAG,CAAC;IALzD,IACI,QAAQ,CAAC,KAAU;QACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAID,+BAA+B,CAAC,SAAiB;QAC/C,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,8BAA8B,CAAC,CAAC,IAAI,CACpE,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAChC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAClB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,SAAS,CAAC;SAClB,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,iCAAiC,CAAC,MAAe;QAC/C,OAAO,aAAa,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;YACjD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;YACjD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,wBAAwB,CAAC;SACrD,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,UAAU,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;YAC/C,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC;SAC5C,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,kCAAkC,CAAC,OAAe;QAChD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAC5D,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAC9B,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;YAChB,OAAO;gBACL,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,oCAAoC,CAAC,SAAiB;QACpD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAC9D,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAChC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAClB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,SAAS,CAAC;SAClB,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,mCAAmC,CAAC,OAAe;QACjD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,4BAA4B,CAAC,CAAC,IAAI,CAClE,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAC9B,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;YAChB,OAAO;gBACL,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,SAAiB;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,IAAI,CAChE,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAChC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAClB,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,SAAS,CAAC;SAClB,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,8BAA8B,CAAC,OAAe;QAC5C,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC,IAAI,CAC7D,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAC9B,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;YAChB,OAAO;gBACL,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,CAAC,OAAO,CAAC;aAChB,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,yBAAyB,CAAC,MAAc;QACtC,OAAO,aAAa,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;YACjD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,6BAA6B,GAAG,MAAM,CAAC;SACnE,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC;YAChC,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,UAAU,CAAC;SACnB,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,sBAAsB,CAAC,QAAgB;QACrC,OAAO,aAAa,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,kCAAkC,CAAC;YAC9D,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,mCAAmC,CAAC;SAChE,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;YACnC,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC;SAC5C,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,6BAA6B,CAC3B,cAA8B;QAE9B,OAAO,aAAa,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,8BAA8B,CAAC;YAC1D,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,kCAAkC,CAAC;YAC9D,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,+BAA+B,CAAC;SAC5D,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;YAC3C,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC;SACzD,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,wBAAwB,CAAC,UAAsB;QAC7C,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,yBAAyB,CAAC,CAAC,IAAI,CAC/D,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,EACjC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;;YAAC,OAAA,CAAC;gBAClB,KAAK,EAAE,SAAS;gBAChB,QAAQ,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI;gBAC1B,IAAI,EAAE,CAAC,GAAG,IAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI,0CAAE,IAAI,CAAA,GAAG,GAAG,CAAC;aAC3C,CAAC,CAAA;SAAA,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,qBAAqB,CAAC,eAAwB;QAC5C,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC,IAAI,CAC1D,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,EACtC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;YAChB,MAAM,gBAAgB,GAAG,IAAI,CAAC,yBAAyB,CACrD,eAAe,CAAC,gBAAgB,CACjC,CAAC;YAEF,OAAO;gBACL,KAAK,EAAE,SAAS;gBAChB,QAAQ,EAAE,GAAG,eAAe,CAAC,SAAS,IAAI,eAAe,CAAC,QAAQ,EAAE;gBACpE,IAAI,EAAE,CAAC,gBAAgB,EAAE,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC;aACvD,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,0BAA0B,CAAC,YAA0B;QACnD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,6BAA6B,CAAC,CAAC,IAAI,CACnE,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,EACnC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;;YAAC,OAAA,CAAC;gBAClB,KAAK,EAAE,SAAS;gBAChB,QAAQ,EAAE,YAAY,CAAC,IAAI;gBAC3B,IAAI,EAAE;oBACJ,YAAY,CAAC,WAAW;oBACxB,CAAA,MAAA,YAAY,CAAC,YAAY,0CAAE,cAAc;wBACvC,CAAC,CAAC,MAAA,YAAY,CAAC,YAAY,0CAAE,cAAc;wBAC3C,CAAC,CAAC,EAAE;iBACP;aACF,CAAC,CAAA;SAAA,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,yBAAyB,CAAC,OAAuB;QAC/C,OAAO,aAAa,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,CAAC;YACjD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,qBAAqB,EAAE;gBAChD,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;gBAClD,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE;aACjD,CAAC;SACH,CAAC,CAAC,IAAI,CACL,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAC9B,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,CAAC;YACjC,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE,OAAO,CAAC,iBAAiB;YACnC,IAAI,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE,WAAW,CAAC;SACxC,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED,4BAA4B,CAAC,cAAuB;QAClD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,4BAA4B,CAAC,CAAC,IAAI,CAClE,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,EACrC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAClB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE,GAAG,cAAc,CAAC,SAAS,IAAI,cAAc,CAAC,QAAQ,EAAE;YAClE,IAAI,EAAE,CAAC,cAAc,CAAC,gBAAgB,EAAE,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC;SACrE,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAEO,yBAAyB,CAAC,gBAAwB;QACxD,MAAM,SAAS,GAAG,gBAAgB;aAC/B,KAAK,CAAC,GAAG,CAAC;aACV,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QAEpC,MAAM,mBAAmB,GAAG,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEjE,OAAO,mBAAmB,CAAC;IAC7B,CAAC;;mHAhNU,sBAAsB;uGAAtB,sBAAsB,sGCjBnC,ilGA8GA;2FD7Fa,sBAAsB;kBALlC,SAAS;mBAAC;oBACT,QAAQ,EAAE,mBAAmB;oBAC7B,WAAW,EAAE,iCAAiC;oBAC9C,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;yGAKK,QAAQ;sBADX,KAAK;uBAAC,OAAO","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport {\n  Address,\n  CostCenter,\n  DeliveryMode,\n  PaymentDetails,\n  TranslationService,\n} from '@spartacus/core';\nimport { combineLatest, Observable } from 'rxjs';\nimport { filter, map } from 'rxjs/operators';\nimport { Card } from '../card/card.component';\n\n@Component({\n  selector: 'cx-order-overview',\n  templateUrl: './order-overview.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OrderOverviewComponent {\n  order: any;\n\n  @Input('order')\n  set setOrder(order: any) {\n    this.order = order;\n  }\n\n  constructor(protected translation: TranslationService) {}\n\n  getReplenishmentCodeCardContent(orderCode: string): Observable<Card> {\n    return this.translation.translate('orderDetails.replenishmentId').pipe(\n      filter(() => Boolean(orderCode)),\n      map((textTitle) => ({\n        title: textTitle,\n        text: [orderCode],\n      }))\n    );\n  }\n\n  getReplenishmentActiveCardContent(active: boolean): Observable<Card> {\n    return combineLatest([\n      this.translation.translate('orderDetails.status'),\n      this.translation.translate('orderDetails.active'),\n      this.translation.translate('orderDetails.cancelled'),\n    ]).pipe(\n      map(([textTitle, textActive, textCancelled]) => ({\n        title: textTitle,\n        text: [active ? textActive : textCancelled],\n      }))\n    );\n  }\n\n  getReplenishmentStartOnCardContent(isoDate: string): Observable<Card> {\n    return this.translation.translate('orderDetails.startOn').pipe(\n      filter(() => Boolean(isoDate)),\n      map((textTitle) => {\n        return {\n          title: textTitle,\n          text: [isoDate],\n        };\n      })\n    );\n  }\n\n  getReplenishmentFrequencyCardContent(frequency: string): Observable<Card> {\n    return this.translation.translate('orderDetails.frequency').pipe(\n      filter(() => Boolean(frequency)),\n      map((textTitle) => ({\n        title: textTitle,\n        text: [frequency],\n      }))\n    );\n  }\n\n  getReplenishmentNextDateCardContent(isoDate: string): Observable<Card> {\n    return this.translation.translate('orderDetails.nextOrderDate').pipe(\n      filter(() => Boolean(isoDate)),\n      map((textTitle) => {\n        return {\n          title: textTitle,\n          text: [isoDate],\n        };\n      })\n    );\n  }\n\n  getOrderCodeCardContent(orderCode: string): Observable<Card> {\n    return this.translation.translate('orderDetails.orderNumber').pipe(\n      filter(() => Boolean(orderCode)),\n      map((textTitle) => ({\n        title: textTitle,\n        text: [orderCode],\n      }))\n    );\n  }\n\n  getOrderCurrentDateCardContent(isoDate: string): Observable<Card> {\n    return this.translation.translate('orderDetails.placedOn').pipe(\n      filter(() => Boolean(isoDate)),\n      map((textTitle) => {\n        return {\n          title: textTitle,\n          text: [isoDate],\n        };\n      })\n    );\n  }\n\n  getOrderStatusCardContent(status: string): Observable<Card> {\n    return combineLatest([\n      this.translation.translate('orderDetails.status'),\n      this.translation.translate('orderDetails.statusDisplay_' + status),\n    ]).pipe(\n      map(([textTitle, textStatus]) => ({\n        title: textTitle,\n        text: [textStatus],\n      }))\n    );\n  }\n\n  getPurchaseOrderNumber(poNumber: string): Observable<Card> {\n    return combineLatest([\n      this.translation.translate('orderDetails.purchaseOrderNumber'),\n      this.translation.translate('orderDetails.emptyPurchaseOrderId'),\n    ]).pipe(\n      map(([textTitle, noneTextTitle]) => ({\n        title: textTitle,\n        text: [poNumber ? poNumber : noneTextTitle],\n      }))\n    );\n  }\n\n  getMethodOfPaymentCardContent(\n    hasPaymentInfo: PaymentDetails\n  ): Observable<Card> {\n    return combineLatest([\n      this.translation.translate('orderDetails.methodOfPayment'),\n      this.translation.translate('paymentTypes.paymentType_ACCOUNT'),\n      this.translation.translate('paymentTypes.paymentType_CARD'),\n    ]).pipe(\n      map(([textTitle, textAccount, textCard]) => ({\n        title: textTitle,\n        text: [Boolean(hasPaymentInfo) ? textCard : textAccount],\n      }))\n    );\n  }\n\n  getCostCenterCardContent(costCenter: CostCenter): Observable<Card> {\n    return this.translation.translate('orderDetails.costCenter').pipe(\n      filter(() => Boolean(costCenter)),\n      map((textTitle) => ({\n        title: textTitle,\n        textBold: costCenter?.name,\n        text: ['(' + costCenter?.unit?.name + ')'],\n      }))\n    );\n  }\n\n  getAddressCardContent(deliveryAddress: Address): Observable<Card> {\n    return this.translation.translate('addressCard.shipTo').pipe(\n      filter(() => Boolean(deliveryAddress)),\n      map((textTitle) => {\n        const formattedAddress = this.normalizeFormattedAddress(\n          deliveryAddress.formattedAddress\n        );\n\n        return {\n          title: textTitle,\n          textBold: `${deliveryAddress.firstName} ${deliveryAddress.lastName}`,\n          text: [formattedAddress, deliveryAddress.country.name],\n        };\n      })\n    );\n  }\n\n  getDeliveryModeCardContent(deliveryMode: DeliveryMode): Observable<Card> {\n    return this.translation.translate('orderDetails.shippingMethod').pipe(\n      filter(() => Boolean(deliveryMode)),\n      map((textTitle) => ({\n        title: textTitle,\n        textBold: deliveryMode.name,\n        text: [\n          deliveryMode.description,\n          deliveryMode.deliveryCost?.formattedValue\n            ? deliveryMode.deliveryCost?.formattedValue\n            : '',\n        ],\n      }))\n    );\n  }\n\n  getPaymentInfoCardContent(payment: PaymentDetails): Observable<Card> {\n    return combineLatest([\n      this.translation.translate('paymentForm.payment'),\n      this.translation.translate('paymentCard.expires', {\n        month: Boolean(payment) ? payment.expiryMonth : '',\n        year: Boolean(payment) ? payment.expiryYear : '',\n      }),\n    ]).pipe(\n      filter(() => Boolean(payment)),\n      map(([textTitle, textExpires]) => ({\n        title: textTitle,\n        textBold: payment.accountHolderName,\n        text: [payment.cardNumber, textExpires],\n      }))\n    );\n  }\n\n  getBillingAddressCardContent(billingAddress: Address): Observable<Card> {\n    return this.translation.translate('paymentForm.billingAddress').pipe(\n      filter(() => Boolean(billingAddress)),\n      map((textTitle) => ({\n        title: textTitle,\n        textBold: `${billingAddress.firstName} ${billingAddress.lastName}`,\n        text: [billingAddress.formattedAddress, billingAddress.country.name],\n      }))\n    );\n  }\n\n  private normalizeFormattedAddress(formattedAddress: string): string {\n    const addresses = formattedAddress\n      .split(',')\n      .map((address) => address.trim());\n\n    const newFormattedAddress = addresses.filter(Boolean).join(', ');\n\n    return newFormattedAddress;\n  }\n}\n","<div class=\"cx-order-summary\">\n  <div class=\"container\">\n    <ng-container *ngIf=\"order.replenishmentOrderCode; else otherOrder\">\n      <div class=\"cx-summary-card\">\n        <cx-card\n          [content]=\"\n            getReplenishmentCodeCardContent(order?.replenishmentOrderCode)\n              | async\n          \"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"getReplenishmentActiveCardContent(order?.active) | async\"\n        ></cx-card>\n      </div>\n\n      <div class=\"cx-summary-card\">\n        <cx-card\n          [content]=\"\n            getReplenishmentStartOnCardContent(order?.firstDate | cxDate)\n              | async\n          \"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"\n            getReplenishmentFrequencyCardContent(\n              order?.trigger?.displayTimeTable\n            ) | async\n          \"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"\n            getReplenishmentNextDateCardContent(\n              order?.trigger?.activationTime | cxDate\n            ) | async\n          \"\n        ></cx-card>\n      </div>\n    </ng-container>\n\n    <ng-template #otherOrder>\n      <div class=\"cx-summary-card\">\n        <cx-card\n          [content]=\"getOrderCodeCardContent(order?.code) | async\"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"\n            getOrderCurrentDateCardContent(order?.created | cxDate) | async\n          \"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"getOrderStatusCardContent(order.statusDisplay) | async\"\n        ></cx-card>\n      </div>\n    </ng-template>\n\n    <ng-container\n      *ngIf=\"order.purchaseOrderNumber || order.purchaseOrderNumber === ''\"\n    >\n      <div class=\"cx-summary-card\">\n        <cx-card\n          [content]=\"getPurchaseOrderNumber(order?.purchaseOrderNumber) | async\"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"getMethodOfPaymentCardContent(order.paymentInfo) | async\"\n        ></cx-card>\n\n        <ng-container *ngIf=\"order.costCenter\">\n          <cx-card\n            [content]=\"getCostCenterCardContent(order?.costCenter) | async\"\n          ></cx-card>\n        </ng-container>\n      </div>\n    </ng-container>\n\n    <div class=\"cx-summary-card\">\n      <ng-container *ngIf=\"order.deliveryAddress\">\n        <cx-card\n          [content]=\"getAddressCardContent(order?.deliveryAddress) | async\"\n        ></cx-card>\n      </ng-container>\n\n      <ng-container *ngIf=\"order.deliveryMode\">\n        <cx-card\n          [content]=\"getDeliveryModeCardContent(order?.deliveryMode) | async\"\n        ></cx-card>\n      </ng-container>\n    </div>\n\n    <ng-container *ngIf=\"order.paymentInfo\">\n      <div class=\"cx-summary-card\">\n        <cx-card\n          [content]=\"getPaymentInfoCardContent(order?.paymentInfo) | async\"\n        ></cx-card>\n\n        <cx-card\n          [content]=\"\n            getBillingAddressCardContent(order?.paymentInfo?.billingAddress)\n              | async\n          \"\n        ></cx-card>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}