@vendure/admin-ui-plugin 2.0.0-next.1 → 2.0.0-next.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/lib/admin-ui/165.6aeb6ecf722558ee.js +2 -0
  2. package/lib/admin-ui/165.6aeb6ecf722558ee.js.map +1 -0
  3. package/lib/admin-ui/239.a68e402e10b798f1.js +2 -0
  4. package/lib/admin-ui/{239.a5ff17f86dbb8ca2.js.map → 239.a68e402e10b798f1.js.map} +1 -1
  5. package/lib/admin-ui/26.477d6446134d960e.js +2 -0
  6. package/lib/admin-ui/{26.2b116578fae1ff6d.js.map → 26.477d6446134d960e.js.map} +1 -1
  7. package/lib/admin-ui/316.07f9c805e4c95dc8.js +2 -0
  8. package/lib/admin-ui/{316.bc52480ffba2e8c2.js.map → 316.07f9c805e4c95dc8.js.map} +1 -1
  9. package/lib/admin-ui/349.abe4847f7fe9b3da.js +2 -0
  10. package/lib/admin-ui/349.abe4847f7fe9b3da.js.map +1 -0
  11. package/lib/admin-ui/356.3a6951fe80b5a001.js +2 -0
  12. package/lib/admin-ui/{356.52ad52413445b7ae.js.map → 356.3a6951fe80b5a001.js.map} +1 -1
  13. package/lib/admin-ui/600.8f0165a8d1255cd0.js +2 -0
  14. package/lib/admin-ui/{600.7fb6e9620c160fac.js.map → 600.8f0165a8d1255cd0.js.map} +1 -1
  15. package/lib/admin-ui/625.adebc6a7222bde82.js +2 -0
  16. package/lib/admin-ui/{625.dcecbc707b7d4b98.js.map → 625.adebc6a7222bde82.js.map} +1 -1
  17. package/lib/admin-ui/849.cc032ddf77c67cc3.js +2 -0
  18. package/lib/admin-ui/849.cc032ddf77c67cc3.js.map +1 -0
  19. package/lib/admin-ui/i18n-messages/cs.json +2 -0
  20. package/lib/admin-ui/i18n-messages/de.json +2 -0
  21. package/lib/admin-ui/i18n-messages/en.json +3 -1
  22. package/lib/admin-ui/i18n-messages/es.json +2 -0
  23. package/lib/admin-ui/i18n-messages/fr.json +2 -0
  24. package/lib/admin-ui/i18n-messages/it.json +2 -0
  25. package/lib/admin-ui/i18n-messages/pl.json +2 -0
  26. package/lib/admin-ui/i18n-messages/pt_BR.json +2 -0
  27. package/lib/admin-ui/i18n-messages/pt_PT.json +2 -0
  28. package/lib/admin-ui/i18n-messages/ru.json +2 -0
  29. package/lib/admin-ui/i18n-messages/uk.json +2 -0
  30. package/lib/admin-ui/i18n-messages/zh_Hans.json +2 -0
  31. package/lib/admin-ui/i18n-messages/zh_Hant.json +2 -0
  32. package/lib/admin-ui/index.html +1 -1
  33. package/lib/admin-ui/main.0b0d9a8ae6759254.js +2740 -0
  34. package/lib/admin-ui/main.0b0d9a8ae6759254.js.map +1 -0
  35. package/lib/admin-ui/runtime.1dd1cbaf09547dd2.js +2 -0
  36. package/lib/admin-ui/{runtime.8bab7ff9a8ad6db6.js.map → runtime.1dd1cbaf09547dd2.js.map} +1 -1
  37. package/lib/admin-ui/vendure-ui-config.json +25 -10
  38. package/lib/src/plugin.js +1 -0
  39. package/lib/src/plugin.js.map +1 -1
  40. package/package.json +4 -4
  41. package/lib/admin-ui/165.acb9630c44bb0271.js +0 -2
  42. package/lib/admin-ui/165.acb9630c44bb0271.js.map +0 -1
  43. package/lib/admin-ui/239.a5ff17f86dbb8ca2.js +0 -2
  44. package/lib/admin-ui/26.2b116578fae1ff6d.js +0 -2
  45. package/lib/admin-ui/316.bc52480ffba2e8c2.js +0 -2
  46. package/lib/admin-ui/349.6f8a30060cc86ada.js +0 -2
  47. package/lib/admin-ui/349.6f8a30060cc86ada.js.map +0 -1
  48. package/lib/admin-ui/356.52ad52413445b7ae.js +0 -2
  49. package/lib/admin-ui/600.7fb6e9620c160fac.js +0 -2
  50. package/lib/admin-ui/625.dcecbc707b7d4b98.js +0 -2
  51. package/lib/admin-ui/849.56aaa5a0d453cfdf.js +0 -2
  52. package/lib/admin-ui/849.56aaa5a0d453cfdf.js.map +0 -1
  53. package/lib/admin-ui/main.8a7673f3d80ec5da.js +0 -2739
  54. package/lib/admin-ui/main.8a7673f3d80ec5da.js.map +0 -1
  55. package/lib/admin-ui/runtime.8bab7ff9a8ad6db6.js +0 -2
@@ -1 +0,0 @@
1
- {"version":3,"mappings":"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","names":["e","cancel","submit","constructor","n","this","a","method","transactionId","ngOnInit","paymentMethods$","dataService","settings","getPaymentMethods","mapSingle","paymentMethods","items","form","value","resolveWith","V","selectors","checkIfAllSelected","select","reasons","map","t","i18nService","translate","selectionCount","Object","values","lineQuantities","reduce","order","lines","id","quantity","radioChanged","cancelAll","o","entries","i","find","l","orderId","getLineInputs","reason","cancelShipping","active","orderLineId","filter","B","getGlobalSettings","single$","subscribe","globalSettings","fulfillmentQuantities","getFulfillableCount","trackInventory","fulfillCount","max","changeDetector","markForCheck","shippingMethod","getShippingMethodOperations","fulfillmentHandlers","fulfillmentHandlerDef","code","shippingLines","fulfillmentHandlerCode","fulfillmentHandler","fulfillmentHandlerControl","patchValue","stockOnHand","productVariant","s","c","getUnfulfilledCount","Math","min","fulfillment","canSubmit","valid","handler","W","chipColorType","state","G","b","customFieldConfig","serverConfigService","getCustomFieldsFor","ngOnChanges","buildCustomFieldsFormGroup","fulfillments","fulfillmentId","Map","orderItems","includes","get","name","set","Array","from","customFields","customFieldFormGroup","addControl","customFieldIsObject","isArray","S","N","oxw","transitionState","nextSuggestedState","nextStates","nextOtherStates","K","line","fulfilledCount","getDeliveredCount","fulfillmentStatus","getFulfillmentStatus","length","getFulfillments","count","D","getRefundedCount","payments","refunds","refundId","cancelled","L","added","removed","getModifiedLines","addedItems","removedItems","getSurcharge","surcharges","getAddedItems","getRemovedItems","modification","getOrderLineAndItem","item","_","x","u","onUpdateClick","z","customFieldForm","formBuilder","group","customFieldsConfig","control","customFieldValues","updateClick","emit","markAsPristine","editable","ee","Fe","Ie","isCancellable","node","to","active$","next","getPos","elementRef","nativeElement","getBoundingClientRect","querySelector","height","y","index","getStyle","j","asObservable","pipe","en","activeTarget$","abs","sqrt","transform","onMouseOver","onMouseOut","te","outerHeight","nodes","setActiveState$","initialState","activeState$","Ve","populateNodes","ngAfterViewInit","setTimeout","populateEdges","getNodeFor","nodeComponents","states","push","edges","ne","getOrderProcessStates","re","refundTotal","refund","proratedUnitPriceWithTax","refundShipping","shippingWithTax","adjustment","settledPaymentsTotal","settledPayments","amount","lineCanBeRefundedOrCancelled","selectedPayment","handleZeroQuantity","isRefunding","isCancelling","getOrderLineInput","shipping","paymentId","oe","ie","selectedState","le","transitionToPreModifyingState","getPreModifyingState","message","cancellable","retry","transitionToStateOrThrow","An","manuallyTransitionToState","modalService","fromComponent","locals","closable","size","k","Error","We","$e","r","bn","Ln","getOrderHistory","type","eq","sort","createdAt","history","data","transitionToState","transitionOrderToState","__typename","notificationService","error","transitionError","I","factory","visibleOrderLineCustomFields","orderLineCustomFieldsVisible","orderLineCustomFields","showElided","getLineCustomFields","toggleOrderLineCustomFields","getLineDiscounts","discounts","config","formGroup","customFieldsForLine","getPromotionLink","adjustmentSource","split","getCouponCodeForAdjustment","promotions","couponCode","R","H","updateNote","deleteNote","getDisplayType","getTimelineIcon","isFeatured","getFulfillment","getPayment","getCancelledItems","orderItemIds","getModification","modifications","getName","administrator","firstName","lastName","customer","addNoteToOrder","addNote","note","isPublic","noteIsPrivate","ae","ce","settleRefund","de","refundHasMetadata","keys","metadata","payment","addManualPayment","transitionToModifying","cancelOrRefund","se","openStateDiagram","fulfillOrder","settlePayment","transitionPaymentState","transitionFulfillment","updateCustomFields","super","init","entity$","router","navigate","relativeTo","route","getCustomFieldConfig","history$","fetchHistory","h","mapStream","nextStates$","Y","defaultStates","ngOnDestroy","destroy","activeState","success","g","orderTransitionService","updateOrderCustomFields","entity","getOrderAddressLines","getOrder","transitionPaymentToState","canAddFulfillment","every","hasUnsettledModifications","outstandingPaymentAmount","isSettled","getOutstandingModificationAmount","q","totalWithTax","outstandingAmount","currencyCode","addManualPaymentToOrder","Le","refetchOrder","result","createFulfillment","E","addFulfillmentToOrder","fulfillmentHandlerError","JSON","stringify","transitionFulfillmentToState","orderHasSettledPayments","refundOrder","cancelOrder","displayPrivacyControls","updateOrderNote","noteId","isPrivate","dialog","title","body","buttons","label","returnValue","deleteOrderNote","setFormValues","ue","A","priceDifference","originalTotalWithTax","refundNote","modifyOrderInput","Cancel","Payment","Refund","refundPaymentId","PriceUnchanged","pe","transitionToPriorState","updateLineQuantity","updateAddedItemQuantity","removeAddedItem","removeSurcharge","previewAndModify","dryRun","addItems","adjustOrderLines","updateShippingAddress","updateBillingAddress","addedLines","addedVariants","productVariantId","price","priceWithTax","addressCustomFields","snapshot","paramMap","destroy$","surchargeForm","description","sku","priceIncludesTax","taxRate","taxDescription","shippingAddressForm","fullName","shippingAddress","company","streetLine1","streetLine2","city","province","postalCode","countryCode","phoneNumber","addAddressCustomFieldsFormGroup","billingAddressForm","w","billingAddress","M","Pe","Se","Ne","Je","Ue","Qe","De","orderLineCustomFieldsFormArray","Oe","ke","Ae","valueChanges","Te","ii","addItemCustomFieldsFormArray","addItemCustomFieldsForm","availableCountries$","getAvailableCountries","countries","lo","take","previousState","canPreviewChanges","dirty","isLineModified","splice","indexOf","trackByProductVariantId","getSelectedItemPrice","addItemToOrder","isMatchingAddItemRow","reset","addItemSelectedVariant","removeAt","getSurchargePrices","round","addSurcharge","options","recalculateShipping","modifyOrder","me","selectFilterPreset","orderStates","setQueryFn","getOrders","skip","refetchOnChannelChange","orders","createQueryOptions","searchOrderCodeControl","searchLastNameControl","queryParamMap","localStorageService","setQueryParam","replaceUrl","activePreset$","Ho","be","refresh","customFilterForm","getAll","placedAtStart","placedAtEnd","page","applyCustomFilters","filterPresets","in","orderPlacedAt","between","start","end","after","before","customerLastName","contains","updatedAt","getShippingNames","join","_e","total","F","rt","path","component","breadcrumb","resolve","canDeactivate","Me","ot","breadcrumbKey","slice","link","concat","ge"],"sources":["./src/lib/order/src/components/add-manual-payment-dialog/add-manual-payment-dialog.component.html","./src/lib/order/src/components/add-manual-payment-dialog/add-manual-payment-dialog.component.ts","./src/lib/order/src/components/cancel-order-dialog/cancel-order-dialog.component.html","./src/lib/order/src/components/cancel-order-dialog/cancel-order-dialog.component.ts","./src/lib/order/src/components/fulfill-order-dialog/fulfill-order-dialog.component.html","./src/lib/order/src/components/fulfill-order-dialog/fulfill-order-dialog.component.ts","./src/lib/order/src/components/fulfillment-state-label/fulfillment-state-label.component.html","./src/lib/order/src/components/fulfillment-state-label/fulfillment-state-label.component.ts","./src/lib/order/src/components/simple-item-list/simple-item-list.component.html","./src/lib/order/src/components/simple-item-list/simple-item-list.component.ts","./src/lib/order/src/components/fulfillment-detail/fulfillment-detail.component.html","./src/lib/order/src/components/fulfillment-detail/fulfillment-detail.component.ts","./src/lib/order/src/components/fulfillment-card/fulfillment-card.component.html","./src/lib/order/src/components/fulfillment-card/fulfillment-card.component.ts","./src/lib/order/src/components/line-fulfillment/line-fulfillment.component.html","./src/lib/order/src/components/line-fulfillment/line-fulfillment.component.ts","./src/lib/order/src/components/line-refunds/line-refunds.component.html","./src/lib/order/src/components/line-refunds/line-refunds.component.ts","./src/lib/order/src/components/modification-detail/modification-detail.component.html","./src/lib/order/src/components/modification-detail/modification-detail.component.ts","./src/lib/order/src/components/order-custom-fields-card/order-custom-fields-card.component.html","./src/lib/order/src/components/order-custom-fields-card/order-custom-fields-card.component.ts","./src/lib/order/src/components/order-process-graph/constants.ts","./src/lib/order/src/components/order-process-graph/order-process-node.component.html","./src/lib/order/src/components/order-process-graph/order-process-node.component.ts","./src/lib/order/src/components/order-process-graph/order-process-edge.component.ts","./src/lib/order/src/components/order-process-graph/order-process-graph.component.html","./src/lib/order/src/components/order-process-graph/order-process-edge.component.html","./src/lib/order/src/components/order-process-graph/order-process-graph.component.ts","./src/lib/order/src/components/order-process-graph-dialog/order-process-graph-dialog.component.html","./src/lib/order/src/components/order-process-graph-dialog/order-process-graph-dialog.component.ts","./src/lib/order/src/components/refund-order-dialog/refund-order-dialog.component.html","./src/lib/order/src/components/refund-order-dialog/refund-order-dialog.component.ts","./src/lib/order/src/components/settle-refund-dialog/settle-refund-dialog.component.html","./src/lib/order/src/components/settle-refund-dialog/settle-refund-dialog.component.ts","./src/lib/order/src/components/order-state-select-dialog/order-state-select-dialog.component.html","./src/lib/order/src/components/order-state-select-dialog/order-state-select-dialog.component.ts","./src/lib/order/src/providers/order-transition.service.ts","./node_modules/@angular-devkit/build-angular/src/babel/webpack-loader.js","./src/lib/order/src/components/order-table/order-table.component.html","./src/lib/order/src/components/order-table/order-table.component.ts","./src/lib/order/src/components/payment-detail/payment-detail.component.html","./src/lib/order/src/components/payment-detail/payment-detail.component.ts","./src/lib/order/src/components/order-history/order-history.component.html","./src/lib/order/src/components/order-history/order-history.component.ts","./src/lib/order/src/components/payment-state-label/payment-state-label.component.html","./src/lib/order/src/components/payment-state-label/payment-state-label.component.ts","./src/lib/order/src/components/refund-state-label/refund-state-label.component.html","./src/lib/order/src/components/refund-state-label/refund-state-label.component.ts","./src/lib/order/src/components/order-payment-card/order-payment-card.component.html","./src/lib/order/src/components/order-payment-card/order-payment-card.component.ts","./src/lib/order/src/components/order-detail/order-detail.component.html","./src/lib/order/src/components/order-detail/order-detail.component.ts","./src/lib/order/src/components/order-edits-preview-dialog/order-edits-preview-dialog.component.ts","./src/lib/order/src/components/order-edits-preview-dialog/order-edits-preview-dialog.component.html","./src/lib/order/src/components/order-editor/order-editor.component.html","./src/lib/order/src/components/order-editor/order-editor.component.ts","./src/lib/order/src/components/order-list/order-list.component.html","./src/lib/order/src/components/order-list/order-list.component.ts","./src/lib/order/src/providers/routing/order-resolver.ts","./src/lib/order/src/order.routes.ts","./src/lib/order/src/order.module.ts"],"sourcesContent":["<ng-template vdrDialogTitle>{{ 'order.add-payment-to-order' | translate }}</ng-template>\r\n<form [formGroup]=\"form\">\r\n <vdr-form-field [label]=\"'order.payment-method' | translate\" for=\"method\">\r\n <ng-select\r\n [items]=\"paymentMethods$ | async\"\r\n bindLabel=\"code\"\r\n autofocus\r\n bindValue=\"code\"\r\n [addTag]=\"true\"\r\n formControlName=\"method\"\r\n ></ng-select>\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'order.transaction-id' | translate\" for=\"transactionId\">\r\n <input id=\"transactionId\" type=\"text\" formControlName=\"transactionId\" />\r\n </vdr-form-field>\r\n</form>\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"submit()\" class=\"btn btn-primary\" [disabled]=\"form.invalid || form.pristine\">\r\n {{ 'order.add-payment' | translate }} ({{ outstandingAmount | localeCurrency: currencyCode }})\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\r\nimport {\r\n CurrencyCode,\r\n DataService,\r\n Dialog,\r\n GetPaymentMethodListQuery,\r\n ItemOf,\r\n ManualPaymentInput,\r\n} from '@vendure/admin-ui/core';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n selector: 'vdr-add-manual-payment-dialog',\r\n templateUrl: './add-manual-payment-dialog.component.html',\r\n styleUrls: ['./add-manual-payment-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AddManualPaymentDialogComponent implements OnInit, Dialog<Omit<ManualPaymentInput, 'orderId'>> {\r\n // populated by ModalService call\r\n outstandingAmount: number;\r\n currencyCode: CurrencyCode;\r\n\r\n resolveWith: (result?: Omit<ManualPaymentInput, 'orderId'>) => void;\r\n form = new FormGroup({\r\n method: new FormControl('', Validators.required),\r\n transactionId: new FormControl('', Validators.required),\r\n });\r\n paymentMethods$: Observable<Array<ItemOf<GetPaymentMethodListQuery, 'paymentMethods'>>>;\r\n constructor(private dataService: DataService) {}\r\n\r\n ngOnInit(): void {\r\n this.paymentMethods$ = this.dataService.settings\r\n .getPaymentMethods(999)\r\n .mapSingle(data => data.paymentMethods.items);\r\n }\r\n\r\n submit() {\r\n const formValue = this.form.value;\r\n this.resolveWith({\r\n method: formValue.method,\r\n transactionId: formValue.transactionId,\r\n });\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.cancel-order' | translate }}</ng-template>\r\n\r\n<div class=\"fulfillment-wrapper\">\r\n <div class=\"order-lines\">\r\n <table class=\"table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.quantity' | translate }}</th>\r\n <th>{{ 'order.unit-price' | translate }}</th>\r\n <th>{{ 'order.cancel' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tr\r\n *ngFor=\"let line of order.lines\"\r\n class=\"order-line\"\r\n [class.is-disabled]=\"cancelAll\"\r\n [class.is-cancelled]=\"line.quantity === 0\"\r\n >\r\n <td class=\"align-middle thumb\">\r\n <img [src]=\"line.featuredAsset | assetPreview:'tiny'\" />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle quantity\">{{ line.quantity }}</td>\r\n <td class=\"align-middle quantity\">\r\n {{ line.unitPriceWithTax | localeCurrency: order.currencyCode }}\r\n </td>\r\n <td class=\"align-middle fulfil\">\r\n <input\r\n *ngIf=\"line.quantity > 0 && !order.active; else nonEditable\"\r\n [(ngModel)]=\"lineQuantities[line.id]\"\r\n (input)=\"checkIfAllSelected()\"\r\n [disabled]=\"cancelAll\"\r\n type=\"number\"\r\n [max]=\"line.quantity\"\r\n min=\"0\"\r\n />\r\n <ng-template #nonEditable>{{ line.quantity }}</ng-template>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n <div class=\"cancellation-details\">\r\n <clr-radio-wrapper>\r\n <input type=\"radio\" clrRadio [value]=\"true\" [(ngModel)]=\"cancelAll\" name=\"options\" (ngModelChange)=\"radioChanged()\" />\r\n <label>{{ 'order.cancel-entire-order' | translate }}</label>\r\n </clr-radio-wrapper>\r\n <clr-radio-wrapper>\r\n <input type=\"radio\" clrRadio [value]=\"false\" [(ngModel)]=\"cancelAll\" name=\"options\" (ngModelChange)=\"radioChanged()\" />\r\n <label>{{ 'order.cancel-specified-items' | translate }}</label>\r\n </clr-radio-wrapper>\r\n <label class=\"clr-control-label\">{{ 'order.cancellation-reason' | translate }}</label>\r\n <ng-select\r\n [items]=\"reasons\"\r\n bindLabel=\"name\"\r\n autofocus\r\n bindValue=\"id\"\r\n [addTag]=\"true\"\r\n [(ngModel)]=\"reason\"\r\n ></ng-select>\r\n </div>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button\r\n type=\"submit\"\r\n (click)=\"select()\"\r\n [disabled]=\"!reason || (!order.active && selectionCount === 0)\"\r\n class=\"btn btn-primary\"\r\n >\r\n <ng-container *ngIf=\"!order.active\">\r\n {{ 'order.cancel-selected-items' | translate }}\r\n </ng-container>\r\n <ng-container *ngIf=\"order.active\">\r\n {{ 'order.cancel-order' | translate }}\r\n </ng-container>\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n CancelOrderInput,\r\n Dialog,\r\n I18nService,\r\n OrderDetailFragment,\r\n OrderLineInput,\r\n} from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-cancel-order-dialog',\r\n templateUrl: './cancel-order-dialog.component.html',\r\n styleUrls: ['./cancel-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class CancelOrderDialogComponent implements OnInit, Dialog<CancelOrderInput> {\r\n order: OrderDetailFragment;\r\n cancelAll = true;\r\n resolveWith: (result?: CancelOrderInput) => void;\r\n reason: string;\r\n lineQuantities: { [lineId: string]: number } = {};\r\n reasons: string[] = [_('order.cancel-reason-customer-request'), _('order.cancel-reason-not-available')];\r\n\r\n get selectionCount(): number {\r\n return Object.values(this.lineQuantities).reduce((sum, n) => sum + n, 0);\r\n }\r\n\r\n constructor(private i18nService: I18nService) {\r\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\r\n }\r\n\r\n ngOnInit() {\r\n this.lineQuantities = this.order.lines.reduce((result, line) => {\r\n return { ...result, [line.id]: line.quantity };\r\n }, {});\r\n }\r\n\r\n radioChanged() {\r\n if (this.cancelAll) {\r\n for (const line of this.order.lines) {\r\n this.lineQuantities[line.id] = line.quantity;\r\n }\r\n } else {\r\n for (const line of this.order.lines) {\r\n this.lineQuantities[line.id] = 0;\r\n }\r\n }\r\n }\r\n\r\n checkIfAllSelected() {\r\n for (const [lineId, quantity] of Object.entries(this.lineQuantities)) {\r\n const quantityInOrder = this.order.lines.find(line => line.id === lineId)?.quantity;\r\n if (quantityInOrder && quantity < quantityInOrder) {\r\n return;\r\n }\r\n }\r\n // If we got here, all of the selected quantities are equal to the order\r\n // line quantities, i.e. everything is selected.\r\n this.cancelAll = true;\r\n }\r\n\r\n select() {\r\n this.resolveWith({\r\n orderId: this.order.id,\r\n lines: this.getLineInputs(),\r\n reason: this.reason,\r\n cancelShipping: this.cancelAll,\r\n });\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n private getLineInputs(): OrderLineInput[] | undefined {\r\n if (this.order.active) {\r\n return;\r\n }\r\n return Object.entries(this.lineQuantities)\r\n .map(([orderLineId, quantity]) => ({\r\n orderLineId,\r\n quantity,\r\n }))\r\n .filter(l => 0 < l.quantity);\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.fulfill-order' | translate }}</ng-template>\r\n\r\n<div class=\"fulfillment-wrapper\">\r\n <div class=\"order-table\">\r\n <table class=\"table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.unfulfilled' | translate }}</th>\r\n <th>{{ 'catalog.stock-on-hand' | translate }}</th>\r\n <th>{{ 'order.fulfill' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tr\r\n *ngFor=\"let line of order.lines\"\r\n class=\"order-line\"\r\n [class.ignore]=\"getUnfulfilledCount(line) === 0\"\r\n >\r\n <td class=\"align-middle thumb\">\r\n <img *ngIf=\"line.featuredAsset\" [src]=\"line.featuredAsset | assetPreview: 'tiny'\" />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle quantity\">{{ getUnfulfilledCount(line) }}</td>\r\n <td class=\"align-middle quantity\">{{ line.productVariant.stockOnHand }}</td>\r\n <td class=\"align-middle fulfil\">\r\n <input\r\n *ngIf=\"fulfillmentQuantities[line.id]\"\r\n [disabled]=\"getUnfulfilledCount(line) === 0\"\r\n [(ngModel)]=\"fulfillmentQuantities[line.id].fulfillCount\"\r\n type=\"number\"\r\n [max]=\"fulfillmentQuantities[line.id].max\"\r\n min=\"0\"\r\n />\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n <div class=\"shipping-details\">\r\n <vdr-formatted-address [address]=\"order.shippingAddress\"></vdr-formatted-address>\r\n <h6>{{ 'order.shipping-method' | translate }}</h6>\r\n {{ order.shippingLines[0]?.shippingMethod?.name }}\r\n <strong>{{ order.shipping | localeCurrency: order.currencyCode }}</strong>\r\n <vdr-configurable-input\r\n [operationDefinition]=\"fulfillmentHandlerDef\"\r\n [operation]=\"fulfillmentHandler\"\r\n [formControl]=\"fulfillmentHandlerControl\"\r\n [removable]=\"false\"\r\n ></vdr-configurable-input>\r\n </div>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"select()\" [disabled]=\"!canSubmit()\" class=\"btn btn-primary\">\r\n {{ 'order.create-fulfillment' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport {\r\n configurableDefinitionToInstance,\r\n ConfigurableOperation,\r\n ConfigurableOperationDefinition,\r\n configurableOperationValueIsValid,\r\n DataService,\r\n Dialog,\r\n FulfillOrderInput,\r\n GlobalFlag,\r\n OrderDetailFragment,\r\n toConfigurableOperationInput,\r\n} from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-fulfill-order-dialog',\r\n templateUrl: './fulfill-order-dialog.component.html',\r\n styleUrls: ['./fulfill-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FulfillOrderDialogComponent implements Dialog<FulfillOrderInput>, OnInit {\r\n resolveWith: (result?: FulfillOrderInput) => void;\r\n fulfillmentHandlerDef: ConfigurableOperationDefinition;\r\n fulfillmentHandler: ConfigurableOperation;\r\n fulfillmentHandlerControl = new FormControl();\r\n fulfillmentQuantities: { [lineId: string]: { fulfillCount: number; max: number } } = {};\r\n\r\n // Provided by modalService.fromComponent() call\r\n order: OrderDetailFragment;\r\n\r\n constructor(private dataService: DataService, private changeDetector: ChangeDetectorRef) {}\r\n\r\n ngOnInit(): void {\r\n this.dataService.settings.getGlobalSettings().single$.subscribe(({ globalSettings }) => {\r\n this.fulfillmentQuantities = this.order.lines.reduce((result, line) => {\r\n const fulfillCount = this.getFulfillableCount(line, globalSettings.trackInventory);\r\n return {\r\n ...result,\r\n [line.id]: { fulfillCount, max: fulfillCount },\r\n };\r\n }, {});\r\n this.changeDetector.markForCheck();\r\n });\r\n\r\n this.dataService.shippingMethod\r\n .getShippingMethodOperations()\r\n .mapSingle(data => data.fulfillmentHandlers)\r\n .subscribe(handlers => {\r\n this.fulfillmentHandlerDef =\r\n handlers.find(\r\n h => h.code === this.order.shippingLines[0]?.shippingMethod?.fulfillmentHandlerCode,\r\n ) || handlers[0];\r\n this.fulfillmentHandler = configurableDefinitionToInstance(this.fulfillmentHandlerDef);\r\n this.fulfillmentHandlerControl.patchValue(this.fulfillmentHandler);\r\n this.changeDetector.markForCheck();\r\n });\r\n }\r\n\r\n getFulfillableCount(line: OrderDetailFragment['lines'][number], globalTrackInventory: boolean): number {\r\n const { trackInventory, stockOnHand } = line.productVariant;\r\n const effectiveTracInventory =\r\n trackInventory === GlobalFlag.INHERIT ? globalTrackInventory : trackInventory === GlobalFlag.TRUE;\r\n\r\n const unfulfilledCount = this.getUnfulfilledCount(line);\r\n return effectiveTracInventory ? Math.min(unfulfilledCount, stockOnHand) : unfulfilledCount;\r\n }\r\n\r\n getUnfulfilledCount(line: OrderDetailFragment['lines'][number]): number {\r\n const fulfilled = line.items.reduce((sum, item) => sum + (item.fulfillment ? 1 : 0), 0);\r\n return line.quantity - fulfilled;\r\n }\r\n\r\n canSubmit(): boolean {\r\n const totalCount = Object.values(this.fulfillmentQuantities).reduce(\r\n (total, { fulfillCount }) => total + fulfillCount,\r\n 0,\r\n );\r\n const formIsValid =\r\n configurableOperationValueIsValid(\r\n this.fulfillmentHandlerDef,\r\n this.fulfillmentHandlerControl.value,\r\n ) && this.fulfillmentHandlerControl.valid;\r\n return formIsValid && 0 < totalCount;\r\n }\r\n\r\n select() {\r\n const lines = Object.entries(this.fulfillmentQuantities).map(([orderLineId, { fulfillCount }]) => ({\r\n orderLineId,\r\n quantity: fulfillCount,\r\n }));\r\n this.resolveWith({\r\n lines,\r\n handler: toConfigurableOperationInput(\r\n this.fulfillmentHandler,\r\n this.fulfillmentHandlerControl.value,\r\n ),\r\n });\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n}\r\n","<vdr-chip [title]=\"'order.payment-state' | translate\" [colorType]=\"chipColorType\">\r\n <clr-icon shape=\"check-circle\" *ngIf=\"state === 'Delivered'\"></clr-icon>\r\n {{ state | stateI18nToken | translate }}\r\n</vdr-chip>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'vdr-fulfillment-state-label',\r\n templateUrl: './fulfillment-state-label.component.html',\r\n styleUrls: ['./fulfillment-state-label.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FulfillmentStateLabelComponent {\r\n @Input() state: string;\r\n\r\n get chipColorType() {\r\n switch (this.state) {\r\n case 'Pending':\r\n case 'Shipped':\r\n return 'warning';\r\n case 'Delivered':\r\n return 'success';\r\n case 'Cancelled':\r\n return 'error';\r\n }\r\n }\r\n}\r\n","<div class=\"items-list\">\r\n <ul>\r\n <li *ngFor=\"let item of items\" [title]=\"item.name\">\r\n <div class=\"quantity\">{{ item.quantity }}</div>\r\n <clr-icon shape=\"times\" size=\"12\"></clr-icon>\r\n {{ item.name }}\r\n </li>\r\n </ul>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'vdr-simple-item-list',\r\n templateUrl: './simple-item-list.component.html',\r\n styleUrls: ['./simple-item-list.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SimpleItemListComponent {\r\n @Input() items: Array<{ name: string; quantity: number }>;\r\n}\r\n","<vdr-labeled-data [label]=\"'common.created-at' | translate\">\r\n {{ fulfillment?.createdAt | localeDate: 'medium' }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data [label]=\"'order.fulfillment-method' | translate\">\r\n {{ fulfillment?.method }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data *ngIf=\"fulfillment?.trackingCode\" [label]=\"'order.tracking-code' | translate\">\r\n {{ fulfillment?.trackingCode }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data [label]=\"'order.contents' | translate\">\r\n <vdr-simple-item-list [items]=\"items\"></vdr-simple-item-list>\r\n</vdr-labeled-data>\r\n<ng-container *ngFor=\"let customField of customFieldConfig\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldFormGroup.get(customField.name)\"\r\n [readonly]=\"true\"\r\n [compact]=\"true\"\r\n [customField]=\"customField\"\r\n [customFieldsFormGroup]=\"customFieldFormGroup\"\r\n ></vdr-custom-field-control>\r\n</ng-container>\r\n","import { ChangeDetectionStrategy, Component, Input, OnChanges, OnInit, SimpleChanges } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { CustomFieldConfig, OrderDetailFragment, ServerConfigService } from '@vendure/admin-ui/core';\r\nimport { isObject } from '@vendure/common/lib/shared-utils';\r\n\r\n@Component({\r\n selector: 'vdr-fulfillment-detail',\r\n templateUrl: './fulfillment-detail.component.html',\r\n styleUrls: ['./fulfillment-detail.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FulfillmentDetailComponent implements OnInit, OnChanges {\r\n @Input() fulfillmentId: string;\r\n @Input() order: OrderDetailFragment;\r\n\r\n customFieldConfig: CustomFieldConfig[] = [];\r\n customFieldFormGroup = new FormGroup({});\r\n\r\n constructor(private serverConfigService: ServerConfigService) {}\r\n\r\n ngOnInit() {\r\n this.customFieldConfig = this.serverConfigService.getCustomFieldsFor('Fulfillment');\r\n }\r\n\r\n ngOnChanges(changes: SimpleChanges) {\r\n this.buildCustomFieldsFormGroup();\r\n }\r\n\r\n get fulfillment(): NonNullable<OrderDetailFragment['fulfillments']>[number] | undefined | null {\r\n return this.order.fulfillments && this.order.fulfillments.find(f => f.id === this.fulfillmentId);\r\n }\r\n\r\n get items(): Array<{ name: string; quantity: number }> {\r\n const itemMap = new Map<string, number>();\r\n const fulfillmentItemIds = this.fulfillment?.orderItems.map(i => i.id);\r\n for (const line of this.order.lines) {\r\n for (const item of line.items) {\r\n if (fulfillmentItemIds?.includes(item.id)) {\r\n const count = itemMap.get(line.productVariant.name);\r\n if (count != null) {\r\n itemMap.set(line.productVariant.name, count + 1);\r\n } else {\r\n itemMap.set(line.productVariant.name, 1);\r\n }\r\n }\r\n }\r\n }\r\n return Array.from(itemMap.entries()).map(([name, quantity]) => ({ name, quantity }));\r\n }\r\n\r\n buildCustomFieldsFormGroup() {\r\n const customFields = (this.fulfillment as any).customFields;\r\n for (const fieldDef of this.serverConfigService.getCustomFieldsFor('Fulfillment')) {\r\n this.customFieldFormGroup.addControl(fieldDef.name, new FormControl(customFields[fieldDef.name]));\r\n }\r\n }\r\n\r\n customFieldIsObject(customField: unknown) {\r\n return Array.isArray(customField) || isObject(customField);\r\n }\r\n}\r\n","<div class=\"card\">\r\n <div class=\"card-header fulfillment-header\">\r\n <div>{{ 'order.fulfillment' | translate }}</div>\r\n <div class=\"fulfillment-state\">\r\n <vdr-fulfillment-state-label [state]=\"fulfillment?.state\"></vdr-fulfillment-state-label>\r\n </div>\r\n </div>\r\n <div class=\"card-block\">\r\n <vdr-fulfillment-detail\r\n *ngIf=\"!!fulfillment\"\r\n [fulfillmentId]=\"fulfillment?.id\"\r\n [order]=\"order\"\r\n ></vdr-fulfillment-detail>\r\n </div>\r\n <div class=\"card-footer\" *ngIf=\"fulfillment?.nextStates.length\">\r\n <ng-container *ngIf=\"nextSuggestedState() as suggestedState\">\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"transitionState.emit(suggestedState)\">\r\n {{ 'order.set-fulfillment-state' | translate: { state: (suggestedState | stateI18nToken | translate) } }}\r\n </button>\r\n </ng-container>\r\n <vdr-dropdown>\r\n <button class=\"icon-button\" vdrDropdownTrigger>\r\n <clr-icon shape=\"ellipsis-vertical\"></clr-icon>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <ng-container *ngFor=\"let nextState of nextOtherStates()\">\r\n <button\r\n type=\"button\"\r\n class=\"btn\"\r\n vdrDropdownItem\r\n (click)=\"transitionState.emit(nextState)\"\r\n >\r\n <ng-container *ngIf=\"nextState !== 'Cancelled'; else cancel\">\r\n <clr-icon shape=\"step-forward-2\"></clr-icon>\r\n {{ 'order.transition-to-state' | translate: { state: (nextState | stateI18nToken | translate) } }}\r\n </ng-container>\r\n <ng-template #cancel>\r\n <clr-icon shape=\"error-standard\" class=\"is-error\"></clr-icon>\r\n {{ 'order.cancel-fulfillment' | translate }}\r\n </ng-template>\r\n </button>\r\n </ng-container>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { FulfillmentFragment, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-fulfillment-card',\r\n templateUrl: './fulfillment-card.component.html',\r\n styleUrls: ['./fulfillment-card.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FulfillmentCardComponent {\r\n @Input() fulfillment: FulfillmentFragment | undefined;\r\n @Input() order: OrderDetailFragment;\r\n @Output() transitionState = new EventEmitter<string>();\r\n\r\n nextSuggestedState(): string | undefined {\r\n if (!this.fulfillment) {\r\n return;\r\n }\r\n const { nextStates } = this.fulfillment;\r\n const namedStateOrDefault = (targetState: string) =>\r\n nextStates.includes(targetState) ? targetState : nextStates[0];\r\n switch (this.fulfillment?.state) {\r\n case 'Pending':\r\n return namedStateOrDefault('Shipped');\r\n case 'Shipped':\r\n return namedStateOrDefault('Delivered');\r\n default:\r\n return nextStates.find(s => s !== 'Cancelled');\r\n }\r\n }\r\n\r\n nextOtherStates(): string[] {\r\n if (!this.fulfillment) {\r\n return [];\r\n }\r\n const suggested = this.nextSuggestedState();\r\n return this.fulfillment.nextStates.filter(s => s !== suggested);\r\n }\r\n}\r\n","<vdr-dropdown class=\"search-settings-menu\" *ngIf=\"fulfilledCount || orderState === 'PartiallyDelivered'\">\r\n <button type=\"button\" class=\"icon-button\" vdrDropdownTrigger>\r\n <clr-icon *ngIf=\"fulfillmentStatus === 'full'\" class=\"item-fulfilled\" shape=\"check-circle\"></clr-icon>\r\n <clr-icon\r\n *ngIf=\"fulfillmentStatus === 'partial'\"\r\n class=\"item-partially-fulfilled\"\r\n shape=\"check-circle\"\r\n ></clr-icon>\r\n <clr-icon\r\n *ngIf=\"fulfillmentStatus === 'none'\"\r\n class=\"item-not-fulfilled\"\r\n shape=\"exclamation-circle\"\r\n ></clr-icon>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <label class=\"dropdown-header\" *ngIf=\"fulfillmentStatus === 'full'\">\r\n {{ 'order.line-fulfillment-all' | translate }}\r\n </label>\r\n <label class=\"dropdown-header\" *ngIf=\"fulfillmentStatus === 'partial'\">\r\n {{\r\n 'order.line-fulfillment-partial' | translate: { total: line.quantity, count: fulfilledCount }\r\n }}\r\n </label>\r\n <label class=\"dropdown-header\" *ngIf=\"fulfillmentStatus === 'none'\">\r\n {{ 'order.line-fulfillment-none' | translate }}\r\n </label>\r\n <div class=\"fulfillment-detail\" *ngFor=\"let item of fulfillments\">\r\n <div class=\"fulfillment-title\">\r\n {{ 'order.fulfillment' | translate }} #{{ item.fulfillment.id }} ({{\r\n 'order.item-count' | translate: { count: item.count }\r\n }})\r\n </div>\r\n <vdr-labeled-data [label]=\"'common.created-at' | translate\">\r\n {{ item.fulfillment.createdAt | localeDate: 'medium' }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.fulfillment-method' | translate\">\r\n {{ item.fulfillment.method }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data\r\n *ngIf=\"item.fulfillment.trackingCode\"\r\n [label]=\"'order.tracking-code' | translate\"\r\n >\r\n {{ item.fulfillment.trackingCode }}\r\n </vdr-labeled-data>\r\n </div>\r\n </vdr-dropdown-menu>\r\n</vdr-dropdown>\r\n","import { ChangeDetectionStrategy, Component, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\nexport type FulfillmentStatus = 'full' | 'partial' | 'none';\r\ntype Fulfillment = NonNullable<OrderDetailFragment['fulfillments']>[number];\r\n\r\n@Component({\r\n selector: 'vdr-line-fulfillment',\r\n templateUrl: './line-fulfillment.component.html',\r\n styleUrls: ['./line-fulfillment.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class LineFulfillmentComponent implements OnChanges {\r\n @Input() line: OrderDetailFragment['lines'][number];\r\n @Input() orderState: string;\r\n fulfilledCount = 0;\r\n fulfillmentStatus: FulfillmentStatus;\r\n fulfillments: Array<{\r\n count: number;\r\n fulfillment: Fulfillment;\r\n }> = [];\r\n\r\n ngOnChanges(changes: SimpleChanges): void {\r\n if (this.line) {\r\n this.fulfilledCount = this.getDeliveredCount(this.line);\r\n this.fulfillmentStatus = this.getFulfillmentStatus(this.fulfilledCount, this.line.items.length);\r\n this.fulfillments = this.getFulfillments(this.line);\r\n }\r\n }\r\n\r\n /**\r\n * Returns the number of items in an OrderLine which are fulfilled.\r\n */\r\n private getDeliveredCount(line: OrderDetailFragment['lines'][number]): number {\r\n return line.items.reduce((sum, item) => sum + (item.fulfillment ? 1 : 0), 0);\r\n }\r\n\r\n private getFulfillmentStatus(fulfilledCount: number, lineQuantity: number): FulfillmentStatus {\r\n if (fulfilledCount === lineQuantity) {\r\n return 'full';\r\n }\r\n if (0 < fulfilledCount && fulfilledCount < lineQuantity) {\r\n return 'partial';\r\n }\r\n return 'none';\r\n }\r\n\r\n private getFulfillments(\r\n line: OrderDetailFragment['lines'][number],\r\n ): Array<{ count: number; fulfillment: Fulfillment }> {\r\n const counts: { [fulfillmentId: string]: number } = {};\r\n\r\n for (const item of line.items) {\r\n if (item.fulfillment) {\r\n if (counts[item.fulfillment.id] === undefined) {\r\n counts[item.fulfillment.id] = 1;\r\n } else {\r\n counts[item.fulfillment.id]++;\r\n }\r\n }\r\n }\r\n const all = line.items.reduce((fulfillments, item) => {\r\n return item.fulfillment ? [...fulfillments, item.fulfillment] : fulfillments;\r\n }, [] as Fulfillment[]);\r\n\r\n return Object.entries(counts).map(([id, count]) => {\r\n return {\r\n count,\r\n // tslint:disable-next-line:no-non-null-assertion\r\n fulfillment: all.find(f => f.id === id)!,\r\n };\r\n });\r\n }\r\n}\r\n","<span *ngIf=\"getRefundedCount()\" [title]=\"'order.refunded-count' | translate: { count: getRefundedCount() }\">\r\n <clr-icon shape=\"redo\" class=\"is-solid\" dir=\"down\"></clr-icon>\r\n</span>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\nimport { OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-line-refunds',\r\n templateUrl: './line-refunds.component.html',\r\n styleUrls: ['./line-refunds.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class LineRefundsComponent {\r\n @Input() line: OrderDetailFragment['lines'][number];\r\n @Input() payments: OrderDetailFragment['payments'];\r\n\r\n getRefundedCount(): number {\r\n const refunds =\r\n this.payments?.reduce(\r\n (all, payment) => [...all, ...payment.refunds],\r\n [] as NonNullable<OrderDetailFragment['payments']>[number]['refunds'],\r\n ) ?? [];\r\n return this.line.items.filter(i => {\r\n if (i.refundId === null && !i.cancelled) {\r\n return false;\r\n }\r\n if (i.refundId) {\r\n const refund = refunds.find(r => r.id === i.refundId);\r\n if (refund?.state === 'Failed') {\r\n return false;\r\n } else {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }).length;\r\n }\r\n}\r\n","<vdr-labeled-data [label]=\"'common.ID' | translate\">{{ modification.id }}</vdr-labeled-data>\r\n<vdr-labeled-data *ngIf=\"modification.note\" [label]=\"'order.note' | translate\">{{\r\n modification.note\r\n}}</vdr-labeled-data>\r\n<vdr-labeled-data *ngFor=\"let surcharge of modification.surcharges\" [label]=\"'order.surcharges' | translate\">\r\n {{ getSurcharge(surcharge.id)?.description }}\r\n {{ getSurcharge(surcharge.id)?.priceWithTax | localeCurrency: order.currencyCode }}</vdr-labeled-data\r\n>\r\n<vdr-labeled-data *ngIf=\"getAddedItems().length\" [label]=\"'order.added-items' | translate\">\r\n <vdr-simple-item-list [items]=\"getAddedItems()\"></vdr-simple-item-list>\r\n</vdr-labeled-data>\r\n<vdr-labeled-data *ngIf=\"getRemovedItems().length\" [label]=\"'order.removed-items' | translate\">\r\n <vdr-simple-item-list [items]=\"getRemovedItems()\"></vdr-simple-item-list>\r\n</vdr-labeled-data>\r\n","import { ChangeDetectionStrategy, Component, Input, OnChanges, OnInit } from '@angular/core';\r\nimport { OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-modification-detail',\r\n templateUrl: './modification-detail.component.html',\r\n styleUrls: ['./modification-detail.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ModificationDetailComponent implements OnChanges {\r\n @Input() order: OrderDetailFragment;\r\n @Input() modification: OrderDetailFragment['modifications'][number];\r\n private addedItems = new Map<OrderDetailFragment['lines'][number], number>();\r\n private removedItems = new Map<OrderDetailFragment['lines'][number], number>();\r\n\r\n ngOnChanges(): void {\r\n const { added, removed } = this.getModifiedLines();\r\n this.addedItems = added;\r\n this.removedItems = removed;\r\n }\r\n\r\n getSurcharge(id: string) {\r\n return this.order.surcharges.find(m => m.id === id);\r\n }\r\n\r\n getAddedItems() {\r\n return [...this.addedItems.entries()].map(([line, count]) => {\r\n return { name: line.productVariant.name, quantity: count };\r\n });\r\n }\r\n\r\n getRemovedItems() {\r\n return [...this.removedItems.entries()].map(([line, count]) => {\r\n return { name: line.productVariant.name, quantity: count };\r\n });\r\n }\r\n\r\n private getModifiedLines() {\r\n const added = new Map<OrderDetailFragment['lines'][number], number>();\r\n const removed = new Map<OrderDetailFragment['lines'][number], number>();\r\n for (const _item of this.modification.orderItems || []) {\r\n const result = this.getOrderLineAndItem(_item.id);\r\n if (result) {\r\n const { line, item } = result;\r\n if (item.cancelled) {\r\n const count = removed.get(line) ?? 0;\r\n removed.set(line, count + 1);\r\n } else {\r\n const count = added.get(line) ?? 0;\r\n added.set(line, count + 1);\r\n }\r\n }\r\n }\r\n return { added, removed };\r\n }\r\n\r\n private getOrderLineAndItem(itemId: string) {\r\n for (const line of this.order.lines) {\r\n const item = line.items.find(i => i.id === itemId);\r\n if (item) {\r\n return { line, item };\r\n }\r\n }\r\n }\r\n}\r\n","<div class=\"card\" *ngIf=\"customFieldsConfig.length\">\r\n <div class=\"card-header\">\r\n {{ 'common.custom-fields' | translate }}\r\n </div>\r\n <div class=\"card-block\">\r\n <div class=\"card-text custom-field-form\" [class.editable]=\"editable\">\r\n <ng-container *ngFor=\"let customField of customFieldsConfig\">\r\n <vdr-custom-field-control\r\n entityName=\"Order\"\r\n [customFieldsFormGroup]=\"customFieldForm\"\r\n [compact]=\"true\"\r\n [readonly]=\"customField.readonly || !editable\"\r\n [customField]=\"customField\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"card-footer\">\r\n <button class=\"btn btn-sm btn-secondary\" (click)=\"editable = true\" *ngIf=\"!editable\">\r\n <clr-icon shape=\"pencil\"></clr-icon>\r\n {{ 'common.edit' | translate }}\r\n </button>\r\n <button\r\n class=\"btn btn-sm btn-primary\"\r\n (click)=\"onUpdateClick()\"\r\n *ngIf=\"editable\"\r\n [disabled]=\"customFieldForm.pristine || customFieldForm.invalid\"\r\n >\r\n <clr-icon shape=\"check\"></clr-icon>\r\n {{ 'common.update' | translate }}\r\n </button>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { CustomFieldConfig } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-order-custom-fields-card',\r\n templateUrl: './order-custom-fields-card.component.html',\r\n styleUrls: ['./order-custom-fields-card.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderCustomFieldsCardComponent implements OnInit {\r\n @Input() customFieldsConfig: CustomFieldConfig[] = [];\r\n @Input() customFieldValues: { [name: string]: any } = {};\r\n @Output() updateClick = new EventEmitter<any>();\r\n customFieldForm: FormGroup;\r\n editable = false;\r\n constructor(private formBuilder: FormBuilder) {}\r\n\r\n ngOnInit() {\r\n this.customFieldForm = this.formBuilder.group({});\r\n for (const field of this.customFieldsConfig) {\r\n this.customFieldForm.addControl(\r\n field.name,\r\n this.formBuilder.control(this.customFieldValues[field.name]),\r\n );\r\n }\r\n }\r\n\r\n onUpdateClick() {\r\n this.updateClick.emit(this.customFieldForm.value);\r\n this.customFieldForm.markAsPristine();\r\n this.editable = false;\r\n }\r\n}\r\n","export const NODE_HEIGHT = 72;\r\n","<div class=\"node-wrapper\" [ngStyle]=\"getStyle()\" [class.active]=\"active$ | async\">\r\n <div\r\n class=\"node\"\r\n [class.active-target]=\"activeTarget$ | async\"\r\n >\r\n {{ node.name | stateI18nToken | translate }}\r\n </div>\r\n <div class=\"cancelled-wrapper\" *ngIf=\"isCancellable\">\r\n <div class=\"cancelled-edge\">\r\n </div>\r\n <clr-icon shape=\"dot-circle\"></clr-icon>\r\n <div class=\"cancelled-node\">\r\n {{ cancelledState | stateI18nToken | translate }}\r\n </div>\r\n </div>\r\n</div>\r\n","import {\r\n ChangeDetectionStrategy,\r\n Component,\r\n ElementRef,\r\n Input,\r\n OnChanges,\r\n SimpleChanges,\r\n} from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { NODE_HEIGHT } from './constants';\r\nimport { StateNode } from './types';\r\n\r\n@Component({\r\n selector: 'vdr-order-process-node',\r\n templateUrl: './order-process-node.component.html',\r\n styleUrls: ['./order-process-node.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderProcessNodeComponent implements OnChanges {\r\n @Input() node: StateNode;\r\n @Input() index: number;\r\n @Input() active: boolean;\r\n active$ = new BehaviorSubject<boolean>(false);\r\n activeTarget$ = new BehaviorSubject<boolean>(false);\r\n isCancellable = false;\r\n // We use a class field here to prevent the\r\n // i18n extractor from extracting a \"Cancelled\" key\r\n cancelledState = 'Cancelled';\r\n\r\n constructor(private elementRef: ElementRef<HTMLDivElement>) {}\r\n\r\n ngOnChanges(changes: SimpleChanges) {\r\n this.isCancellable = !!this.node.to.find((s) => s.name === 'Cancelled');\r\n if (changes.active) {\r\n this.active$.next(this.active);\r\n }\r\n }\r\n\r\n getPos(origin: 'top' | 'bottom' = 'top'): { x: number; y: number } {\r\n const rect = this.elementRef.nativeElement.getBoundingClientRect();\r\n const nodeHeight =\r\n this.elementRef.nativeElement.querySelector('.node')?.getBoundingClientRect().height ?? 0;\r\n return {\r\n x: 10,\r\n y: this.index * NODE_HEIGHT + (origin === 'bottom' ? nodeHeight : 0),\r\n };\r\n }\r\n\r\n getStyle() {\r\n const pos = this.getPos();\r\n return {\r\n 'top.px': pos.y,\r\n 'left.px': pos.x,\r\n };\r\n }\r\n}\r\n","import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\n\r\nimport { OrderProcessNodeComponent } from './order-process-node.component';\r\n\r\n@Component({\r\n selector: 'vdr-order-process-edge',\r\n templateUrl: './order-process-edge.component.html',\r\n styleUrls: ['./order-process-edge.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderProcessEdgeComponent implements OnInit {\r\n @Input() from: OrderProcessNodeComponent;\r\n @Input() to: OrderProcessNodeComponent;\r\n @Input() index: number;\r\n active$: Observable<boolean>;\r\n\r\n ngOnInit() {\r\n this.active$ = this.from.active$\r\n .asObservable()\r\n .pipe(tap((active) => this.to.activeTarget$.next(active)));\r\n }\r\n\r\n getStyle() {\r\n const direction = this.from.index < this.to.index ? 'down' : 'up';\r\n const startPos = this.from.getPos(direction === 'down' ? 'bottom' : 'top');\r\n const endPos = this.to.getPos(direction === 'down' ? 'top' : 'bottom');\r\n const dX = Math.abs(startPos.x - endPos.x);\r\n const dY = Math.abs(startPos.y - endPos.y);\r\n const length = Math.sqrt(dX ** 2 + dY ** 2);\r\n return {\r\n 'top.px': startPos.y,\r\n 'left.px': startPos.x + (direction === 'down' ? 10 : 40) + this.index * 12,\r\n 'height.px': length,\r\n 'width.px': 1,\r\n ...(direction === 'up'\r\n ? {\r\n transform: 'rotateZ(180deg)',\r\n 'transform-origin': 'top',\r\n }\r\n : {}),\r\n };\r\n }\r\n}\r\n","<ng-container *ngFor=\"let state of nodes; let i = index\">\r\n <vdr-order-process-node\r\n [node]=\"state\"\r\n [index]=\"i\"\r\n [active]=\"(activeState$ | async) === state.name\"\r\n (mouseenter)=\"onMouseOver(state.name)\"\r\n (mouseleave)=\"onMouseOut()\"\r\n ></vdr-order-process-node>\r\n</ng-container>\r\n<ng-container *ngFor=\"let edge of edges\">\r\n <vdr-order-process-edge [from]=\"edge.from\" [to]=\"edge.to\" [index]=\"edge.index\"></vdr-order-process-edge>\r\n</ng-container>\r\n","<div\r\n [attr.data-from]=\"from.node.name\"\r\n [attr.data-to]=\"to.node.name\"\r\n [ngStyle]=\"getStyle()\"\r\n [class.active]=\"active$ | async\"\r\n class=\"edge\">\r\n <clr-icon shape=\"arrow\" flip=\"vertical\" class=\"arrow\"></clr-icon>\r\n</div>\r\n","import {\r\n AfterViewInit,\r\n ChangeDetectionStrategy,\r\n ChangeDetectorRef,\r\n Component,\r\n HostBinding,\r\n Input,\r\n OnChanges,\r\n OnInit,\r\n QueryList,\r\n SimpleChanges,\r\n ViewChildren,\r\n} from '@angular/core';\r\nimport { OrderProcessState } from '@vendure/admin-ui/core';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\n\r\nimport { NODE_HEIGHT } from './constants';\r\nimport { OrderProcessNodeComponent } from './order-process-node.component';\r\nimport { StateNode } from './types';\r\n\r\n@Component({\r\n selector: 'vdr-order-process-graph',\r\n templateUrl: './order-process-graph.component.html',\r\n styleUrls: ['./order-process-graph.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderProcessGraphComponent implements OnInit, OnChanges, AfterViewInit {\r\n @Input() states: OrderProcessState[];\r\n @Input() initialState?: string;\r\n setActiveState$ = new BehaviorSubject<string | undefined>(undefined);\r\n activeState$: Observable<string | undefined>;\r\n nodes: StateNode[] = [];\r\n edges: Array<{ from: OrderProcessNodeComponent; to: OrderProcessNodeComponent; index: number }> = [];\r\n\r\n @ViewChildren(OrderProcessNodeComponent) nodeComponents: QueryList<OrderProcessNodeComponent>;\r\n\r\n constructor(private changeDetector: ChangeDetectorRef) {}\r\n\r\n @HostBinding('style.height.px')\r\n get outerHeight(): number {\r\n return this.nodes.length * NODE_HEIGHT;\r\n }\r\n\r\n ngOnInit() {\r\n this.setActiveState$.next(this.initialState);\r\n this.activeState$ = this.setActiveState$.pipe(debounceTime(150));\r\n }\r\n\r\n ngOnChanges(changes: SimpleChanges) {\r\n this.populateNodes();\r\n }\r\n\r\n ngAfterViewInit() {\r\n setTimeout(() => this.populateEdges());\r\n }\r\n\r\n onMouseOver(stateName: string) {\r\n this.setActiveState$.next(stateName);\r\n }\r\n\r\n onMouseOut() {\r\n this.setActiveState$.next(this.initialState);\r\n }\r\n\r\n getNodeFor(state: string): OrderProcessNodeComponent | undefined {\r\n if (this.nodeComponents) {\r\n return this.nodeComponents.find((n) => n.node.name === state);\r\n }\r\n }\r\n\r\n private populateNodes() {\r\n const stateNodeMap = new Map<string, StateNode>();\r\n for (const state of this.states) {\r\n stateNodeMap.set(state.name, {\r\n name: state.name,\r\n to: [],\r\n });\r\n }\r\n\r\n for (const [name, stateNode] of stateNodeMap.entries()) {\r\n const targets = this.states.find((s) => s.name === name)?.to ?? [];\r\n for (const target of targets) {\r\n const targetNode = stateNodeMap.get(target);\r\n if (targetNode) {\r\n stateNode.to.push(targetNode);\r\n }\r\n }\r\n }\r\n this.nodes = [...stateNodeMap.values()].filter((n) => n.name !== 'Cancelled');\r\n }\r\n\r\n private populateEdges() {\r\n for (const node of this.nodes) {\r\n const nodeCmp = this.getNodeFor(node.name);\r\n let index = 0;\r\n for (const to of node.to) {\r\n const toCmp = this.getNodeFor(to.name);\r\n if (nodeCmp && toCmp && nodeCmp !== toCmp) {\r\n this.edges.push({\r\n to: toCmp,\r\n from: nodeCmp,\r\n index,\r\n });\r\n index++;\r\n }\r\n }\r\n }\r\n this.edges = [...this.edges];\r\n this.changeDetector.markForCheck();\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.order-state-diagram' | translate }}</ng-template>\r\n\r\n<vdr-order-process-graph [states]=\"states\" [initialState]=\"activeState\"></vdr-order-process-graph>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport {\r\n CancelOrderInput,\r\n DataService,\r\n Dialog,\r\n OrderProcessState,\r\n ServerConfigService,\r\n} from '@vendure/admin-ui/core';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n selector: 'vdr-order-process-graph-dialog',\r\n templateUrl: './order-process-graph-dialog.component.html',\r\n styleUrls: ['./order-process-graph-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderProcessGraphDialogComponent implements OnInit, Dialog<void> {\r\n activeState: string;\r\n states: OrderProcessState[] = [];\r\n constructor(private serverConfigService: ServerConfigService) {}\r\n\r\n ngOnInit(): void {\r\n this.states = this.serverConfigService.getOrderProcessStates();\r\n }\r\n\r\n resolveWith: (result: void | undefined) => void;\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.refund-and-cancel-order' | translate }}</ng-template>\r\n\r\n<div class=\"refund-wrapper\">\r\n <div class=\"order-table\">\r\n <table class=\"table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.quantity' | translate }}</th>\r\n <th>{{ 'order.unit-price' | translate }}</th>\r\n <th>{{ 'order.prorated-unit-price' | translate }}</th>\r\n <th>{{ 'order.quantity' | translate }}</th>\r\n <th>{{ 'order.refund' | translate }}</th>\r\n <th>{{ 'order.cancel' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tr *ngFor=\"let line of order.lines\" class=\"order-line\">\r\n <td class=\"align-middle thumb\">\r\n <img [src]=\"line.featuredAsset | assetPreview: 'tiny'\" />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle quantity\">\r\n {{ line.quantity }}\r\n <vdr-line-refunds [line]=\"line\" [payments]=\"order.payments\"></vdr-line-refunds>\r\n </td>\r\n <td class=\"align-middle quantity\">\r\n {{ line.unitPriceWithTax | localeCurrency: order.currencyCode }}\r\n </td>\r\n <td class=\"align-middle quantity\">\r\n <div class=\"prorated-wrapper\">\r\n {{ line.proratedUnitPriceWithTax | localeCurrency: order.currencyCode }}\r\n <ng-container *ngIf=\"line.discounts as discounts\">\r\n <vdr-dropdown *ngIf=\"discounts.length\">\r\n <div class=\"promotions-label\" vdrDropdownTrigger>\r\n <button class=\"icon-button\"><clr-icon shape=\"info\"></clr-icon></button>\r\n </div>\r\n <vdr-dropdown-menu>\r\n <div class=\"line-promotion\" *ngFor=\"let discount of discounts\">\r\n {{ discount.description }}\r\n <div class=\"promotion-amount\">\r\n {{\r\n discount.amount / 100 / line.quantity\r\n | number: '1.0-2'\r\n | currency: order.currencyCode\r\n }}\r\n </div>\r\n </div>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </ng-container>\r\n </div>\r\n </td>\r\n <td class=\"align-middle fulfil\">\r\n <input\r\n *ngIf=\"lineCanBeRefundedOrCancelled(line)\"\r\n [(ngModel)]=\"lineQuantities[line.id].quantity\"\r\n type=\"number\"\r\n [max]=\"line.quantity\"\r\n min=\"0\"\r\n (input)=\"handleZeroQuantity(lineQuantities[line.id])\"\r\n />\r\n </td>\r\n <td class=\"align-middle\">\r\n <div class=\"cancel-checkbox-wrapper\">\r\n <input\r\n type=\"checkbox\"\r\n *ngIf=\"lineCanBeRefundedOrCancelled(line)\"\r\n clrCheckbox\r\n [disabled]=\"0 === lineQuantities[line.id].quantity\"\r\n [(ngModel)]=\"lineQuantities[line.id].refund\"\r\n />\r\n </div>\r\n </td>\r\n <td class=\"align-middle\">\r\n <div class=\"cancel-checkbox-wrapper\">\r\n <input\r\n type=\"checkbox\"\r\n *ngIf=\"lineCanBeRefundedOrCancelled(line)\"\r\n clrCheckbox\r\n [disabled]=\"0 === lineQuantities[line.id].quantity\"\r\n [(ngModel)]=\"lineQuantities[line.id].cancel\"\r\n />\r\n </div>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n <div class=\"refund-details mt4\">\r\n <div>\r\n <label class=\"clr-control-label\">{{ 'order.refund-cancellation-reason' | translate }}</label>\r\n <ng-select\r\n [disabled]=\"!isRefunding() && !isCancelling()\"\r\n [items]=\"reasons\"\r\n bindLabel=\"name\"\r\n autofocus\r\n [placeholder]=\"'order.refund-cancellation-reason-required' | translate\"\r\n bindValue=\"id\"\r\n [addTag]=\"true\"\r\n [(ngModel)]=\"reason\"\r\n ></ng-select>\r\n </div>\r\n\r\n <div>\r\n <clr-select-container>\r\n <label>{{ 'order.payment-to-refund' | translate }}</label>\r\n <select clrSelect name=\"options\" [(ngModel)]=\"selectedPayment\" [disabled]=\"!isRefunding()\">\r\n <option\r\n *ngFor=\"let payment of settledPayments\"\r\n [ngValue]=\"payment\"\r\n [disabled]=\"payment.state !== 'Settled'\"\r\n >\r\n #{{ payment.id }} {{ payment.method }}:\r\n {{ payment.amount | localeCurrency: order.currencyCode }}\r\n </option>\r\n </select>\r\n </clr-select-container>\r\n\r\n <clr-checkbox-wrapper>\r\n <input type=\"checkbox\" clrCheckbox [(ngModel)]=\"refundShipping\" [disabled]=\"!isRefunding()\" />\r\n <label>\r\n {{ 'order.refund-shipping' | translate }} ({{\r\n order.shippingWithTax | localeCurrency: order.currencyCode\r\n }})\r\n </label>\r\n </clr-checkbox-wrapper>\r\n <clr-input-container>\r\n <label>{{ 'order.refund-adjustment' | translate }}</label>\r\n <vdr-currency-input\r\n clrInput\r\n [disabled]=\"!isRefunding()\"\r\n [currencyCode]=\"order.currencyCode\"\r\n [(ngModel)]=\"adjustment\"\r\n ></vdr-currency-input>\r\n </clr-input-container>\r\n <div class=\"totals\" [class.disabled]=\"!isRefunding()\">\r\n <div class=\"order-total\">\r\n {{ 'order.payment-amount' | translate }}:\r\n {{ selectedPayment.amount | localeCurrency: order.currencyCode }}\r\n </div>\r\n <div class=\"refund-total\">\r\n {{ 'order.refund-total' | translate }}:\r\n {{ refundTotal | localeCurrency: order.currencyCode }}\r\n </div>\r\n <div class=\"refund-total-error\" *ngIf=\"refundTotal < 0 || settledPaymentsTotal < refundTotal\">\r\n {{\r\n 'order.refund-total-error'\r\n | translate\r\n : {\r\n min: 0 | currency: order.currencyCode,\r\n max: settledPaymentsTotal | localeCurrency: order.currencyCode\r\n }\r\n }}\r\n </div>\r\n <div class=\"refund-total-warning\" *ngIf=\"selectedPayment.amount < refundTotal\">\r\n {{ 'order.refund-total-warning' | translate }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"select()\" [disabled]=\"!canSubmit()\" class=\"btn btn-primary\">\r\n <ng-container *ngIf=\"isRefunding(); else cancelling\">\r\n {{\r\n 'order.refund-with-amount'\r\n | translate: { amount: refundTotal | localeCurrency: order.currencyCode }\r\n }}\r\n </ng-container>\r\n <ng-template #cancelling>\r\n {{ 'order.cancel-selected-items' | translate }}\r\n </ng-template>\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n CancelOrderInput,\r\n Dialog,\r\n I18nService,\r\n OrderDetailFragment,\r\n OrderLineInput,\r\n RefundOrderInput,\r\n} from '@vendure/admin-ui/core';\r\nimport { summate } from '@vendure/common/lib/shared-utils';\r\n\r\ntype SelectionLine = { quantity: number; refund: boolean; cancel: boolean };\r\ntype Payment = NonNullable<OrderDetailFragment['payments']>[number];\r\n\r\n@Component({\r\n selector: 'vdr-refund-order-dialog',\r\n templateUrl: './refund-order-dialog.component.html',\r\n styleUrls: ['./refund-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class RefundOrderDialogComponent\r\n implements OnInit, Dialog<{ cancel: CancelOrderInput; refund: RefundOrderInput }>\r\n{\r\n order: OrderDetailFragment;\r\n resolveWith: (result?: { cancel: CancelOrderInput; refund: RefundOrderInput }) => void;\r\n reason: string;\r\n settledPayments: Payment[];\r\n selectedPayment: Payment;\r\n lineQuantities: { [lineId: string]: SelectionLine } = {};\r\n refundShipping = false;\r\n adjustment = 0;\r\n reasons: string[] = [_('order.refund-reason-customer-request'), _('order.refund-reason-not-available')];\r\n\r\n constructor(private i18nService: I18nService) {\r\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\r\n }\r\n\r\n get refundTotal(): number {\r\n const itemTotal = this.order.lines.reduce((total, line) => {\r\n const lineRef = this.lineQuantities[line.id];\r\n const refundCount = (lineRef.refund && lineRef.quantity) || 0;\r\n return total + line.proratedUnitPriceWithTax * refundCount;\r\n }, 0);\r\n return itemTotal + (this.refundShipping ? this.order.shippingWithTax : 0) + this.adjustment;\r\n }\r\n\r\n get settledPaymentsTotal(): number {\r\n return this.settledPayments\r\n .map(payment => {\r\n const paymentTotal = payment.amount;\r\n const alreadyRefundedTotal = summate(\r\n payment.refunds.filter(r => r.state !== 'Failed') as Array<\r\n Required<Payment['refunds'][number]>\r\n >,\r\n 'total',\r\n );\r\n return paymentTotal - alreadyRefundedTotal;\r\n })\r\n .reduce((sum, amount) => sum + amount, 0);\r\n }\r\n\r\n lineCanBeRefundedOrCancelled(line: OrderDetailFragment['lines'][number]): boolean {\r\n const refunds =\r\n this.order.payments?.reduce(\r\n (all, payment) => [...all, ...payment.refunds],\r\n [] as Payment['refunds'],\r\n ) ?? [];\r\n\r\n const refundable = line.items.filter(i => {\r\n if (i.cancelled) {\r\n return false;\r\n }\r\n if (i.refundId == null) {\r\n return true;\r\n }\r\n const refund = refunds.find(r => r.id === i.refundId);\r\n return refund?.state === 'Failed';\r\n });\r\n return 0 < refundable.length;\r\n }\r\n\r\n ngOnInit() {\r\n this.lineQuantities = this.order.lines.reduce((result, line) => {\r\n return {\r\n ...result,\r\n [line.id]: {\r\n quantity: 0,\r\n refund: false,\r\n cancel: false,\r\n },\r\n };\r\n }, {});\r\n this.settledPayments = (this.order.payments || []).filter(p => p.state === 'Settled');\r\n if (this.settledPayments.length) {\r\n this.selectedPayment = this.settledPayments[0];\r\n }\r\n }\r\n\r\n handleZeroQuantity(line?: SelectionLine) {\r\n if (line?.quantity === 0) {\r\n line.cancel = false;\r\n line.refund = false;\r\n }\r\n }\r\n\r\n isRefunding(): boolean {\r\n const result = Object.values(this.lineQuantities).reduce((isRefunding, line) => {\r\n return isRefunding || (0 < line.quantity && line.refund);\r\n }, false);\r\n return result;\r\n }\r\n\r\n isCancelling(): boolean {\r\n const result = Object.values(this.lineQuantities).reduce((isCancelling, line) => {\r\n return isCancelling || (0 < line.quantity && line.cancel);\r\n }, false);\r\n return result;\r\n }\r\n\r\n canSubmit(): boolean {\r\n if (this.isRefunding()) {\r\n return !!(\r\n this.selectedPayment &&\r\n this.reason &&\r\n 0 < this.refundTotal &&\r\n this.refundTotal <= this.settledPaymentsTotal\r\n );\r\n } else if (this.isCancelling()) {\r\n return !!this.reason;\r\n }\r\n return false;\r\n }\r\n\r\n select() {\r\n const payment = this.selectedPayment;\r\n if (payment) {\r\n const refundLines = this.getOrderLineInput(line => line.refund);\r\n const cancelLines = this.getOrderLineInput(line => line.cancel);\r\n\r\n this.resolveWith({\r\n refund: {\r\n lines: refundLines,\r\n reason: this.reason,\r\n shipping: this.refundShipping ? this.order.shippingWithTax : 0,\r\n adjustment: this.adjustment,\r\n paymentId: payment.id,\r\n },\r\n cancel: {\r\n lines: cancelLines,\r\n orderId: this.order.id,\r\n reason: this.reason,\r\n cancelShipping: this.refundShipping,\r\n },\r\n });\r\n }\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n private getOrderLineInput(filterFn: (line: SelectionLine) => boolean): OrderLineInput[] {\r\n return Object.entries(this.lineQuantities)\r\n .filter(([orderLineId, line]) => 0 < line.quantity && filterFn(line))\r\n .map(([orderLineId, line]) => ({\r\n orderLineId,\r\n quantity: line.quantity,\r\n }));\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.settle-refund' | translate }}</ng-template>\r\n<p class=\"instruction\">\r\n {{ 'order.settle-refund-manual-instructions' | translate: { method: refund.method } }}\r\n</p>\r\n<clr-input-container>\r\n <label>{{ 'order.transaction-id' | translate }}</label>\r\n <input clrInput name=\"transactionId\" [(ngModel)]=\"transactionId\" />\r\n</clr-input-container>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"submit()\" [disabled]=\"!transactionId\" class=\"btn btn-primary\">\r\n {{ 'order.settle-refund' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component } from '@angular/core';\r\nimport { Dialog, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-settle-refund-dialog',\r\n templateUrl: './settle-refund-dialog.component.html',\r\n styleUrls: ['./settle-refund-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SettleRefundDialogComponent implements Dialog<string> {\r\n resolveWith: (result?: string) => void;\r\n transactionId = '';\r\n refund: NonNullable<OrderDetailFragment['payments']>[number]['refunds'][number];\r\n\r\n submit() {\r\n this.resolveWith(this.transactionId);\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.select-state' | translate }}</ng-template>\r\n<p>{{ message | translate }}</p>\r\n<clr-select-container>\r\n <select clrSelect name=\"state\" [(ngModel)]=\"selectedState\">\r\n <option *ngFor=\"let state of nextStates\" [value]=\"state\">\r\n {{ state | stateI18nToken | translate }}\r\n </option>\r\n </select>\r\n</clr-select-container>\r\n<ng-template vdrDialogButtons>\r\n <button type=\"submit\" *ngIf=\"cancellable\" (click)=\"cancel()\" class=\"btn btn-secondary\">\r\n {{ 'common.cancel' | translate }}\r\n </button>\r\n <button type=\"submit\" (click)=\"select()\" class=\"btn btn-primary\" [disabled]=\"!selectedState\">\r\n {{ 'order.transition-to-state' | translate: { state: (selectedState | stateI18nToken | translate) } }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { Dialog } from '@vendure/admin-ui/core';\n\n@Component({\n selector: 'vdr-order-state-select-dialog',\n templateUrl: './order-state-select-dialog.component.html',\n styleUrls: ['./order-state-select-dialog.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OrderStateSelectDialogComponent implements Dialog<string> {\n resolveWith: (result?: string) => void;\n nextStates: string[] = [];\n message = '';\n cancellable: boolean;\n selectedState = '';\n\n select() {\n if (this.selectedState) {\n this.resolveWith(this.selectedState);\n }\n }\n\n cancel() {\n this.resolveWith();\n }\n}\n","import { Injectable } from '@angular/core';\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\nimport {\n DataService,\n HistoryEntryType,\n I18nService,\n ModalService,\n NotificationService,\n SortOrder,\n} from '@vendure/admin-ui/core';\nimport { EMPTY } from 'rxjs';\nimport { catchError, delay, map, retryWhen, switchMap, take } from 'rxjs/operators';\n\nimport { OrderStateSelectDialogComponent } from '../components/order-state-select-dialog/order-state-select-dialog.component';\n\n@Injectable({\n providedIn: 'root',\n})\nexport class OrderTransitionService {\n constructor(\n private dataService: DataService,\n private modalService: ModalService,\n private notificationService: NotificationService,\n private i18nService: I18nService,\n ) {}\n\n /**\n * Attempts to transition the Order to the last state it was in before it was transitioned\n * to the \"Modifying\" state. If this fails, a manual prompt is used.\n */\n transitionToPreModifyingState(orderId: string, nextStates: string[]) {\n return this.getPreModifyingState(orderId).pipe(\n switchMap(state => {\n const manualTransitionOptions = {\n orderId,\n nextStates,\n message: this.i18nService.translate(\n _('order.unable-to-transition-to-state-try-another'),\n { state },\n ),\n cancellable: false,\n retry: 10,\n };\n if (state) {\n return this.transitionToStateOrThrow(orderId, state).pipe(\n catchError(err => this.manuallyTransitionToState(manualTransitionOptions)),\n );\n } else {\n return this.manuallyTransitionToState(manualTransitionOptions);\n }\n }),\n );\n }\n\n /**\n * Displays a modal for manually selecting the next state.\n */\n manuallyTransitionToState(options: {\n orderId: string;\n nextStates: string[];\n message: string;\n cancellable: boolean;\n retry: number;\n }) {\n return this.modalService\n .fromComponent(OrderStateSelectDialogComponent, {\n locals: {\n nextStates: options.nextStates,\n cancellable: options.cancellable,\n message: options.message,\n },\n closable: false,\n size: 'md',\n })\n .pipe(\n switchMap(result => {\n if (result) {\n return this.transitionToStateOrThrow(options.orderId, result);\n } else {\n if (!options.cancellable) {\n throw new Error(`An order state must be selected`);\n } else {\n return EMPTY;\n }\n }\n }),\n retryWhen(errors => errors.pipe(delay(2000), take(options.retry))),\n );\n }\n\n /**\n * Attempts to get the last state the Order was in before it was transitioned\n * to the \"Modifying\" state.\n */\n private getPreModifyingState(orderId: string) {\n return this.dataService.order\n .getOrderHistory(orderId, {\n filter: {\n type: {\n eq: HistoryEntryType.ORDER_STATE_TRANSITION,\n },\n },\n sort: {\n createdAt: SortOrder.DESC,\n },\n })\n .mapSingle(result => result.order)\n .pipe(\n map(result => {\n const item = result?.history.items.find(i => i.data.to === 'Modifying');\n if (item) {\n return item.data.from as string;\n } else {\n return;\n }\n }),\n );\n }\n\n private transitionToStateOrThrow(orderId: string, state: string) {\n return this.dataService.order.transitionToState(orderId, state).pipe(\n map(({ transitionOrderToState }) => {\n switch (transitionOrderToState?.__typename) {\n case 'Order':\n return transitionOrderToState?.state;\n case 'OrderStateTransitionError':\n this.notificationService.error(transitionOrderToState?.transitionError);\n throw new Error(transitionOrderToState?.transitionError);\n }\n }),\n );\n }\n}\n","import { Subject } from '../Subject';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function retryWhen(notifier) {\n return operate((source, subscriber) => {\n let innerSub;\n let syncResub = false;\n let errors$;\n const subscribeForRetryWhen = () => {\n innerSub = source.subscribe(createOperatorSubscriber(subscriber, undefined, undefined, (err) => {\n if (!errors$) {\n errors$ = new Subject();\n notifier(errors$).subscribe(createOperatorSubscriber(subscriber, () => innerSub ? subscribeForRetryWhen() : (syncResub = true)));\n }\n if (errors$) {\n errors$.next(err);\n }\n }));\n if (syncResub) {\n innerSub.unsubscribe();\n innerSub = null;\n syncResub = false;\n subscribeForRetryWhen();\n }\n };\n subscribeForRetryWhen();\n });\n}\n","<table class=\"order-table table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.unit-price' | translate }}</th>\r\n <th>{{ 'order.quantity' | translate }}</th>\r\n <th>{{ 'order.total' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngFor=\"let line of order.lines\">\r\n <tr class=\"order-line\" [class.is-cancelled]=\"line.quantity === 0\">\r\n <td class=\"align-middle thumb\">\r\n <img *ngIf=\"line.featuredAsset\" [src]=\"line.featuredAsset | assetPreview: 'tiny'\" />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle unit-price\">\r\n {{ line.unitPriceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ line.unitPrice | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n <td class=\"align-middle quantity\">\r\n {{ line.quantity }}\r\n <vdr-line-refunds [line]=\"line\" [payments]=\"order.payments\"></vdr-line-refunds>\r\n <vdr-line-fulfillment [line]=\"line\" [orderState]=\"order.state\"></vdr-line-fulfillment>\r\n </td>\r\n <td class=\"align-middle total\">\r\n {{ line.linePriceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ line.linePrice | localeCurrency: order.currencyCode }}\r\n </div>\r\n\r\n <ng-container *ngIf=\"getLineDiscounts(line) as discounts\">\r\n <vdr-dropdown *ngIf=\"discounts.length\">\r\n <div class=\"promotions-label\" vdrDropdownTrigger>\r\n {{ 'order.promotions-applied' | translate }}\r\n </div>\r\n <vdr-dropdown-menu>\r\n <div class=\"line-promotion\" *ngFor=\"let discount of discounts\">\r\n <a class=\"promotion-name\" [routerLink]=\"getPromotionLink(discount)\">{{\r\n discount.description\r\n }}</a>\r\n <div class=\"promotion-amount\">\r\n {{ discount.amountWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ discount.amount | localeCurrency: order.currencyCode }}\r\n </div>\r\n </div>\r\n </div>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </ng-container>\r\n </td>\r\n </tr>\r\n <ng-container *ngIf=\"customFieldsForLine[line.id] as customFields\">\r\n <tr *ngIf=\"customFields.length\">\r\n <td colspan=\"6\" class=\"custom-fields-row\">\r\n <div class=\"order-line-custom-fields\">\r\n <div class=\"custom-field\" *ngFor=\"let field of customFields\">\r\n <vdr-custom-field-control\r\n [compact]=\"true\"\r\n [readonly]=\"true\"\r\n [customField]=\"field.config\"\r\n [customFieldsFormGroup]=\"field.formGroup\"\r\n ></vdr-custom-field-control>\r\n </div>\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </ng-container>\r\n <tr class=\"surcharge\" *ngFor=\"let surcharge of order.surcharges\">\r\n <td class=\"align-middle name left\" colspan=\"2\">{{ surcharge.description }}</td>\r\n <td class=\"align-middle sku\">{{ surcharge.sku }}</td>\r\n <td class=\"align-middle\" colspan=\"2\"></td>\r\n <td class=\"align-middle total\">\r\n {{ surcharge.priceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ surcharge.price | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n <ng-container *ngFor=\"let discount of order.discounts\">\r\n <tr class=\"order-adjustment\" *ngIf=\"discount.type !== 'OTHER'\">\r\n <td colspan=\"5\" class=\"left clr-align-middle\">\r\n <a [routerLink]=\"getPromotionLink(discount)\">{{ discount.description }}</a>\r\n <vdr-chip *ngIf=\"getCouponCodeForAdjustment(order, discount) as couponCode\">{{\r\n couponCode\r\n }}</vdr-chip>\r\n </td>\r\n <td class=\"clr-align-middle\">\r\n {{ discount.amountWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ discount.amount | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n <tr class=\"sub-total\">\r\n <td class=\"left clr-align-middle\">{{ 'order.sub-total' | translate }}</td>\r\n <td colspan=\"4\"></td>\r\n <td class=\"clr-align-middle\">\r\n {{ order.subTotalWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ order.subTotal | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n <tr class=\"shipping\">\r\n <td class=\"left clr-align-middle\">{{ 'order.shipping' | translate }}</td>\r\n <td class=\"clr-align-middle\">{{ order.shippingLines[0]?.shippingMethod?.name }}</td>\r\n <td colspan=\"3\"></td>\r\n <td class=\"clr-align-middle\">\r\n {{ order.shippingWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ order.shipping | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n <tr class=\"total\">\r\n <td class=\"left clr-align-middle\">{{ 'order.total' | translate }}</td>\r\n <td colspan=\"4\"></td>\r\n <td class=\"clr-align-middle\">\r\n {{ order.totalWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ order.total | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n","import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { AdjustmentType, CustomFieldConfig, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-order-table',\r\n templateUrl: './order-table.component.html',\r\n styleUrls: ['./order-table.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderTableComponent implements OnInit {\r\n @Input() order: OrderDetailFragment;\r\n @Input() orderLineCustomFields: CustomFieldConfig[];\r\n orderLineCustomFieldsVisible = false;\r\n customFieldsForLine: {\r\n [lineId: string]: Array<{ config: CustomFieldConfig; formGroup: FormGroup; value: any }>;\r\n } = {};\r\n\r\n get visibleOrderLineCustomFields(): CustomFieldConfig[] {\r\n return this.orderLineCustomFieldsVisible ? this.orderLineCustomFields : [];\r\n }\r\n\r\n get showElided(): boolean {\r\n return !this.orderLineCustomFieldsVisible && 0 < this.orderLineCustomFields.length;\r\n }\r\n\r\n ngOnInit(): void {\r\n this.orderLineCustomFieldsVisible = this.orderLineCustomFields.length < 2;\r\n this.getLineCustomFields();\r\n }\r\n\r\n toggleOrderLineCustomFields() {\r\n this.orderLineCustomFieldsVisible = !this.orderLineCustomFieldsVisible;\r\n }\r\n\r\n getLineDiscounts(line: OrderDetailFragment['lines'][number]) {\r\n return line.discounts.filter(a => a.type === AdjustmentType.PROMOTION);\r\n }\r\n\r\n private getLineCustomFields() {\r\n for (const line of this.order.lines) {\r\n const formGroup = new FormGroup({});\r\n const result = this.orderLineCustomFields\r\n .map(config => {\r\n const value = (line as any).customFields[config.name];\r\n formGroup.addControl(config.name, new FormControl(value));\r\n return {\r\n config,\r\n formGroup,\r\n value,\r\n };\r\n })\r\n .filter(field => {\r\n return this.orderLineCustomFieldsVisible ? true : field.value != null;\r\n });\r\n this.customFieldsForLine[line.id] = result;\r\n }\r\n }\r\n\r\n getPromotionLink(promotion: OrderDetailFragment['discounts'][number]): any[] {\r\n const id = promotion.adjustmentSource.split(':')[1];\r\n return ['/marketing', 'promotions', id];\r\n }\r\n\r\n getCouponCodeForAdjustment(\r\n order: OrderDetailFragment,\r\n promotionAdjustment: OrderDetailFragment['discounts'][number],\r\n ): string | undefined {\r\n const id = promotionAdjustment.adjustmentSource.split(':')[1];\r\n const promotion = order.promotions.find(p => p.id === id);\r\n if (promotion) {\r\n return promotion.couponCode || undefined;\r\n }\r\n }\r\n}\r\n","<vdr-labeled-data [label]=\"'order.payment-method' | translate\">\r\n {{ payment.method }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data [label]=\"'order.amount' | translate\">\r\n {{ payment.amount | localeCurrency: currencyCode }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data *ngIf=\"payment.errorMessage\" [label]=\"'order.error-message' | translate\">\r\n {{ payment.errorMessage }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data *ngIf=\"payment.transactionId\" [label]=\"'order.transaction-id' | translate\">\r\n {{ payment.transactionId }}\r\n</vdr-labeled-data>\r\n<vdr-labeled-data [label]=\"'order.payment-metadata' | translate\">\r\n <vdr-object-tree [value]=\"payment.metadata\"></vdr-object-tree>\r\n</vdr-labeled-data>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\nimport { CurrencyCode, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-payment-detail',\r\n templateUrl: './payment-detail.component.html',\r\n styleUrls: ['./payment-detail.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PaymentDetailComponent {\r\n @Input() payment: NonNullable<OrderDetailFragment['payments']>[number];\r\n @Input() currencyCode: CurrencyCode;\r\n}\r\n","<h4>{{ 'order.order-history' | translate }}</h4>\r\n<div class=\"entry-list\" [class.expanded]=\"expanded\">\r\n <vdr-timeline-entry iconShape=\"note\" displayType=\"muted\" [featured]=\"true\">\r\n <div class=\"note-entry\">\r\n <textarea [(ngModel)]=\"note\" name=\"note\" class=\"note\"></textarea>\r\n <button class=\"btn btn-secondary\" [disabled]=\"!note\" (click)=\"addNoteToOrder()\">\r\n {{ 'common.add-note' | translate }}\r\n </button>\r\n </div>\r\n <div class=\"visibility-select\">\r\n <clr-checkbox-wrapper>\r\n <input type=\"checkbox\" clrCheckbox [(ngModel)]=\"noteIsPrivate\" />\r\n <label>{{ 'order.note-is-private' | translate }}</label>\r\n </clr-checkbox-wrapper>\r\n <span *ngIf=\"noteIsPrivate\" class=\"private\">\r\n {{ 'order.note-only-visible-to-administrators' | translate }}\r\n </span>\r\n <span *ngIf=\"!noteIsPrivate\" class=\"public\">\r\n {{ 'order.note-visible-to-customer' | translate }}\r\n </span>\r\n </div>\r\n </vdr-timeline-entry>\r\n <vdr-timeline-entry\r\n *ngFor=\"let entry of history\"\r\n [displayType]=\"getDisplayType(entry)\"\r\n [iconShape]=\"getTimelineIcon(entry)\"\r\n [createdAt]=\"entry.createdAt\"\r\n [name]=\"getName(entry)\"\r\n [featured]=\"isFeatured(entry)\"\r\n [collapsed]=\"!expanded && !isFeatured(entry)\"\r\n (expandClick)=\"expanded = !expanded\"\r\n >\r\n <ng-container [ngSwitch]=\"entry.type\">\r\n <ng-container *ngSwitchCase=\"type.ORDER_STATE_TRANSITION\">\r\n <div class=\"title\" *ngIf=\"entry.data.to === 'Delivered'\">\r\n {{ 'order.history-order-fulfilled' | translate }}\r\n </div>\r\n <div class=\"title\" *ngIf=\"entry.data.to === 'Cancelled'\">\r\n {{ 'order.history-order-cancelled' | translate }}\r\n </div>\r\n <ng-template [ngIf]=\"entry.data.to !== 'Cancelled' && entry.data.to !== 'Delivered'\">\r\n {{\r\n 'order.history-order-transition'\r\n | translate: { from: entry.data.from, to: entry.data.to }\r\n }}\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_MODIFIED\">\r\n <div class=\"title\">\r\n {{ 'order.history-order-modified' | translate }}\r\n </div>\r\n <ng-container *ngIf=\"getModification(entry.data.modificationId) as modification\">\r\n {{ 'order.modify-order-price-difference' | translate }}:\r\n <strong>{{ modification.priceChange | localeCurrency: order.currencyCode }}</strong>\r\n <vdr-chip colorType=\"success\" *ngIf=\"modification.isSettled\">{{\r\n 'order.modification-settled' | translate\r\n }}</vdr-chip>\r\n <vdr-chip colorType=\"error\" *ngIf=\"!modification.isSettled\">{{\r\n 'order.modification-not-settled' | translate\r\n }}</vdr-chip>\r\n <vdr-history-entry-detail>\r\n <vdr-modification-detail\r\n [order]=\"order\"\r\n [modification]=\"modification\"\r\n ></vdr-modification-detail>\r\n </vdr-history-entry-detail>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_PAYMENT_TRANSITION\">\r\n <ng-container *ngIf=\"entry.data.to === 'Settled'; else regularPaymentTransition\">\r\n <div class=\"title\">\r\n {{ 'order.history-payment-settled' | translate }}\r\n </div>\r\n {{ 'order.transaction-id' | translate }}: {{ getPayment(entry)?.transactionId }}\r\n <vdr-history-entry-detail *ngIf=\"getPayment(entry) as payment\">\r\n <vdr-payment-detail\r\n [payment]=\"payment\"\r\n [currencyCode]=\"order.currencyCode\"\r\n ></vdr-payment-detail>\r\n </vdr-history-entry-detail>\r\n </ng-container>\r\n <ng-template #regularPaymentTransition>\r\n {{\r\n 'order.history-payment-transition'\r\n | translate\r\n : {\r\n from: entry.data.from,\r\n to: entry.data.to,\r\n id: getPayment(entry)?.transactionId\r\n }\r\n }}\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_REFUND_TRANSITION\">\r\n {{\r\n 'order.history-refund-transition'\r\n | translate: { from: entry.data.from, to: entry.data.to, id: entry.data.refundId }\r\n }}\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_CANCELLATION\">\r\n {{ 'order.history-items-cancelled' | translate: { count: entry.data.orderItemIds.length } }}\r\n <vdr-history-entry-detail *ngIf=\"getCancelledItems(entry) as items\">\r\n <vdr-labeled-data [label]=\"'order.cancellation-reason' | translate\">\r\n {{ entry.data.reason }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.contents' | translate\">\r\n <vdr-simple-item-list [items]=\"items\"></vdr-simple-item-list>\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.shipping-cancelled' | translate\">\r\n {{ entry.data.shippingCancelled }}\r\n </vdr-labeled-data>\r\n </vdr-history-entry-detail>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_FULFILLMENT\">\r\n {{ 'order.history-fulfillment-created' | translate }}\r\n <vdr-history-entry-detail *ngIf=\"getFulfillment(entry) as fulfillment\">\r\n <vdr-fulfillment-detail\r\n [fulfillmentId]=\"fulfillment.id\"\r\n [order]=\"order\"\r\n ></vdr-fulfillment-detail>\r\n </vdr-history-entry-detail>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_FULFILLMENT_TRANSITION\">\r\n <ng-container *ngIf=\"entry.data.to === 'Delivered'\">\r\n <div class=\"title\">\r\n {{ 'order.history-fulfillment-delivered' | translate }}\r\n </div>\r\n {{ 'order.tracking-code' | translate }}: {{ getFulfillment(entry)?.trackingCode }}\r\n </ng-container>\r\n <ng-container *ngIf=\"entry.data.to === 'Shipped'\">\r\n <div class=\"title\">\r\n {{ 'order.history-fulfillment-shipped' | translate }}\r\n </div>\r\n {{ 'order.tracking-code' | translate }}: {{ getFulfillment(entry)?.trackingCode }}\r\n </ng-container>\r\n <ng-container *ngIf=\"entry.data.to !== 'Delivered' && entry.data.to !== 'Shipped'\">\r\n {{\r\n 'order.history-fulfillment-transition'\r\n | translate: { from: entry.data.from, to: entry.data.to }\r\n }}\r\n </ng-container>\r\n <vdr-history-entry-detail *ngIf=\"getFulfillment(entry) as fulfillment\">\r\n <vdr-fulfillment-detail\r\n [fulfillmentId]=\"fulfillment.id\"\r\n [order]=\"order\"\r\n ></vdr-fulfillment-detail>\r\n </vdr-history-entry-detail>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_NOTE\">\r\n <div class=\"flex\">\r\n <div class=\"note-text\">\r\n <span *ngIf=\"entry.isPublic\" class=\"note-visibility public\">{{\r\n 'common.public' | translate\r\n }}</span>\r\n <span *ngIf=\"!entry.isPublic\" class=\"note-visibility private\">{{\r\n 'common.private' | translate\r\n }}</span>\r\n {{ entry.data.note }}\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <vdr-dropdown>\r\n <button class=\"icon-button\" vdrDropdownTrigger>\r\n <clr-icon shape=\"ellipsis-vertical\"></clr-icon>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <button\r\n class=\"button\"\r\n vdrDropdownItem\r\n (click)=\"updateNote.emit(entry)\"\r\n [disabled]=\"!('UpdateOrder' | hasPermission)\"\r\n >\r\n <clr-icon shape=\"edit\"></clr-icon>\r\n {{ 'common.edit' | translate }}\r\n </button>\r\n <div class=\"dropdown-divider\"></div>\r\n <button\r\n class=\"button\"\r\n vdrDropdownItem\r\n (click)=\"deleteNote.emit(entry)\"\r\n [disabled]=\"!('UpdateOrder' | hasPermission)\"\r\n >\r\n <clr-icon shape=\"trash\" class=\"is-danger\"></clr-icon>\r\n {{ 'common.delete' | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_COUPON_APPLIED\">\r\n {{ 'order.history-coupon-code-applied' | translate }}:\r\n <vdr-chip>\r\n <a [routerLink]=\"['/marketing', 'promotions', entry.data.promotionId]\">{{\r\n entry.data.couponCode\r\n }}</a>\r\n </vdr-chip>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"type.ORDER_COUPON_REMOVED\">\r\n {{ 'order.history-coupon-code-removed' | translate }}:\r\n <vdr-chip\r\n ><span class=\"cancelled-coupon-code\">{{ entry.data.couponCode }}</span></vdr-chip\r\n >\r\n </ng-container>\r\n </ng-container>\r\n </vdr-timeline-entry>\r\n <vdr-timeline-entry [isLast]=\"true\" [createdAt]=\"order.createdAt\" [featured]=\"true\">\r\n <div class=\"title\">\r\n {{ 'order.history-order-created' | translate }}\r\n </div>\r\n </vdr-timeline-entry>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport {\r\n GetOrderHistoryQuery,\r\n HistoryEntry,\r\n HistoryEntryType,\r\n OrderDetailFragment,\r\n TimelineDisplayType,\r\n} from '@vendure/admin-ui/core';\r\n\r\ntype OrderHistoryItem = NonNullable<GetOrderHistoryQuery['order']>['history']['items'][number];\r\n\r\n@Component({\r\n selector: 'vdr-order-history',\r\n templateUrl: './order-history.component.html',\r\n styleUrls: ['./order-history.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderHistoryComponent {\r\n @Input() order: OrderDetailFragment;\r\n @Input() history: OrderHistoryItem[];\r\n @Output() addNote = new EventEmitter<{ note: string; isPublic: boolean }>();\r\n @Output() updateNote = new EventEmitter<HistoryEntry>();\r\n @Output() deleteNote = new EventEmitter<HistoryEntry>();\r\n note = '';\r\n noteIsPrivate = true;\r\n expanded = false;\r\n readonly type = HistoryEntryType;\r\n\r\n getDisplayType(entry: OrderHistoryItem): TimelineDisplayType {\r\n if (entry.type === HistoryEntryType.ORDER_STATE_TRANSITION) {\r\n if (entry.data.to === 'Delivered') {\r\n return 'success';\r\n }\r\n if (entry.data.to === 'Cancelled') {\r\n return 'error';\r\n }\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_FULFILLMENT_TRANSITION) {\r\n if (entry.data.to === 'Delivered') {\r\n return 'success';\r\n }\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_PAYMENT_TRANSITION) {\r\n if (entry.data.to === 'Declined' || entry.data.to === 'Cancelled') {\r\n return 'error';\r\n }\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_CANCELLATION) {\r\n return 'error';\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_REFUND_TRANSITION) {\r\n return 'warning';\r\n }\r\n return 'default';\r\n }\r\n\r\n getTimelineIcon(entry: OrderHistoryItem) {\r\n if (entry.type === HistoryEntryType.ORDER_STATE_TRANSITION) {\r\n if (entry.data.to === 'Delivered') {\r\n return ['success-standard', 'is-solid'];\r\n }\r\n if (entry.data.to === 'Cancelled') {\r\n return 'ban';\r\n }\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_PAYMENT_TRANSITION) {\r\n if (entry.data.to === 'Settled') {\r\n return 'credit-card';\r\n }\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_NOTE) {\r\n return 'note';\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_MODIFIED) {\r\n return 'pencil';\r\n }\r\n if (entry.type === HistoryEntryType.ORDER_FULFILLMENT_TRANSITION) {\r\n if (entry.data.to === 'Shipped') {\r\n return 'truck';\r\n }\r\n if (entry.data.to === 'Delivered') {\r\n return 'truck';\r\n }\r\n }\r\n }\r\n\r\n isFeatured(entry: OrderHistoryItem): boolean {\r\n switch (entry.type) {\r\n case HistoryEntryType.ORDER_STATE_TRANSITION: {\r\n return (\r\n entry.data.to === 'Delivered' ||\r\n entry.data.to === 'Cancelled' ||\r\n entry.data.to === 'Settled'\r\n );\r\n }\r\n case HistoryEntryType.ORDER_PAYMENT_TRANSITION:\r\n return entry.data.to === 'Settled' || entry.data.to === 'Cancelled';\r\n case HistoryEntryType.ORDER_FULFILLMENT_TRANSITION:\r\n return entry.data.to === 'Delivered' || entry.data.to === 'Shipped';\r\n case HistoryEntryType.ORDER_NOTE:\r\n case HistoryEntryType.ORDER_MODIFIED:\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n getFulfillment(\r\n entry: OrderHistoryItem,\r\n ): NonNullable<OrderDetailFragment['fulfillments']>[number] | undefined {\r\n if (\r\n (entry.type === HistoryEntryType.ORDER_FULFILLMENT ||\r\n entry.type === HistoryEntryType.ORDER_FULFILLMENT_TRANSITION) &&\r\n this.order.fulfillments\r\n ) {\r\n return this.order.fulfillments.find(f => f.id === entry.data.fulfillmentId);\r\n }\r\n }\r\n\r\n getPayment(entry: OrderHistoryItem): NonNullable<OrderDetailFragment['payments']>[number] | undefined {\r\n if (entry.type === HistoryEntryType.ORDER_PAYMENT_TRANSITION && this.order.payments) {\r\n return this.order.payments.find(p => p.id === entry.data.paymentId);\r\n }\r\n }\r\n\r\n getCancelledItems(entry: OrderHistoryItem): Array<{ name: string; quantity: number }> {\r\n const itemMap = new Map<string, number>();\r\n const cancelledItemIds: string[] = entry.data.orderItemIds;\r\n for (const line of this.order.lines) {\r\n for (const item of line.items) {\r\n if (cancelledItemIds.includes(item.id)) {\r\n const count = itemMap.get(line.productVariant.name);\r\n if (count != null) {\r\n itemMap.set(line.productVariant.name, count + 1);\r\n } else {\r\n itemMap.set(line.productVariant.name, 1);\r\n }\r\n }\r\n }\r\n }\r\n return Array.from(itemMap.entries()).map(([name, quantity]) => ({ name, quantity }));\r\n }\r\n\r\n getModification(id: string) {\r\n return this.order.modifications.find(m => m.id === id);\r\n }\r\n\r\n getName(entry: OrderHistoryItem): string {\r\n const { administrator } = entry;\r\n if (administrator) {\r\n return `${administrator.firstName} ${administrator.lastName}`;\r\n } else {\r\n const customer = this.order.customer;\r\n if (customer) {\r\n return `${customer.firstName} ${customer.lastName}`;\r\n }\r\n }\r\n return '';\r\n }\r\n\r\n addNoteToOrder() {\r\n this.addNote.emit({ note: this.note, isPublic: !this.noteIsPrivate });\r\n this.note = '';\r\n this.noteIsPrivate = true;\r\n }\r\n}\r\n","<vdr-chip [title]=\"'order.payment-state' | translate\" [colorType]=\"chipColorType\">\r\n <clr-icon shape=\"check-circle\" *ngIf=\"state === 'Settled'\"></clr-icon>\r\n {{ state | stateI18nToken | translate }}\r\n</vdr-chip>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'vdr-payment-state-label',\r\n templateUrl: './payment-state-label.component.html',\r\n styleUrls: ['./payment-state-label.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PaymentStateLabelComponent {\r\n @Input() state: string;\r\n\r\n get chipColorType() {\r\n switch (this.state) {\r\n case 'Authorized':\r\n return 'warning';\r\n case 'Settled':\r\n return 'success';\r\n case 'Declined':\r\n case 'Cancelled':\r\n return 'error';\r\n }\r\n }\r\n}\r\n","<vdr-chip [title]=\"'order.payment-state' | translate\" [colorType]=\"chipColorType\">\r\n <clr-icon shape=\"check-circle\" *ngIf=\"state === 'Settled'\"></clr-icon>\r\n {{ state | stateI18nToken | translate }}\r\n</vdr-chip>\r\n","import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'vdr-refund-state-label',\r\n templateUrl: './refund-state-label.component.html',\r\n styleUrls: ['./refund-state-label.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class RefundStateLabelComponent {\r\n @Input() state: string;\r\n\r\n get chipColorType() {\r\n switch (this.state) {\r\n case 'Pending':\r\n return 'warning';\r\n case 'Settled':\r\n return 'success';\r\n case 'Failed':\r\n return 'error';\r\n }\r\n }\r\n}\r\n","<div class=\"card\">\r\n <div class=\"card-header payment-header\">\r\n <div>\r\n {{ 'order.payment' | translate }}\r\n <ng-container *ngIf=\"payment.transactionId\">#{{ payment.transactionId }}</ng-container>\r\n </div>\r\n <div class=\"payment-state\">\r\n <vdr-payment-state-label [state]=\"payment.state\"></vdr-payment-state-label>\r\n </div>\r\n </div>\r\n <div class=\"card-block\">\r\n <vdr-payment-detail [payment]=\"payment\" [currencyCode]=\"currencyCode\"></vdr-payment-detail>\r\n </div>\r\n <ng-container *ngFor=\"let refund of payment.refunds\">\r\n <div class=\"card-header payment-header\">\r\n <clr-icon shape=\"redo\" class=\"refund-icon\" dir=\"down\"></clr-icon>\r\n {{ 'order.refund' | translate }} #{{ refund.id }}\r\n <div class=\"clr-flex-fill\"></div>\r\n <vdr-refund-state-label [state]=\"refund.state\"></vdr-refund-state-label>\r\n </div>\r\n <div class=\"card-block\">\r\n <vdr-labeled-data [label]=\"'common.created-at' | translate\">\r\n {{ refund.createdAt | localeDate: 'medium' }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.refund-total' | translate\">\r\n {{ refund.total | localeCurrency: currencyCode }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.transaction-id' | translate\" *ngIf=\"refund.transactionId\">\r\n {{ refund.transactionId }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.refund-reason' | translate\" *ngIf=\"refund.reason\">\r\n {{ refund.reason }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'order.refund-metadata' | translate\" *ngIf=\"refundHasMetadata(refund)\">\r\n <vdr-object-tree [value]=\"refund.metadata\"></vdr-object-tree>\r\n </vdr-labeled-data>\r\n </div>\r\n <div class=\"card-footer\" *ngIf=\"refund.state === 'Pending'\">\r\n <button class=\"btn btn-sm btn-primary\" (click)=\"settleRefund.emit(refund)\">\r\n {{ 'order.settle-refund' | translate }}\r\n </button>\r\n </div>\r\n </ng-container>\r\n <div class=\"card-footer\" *ngIf=\"payment.nextStates.length\">\r\n <button\r\n class=\"btn btn-sm btn-primary\"\r\n *ngIf=\"payment.nextStates.includes('Settled')\"\r\n (click)=\"settlePayment.emit(payment)\"\r\n >\r\n {{ 'order.settle-payment' | translate }}\r\n </button>\r\n <vdr-dropdown>\r\n <button class=\"icon-button\" vdrDropdownTrigger>\r\n <clr-icon shape=\"ellipsis-vertical\"></clr-icon>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <ng-container *ngFor=\"let nextState of nextOtherStates()\">\r\n <button\r\n type=\"button\"\r\n class=\"btn\"\r\n vdrDropdownItem\r\n (click)=\"transitionPaymentState.emit({ payment: payment, state: nextState })\"\r\n >\r\n <ng-container *ngIf=\"nextState !== 'Cancelled'; else cancel\">\r\n <clr-icon shape=\"step-forward-2\"></clr-icon>\r\n {{\r\n 'order.transition-to-state'\r\n | translate: { state: (nextState | stateI18nToken | translate) }\r\n }}\r\n </ng-container>\r\n <ng-template #cancel>\r\n <clr-icon shape=\"error-standard\" class=\"is-error\"></clr-icon>\r\n {{ 'order.cancel-payment' | translate }}\r\n </ng-template>\r\n </button>\r\n </ng-container>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { CurrencyCode, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\ntype Payment = NonNullable<OrderDetailFragment['payments']>[number];\r\n\r\n@Component({\r\n selector: 'vdr-order-payment-card',\r\n templateUrl: './order-payment-card.component.html',\r\n styleUrls: ['./order-payment-card.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderPaymentCardComponent {\r\n @Input() payment: Payment;\r\n @Input() currencyCode: CurrencyCode;\r\n @Output() settlePayment = new EventEmitter<Payment>();\r\n @Output() transitionPaymentState = new EventEmitter<{ payment: Payment; state: string }>();\r\n @Output() settleRefund = new EventEmitter<Payment['refunds'][number]>();\r\n\r\n refundHasMetadata(refund?: Payment['refunds'][number]): boolean {\r\n return !!refund && Object.keys(refund.metadata).length > 0;\r\n }\r\n\r\n nextOtherStates(): string[] {\r\n if (!this.payment) {\r\n return [];\r\n }\r\n return this.payment.nextStates.filter(s => s !== 'Settled');\r\n }\r\n}\r\n","<vdr-action-bar *ngIf=\"entity$ | async as order\">\r\n <vdr-ab-left>\r\n <div class=\"flex clr-align-items-center\">\r\n <vdr-entity-info [entity]=\"entity$ | async\"></vdr-entity-info>\r\n <vdr-order-state-label [state]=\"order.state\">\r\n <button\r\n class=\"icon-button\"\r\n (click)=\"openStateDiagram()\"\r\n [title]=\"'order.order-state-diagram' | translate\"\r\n >\r\n <clr-icon shape=\"list\"></clr-icon>\r\n </button>\r\n </vdr-order-state-label>\r\n </div>\r\n </vdr-ab-left>\r\n\r\n <vdr-ab-right>\r\n <vdr-action-bar-items locationId=\"order-detail\"></vdr-action-bar-items>\r\n <button\r\n class=\"btn btn-primary\"\r\n *ngIf=\"\r\n (order.state === 'ArrangingPayment' || order.state === 'ArrangingAdditionalPayment') &&\r\n (hasUnsettledModifications(order) || 0 < outstandingPaymentAmount(order))\r\n \"\r\n (click)=\"addManualPayment(order)\"\r\n >\r\n {{ 'order.add-payment-to-order' | translate }}\r\n ({{ outstandingPaymentAmount(order) | localeCurrency: order.currencyCode }})\r\n </button>\r\n <button\r\n class=\"btn btn-primary\"\r\n *ngIf=\"\r\n order.active === false &&\r\n order.state !== 'ArrangingAdditionalPayment' &&\r\n 0 < outstandingPaymentAmount(order)\r\n \"\r\n (click)=\"transitionToState('ArrangingAdditionalPayment')\"\r\n >\r\n {{ 'order.arrange-additional-payment' | translate }}\r\n </button>\r\n <button class=\"btn btn-primary\" (click)=\"fulfillOrder()\" [disabled]=\"!canAddFulfillment(order)\">\r\n {{ 'order.fulfill-order' | translate }}\r\n </button>\r\n <vdr-dropdown>\r\n <button class=\"icon-button\" vdrDropdownTrigger>\r\n <clr-icon shape=\"ellipsis-vertical\"></clr-icon>\r\n </button>\r\n <vdr-dropdown-menu vdrPosition=\"bottom-right\">\r\n <ng-container *ngIf=\"order.nextStates.includes('Modifying')\">\r\n <button type=\"button\" class=\"btn\" vdrDropdownItem (click)=\"transitionToModifying()\">\r\n <clr-icon shape=\"pencil\"></clr-icon>\r\n {{ 'order.modify-order' | translate }}\r\n </button>\r\n <div class=\"dropdown-divider\"></div>\r\n </ng-container>\r\n <button\r\n type=\"button\"\r\n class=\"btn\"\r\n vdrDropdownItem\r\n *ngIf=\"order.nextStates.includes('Cancelled')\"\r\n (click)=\"cancelOrRefund(order)\"\r\n >\r\n <clr-icon shape=\"error-standard\" class=\"is-error\"></clr-icon>\r\n <ng-container *ngIf=\"orderHasSettledPayments(order); else cancelOnly\">\r\n {{ 'order.refund-and-cancel-order' | translate }}\r\n </ng-container>\r\n <ng-template #cancelOnly>\r\n {{ 'order.cancel-order' | translate }}\r\n </ng-template>\r\n </button>\r\n\r\n <ng-container *ngIf=\"(nextStates$ | async)?.length\">\r\n <div class=\"dropdown-divider\"></div>\r\n <button\r\n *ngFor=\"let nextState of nextStates$ | async\"\r\n type=\"button\"\r\n class=\"btn\"\r\n vdrDropdownItem\r\n (click)=\"transitionToState(nextState)\"\r\n >\r\n <clr-icon shape=\"step-forward-2\"></clr-icon>\r\n {{\r\n 'order.transition-to-state'\r\n | translate: { state: (nextState | stateI18nToken | translate) }\r\n }}\r\n </button>\r\n </ng-container>\r\n <div class=\"dropdown-divider\"></div>\r\n <button type=\"button\" class=\"btn\" vdrDropdownItem (click)=\"manuallyTransitionToState(order)\">\r\n <clr-icon shape=\"step-forward-2\" class=\"is-warning\"></clr-icon>\r\n {{ 'order.manually-transition-to-state' | translate }}\r\n </button>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </vdr-ab-right>\r\n</vdr-action-bar>\r\n\r\n<div *ngIf=\"entity$ | async as order\">\r\n <div class=\"clr-row\">\r\n <div class=\"clr-col-lg-8\">\r\n <vdr-order-table\r\n [order]=\"order\"\r\n [orderLineCustomFields]=\"orderLineCustomFields\"\r\n ></vdr-order-table>\r\n <h4>{{ 'order.tax-summary' | translate }}</h4>\r\n <table class=\"table\">\r\n <thead>\r\n <tr>\r\n <th>{{ 'common.description' | translate }}</th>\r\n <th>{{ 'order.tax-rate' | translate }}</th>\r\n <th>{{ 'order.tax-base' | translate }}</th>\r\n <th>{{ 'order.tax-total' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of order.taxSummary\">\r\n <td>{{ row.description }}</td>\r\n <td>{{ row.taxRate / 100 | percent }}</td>\r\n <td>{{ row.taxBase | localeCurrency: order.currencyCode }}</td>\r\n <td>{{ row.taxTotal | localeCurrency: order.currencyCode }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <vdr-custom-detail-component-host\r\n locationId=\"order-detail\"\r\n [entity$]=\"entity$\"\r\n [detailForm]=\"detailForm\"\r\n ></vdr-custom-detail-component-host>\r\n\r\n <vdr-order-history\r\n [order]=\"order\"\r\n [history]=\"history$ | async\"\r\n (addNote)=\"addNote($event)\"\r\n (updateNote)=\"updateNote($event)\"\r\n (deleteNote)=\"deleteNote($event)\"\r\n ></vdr-order-history>\r\n </div>\r\n <div class=\"clr-col-lg-4 order-cards\">\r\n <vdr-order-custom-fields-card\r\n [customFieldsConfig]=\"customFields\"\r\n [customFieldValues]=\"order.customFields\"\r\n (updateClick)=\"updateCustomFields($event)\"\r\n ></vdr-order-custom-fields-card>\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n {{ 'order.customer' | translate }}\r\n </div>\r\n <div class=\"card-block\">\r\n <div class=\"card-text\">\r\n <vdr-customer-label [customer]=\"order.customer\"></vdr-customer-label>\r\n <h6 *ngIf=\"getOrderAddressLines(order.shippingAddress).length\">\r\n {{ 'order.shipping-address' | translate }}\r\n </h6>\r\n <vdr-formatted-address [address]=\"order.shippingAddress\"></vdr-formatted-address>\r\n <h6 *ngIf=\"getOrderAddressLines(order.billingAddress).length\">\r\n {{ 'order.billing-address' | translate }}\r\n </h6>\r\n <vdr-formatted-address [address]=\"order.billingAddress\"></vdr-formatted-address>\r\n </div>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"order.payments && order.payments.length\">\r\n <vdr-order-payment-card\r\n *ngFor=\"let payment of order.payments\"\r\n [currencyCode]=\"order.currencyCode\"\r\n [payment]=\"payment\"\r\n (settlePayment)=\"settlePayment($event)\"\r\n (transitionPaymentState)=\"transitionPaymentState($event)\"\r\n (settleRefund)=\"settleRefund($event)\"\r\n ></vdr-order-payment-card>\r\n </ng-container>\r\n <ng-container *ngFor=\"let fulfillment of order.fulfillments\">\r\n <vdr-fulfillment-card\r\n [fulfillment]=\"fulfillment\"\r\n [order]=\"order\"\r\n (transitionState)=\"transitionFulfillment(fulfillment.id, $event)\"\r\n ></vdr-fulfillment-card>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n BaseDetailComponent,\r\n CancelOrderMutation,\r\n CustomFieldConfig,\r\n DataService,\r\n EditNoteDialogComponent,\r\n GetOrderHistoryQuery,\r\n GetOrderQuery,\r\n HistoryEntry,\r\n ModalService,\r\n NotificationService,\r\n Order,\r\n OrderDetailFragment,\r\n OrderLineFragment,\r\n Refund,\r\n RefundOrderMutation,\r\n ServerConfigService,\r\n SortOrder,\r\n} from '@vendure/admin-ui/core';\r\nimport { assertNever, summate } from '@vendure/common/lib/shared-utils';\r\nimport { EMPTY, merge, Observable, of, Subject } from 'rxjs';\r\nimport { map, mapTo, startWith, switchMap, take } from 'rxjs/operators';\r\n\r\nimport { OrderTransitionService } from '../../providers/order-transition.service';\r\nimport { AddManualPaymentDialogComponent } from '../add-manual-payment-dialog/add-manual-payment-dialog.component';\r\nimport { CancelOrderDialogComponent } from '../cancel-order-dialog/cancel-order-dialog.component';\r\nimport { FulfillOrderDialogComponent } from '../fulfill-order-dialog/fulfill-order-dialog.component';\r\nimport { OrderProcessGraphDialogComponent } from '../order-process-graph-dialog/order-process-graph-dialog.component';\r\nimport { RefundOrderDialogComponent } from '../refund-order-dialog/refund-order-dialog.component';\r\nimport { SettleRefundDialogComponent } from '../settle-refund-dialog/settle-refund-dialog.component';\r\n\r\ntype Payment = NonNullable<OrderDetailFragment['payments']>[number];\r\n\r\n@Component({\r\n selector: 'vdr-order-detail',\r\n templateUrl: './order-detail.component.html',\r\n styleUrls: ['./order-detail.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderDetailComponent\r\n extends BaseDetailComponent<OrderDetailFragment>\r\n implements OnInit, OnDestroy\r\n{\r\n detailForm = new FormGroup({});\r\n history$: Observable<NonNullable<GetOrderHistoryQuery['order']>['history']['items'] | undefined>;\r\n nextStates$: Observable<string[]>;\r\n fetchHistory = new Subject<void>();\r\n customFields: CustomFieldConfig[];\r\n orderLineCustomFields: CustomFieldConfig[];\r\n private readonly defaultStates = [\r\n 'AddingItems',\r\n 'ArrangingPayment',\r\n 'PaymentAuthorized',\r\n 'PaymentSettled',\r\n 'PartiallyShipped',\r\n 'Shipped',\r\n 'PartiallyDelivered',\r\n 'Delivered',\r\n 'Cancelled',\r\n 'Modifying',\r\n 'ArrangingAdditionalPayment',\r\n ];\r\n\r\n constructor(\r\n router: Router,\r\n route: ActivatedRoute,\r\n serverConfigService: ServerConfigService,\r\n private changeDetector: ChangeDetectorRef,\r\n protected dataService: DataService,\r\n private notificationService: NotificationService,\r\n private modalService: ModalService,\r\n private orderTransitionService: OrderTransitionService,\r\n ) {\r\n super(route, router, serverConfigService, dataService);\r\n }\r\n\r\n ngOnInit() {\r\n this.init();\r\n this.entity$.pipe(take(1)).subscribe(order => {\r\n if (order.state === 'Modifying') {\r\n this.router.navigate(['./', 'modify'], { relativeTo: this.route });\r\n }\r\n });\r\n this.customFields = this.getCustomFieldConfig('Order');\r\n this.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\r\n this.history$ = this.fetchHistory.pipe(\r\n startWith(null),\r\n switchMap(() => {\r\n return this.dataService.order\r\n .getOrderHistory(this.id, {\r\n sort: {\r\n createdAt: SortOrder.DESC,\r\n },\r\n })\r\n .mapStream(data => data.order?.history.items);\r\n }),\r\n );\r\n this.nextStates$ = this.entity$.pipe(\r\n map(order => {\r\n const isInCustomState = !this.defaultStates.includes(order.state);\r\n return isInCustomState\r\n ? order.nextStates\r\n : order.nextStates.filter(s => !this.defaultStates.includes(s));\r\n }),\r\n );\r\n }\r\n\r\n ngOnDestroy() {\r\n this.destroy();\r\n }\r\n\r\n openStateDiagram() {\r\n this.entity$\r\n .pipe(\r\n take(1),\r\n switchMap(order =>\r\n this.modalService.fromComponent(OrderProcessGraphDialogComponent, {\r\n closable: true,\r\n locals: {\r\n activeState: order.state,\r\n },\r\n }),\r\n ),\r\n )\r\n .subscribe();\r\n }\r\n\r\n transitionToState(state: string) {\r\n this.dataService.order.transitionToState(this.id, state).subscribe(({ transitionOrderToState }) => {\r\n switch (transitionOrderToState?.__typename) {\r\n case 'Order':\r\n this.notificationService.success(_('order.transitioned-to-state-success'), { state });\r\n this.fetchHistory.next();\r\n break;\r\n case 'OrderStateTransitionError':\r\n this.notificationService.error(transitionOrderToState.transitionError);\r\n }\r\n });\r\n }\r\n\r\n manuallyTransitionToState(order: OrderDetailFragment) {\r\n this.orderTransitionService\r\n .manuallyTransitionToState({\r\n orderId: order.id,\r\n nextStates: order.nextStates,\r\n cancellable: true,\r\n message: _('order.manually-transition-to-state-message'),\r\n retry: 0,\r\n })\r\n .subscribe();\r\n }\r\n\r\n transitionToModifying() {\r\n this.dataService.order\r\n .transitionToState(this.id, 'Modifying')\r\n .subscribe(({ transitionOrderToState }) => {\r\n switch (transitionOrderToState?.__typename) {\r\n case 'Order':\r\n this.router.navigate(['./modify'], { relativeTo: this.route });\r\n break;\r\n case 'OrderStateTransitionError':\r\n this.notificationService.error(transitionOrderToState.transitionError);\r\n }\r\n });\r\n }\r\n\r\n updateCustomFields(customFieldsValue: any) {\r\n this.dataService.order\r\n .updateOrderCustomFields({\r\n id: this.id,\r\n customFields: customFieldsValue,\r\n })\r\n .subscribe(() => {\r\n this.notificationService.success(_('common.notify-update-success'), { entity: 'Order' });\r\n });\r\n }\r\n\r\n getOrderAddressLines(orderAddress?: { [key: string]: string }): string[] {\r\n if (!orderAddress) {\r\n return [];\r\n }\r\n return Object.values(orderAddress)\r\n .filter(val => val !== 'OrderAddress')\r\n .filter(line => !!line);\r\n }\r\n\r\n settlePayment(payment: Payment) {\r\n this.dataService.order.settlePayment(payment.id).subscribe(({ settlePayment }) => {\r\n switch (settlePayment.__typename) {\r\n case 'Payment':\r\n if (settlePayment.state === 'Settled') {\r\n this.notificationService.success(_('order.settle-payment-success'));\r\n } else {\r\n this.notificationService.error(_('order.settle-payment-error'));\r\n }\r\n this.dataService.order.getOrder(this.id).single$.subscribe();\r\n this.fetchHistory.next();\r\n break;\r\n case 'OrderStateTransitionError':\r\n case 'PaymentStateTransitionError':\r\n case 'SettlePaymentError':\r\n this.notificationService.error(settlePayment.message);\r\n }\r\n });\r\n }\r\n\r\n transitionPaymentState({ payment, state }: { payment: Payment; state: string }) {\r\n this.dataService.order\r\n .transitionPaymentToState(payment.id, state)\r\n .subscribe(({ transitionPaymentToState }) => {\r\n switch (transitionPaymentToState.__typename) {\r\n case 'Payment':\r\n this.notificationService.success(_('order.transitioned-payment-to-state-success'), {\r\n state,\r\n });\r\n this.dataService.order.getOrder(this.id).single$.subscribe();\r\n this.fetchHistory.next();\r\n break;\r\n case 'PaymentStateTransitionError':\r\n this.notificationService.error(transitionPaymentToState.message);\r\n break;\r\n }\r\n });\r\n }\r\n\r\n canAddFulfillment(order: OrderDetailFragment): boolean {\r\n const allItemsFulfilled = order.lines\r\n .reduce((items, line) => [...items, ...line.items], [] as OrderLineFragment['items'])\r\n .every(item => !!item.fulfillment || item.cancelled);\r\n return (\r\n !allItemsFulfilled &&\r\n !this.hasUnsettledModifications(order) &&\r\n this.outstandingPaymentAmount(order) === 0 &&\r\n (order.nextStates.includes('Shipped') ||\r\n order.nextStates.includes('PartiallyShipped') ||\r\n order.nextStates.includes('Delivered'))\r\n );\r\n }\r\n\r\n hasUnsettledModifications(order: OrderDetailFragment): boolean {\r\n return 0 < order.modifications.filter(m => !m.isSettled).length;\r\n }\r\n\r\n getOutstandingModificationAmount(order: OrderDetailFragment): number {\r\n return summate(\r\n order.modifications.filter(m => !m.isSettled),\r\n 'priceChange',\r\n );\r\n }\r\n\r\n outstandingPaymentAmount(order: OrderDetailFragment): number {\r\n const paymentIsValid = (p: Payment): boolean =>\r\n p.state !== 'Cancelled' && p.state !== 'Declined' && p.state !== 'Error';\r\n\r\n let amountCovered = 0;\r\n for (const payment of order.payments?.filter(paymentIsValid) ?? []) {\r\n const refunds = payment.refunds.filter(r => r.state !== 'Failed') ?? [];\r\n const refundsTotal = summate(refunds as Array<Required<Refund>>, 'total');\r\n amountCovered += payment.amount - refundsTotal;\r\n }\r\n return order.totalWithTax - amountCovered;\r\n }\r\n\r\n addManualPayment(order: OrderDetailFragment) {\r\n const priorState = order.state;\r\n this.modalService\r\n .fromComponent(AddManualPaymentDialogComponent, {\r\n closable: true,\r\n locals: {\r\n outstandingAmount: this.outstandingPaymentAmount(order),\r\n currencyCode: order.currencyCode,\r\n },\r\n })\r\n .pipe(\r\n switchMap(result => {\r\n if (result) {\r\n return this.dataService.order.addManualPaymentToOrder({\r\n orderId: this.id,\r\n transactionId: result.transactionId,\r\n method: result.method,\r\n metadata: result.metadata || {},\r\n });\r\n } else {\r\n return EMPTY;\r\n }\r\n }),\r\n switchMap(({ addManualPaymentToOrder }) => {\r\n switch (addManualPaymentToOrder.__typename) {\r\n case 'Order':\r\n this.notificationService.success(_('order.add-payment-to-order-success'));\r\n if (priorState === 'ArrangingAdditionalPayment') {\r\n return this.orderTransitionService.transitionToPreModifyingState(\r\n order.id,\r\n order.nextStates,\r\n );\r\n } else {\r\n return this.dataService.order\r\n .transitionToState(this.id, 'PaymentSettled')\r\n .pipe(mapTo('PaymentSettled'));\r\n }\r\n case 'ManualPaymentStateError':\r\n this.notificationService.error(addManualPaymentToOrder.message);\r\n return EMPTY;\r\n default:\r\n return EMPTY;\r\n }\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.refetchOrder({ result });\r\n }\r\n });\r\n }\r\n\r\n fulfillOrder() {\r\n this.entity$\r\n .pipe(\r\n take(1),\r\n switchMap(order => {\r\n return this.modalService.fromComponent(FulfillOrderDialogComponent, {\r\n size: 'xl',\r\n locals: {\r\n order,\r\n },\r\n });\r\n }),\r\n switchMap(input => {\r\n if (input) {\r\n return this.dataService.order.createFulfillment(input);\r\n } else {\r\n return of(undefined);\r\n }\r\n }),\r\n switchMap(result => this.refetchOrder(result).pipe(mapTo(result))),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n const { addFulfillmentToOrder } = result;\r\n switch (addFulfillmentToOrder.__typename) {\r\n case 'Fulfillment':\r\n this.notificationService.success(_('order.create-fulfillment-success'));\r\n break;\r\n case 'EmptyOrderLineSelectionError':\r\n case 'InsufficientStockOnHandError':\r\n case 'ItemsAlreadyFulfilledError':\r\n case 'InvalidFulfillmentHandlerError':\r\n this.notificationService.error(addFulfillmentToOrder.message);\r\n break;\r\n case 'FulfillmentStateTransitionError':\r\n this.notificationService.error(addFulfillmentToOrder.transitionError);\r\n break;\r\n case 'CreateFulfillmentError':\r\n this.notificationService.error(addFulfillmentToOrder.fulfillmentHandlerError);\r\n break;\r\n case undefined:\r\n this.notificationService.error(JSON.stringify(addFulfillmentToOrder));\r\n break;\r\n default:\r\n assertNever(addFulfillmentToOrder);\r\n }\r\n }\r\n });\r\n }\r\n\r\n transitionFulfillment(id: string, state: string) {\r\n this.dataService.order\r\n .transitionFulfillmentToState(id, state)\r\n .pipe(switchMap(result => this.refetchOrder(result)))\r\n .subscribe(() => {\r\n this.notificationService.success(_('order.successfully-updated-fulfillment'));\r\n });\r\n }\r\n\r\n cancelOrRefund(order: OrderDetailFragment) {\r\n const isRefundable = this.orderHasSettledPayments(order);\r\n if (order.state === 'PaymentAuthorized' || order.active === true || !isRefundable) {\r\n this.cancelOrder(order);\r\n } else {\r\n this.refundOrder(order);\r\n }\r\n }\r\n\r\n settleRefund(refund: Payment['refunds'][number]) {\r\n this.modalService\r\n .fromComponent(SettleRefundDialogComponent, {\r\n size: 'md',\r\n locals: {\r\n refund,\r\n },\r\n })\r\n .pipe(\r\n switchMap(transactionId => {\r\n if (transactionId) {\r\n return this.dataService.order.settleRefund(\r\n {\r\n transactionId,\r\n id: refund.id,\r\n },\r\n this.id,\r\n );\r\n } else {\r\n return of(undefined);\r\n }\r\n }),\r\n // switchMap(result => this.refetchOrder(result)),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.notificationService.success(_('order.settle-refund-success'));\r\n }\r\n });\r\n }\r\n\r\n addNote(event: { note: string; isPublic: boolean }) {\r\n const { note, isPublic } = event;\r\n this.dataService.order\r\n .addNoteToOrder({\r\n id: this.id,\r\n note,\r\n isPublic,\r\n })\r\n .pipe(switchMap(result => this.refetchOrder(result)))\r\n .subscribe(result => {\r\n this.notificationService.success(_('common.notify-create-success'), {\r\n entity: 'Note',\r\n });\r\n });\r\n }\r\n\r\n updateNote(entry: HistoryEntry) {\r\n this.modalService\r\n .fromComponent(EditNoteDialogComponent, {\r\n closable: true,\r\n locals: {\r\n displayPrivacyControls: true,\r\n note: entry.data.note,\r\n noteIsPrivate: !entry.isPublic,\r\n },\r\n })\r\n .pipe(\r\n switchMap(result => {\r\n if (result) {\r\n return this.dataService.order.updateOrderNote({\r\n noteId: entry.id,\r\n isPublic: !result.isPrivate,\r\n note: result.note,\r\n });\r\n } else {\r\n return EMPTY;\r\n }\r\n }),\r\n )\r\n .subscribe(result => {\r\n this.fetchHistory.next();\r\n this.notificationService.success(_('common.notify-update-success'), {\r\n entity: 'Note',\r\n });\r\n });\r\n }\r\n\r\n deleteNote(entry: HistoryEntry) {\r\n return this.modalService\r\n .dialog({\r\n title: _('common.confirm-delete-note'),\r\n body: entry.data.note,\r\n buttons: [\r\n { type: 'secondary', label: _('common.cancel') },\r\n { type: 'danger', label: _('common.delete'), returnValue: true },\r\n ],\r\n })\r\n .pipe(switchMap(res => (res ? this.dataService.order.deleteOrderNote(entry.id) : EMPTY)))\r\n .subscribe(() => {\r\n this.fetchHistory.next();\r\n this.notificationService.success(_('common.notify-delete-success'), {\r\n entity: 'Note',\r\n });\r\n });\r\n }\r\n\r\n orderHasSettledPayments(order: OrderDetailFragment): boolean {\r\n return !!order.payments?.find(p => p.state === 'Settled');\r\n }\r\n\r\n private cancelOrder(order: OrderDetailFragment) {\r\n this.modalService\r\n .fromComponent(CancelOrderDialogComponent, {\r\n size: 'xl',\r\n locals: {\r\n order,\r\n },\r\n })\r\n .pipe(\r\n switchMap(input => {\r\n if (input) {\r\n return this.dataService.order.cancelOrder(input);\r\n } else {\r\n return of(undefined);\r\n }\r\n }),\r\n switchMap(result => this.refetchOrder(result)),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.notificationService.success(_('order.cancelled-order-success'));\r\n }\r\n });\r\n }\r\n\r\n private refundOrder(order: OrderDetailFragment) {\r\n this.modalService\r\n .fromComponent(RefundOrderDialogComponent, {\r\n size: 'xl',\r\n locals: {\r\n order,\r\n },\r\n })\r\n .pipe(\r\n switchMap(input => {\r\n if (!input) {\r\n return of(undefined);\r\n }\r\n\r\n const operations: Array<\r\n Observable<RefundOrderMutation['refundOrder'] | CancelOrderMutation['cancelOrder']>\r\n > = [];\r\n if (input.refund.lines.length) {\r\n operations.push(\r\n this.dataService.order\r\n .refundOrder(input.refund)\r\n .pipe(map(res => res.refundOrder)),\r\n );\r\n }\r\n if (input.cancel.lines?.length) {\r\n operations.push(\r\n this.dataService.order\r\n .cancelOrder(input.cancel)\r\n .pipe(map(res => res.cancelOrder)),\r\n );\r\n }\r\n return merge(...operations);\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n switch (result.__typename) {\r\n case 'Order':\r\n this.refetchOrder(result).subscribe();\r\n this.notificationService.success(_('order.cancelled-order-success'));\r\n break;\r\n case 'Refund':\r\n this.refetchOrder(result).subscribe();\r\n if (result.state === 'Failed') {\r\n this.notificationService.error(_('order.refund-order-failed'));\r\n } else {\r\n this.notificationService.success(_('order.refund-order-success'));\r\n }\r\n break;\r\n case 'QuantityTooGreatError':\r\n case 'MultipleOrderError':\r\n case 'OrderStateTransitionError':\r\n case 'CancelActiveOrderError':\r\n case 'EmptyOrderLineSelectionError':\r\n case 'AlreadyRefundedError':\r\n case 'NothingToRefundError':\r\n case 'PaymentOrderMismatchError':\r\n case 'RefundOrderStateError':\r\n case 'RefundStateTransitionError':\r\n this.notificationService.error(result.message);\r\n break;\r\n }\r\n }\r\n });\r\n }\r\n\r\n private refetchOrder(result: object | undefined): Observable<GetOrderQuery | undefined> {\r\n this.fetchHistory.next();\r\n if (result) {\r\n return this.dataService.order.getOrder(this.id).single$;\r\n } else {\r\n return of(undefined);\r\n }\r\n }\r\n\r\n protected setFormValues(entity: OrderDetailFragment): void {\r\n // empty\r\n }\r\n}\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { CustomFieldConfig, Dialog, ModifyOrderInput, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\nexport enum OrderEditResultType {\r\n Refund,\r\n Payment,\r\n PriceUnchanged,\r\n Cancel,\r\n}\r\n\r\ninterface OrderEditsRefundResult {\r\n result: OrderEditResultType.Refund;\r\n refundPaymentId: string;\r\n refundNote?: string;\r\n}\r\ninterface OrderEditsPaymentResult {\r\n result: OrderEditResultType.Payment;\r\n}\r\ninterface OrderEditsPriceUnchangedResult {\r\n result: OrderEditResultType.PriceUnchanged;\r\n}\r\ninterface OrderEditsCancelResult {\r\n result: OrderEditResultType.Cancel;\r\n}\r\ntype OrderEditResult =\r\n | OrderEditsRefundResult\r\n | OrderEditsPaymentResult\r\n | OrderEditsPriceUnchangedResult\r\n | OrderEditsCancelResult;\r\n\r\n@Component({\r\n selector: 'vdr-order-edits-preview-dialog',\r\n templateUrl: './order-edits-preview-dialog.component.html',\r\n styleUrls: ['./order-edits-preview-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderEditsPreviewDialogComponent implements OnInit, Dialog<OrderEditResult> {\r\n // Passed in via the modalService\r\n order: OrderDetailFragment;\r\n originalTotalWithTax: number;\r\n orderLineCustomFields: CustomFieldConfig[];\r\n modifyOrderInput: ModifyOrderInput;\r\n\r\n selectedPayment?: NonNullable<OrderDetailFragment['payments']>[number];\r\n refundNote: string;\r\n resolveWith: (result?: OrderEditResult) => void;\r\n\r\n get priceDifference(): number {\r\n return this.order.totalWithTax - this.originalTotalWithTax;\r\n }\r\n\r\n ngOnInit() {\r\n this.refundNote = this.modifyOrderInput.note || '';\r\n }\r\n\r\n cancel() {\r\n this.resolveWith({\r\n result: OrderEditResultType.Cancel,\r\n });\r\n }\r\n\r\n submit() {\r\n if (0 < this.priceDifference) {\r\n this.resolveWith({\r\n result: OrderEditResultType.Payment,\r\n });\r\n } else if (this.priceDifference < 0) {\r\n this.resolveWith({\r\n result: OrderEditResultType.Refund,\r\n // tslint:disable-next-line:no-non-null-assertion\r\n refundPaymentId: this.selectedPayment!.id,\r\n refundNote: this.refundNote,\r\n });\r\n } else {\r\n this.resolveWith({\r\n result: OrderEditResultType.PriceUnchanged,\r\n });\r\n }\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.confirm-modifications' | translate }}</ng-template>\r\n<vdr-order-table [order]=\"order\" [orderLineCustomFields]=\"orderLineCustomFields\"></vdr-order-table>\r\n\r\n<h4 class=\"h4\">\r\n {{ 'order.modify-order-price-difference' | translate }}:\r\n <strong>{{ priceDifference | localeCurrency: order.currencyCode }}</strong>\r\n</h4>\r\n<div *ngIf=\"priceDifference < 0\">\r\n<clr-select-container>\r\n <label>{{ 'order.payment-to-refund' | translate }}</label>\r\n <select clrSelect name=\"options\" [(ngModel)]=\"selectedPayment\">\r\n <option\r\n *ngFor=\"let payment of order.payments\"\r\n [ngValue]=\"payment\"\r\n >\r\n #{{ payment.id }} {{ payment.method }}:\r\n {{ payment.amount | localeCurrency: order.currencyCode }}\r\n </option>\r\n </select>\r\n</clr-select-container>\r\n <label class=\"clr-control-label\">{{ 'order.refund-cancellation-reason' | translate }}</label>\r\n <textarea [(ngModel)]=\"refundNote\" name=\"refundNote\" clrTextarea required></textarea>\r\n</div>\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"submit()\" [disabled]=\"priceDifference < 0 && !selectedPayment\" class=\"btn btn-primary\">\r\n {{ 'common.confirm' | translate }}\r\n </button>\r\n</ng-template>\r\n","<vdr-action-bar *ngIf=\"entity$ | async as order\">\r\n <vdr-ab-left>\r\n <div class=\"flex clr-align-items-center\">\r\n <vdr-entity-info [entity]=\"entity$ | async\"></vdr-entity-info>\r\n <vdr-order-state-label [state]=\"order.state\"></vdr-order-state-label>\r\n </div>\r\n </vdr-ab-left>\r\n\r\n <vdr-ab-right>\r\n <button class=\"btn btn-secondary\" (click)=\"transitionToPriorState(order)\">\r\n {{ 'order.cancel-modification' | translate }}\r\n </button>\r\n </vdr-ab-right>\r\n</vdr-action-bar>\r\n\r\n<div *ngIf=\"entity$ | async as order\">\r\n <div class=\"clr-row\">\r\n <div class=\"clr-col-lg-8\">\r\n <table class=\"order-table table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.unit-price' | translate }}</th>\r\n <th>{{ 'order.quantity' | translate }}</th>\r\n <th *ngIf=\"orderLineCustomFields.length\">{{ 'common.custom-fields' | translate }}</th>\r\n <th>{{ 'order.total' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr\r\n *ngFor=\"let line of order.lines; let i = index\"\r\n class=\"order-line\"\r\n [class.is-cancelled]=\"line.quantity === 0\"\r\n [class.modified]=\"isLineModified(line)\"\r\n >\r\n <td class=\"align-middle thumb\">\r\n <img\r\n *ngIf=\"line.featuredAsset\"\r\n [src]=\"line.featuredAsset | assetPreview: 'tiny'\"\r\n />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle unit-price\">\r\n {{ line.unitPriceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ line.unitPrice | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n <td class=\"align-middle quantity\">\r\n <input\r\n type=\"number\"\r\n min=\"0\"\r\n [value]=\"line.quantity\"\r\n (input)=\"updateLineQuantity(line, $event.target.value)\"\r\n />\r\n <vdr-line-refunds [line]=\"line\" [payments]=\"order.payments\"></vdr-line-refunds>\r\n <vdr-line-fulfillment\r\n [line]=\"line\"\r\n [orderState]=\"order.state\"\r\n ></vdr-line-fulfillment>\r\n </td>\r\n <td *ngIf=\"orderLineCustomFields.length\" class=\"order-line-custom-field align-middle\">\r\n <ng-container *ngFor=\"let customField of orderLineCustomFields\">\r\n <vdr-custom-field-control\r\n [customField]=\"customField\"\r\n [customFieldsFormGroup]=\"orderLineCustomFieldsFormArray.get([i])\"\r\n entityName=\"OrderLine\"\r\n [compact]=\"true\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </td>\r\n <td class=\"align-middle total\">\r\n {{ line.linePriceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ line.linePrice | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n <tr\r\n *ngFor=\"let addedLine of addedLines; trackBy: trackByProductVariantId; let i = index\"\r\n class=\"modified\"\r\n >\r\n <td class=\"align-middle thumb\">\r\n <img\r\n *ngIf=\"addedLine.productAsset\"\r\n [src]=\"addedLine.productAsset | assetPreview: 'tiny'\"\r\n />\r\n </td>\r\n <td class=\"align-middle name\">{{ addedLine.productVariantName }}</td>\r\n <td class=\"align-middle sku\">{{ addedLine.sku }}</td>\r\n <td class=\"align-middle unit-price\">\r\n {{ addedLine.priceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ addedLine.price | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n <td class=\"align-middle quantity\">\r\n <input\r\n type=\"number\"\r\n min=\"0\"\r\n [value]=\"addedLine.quantity\"\r\n (input)=\"updateAddedItemQuantity(addedLine, $event.target.value)\"\r\n />\r\n <button class=\"icon-button\" (click)=\"removeAddedItem(i)\">\r\n <clr-icon shape=\"trash\"></clr-icon>\r\n </button>\r\n </td>\r\n <td *ngIf=\"orderLineCustomFields.length\" class=\"order-line-custom-field align-middle\">\r\n <ng-container *ngFor=\"let customField of orderLineCustomFields\">\r\n <vdr-custom-field-control\r\n [customField]=\"customField\"\r\n [customFieldsFormGroup]=\"addItemCustomFieldsFormArray.get([i])\"\r\n entityName=\"OrderLine\"\r\n [compact]=\"true\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </td>\r\n <td class=\"align-middle total\">\r\n {{\r\n (addedLine.priceWithTax * addedLine.quantity) / 100\r\n | currency: order.currencyCode\r\n }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{\r\n (addedLine.price * addedLine.quantity) / 100\r\n | currency: order.currencyCode\r\n }}\r\n </div>\r\n </td>\r\n </tr>\r\n <tr class=\"surcharge\" *ngFor=\"let surcharge of order.surcharges\">\r\n <td class=\"align-middle name left\" colspan=\"2\">{{ surcharge.description }}</td>\r\n <td class=\"align-middle sku\">{{ surcharge.sku }}</td>\r\n <td class=\"align-middle\"></td>\r\n <td></td>\r\n <td *ngIf=\"orderLineCustomFields.length\"></td>\r\n <td class=\"align-middle total\">\r\n {{ surcharge.priceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ surcharge.price | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n <tr\r\n class=\"surcharge modified\"\r\n *ngFor=\"let surcharge of modifyOrderInput.surcharges; let i = index\"\r\n >\r\n <td class=\"align-middle name left\" colspan=\"2\">\r\n {{ surcharge.description }}\r\n <button class=\"icon-button\" (click)=\"removeSurcharge(i)\">\r\n <clr-icon shape=\"trash\"></clr-icon>\r\n </button>\r\n </td>\r\n <td class=\"align-middle sku\">{{ surcharge.sku }}</td>\r\n <td class=\"align-middle\"></td>\r\n <td></td>\r\n <td *ngIf=\"orderLineCustomFields.length\"></td>\r\n <td class=\"align-middle total\">\r\n <ng-container *ngIf=\"getSurchargePrices(surcharge) as surchargePrice\">\r\n {{ surchargePrice.priceWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ surchargePrice.price | localeCurrency: order.currencyCode }}\r\n </div>\r\n </ng-container>\r\n </td>\r\n </tr>\r\n <tr class=\"shipping\">\r\n <td class=\"left clr-align-middle\">{{ 'order.shipping' | translate }}</td>\r\n <td class=\"clr-align-middle\">{{ order.shippingLines[0]?.shippingMethod?.name }}</td>\r\n <td colspan=\"3\"></td>\r\n <td *ngIf=\"orderLineCustomFields.length\"></td>\r\n <td class=\"clr-align-middle\">\r\n {{ order.shippingWithTax | localeCurrency: order.currencyCode }}\r\n <div class=\"net-price\" [title]=\"'order.net-price' | translate\">\r\n {{ order.shipping | localeCurrency: order.currencyCode }}\r\n </div>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <h4 class=\"mb2\">{{ 'order.modifications' | translate }}</h4>\r\n <clr-accordion>\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.add-item-to-order' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <vdr-product-variant-selector class=\"mb4\" (productSelected)=\"addItemSelectedVariant = $event\">\r\n </vdr-product-variant-selector>\r\n <div *ngIf=\"addItemSelectedVariant\" class=\"flex mb4\">\r\n <img\r\n *ngIf=\"addItemSelectedVariant.productAsset as asset\"\r\n [src]=\"asset | assetPreview: 'tiny'\"\r\n class=\"mr4\"\r\n />\r\n <div>\r\n <strong class=\"mr4\">{{ addItemSelectedVariant.productVariantName }}</strong>\r\n <small>{{ addItemSelectedVariant.sku }}</small>\r\n <div>\r\n {{\r\n getSelectedItemPrice(addItemSelectedVariant)\r\n | localeCurrency: order.currencyCode\r\n }}\r\n </div>\r\n </div>\r\n </div>\r\n <ng-container *ngFor=\"let customField of orderLineCustomFields\">\r\n <vdr-custom-field-control\r\n [readonly]=\"!addItemSelectedVariant\"\r\n [customField]=\"customField\"\r\n [customFieldsFormGroup]=\"addItemCustomFieldsForm\"\r\n entityName=\"OrderLine\"\r\n [compact]=\"true\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n <button\r\n class=\"btn btn-secondary\"\r\n [disabled]=\"!addItemSelectedVariant || addItemCustomFieldsForm.invalid\"\r\n (click)=\"addItemToOrder(addItemSelectedVariant)\"\r\n >\r\n {{ 'order.add-item-to-order' | translate }}\r\n </button>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.add-surcharge' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <form [formGroup]=\"surchargeForm\" (submit)=\"addSurcharge(surchargeForm.value)\">\r\n <vdr-form-field [label]=\"'common.description' | translate\" for=\"description\"\r\n ><input id=\"description\" type=\"text\" formControlName=\"description\"\r\n /></vdr-form-field>\r\n <vdr-form-field [label]=\"'order.product-sku' | translate\" for=\"sku\"\r\n ><input id=\"sku\" type=\"text\" formControlName=\"sku\"\r\n /></vdr-form-field>\r\n <vdr-form-field [label]=\"'common.price' | translate\" for=\"price\"\r\n ><vdr-currency-input\r\n [currencyCode]=\"order.currencyCode\"\r\n id=\"price\"\r\n formControlName=\"price\"\r\n ></vdr-currency-input\r\n ></vdr-form-field>\r\n <vdr-form-field\r\n [label]=\"\r\n 'catalog.price-includes-tax-at'\r\n | translate: { rate: surchargeForm.get('taxRate')?.value }\r\n \"\r\n for=\"priceIncludesTax\"\r\n ><input\r\n id=\"priceIncludesTax\"\r\n type=\"checkbox\"\r\n clrCheckbox\r\n formControlName=\"priceIncludesTax\"\r\n /></vdr-form-field>\r\n <vdr-form-field [label]=\"'order.tax-rate' | translate\" for=\"taxRate\"\r\n ><vdr-affixed-input suffix=\"%\"\r\n ><input\r\n id=\"taxRate\"\r\n type=\"number\"\r\n min=\"0\"\r\n max=\"100\"\r\n formControlName=\"taxRate\" /></vdr-affixed-input\r\n ></vdr-form-field>\r\n <vdr-form-field [label]=\"'order.tax-description' | translate\" for=\"taxDescription\"\r\n ><input id=\"taxDescription\" type=\"text\" formControlName=\"taxDescription\"\r\n /></vdr-form-field>\r\n <button\r\n class=\"btn btn-secondary\"\r\n [disabled]=\"\r\n surchargeForm.invalid ||\r\n surchargeForm.pristine ||\r\n surchargeForm.get('price')?.value === 0\r\n \"\r\n >\r\n {{ 'order.add-surcharge' | translate }}\r\n </button>\r\n </form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.edit-shipping-address' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <vdr-address-form\r\n [formGroup]=\"shippingAddressForm\"\r\n [availableCountries]=\"availableCountries$ | async\"\r\n [customFields]=\"addressCustomFields\"\r\n ></vdr-address-form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.edit-billing-address' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <vdr-address-form\r\n [formGroup]=\"billingAddressForm\"\r\n [availableCountries]=\"availableCountries$ | async\"\r\n [customFields]=\"addressCustomFields\"\r\n ></vdr-address-form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n </clr-accordion>\r\n </div>\r\n <div class=\"clr-col-lg-4 order-cards\">\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n {{ 'order.modification-summary' | translate }}\r\n </div>\r\n <div class=\"card-block\">\r\n <ul>\r\n <li *ngIf=\"modifyOrderInput.addItems?.length\">\r\n {{\r\n 'order.modification-adding-items'\r\n | translate: { count: modifyOrderInput.addItems?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"modifyOrderInput.adjustOrderLines?.length\">\r\n {{\r\n 'order.modification-adjusting-lines'\r\n | translate: { count: modifyOrderInput.adjustOrderLines?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"modifyOrderInput.surcharges?.length\">\r\n {{\r\n 'order.modification-adding-surcharges'\r\n | translate: { count: modifyOrderInput.surcharges?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"shippingAddressForm.dirty\">\r\n {{ 'order.modification-updating-shipping-address' | translate }}\r\n </li>\r\n <li *ngIf=\"billingAddressForm.dirty\">\r\n {{ 'order.modification-updating-billing-address' | translate }}\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"card-block\">\r\n <label class=\"clr-control-label\">{{ 'order.note' | translate }}</label>\r\n <textarea [(ngModel)]=\"note\" name=\"note\" clrTextarea required></textarea>\r\n <clr-checkbox-wrapper class=\"\">\r\n <input type=\"checkbox\" clrCheckbox [(ngModel)]=\"recalculateShipping\" />\r\n <label>{{ 'order.modification-recalculate-shipping' | translate }}</label>\r\n </clr-checkbox-wrapper>\r\n </div>\r\n <div class=\"card-footer\">\r\n <button\r\n class=\"btn btn-primary\"\r\n [disabled]=\"!canPreviewChanges()\"\r\n (click)=\"previewAndModify(order)\"\r\n >\r\n {{ 'order.preview-changes' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport {\r\n AddItemInput,\r\n AdjustOrderLineInput,\r\n BaseDetailComponent,\r\n CustomFieldConfig,\r\n DataService,\r\n ErrorResult,\r\n GetAvailableCountriesQuery,\r\n HistoryEntryType,\r\n LanguageCode,\r\n ModalService,\r\n ModifyOrderInput,\r\n NotificationService,\r\n OrderAddressFragment,\r\n OrderDetailFragment,\r\n ProductSelectorSearchQuery,\r\n ServerConfigService,\r\n SortOrder,\r\n SurchargeInput,\r\n} from '@vendure/admin-ui/core';\r\nimport { assertNever, notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport { EMPTY, Observable, of } from 'rxjs';\r\nimport { mapTo, shareReplay, switchMap, takeUntil } from 'rxjs/operators';\r\n\r\nimport { OrderTransitionService } from '../../providers/order-transition.service';\r\nimport {\r\n OrderEditResultType,\r\n OrderEditsPreviewDialogComponent,\r\n} from '../order-edits-preview-dialog/order-edits-preview-dialog.component';\r\n\r\ntype ProductSelectorItem = ProductSelectorSearchQuery['search']['items'][number];\r\n\r\ninterface AddedLine {\r\n productVariantId: string;\r\n productAsset?: ProductSelectorItem['productAsset'] | null;\r\n productVariantName: string;\r\n sku: string;\r\n priceWithTax: number;\r\n price: number;\r\n quantity: number;\r\n}\r\n\r\ntype ModifyOrderData = Omit<ModifyOrderInput, 'addItems' | 'adjustOrderLines'> & {\r\n addItems: Array<AddItemInput & { customFields?: any }>;\r\n adjustOrderLines: Array<AdjustOrderLineInput & { customFields?: any }>;\r\n};\r\n\r\n@Component({\r\n selector: 'vdr-order-editor',\r\n templateUrl: './order-editor.component.html',\r\n styleUrls: ['./order-editor.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderEditorComponent\r\n extends BaseDetailComponent<OrderDetailFragment>\r\n implements OnInit, OnDestroy\r\n{\r\n availableCountries$: Observable<GetAvailableCountriesQuery['countries']['items']>;\r\n addressCustomFields: CustomFieldConfig[];\r\n detailForm = new FormGroup({});\r\n orderLineCustomFieldsFormArray: FormArray;\r\n addItemCustomFieldsFormArray: FormArray;\r\n addItemCustomFieldsForm: FormGroup;\r\n addItemSelectedVariant: ProductSelectorItem | undefined;\r\n orderLineCustomFields: CustomFieldConfig[];\r\n modifyOrderInput: ModifyOrderData = {\r\n dryRun: true,\r\n orderId: '',\r\n addItems: [],\r\n adjustOrderLines: [],\r\n surcharges: [],\r\n note: '',\r\n updateShippingAddress: {},\r\n updateBillingAddress: {},\r\n };\r\n surchargeForm: FormGroup;\r\n shippingAddressForm: FormGroup;\r\n billingAddressForm: FormGroup;\r\n note = '';\r\n recalculateShipping = true;\r\n previousState: string;\r\n private addedVariants = new Map<string, ProductSelectorItem>();\r\n\r\n constructor(\r\n router: Router,\r\n route: ActivatedRoute,\r\n serverConfigService: ServerConfigService,\r\n private changeDetector: ChangeDetectorRef,\r\n protected dataService: DataService,\r\n private notificationService: NotificationService,\r\n private modalService: ModalService,\r\n private orderTransitionService: OrderTransitionService,\r\n ) {\r\n super(route, router, serverConfigService, dataService);\r\n }\r\n\r\n get addedLines(): AddedLine[] {\r\n const getSinglePriceValue = (price: ProductSelectorItem['price']) =>\r\n price.__typename === 'SinglePrice' ? price.value : 0;\r\n return (this.modifyOrderInput.addItems || [])\r\n .map(row => {\r\n const variantInfo = this.addedVariants.get(row.productVariantId);\r\n if (variantInfo) {\r\n return {\r\n ...variantInfo,\r\n price: getSinglePriceValue(variantInfo.price),\r\n priceWithTax: getSinglePriceValue(variantInfo.priceWithTax),\r\n quantity: row.quantity,\r\n };\r\n }\r\n })\r\n .filter(notNullOrUndefined);\r\n }\r\n\r\n ngOnInit(): void {\r\n this.init();\r\n this.addressCustomFields = this.getCustomFieldConfig('Address');\r\n this.modifyOrderInput.orderId = this.route.snapshot.paramMap.get('id') as string;\r\n this.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\r\n this.entity$.pipe(takeUntil(this.destroy$)).subscribe(order => {\r\n this.surchargeForm = new FormGroup({\r\n description: new FormControl('', Validators.required),\r\n sku: new FormControl(''),\r\n price: new FormControl(0, Validators.required),\r\n priceIncludesTax: new FormControl(true),\r\n taxRate: new FormControl(0),\r\n taxDescription: new FormControl(''),\r\n });\r\n if (!this.shippingAddressForm) {\r\n this.shippingAddressForm = new FormGroup({\r\n fullName: new FormControl(order.shippingAddress?.fullName),\r\n company: new FormControl(order.shippingAddress?.company),\r\n streetLine1: new FormControl(order.shippingAddress?.streetLine1),\r\n streetLine2: new FormControl(order.shippingAddress?.streetLine2),\r\n city: new FormControl(order.shippingAddress?.city),\r\n province: new FormControl(order.shippingAddress?.province),\r\n postalCode: new FormControl(order.shippingAddress?.postalCode),\r\n countryCode: new FormControl(order.shippingAddress?.countryCode),\r\n phoneNumber: new FormControl(order.shippingAddress?.phoneNumber),\r\n });\r\n this.addAddressCustomFieldsFormGroup(this.shippingAddressForm, order.shippingAddress);\r\n }\r\n if (!this.billingAddressForm) {\r\n this.billingAddressForm = new FormGroup({\r\n fullName: new FormControl(order.billingAddress?.fullName),\r\n company: new FormControl(order.billingAddress?.company),\r\n streetLine1: new FormControl(order.billingAddress?.streetLine1),\r\n streetLine2: new FormControl(order.billingAddress?.streetLine2),\r\n city: new FormControl(order.billingAddress?.city),\r\n province: new FormControl(order.billingAddress?.province),\r\n postalCode: new FormControl(order.billingAddress?.postalCode),\r\n countryCode: new FormControl(order.billingAddress?.countryCode),\r\n phoneNumber: new FormControl(order.billingAddress?.phoneNumber),\r\n });\r\n this.addAddressCustomFieldsFormGroup(this.billingAddressForm, order.billingAddress);\r\n }\r\n this.orderLineCustomFieldsFormArray = new FormArray([]);\r\n for (const line of order.lines) {\r\n const formGroup = new FormGroup({});\r\n for (const { name } of this.orderLineCustomFields) {\r\n formGroup.addControl(name, new FormControl((line as any).customFields[name]));\r\n }\r\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\r\n let modifyRow = this.modifyOrderInput.adjustOrderLines.find(\r\n l => l.orderLineId === line.id,\r\n );\r\n if (!modifyRow) {\r\n modifyRow = {\r\n orderLineId: line.id,\r\n quantity: line.quantity,\r\n };\r\n this.modifyOrderInput.adjustOrderLines.push(modifyRow);\r\n }\r\n if (this.orderLineCustomFields.length) {\r\n modifyRow.customFields = value;\r\n }\r\n });\r\n this.orderLineCustomFieldsFormArray.push(formGroup);\r\n }\r\n });\r\n this.addItemCustomFieldsFormArray = new FormArray([]);\r\n this.addItemCustomFieldsForm = new FormGroup({});\r\n for (const customField of this.orderLineCustomFields) {\r\n this.addItemCustomFieldsForm.addControl(customField.name, new FormControl());\r\n }\r\n this.availableCountries$ = this.dataService.settings\r\n .getAvailableCountries()\r\n .mapSingle(result => result.countries.items)\r\n .pipe(shareReplay(1));\r\n this.dataService.order\r\n .getOrderHistory(this.id, {\r\n take: 1,\r\n sort: {\r\n createdAt: SortOrder.DESC,\r\n },\r\n filter: { type: { eq: HistoryEntryType.ORDER_STATE_TRANSITION } },\r\n })\r\n .single$.subscribe(({ order }) => {\r\n this.previousState = order?.history.items[0].data.from;\r\n });\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.destroy();\r\n }\r\n\r\n transitionToPriorState(order: OrderDetailFragment) {\r\n this.orderTransitionService\r\n .transitionToPreModifyingState(order.id, order.nextStates)\r\n .subscribe(result => {\r\n this.router.navigate(['..'], { relativeTo: this.route });\r\n });\r\n }\r\n\r\n canPreviewChanges(): boolean {\r\n const { addItems, adjustOrderLines, surcharges } = this.modifyOrderInput;\r\n return (\r\n !!addItems?.length ||\r\n !!surcharges?.length ||\r\n !!adjustOrderLines?.length ||\r\n (this.shippingAddressForm.dirty && this.shippingAddressForm.valid) ||\r\n (this.billingAddressForm.dirty && this.billingAddressForm.valid)\r\n );\r\n }\r\n\r\n isLineModified(line: OrderDetailFragment['lines'][number]): boolean {\r\n return !!this.modifyOrderInput.adjustOrderLines?.find(\r\n l => l.orderLineId === line.id && l.quantity !== line.quantity,\r\n );\r\n }\r\n\r\n updateLineQuantity(line: OrderDetailFragment['lines'][number], quantity: string) {\r\n const { adjustOrderLines } = this.modifyOrderInput;\r\n let row = adjustOrderLines?.find(l => l.orderLineId === line.id);\r\n if (row && +quantity === line.quantity) {\r\n // Remove the modification if the quantity is the same as\r\n // the original order\r\n adjustOrderLines?.splice(adjustOrderLines?.indexOf(row), 1);\r\n }\r\n if (!row) {\r\n row = { orderLineId: line.id, quantity: +quantity };\r\n adjustOrderLines?.push(row);\r\n }\r\n row.quantity = +quantity;\r\n }\r\n\r\n updateAddedItemQuantity(item: AddedLine, quantity: string) {\r\n const row = this.modifyOrderInput.addItems?.find(l => l.productVariantId === item.productVariantId);\r\n if (row) {\r\n row.quantity = +quantity;\r\n }\r\n }\r\n\r\n trackByProductVariantId(index: number, item: AddedLine) {\r\n return item.productVariantId;\r\n }\r\n\r\n getSelectedItemPrice(result: ProductSelectorItem | undefined): number {\r\n switch (result?.priceWithTax.__typename) {\r\n case 'SinglePrice':\r\n return result.priceWithTax.value;\r\n default:\r\n return 0;\r\n }\r\n }\r\n\r\n addItemToOrder(result: ProductSelectorItem | undefined) {\r\n if (!result) {\r\n return;\r\n }\r\n const customFields = this.orderLineCustomFields.length\r\n ? this.addItemCustomFieldsForm.value\r\n : undefined;\r\n let row = this.modifyOrderInput.addItems?.find(l =>\r\n this.isMatchingAddItemRow(l, result, customFields),\r\n );\r\n if (!row) {\r\n row = { productVariantId: result.productVariantId, quantity: 1 };\r\n if (customFields) {\r\n row.customFields = customFields;\r\n }\r\n this.modifyOrderInput.addItems?.push(row);\r\n } else {\r\n row.quantity++;\r\n }\r\n if (customFields) {\r\n const formGroup = new FormGroup({});\r\n for (const [key, value] of Object.entries(customFields)) {\r\n formGroup.addControl(key, new FormControl(value));\r\n }\r\n this.addItemCustomFieldsFormArray.push(formGroup);\r\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\r\n if (row) {\r\n row.customFields = value;\r\n }\r\n });\r\n }\r\n this.addItemCustomFieldsForm.reset({});\r\n this.addItemSelectedVariant = undefined;\r\n this.addedVariants.set(result.productVariantId, result);\r\n }\r\n\r\n private isMatchingAddItemRow(\r\n row: ModifyOrderData['addItems'][number],\r\n result: ProductSelectorItem,\r\n customFields: any,\r\n ): boolean {\r\n return (\r\n row.productVariantId === result.productVariantId &&\r\n JSON.stringify(row.customFields) === JSON.stringify(customFields)\r\n );\r\n }\r\n\r\n removeAddedItem(index: number) {\r\n this.modifyOrderInput.addItems.splice(index, 1);\r\n if (-1 < index) {\r\n this.addItemCustomFieldsFormArray.removeAt(index);\r\n }\r\n }\r\n\r\n getSurchargePrices(surcharge: SurchargeInput) {\r\n const priceWithTax = surcharge.priceIncludesTax\r\n ? surcharge.price\r\n : Math.round(surcharge.price * ((100 + (surcharge.taxRate || 0)) / 100));\r\n const price = surcharge.priceIncludesTax\r\n ? Math.round(surcharge.price / ((100 + (surcharge.taxRate || 0)) / 100))\r\n : surcharge.price;\r\n return {\r\n price,\r\n priceWithTax,\r\n };\r\n }\r\n\r\n addSurcharge(value: any) {\r\n this.modifyOrderInput.surcharges?.push(value);\r\n this.surchargeForm.reset({\r\n price: 0,\r\n priceIncludesTax: true,\r\n taxRate: 0,\r\n });\r\n }\r\n\r\n removeSurcharge(index: number) {\r\n this.modifyOrderInput.surcharges?.splice(index, 1);\r\n }\r\n\r\n previewAndModify(order: OrderDetailFragment) {\r\n const input: ModifyOrderInput = {\r\n ...this.modifyOrderInput,\r\n ...(this.billingAddressForm.dirty ? { updateBillingAddress: this.billingAddressForm.value } : {}),\r\n ...(this.shippingAddressForm.dirty\r\n ? { updateShippingAddress: this.shippingAddressForm.value }\r\n : {}),\r\n dryRun: true,\r\n note: this.note ?? '',\r\n options: {\r\n recalculateShipping: this.recalculateShipping,\r\n },\r\n };\r\n const originalTotalWithTax = order.totalWithTax;\r\n this.dataService.order\r\n .modifyOrder(input)\r\n .pipe(\r\n switchMap(({ modifyOrder }) => {\r\n switch (modifyOrder.__typename) {\r\n case 'Order':\r\n return this.modalService.fromComponent(OrderEditsPreviewDialogComponent, {\r\n size: 'xl',\r\n closable: false,\r\n locals: {\r\n originalTotalWithTax,\r\n order: modifyOrder,\r\n orderLineCustomFields: this.orderLineCustomFields,\r\n modifyOrderInput: input,\r\n },\r\n });\r\n case 'InsufficientStockError':\r\n case 'NegativeQuantityError':\r\n case 'NoChangesSpecifiedError':\r\n case 'OrderLimitError':\r\n case 'OrderModificationStateError':\r\n case 'PaymentMethodMissingError':\r\n case 'RefundPaymentIdMissingError': {\r\n this.notificationService.error(modifyOrder.message);\r\n return of(false as const);\r\n }\r\n case null:\r\n case undefined:\r\n return of(false as const);\r\n default:\r\n assertNever(modifyOrder);\r\n }\r\n }),\r\n switchMap(result => {\r\n if (!result || result.result === OrderEditResultType.Cancel) {\r\n // re-fetch so that the preview values get overwritten in the cache.\r\n return this.dataService.order.getOrder(this.id).mapSingle(() => false);\r\n } else {\r\n // Do the modification\r\n const wetRunInput = {\r\n ...input,\r\n dryRun: false,\r\n };\r\n if (result.result === OrderEditResultType.Refund) {\r\n wetRunInput.refund = {\r\n paymentId: result.refundPaymentId,\r\n reason: result.refundNote,\r\n };\r\n }\r\n return this.dataService.order.modifyOrder(wetRunInput).pipe(\r\n switchMap(({ modifyOrder }) => {\r\n if (modifyOrder.__typename === 'Order') {\r\n const priceDelta = modifyOrder.totalWithTax - originalTotalWithTax;\r\n const nextState =\r\n 0 < priceDelta ? 'ArrangingAdditionalPayment' : this.previousState;\r\n\r\n return this.dataService.order\r\n .transitionToState(order.id, nextState)\r\n .pipe(mapTo(true));\r\n } else {\r\n this.notificationService.error((modifyOrder as ErrorResult).message);\r\n return EMPTY;\r\n }\r\n }),\r\n );\r\n }\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.router.navigate(['../'], { relativeTo: this.route });\r\n }\r\n });\r\n }\r\n\r\n private addAddressCustomFieldsFormGroup(\r\n parentFormGroup: FormGroup,\r\n address?: OrderAddressFragment | null,\r\n ) {\r\n if (address && this.addressCustomFields.length) {\r\n const addressCustomFieldsFormGroup = new FormGroup({});\r\n for (const customFieldDef of this.addressCustomFields) {\r\n const name = customFieldDef.name;\r\n const value = (address as any).customFields?.[name];\r\n addressCustomFieldsFormGroup.addControl(name, new FormControl(value));\r\n }\r\n parentFormGroup.addControl('customFields', addressCustomFieldsFormGroup);\r\n }\r\n }\r\n\r\n protected setFormValues(entity: OrderDetailFragment, languageCode: LanguageCode): void {\r\n /* not used */\r\n }\r\n}\r\n","<vdr-action-bar>\r\n <vdr-ab-left>\r\n <div class=\"search-form\">\r\n <div class=\"btn-group btn-outline-primary\" *ngIf=\"activePreset$ | async as activePreset\">\r\n <button\r\n class=\"btn\"\r\n *ngFor=\"let preset of filterPresets\"\r\n [class.btn-primary]=\"activePreset === preset.name\"\r\n (click)=\"selectFilterPreset(preset.name)\"\r\n >\r\n {{ preset.label | translate }}\r\n </button>\r\n <button\r\n class=\"btn\"\r\n [class.btn-primary]=\"activePreset === 'custom'\"\r\n (click)=\"selectFilterPreset('custom')\"\r\n >\r\n {{ 'order.filter-custom' | translate }}\r\n <clr-icon shape=\"angle down\"></clr-icon>\r\n </button>\r\n </div>\r\n\r\n <input\r\n type=\"text\"\r\n name=\"searchTerm\"\r\n [formControl]=\"searchOrderCodeControl\"\r\n [placeholder]=\"'order.search-by-order-code' | translate\"\r\n class=\"search-input\"\r\n />\r\n <input\r\n type=\"text\"\r\n name=\"searchTerm\"\r\n [formControl]=\"searchLastNameControl\"\r\n [placeholder]=\"'order.search-by-customer-last-name' | translate\"\r\n class=\"search-input\"\r\n />\r\n </div>\r\n <div class=\"custom-filters\" [class.expanded]=\"(activePreset$ | async) === 'custom'\">\r\n <form [formGroup]=\"customFilterForm\">\r\n <div class=\"flex align-center\">\r\n <ng-select\r\n [items]=\"orderStates\"\r\n appendTo=\"body\"\r\n [addTag]=\"false\"\r\n [multiple]=\"true\"\r\n formControlName=\"states\"\r\n [placeholder]=\"'state.all-orders' | translate\"\r\n [clearable]=\"true\"\r\n [searchable]=\"false\"\r\n >\r\n <ng-template ng-option-tmp let-item=\"item\">{{ item | stateI18nToken | translate }}</ng-template>\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <span class=\"ng-value-label\"> {{ item | stateI18nToken | translate }}</span>\r\n <span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n </ng-template>\r\n </ng-select>\r\n <button\r\n class=\"btn btn-secondary\"\r\n [disabled]=\"customFilterForm.pristine\"\r\n (click)=\"applyCustomFilters()\"\r\n >\r\n {{ 'order.apply-filters' | translate }}\r\n <clr-icon shape=\"filter\"></clr-icon>\r\n </button>\r\n </div>\r\n <div class=\"flex\">\r\n <div>\r\n <label>{{ 'order.placed-at-start' | translate }}</label>\r\n <vdr-datetime-picker formControlName=\"placedAtStart\"></vdr-datetime-picker>\r\n </div>\r\n <div>\r\n <label>{{ 'order.placed-at-end' | translate }}</label>\r\n <vdr-datetime-picker formControlName=\"placedAtEnd\"></vdr-datetime-picker>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </vdr-ab-left>\r\n <vdr-ab-right>\r\n <vdr-action-bar-items locationId=\"order-list\"></vdr-action-bar-items>\r\n </vdr-ab-right>\r\n</vdr-action-bar>\r\n\r\n<vdr-data-table\r\n [items]=\"items$ | async\"\r\n [itemsPerPage]=\"itemsPerPage$ | async\"\r\n [totalItems]=\"totalItems$ | async\"\r\n [currentPage]=\"currentPage$ | async\"\r\n (pageChange)=\"setPageNumber($event)\"\r\n (itemsPerPageChange)=\"setItemsPerPage($event)\"\r\n>\r\n <vdr-dt-column>{{ 'common.code' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'order.customer' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'order.state' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'order.total' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'common.updated-at' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'order.placed-at' | translate }}</vdr-dt-column>\r\n <vdr-dt-column>{{ 'order.shipping' | translate }}</vdr-dt-column>\r\n <vdr-dt-column></vdr-dt-column>\r\n <ng-template let-order=\"item\">\r\n <td class=\"left align-middle\">{{ order.code }}</td>\r\n <td class=\"left align-middle\">\r\n <vdr-customer-label [customer]=\"order.customer\"></vdr-customer-label>\r\n </td>\r\n <td class=\"left align-middle\">\r\n <vdr-order-state-label [state]=\"order.state\"></vdr-order-state-label>\r\n </td>\r\n <td class=\"left align-middle\">{{ order.total | localeCurrency: order.currencyCode }}</td>\r\n <td class=\"left align-middle\">{{ order.updatedAt | timeAgo }}</td>\r\n <td class=\"left align-middle\">{{ order.orderPlacedAt | localeDate: 'medium' }}</td>\r\n <td class=\"left align-middle\">{{ getShippingNames(order) }}</td>\r\n <td class=\"right align-middle\">\r\n <vdr-table-row-action\r\n iconShape=\"shopping-cart\"\r\n [label]=\"'common.open' | translate\"\r\n [linkTo]=\"order.state === 'Modifying' ? ['./', order.id, 'modify'] : ['./', order.id]\"\r\n ></vdr-table-row-action>\r\n </td>\r\n </ng-template>\r\n</vdr-data-table>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n BaseListComponent,\r\n DataService,\r\n GetOrderListQuery,\r\n ItemOf,\r\n LocalStorageService,\r\n OrderListOptions,\r\n ServerConfigService,\r\n SortOrder,\r\n} from '@vendure/admin-ui/core';\r\nimport { Order } from '@vendure/common/lib/generated-types';\r\nimport { merge, Observable } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, filter, map, takeUntil } from 'rxjs/operators';\r\n\r\ninterface OrderFilterConfig {\r\n active?: boolean;\r\n states?: string[];\r\n}\r\n\r\ninterface FilterPreset {\r\n name: string;\r\n label: string;\r\n config: OrderFilterConfig;\r\n}\r\n\r\n@Component({\r\n selector: 'vdr-order-list',\r\n templateUrl: './order-list.component.html',\r\n styleUrls: ['./order-list.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderListComponent\r\n extends BaseListComponent<GetOrderListQuery, ItemOf<GetOrderListQuery, 'orders'>>\r\n implements OnInit\r\n{\r\n searchOrderCodeControl = new FormControl('');\r\n searchLastNameControl = new FormControl('');\r\n customFilterForm: FormGroup;\r\n orderStates = this.serverConfigService.getOrderProcessStates().map(item => item.name);\r\n filterPresets: FilterPreset[] = [\r\n {\r\n name: 'open',\r\n label: _('order.filter-preset-open'),\r\n config: {\r\n active: false,\r\n states: this.orderStates.filter(\r\n s => s !== 'Delivered' && s !== 'Cancelled' && s !== 'Shipped',\r\n ),\r\n },\r\n },\r\n {\r\n name: 'shipped',\r\n label: _('order.filter-preset-shipped'),\r\n config: {\r\n active: false,\r\n states: ['Shipped'],\r\n },\r\n },\r\n {\r\n name: 'completed',\r\n label: _('order.filter-preset-completed'),\r\n config: {\r\n active: false,\r\n states: ['Delivered', 'Cancelled'],\r\n },\r\n },\r\n {\r\n name: 'active',\r\n label: _('order.filter-preset-active'),\r\n config: {\r\n active: true,\r\n },\r\n },\r\n ];\r\n activePreset$: Observable<string>;\r\n\r\n constructor(\r\n private serverConfigService: ServerConfigService,\r\n private dataService: DataService,\r\n private localStorageService: LocalStorageService,\r\n router: Router,\r\n route: ActivatedRoute,\r\n ) {\r\n super(router, route);\r\n super.setQueryFn(\r\n // tslint:disable-next-line:no-shadowed-variable\r\n (take, skip) => this.dataService.order.getOrders({ take, skip }).refetchOnChannelChange(),\r\n data => data.orders,\r\n // tslint:disable-next-line:no-shadowed-variable\r\n (skip, take) =>\r\n this.createQueryOptions(\r\n skip,\r\n take,\r\n this.searchOrderCodeControl.value,\r\n this.searchLastNameControl.value,\r\n this.route.snapshot.queryParamMap.get('filter') || 'open',\r\n ),\r\n );\r\n const lastFilters = this.localStorageService.get('orderListLastCustomFilters');\r\n if (lastFilters) {\r\n this.setQueryParam(lastFilters, { replaceUrl: true });\r\n }\r\n }\r\n\r\n ngOnInit() {\r\n super.ngOnInit();\r\n this.activePreset$ = this.route.queryParamMap.pipe(\r\n map(qpm => qpm.get('filter') || 'open'),\r\n distinctUntilChanged(),\r\n );\r\n const searchTerms$ = merge(\r\n this.searchOrderCodeControl.valueChanges,\r\n this.searchLastNameControl.valueChanges,\r\n ).pipe(\r\n filter(value => 2 < value.length || value.length === 0),\r\n debounceTime(250),\r\n );\r\n merge(searchTerms$, this.route.queryParamMap)\r\n .pipe(takeUntil(this.destroy$))\r\n .subscribe(val => {\r\n this.refresh();\r\n });\r\n\r\n const queryParamMap = this.route.snapshot.queryParamMap;\r\n this.customFilterForm = new FormGroup({\r\n states: new FormControl(queryParamMap.getAll('states') ?? []),\r\n placedAtStart: new FormControl(queryParamMap.get('placedAtStart')),\r\n placedAtEnd: new FormControl(queryParamMap.get('placedAtEnd')),\r\n });\r\n }\r\n\r\n selectFilterPreset(presetName: string) {\r\n const lastCustomFilters = this.localStorageService.get('orderListLastCustomFilters') ?? {};\r\n const emptyCustomFilters = { states: undefined, placedAtStart: undefined, placedAtEnd: undefined };\r\n const filters = presetName === 'custom' ? lastCustomFilters : emptyCustomFilters;\r\n this.setQueryParam(\r\n {\r\n filter: presetName,\r\n page: 1,\r\n ...filters,\r\n },\r\n { replaceUrl: true },\r\n );\r\n }\r\n\r\n applyCustomFilters() {\r\n const formValue = this.customFilterForm.value;\r\n const customFilters = {\r\n states: formValue.states,\r\n placedAtStart: formValue.placedAtStart,\r\n placedAtEnd: formValue.placedAtEnd,\r\n };\r\n this.setQueryParam({\r\n filter: 'custom',\r\n ...customFilters,\r\n });\r\n this.customFilterForm.markAsPristine();\r\n this.localStorageService.set('orderListLastCustomFilters', customFilters);\r\n }\r\n\r\n private createQueryOptions(\r\n // tslint:disable-next-line:no-shadowed-variable\r\n skip: number,\r\n take: number,\r\n orderCodeSearchTerm: string,\r\n customerNameSearchTerm: string,\r\n activeFilterPreset?: string,\r\n ): { options: OrderListOptions } {\r\n const filterConfig = this.filterPresets.find(p => p.name === activeFilterPreset);\r\n // tslint:disable-next-line:no-shadowed-variable\r\n const filter: any = {};\r\n if (filterConfig) {\r\n if (filterConfig.config.active != null) {\r\n filter.active = {\r\n eq: filterConfig.config.active,\r\n };\r\n }\r\n if (filterConfig.config.states) {\r\n filter.state = {\r\n in: filterConfig.config.states,\r\n };\r\n }\r\n } else if (activeFilterPreset === 'custom') {\r\n const queryParams = this.route.snapshot.queryParamMap;\r\n const states = queryParams.getAll('states') ?? [];\r\n const placedAtStart = queryParams.get('placedAtStart');\r\n const placedAtEnd = queryParams.get('placedAtEnd');\r\n if (states.length) {\r\n filter.state = {\r\n in: states,\r\n };\r\n }\r\n if (placedAtStart && placedAtEnd) {\r\n filter.orderPlacedAt = {\r\n between: {\r\n start: placedAtStart,\r\n end: placedAtEnd,\r\n },\r\n };\r\n } else if (placedAtStart) {\r\n filter.orderPlacedAt = {\r\n after: placedAtStart,\r\n };\r\n } else if (placedAtEnd) {\r\n filter.orderPlacedAt = {\r\n before: placedAtEnd,\r\n };\r\n }\r\n }\r\n if (customerNameSearchTerm) {\r\n filter.customerLastName = {\r\n contains: customerNameSearchTerm,\r\n };\r\n }\r\n if (orderCodeSearchTerm) {\r\n filter.code = {\r\n contains: orderCodeSearchTerm,\r\n };\r\n }\r\n return {\r\n options: {\r\n skip,\r\n take,\r\n filter: {\r\n ...(filter ?? {}),\r\n },\r\n sort: {\r\n updatedAt: SortOrder.DESC,\r\n },\r\n },\r\n };\r\n }\r\n\r\n getShippingNames(order: Order) {\r\n if (order.shippingLines.length) {\r\n return order.shippingLines.map(shippingLine => shippingLine.shippingMethod.name).join(', ');\r\n } else {\r\n return '';\r\n }\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { BaseEntityResolver, DataService, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n/**\r\n * Resolves the id from the path into a Customer entity.\r\n */\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class OrderResolver extends BaseEntityResolver<OrderDetailFragment> {\r\n constructor(router: Router, dataService: DataService) {\r\n super(\r\n router,\r\n {\r\n __typename: 'Order',\r\n id: '',\r\n code: '',\r\n createdAt: '',\r\n updatedAt: '',\r\n total: 0,\r\n } as any,\r\n id => dataService.order.getOrder(id).mapStream(data => data.order),\r\n );\r\n }\r\n}\r\n","import { Route } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n BreadcrumbLabelLinkPair,\r\n CanDeactivateDetailGuard,\r\n createResolveData,\r\n detailBreadcrumb,\r\n OrderDetailFragment,\r\n} from '@vendure/admin-ui/core';\r\nimport { map } from 'rxjs/operators';\r\n\r\nimport { OrderDetailComponent } from './components/order-detail/order-detail.component';\r\nimport { OrderEditorComponent } from './components/order-editor/order-editor.component';\r\nimport { OrderListComponent } from './components/order-list/order-list.component';\r\nimport { OrderResolver } from './providers/routing/order-resolver';\r\n\r\nexport const orderRoutes: Route[] = [\r\n {\r\n path: '',\r\n component: OrderListComponent,\r\n data: {\r\n breadcrumb: _('breadcrumb.orders'),\r\n },\r\n },\r\n {\r\n path: ':id',\r\n component: OrderDetailComponent,\r\n resolve: createResolveData(OrderResolver),\r\n canDeactivate: [CanDeactivateDetailGuard],\r\n data: {\r\n breadcrumb: orderBreadcrumb,\r\n },\r\n },\r\n {\r\n path: ':id/modify',\r\n component: OrderEditorComponent,\r\n resolve: createResolveData(OrderResolver),\r\n // canDeactivate: [CanDeactivateDetailGuard],\r\n data: {\r\n breadcrumb: modifyingOrderBreadcrumb,\r\n },\r\n },\r\n];\r\n\r\nexport function orderBreadcrumb(data: any, params: any) {\r\n return detailBreadcrumb<OrderDetailFragment>({\r\n entity: data.entity,\r\n id: params.id,\r\n breadcrumbKey: 'breadcrumb.orders',\r\n getName: order => order.code,\r\n route: '',\r\n });\r\n}\r\n\r\nexport function modifyingOrderBreadcrumb(data: any, params: any) {\r\n return orderBreadcrumb(data, params).pipe(\r\n map((breadcrumbs: BreadcrumbLabelLinkPair[]) => {\r\n const modifiedBreadcrumbs = breadcrumbs.slice();\r\n modifiedBreadcrumbs[0].link[0] = '../';\r\n modifiedBreadcrumbs[1].link[0] = '../orders';\r\n return modifiedBreadcrumbs.concat({ label: _('breadcrumb.modifying'), link: [''] });\r\n }) as any,\r\n );\r\n}\r\n","import { NgModule } from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { SharedModule } from '@vendure/admin-ui/core';\n\nimport { AddManualPaymentDialogComponent } from './components/add-manual-payment-dialog/add-manual-payment-dialog.component';\nimport { CancelOrderDialogComponent } from './components/cancel-order-dialog/cancel-order-dialog.component';\nimport { FulfillOrderDialogComponent } from './components/fulfill-order-dialog/fulfill-order-dialog.component';\nimport { FulfillmentCardComponent } from './components/fulfillment-card/fulfillment-card.component';\nimport { FulfillmentDetailComponent } from './components/fulfillment-detail/fulfillment-detail.component';\nimport { FulfillmentStateLabelComponent } from './components/fulfillment-state-label/fulfillment-state-label.component';\nimport { LineFulfillmentComponent } from './components/line-fulfillment/line-fulfillment.component';\nimport { LineRefundsComponent } from './components/line-refunds/line-refunds.component';\nimport { ModificationDetailComponent } from './components/modification-detail/modification-detail.component';\nimport { OrderCustomFieldsCardComponent } from './components/order-custom-fields-card/order-custom-fields-card.component';\nimport { OrderDetailComponent } from './components/order-detail/order-detail.component';\nimport { OrderEditorComponent } from './components/order-editor/order-editor.component';\nimport { OrderEditsPreviewDialogComponent } from './components/order-edits-preview-dialog/order-edits-preview-dialog.component';\nimport { OrderHistoryComponent } from './components/order-history/order-history.component';\nimport { OrderListComponent } from './components/order-list/order-list.component';\nimport { OrderPaymentCardComponent } from './components/order-payment-card/order-payment-card.component';\nimport { OrderProcessGraphDialogComponent } from './components/order-process-graph-dialog/order-process-graph-dialog.component';\nimport { OrderProcessEdgeComponent } from './components/order-process-graph/order-process-edge.component';\nimport { OrderProcessGraphComponent } from './components/order-process-graph/order-process-graph.component';\nimport { OrderProcessNodeComponent } from './components/order-process-graph/order-process-node.component';\nimport { OrderStateSelectDialogComponent } from './components/order-state-select-dialog/order-state-select-dialog.component';\nimport { OrderTableComponent } from './components/order-table/order-table.component';\nimport { PaymentDetailComponent } from './components/payment-detail/payment-detail.component';\nimport { PaymentStateLabelComponent } from './components/payment-state-label/payment-state-label.component';\nimport { RefundOrderDialogComponent } from './components/refund-order-dialog/refund-order-dialog.component';\nimport { RefundStateLabelComponent } from './components/refund-state-label/refund-state-label.component';\nimport { SettleRefundDialogComponent } from './components/settle-refund-dialog/settle-refund-dialog.component';\nimport { SimpleItemListComponent } from './components/simple-item-list/simple-item-list.component';\nimport { orderRoutes } from './order.routes';\n\n@NgModule({\n imports: [SharedModule, RouterModule.forChild(orderRoutes)],\n declarations: [\n OrderListComponent,\n OrderDetailComponent,\n FulfillOrderDialogComponent,\n LineFulfillmentComponent,\n RefundOrderDialogComponent,\n CancelOrderDialogComponent,\n PaymentStateLabelComponent,\n LineRefundsComponent,\n OrderPaymentCardComponent,\n RefundStateLabelComponent,\n SettleRefundDialogComponent,\n OrderHistoryComponent,\n FulfillmentDetailComponent,\n PaymentDetailComponent,\n SimpleItemListComponent,\n OrderCustomFieldsCardComponent,\n OrderProcessGraphComponent,\n OrderProcessNodeComponent,\n OrderProcessEdgeComponent,\n OrderProcessGraphDialogComponent,\n FulfillmentStateLabelComponent,\n FulfillmentCardComponent,\n OrderEditorComponent,\n OrderTableComponent,\n OrderEditsPreviewDialogComponent,\n ModificationDetailComponent,\n AddManualPaymentDialogComponent,\n OrderStateSelectDialogComponent,\n ],\n})\nexport class OrderModule {}\n"],"sourceRoot":"webpack:///","file":"849.56aaa5a0d453cfdf.js"}