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

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 (65) hide show
  1. package/lib/admin-ui/165.6aeb6ecf722558ee.js.map +1 -1
  2. package/lib/admin-ui/239.e2e63f2ccd517604.js +2 -0
  3. package/lib/admin-ui/239.e2e63f2ccd517604.js.map +1 -0
  4. package/lib/admin-ui/26.5cc3bfffe8943e16.js +2 -0
  5. package/lib/admin-ui/26.5cc3bfffe8943e16.js.map +1 -0
  6. package/lib/admin-ui/316.265d65a6a9d1b4c0.js +2 -0
  7. package/lib/admin-ui/{316.07f9c805e4c95dc8.js.map → 316.265d65a6a9d1b4c0.js.map} +1 -1
  8. package/lib/admin-ui/356.975f7f2d201afda5.js +2 -0
  9. package/lib/admin-ui/356.975f7f2d201afda5.js.map +1 -0
  10. package/lib/admin-ui/3rdpartylicenses.txt +23 -0
  11. package/lib/admin-ui/407.a3fde1da25c0935c.js +12 -0
  12. package/lib/admin-ui/407.a3fde1da25c0935c.js.map +1 -0
  13. package/lib/admin-ui/451.a7fd4069c4f4c687.js +65 -0
  14. package/lib/admin-ui/451.a7fd4069c4f4c687.js.map +1 -0
  15. package/lib/admin-ui/600.17470a2c90aa79d8.js +2 -0
  16. package/lib/admin-ui/600.17470a2c90aa79d8.js.map +1 -0
  17. package/lib/admin-ui/625.3c0c5821b952b58e.js +2 -0
  18. package/lib/admin-ui/{625.adebc6a7222bde82.js.map → 625.3c0c5821b952b58e.js.map} +1 -1
  19. package/lib/admin-ui/i18n-messages/cs.json +50 -3
  20. package/lib/admin-ui/i18n-messages/de.json +53 -3
  21. package/lib/admin-ui/i18n-messages/en.json +55 -8
  22. package/lib/admin-ui/i18n-messages/es.json +50 -3
  23. package/lib/admin-ui/i18n-messages/fr.json +50 -3
  24. package/lib/admin-ui/i18n-messages/it.json +50 -3
  25. package/lib/admin-ui/i18n-messages/pl.json +50 -3
  26. package/lib/admin-ui/i18n-messages/pt_BR.json +50 -3
  27. package/lib/admin-ui/i18n-messages/pt_PT.json +50 -3
  28. package/lib/admin-ui/i18n-messages/ru.json +50 -3
  29. package/lib/admin-ui/i18n-messages/uk.json +50 -3
  30. package/lib/admin-ui/i18n-messages/zh_Hans.json +50 -3
  31. package/lib/admin-ui/i18n-messages/zh_Hant.json +50 -3
  32. package/lib/admin-ui/index.html +2 -2
  33. package/lib/admin-ui/main.65109179713dd228.js +2944 -0
  34. package/lib/admin-ui/main.65109179713dd228.js.map +1 -0
  35. package/lib/admin-ui/runtime.28bd5da02a9b1f7b.js +2 -0
  36. package/lib/admin-ui/{runtime.1dd1cbaf09547dd2.js.map → runtime.28bd5da02a9b1f7b.js.map} +1 -1
  37. package/lib/admin-ui/styles/_variables.scss +4 -0
  38. package/lib/admin-ui/styles/global/_forms.scss +8 -7
  39. package/lib/admin-ui/styles/global/_overrides.scss +11 -1
  40. package/lib/admin-ui/styles/global/_sass-overrides.scss +3 -0
  41. package/lib/admin-ui/styles/global/_utilities.scss +14 -0
  42. package/lib/admin-ui/styles/styles.scss +1 -0
  43. package/lib/admin-ui/styles/theme/default.scss +13 -1
  44. package/lib/admin-ui/styles/ui-extension-theme.scss +1 -0
  45. package/lib/admin-ui/{styles.fb1aaa9a9baed129.css → styles.88d3f0120bfc894a.css} +2 -2
  46. package/lib/admin-ui/styles.88d3f0120bfc894a.css.map +1 -0
  47. package/package.json +4 -4
  48. package/lib/admin-ui/239.a68e402e10b798f1.js +0 -2
  49. package/lib/admin-ui/239.a68e402e10b798f1.js.map +0 -1
  50. package/lib/admin-ui/26.477d6446134d960e.js +0 -2
  51. package/lib/admin-ui/26.477d6446134d960e.js.map +0 -1
  52. package/lib/admin-ui/316.07f9c805e4c95dc8.js +0 -2
  53. package/lib/admin-ui/349.abe4847f7fe9b3da.js +0 -2
  54. package/lib/admin-ui/349.abe4847f7fe9b3da.js.map +0 -1
  55. package/lib/admin-ui/356.3a6951fe80b5a001.js +0 -2
  56. package/lib/admin-ui/356.3a6951fe80b5a001.js.map +0 -1
  57. package/lib/admin-ui/600.8f0165a8d1255cd0.js +0 -2
  58. package/lib/admin-ui/600.8f0165a8d1255cd0.js.map +0 -1
  59. package/lib/admin-ui/625.adebc6a7222bde82.js +0 -2
  60. package/lib/admin-ui/849.cc032ddf77c67cc3.js +0 -2
  61. package/lib/admin-ui/849.cc032ddf77c67cc3.js.map +0 -1
  62. package/lib/admin-ui/main.0b0d9a8ae6759254.js +0 -2740
  63. package/lib/admin-ui/main.0b0d9a8ae6759254.js.map +0 -1
  64. package/lib/admin-ui/runtime.1dd1cbaf09547dd2.js +0 -2
  65. package/lib/admin-ui/styles.fb1aaa9a9baed129.css.map +0 -1
@@ -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","radioChanged","select","t","cancellationReasons","g","reasons","map","o","i18nService","translate","selectionCount","Object","values","lineQuantities","reduce","order","lines","id","quantity","cancelAll","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","X","L","customFieldConfig","serverConfigService","getCustomFieldsFor","ngOnChanges","buildCustomFieldsFormGroup","fulfillments","fulfillmentId","Map","orderItems","includes","get","name","set","Array","from","customFields","customFieldFormGroup","addControl","customFieldIsObject","isArray","J","U","oxw","transitionState","nextSuggestedState","nextStates","nextOtherStates","z","line","fulfilledCount","getDeliveredCount","fulfillmentStatus","getFulfillmentStatus","length","getFulfillments","count","E","getRefundedCount","payments","refunds","refundId","cancelled","I","added","removed","getModifiedLines","addedItems","removedItems","getSurcharge","surcharges","getAddedItems","getRemovedItems","modification","getOrderLineAndItem","item","_","x","u","onUpdateClick","ee","customFieldForm","formBuilder","group","customFieldsConfig","control","customFieldValues","updateClick","emit","markAsPristine","editable","te","Fe","qe","isCancellable","node","to","active$","next","getPos","elementRef","nativeElement","getBoundingClientRect","querySelector","height","y","index","getStyle","R","asObservable","pipe","nn","activeTarget$","abs","sqrt","transform","onMouseOver","onMouseOut","ne","outerHeight","nodes","setActiveState$","initialState","activeState$","Be","populateNodes","ngAfterViewInit","setTimeout","populateEdges","getNodeFor","nodeComponents","states","push","edges","re","getOrderProcessStates","oe","refundTotal","refund","proratedUnitPriceWithTax","refundShipping","shippingWithTax","adjustment","settledPaymentsTotal","settledPayments","amount","lineCanBeRefundedOrCancelled","selectedPayment","handleZeroQuantity","isRefunding","isCancelling","getOrderLineInput","shipping","paymentId","ie","le","selectedState","ae","transitionToPreModifyingState","getPreModifyingState","message","cancellable","retry","transitionToStateOrThrow","bn","manuallyTransitionToState","modalService","fromComponent","locals","closable","size","Y","Error","Ge","be","r","In","qn","getOrderHistory","type","eq","sort","createdAt","history","data","transitionToState","transitionOrderToState","__typename","notificationService","error","transitionError","F","factory","visibleOrderLineCustomFields","orderLineCustomFieldsVisible","orderLineCustomFields","showElided","getLineCustomFields","toggleOrderLineCustomFields","getLineDiscounts","discounts","config","formGroup","customFieldsForLine","getPromotionLink","adjustmentSource","split","getCouponCodeForAdjustment","promotions","couponCode","H","$","updateNote","deleteNote","getDisplayType","getTimelineIcon","isFeatured","getFulfillment","getPayment","getCancelledItems","orderItemIds","getModification","modifications","getName","administrator","firstName","lastName","customer","addNoteToOrder","addNote","note","isPublic","noteIsPrivate","ce","de","settleRefund","se","refundHasMetadata","keys","metadata","payment","addManualPayment","transitionToModifying","cancelOrRefund","ue","openStateDiagram","fulfillOrder","settlePayment","transitionPaymentState","transitionFulfillment","updateCustomFields","super","init","entity$","router","navigate","relativeTo","route","getCustomFieldConfig","history$","fetchHistory","h","mapStream","nextStates$","q","defaultStates","ngOnDestroy","destroy","activeState","success","orderTransitionService","updateOrderCustomFields","entity","getOrderAddressLines","getOrder","transitionPaymentToState","canAddFulfillment","every","hasUnsettledModifications","outstandingPaymentAmount","isSettled","getOutstandingModificationAmount","M","totalWithTax","outstandingAmount","currencyCode","addManualPaymentToOrder","Ie","refetchOrder","result","createFulfillment","j","addFulfillmentToOrder","fulfillmentHandlerError","JSON","stringify","transitionFulfillmentToState","orderHasSettledPayments","refundOrder","cancelOrder","displayPrivacyControls","updateOrderNote","noteId","isPrivate","dialog","title","body","buttons","label","returnValue","deleteOrderNote","setFormValues","pe","T","priceDifference","originalTotalWithTax","refundNote","modifyOrderInput","Cancel","Payment","Refund","refundPaymentId","PriceUnchanged","me","transitionToPriorState","updateLineQuantity","updateAddedItemQuantity","removeAddedItem","removeSurcharge","previewAndModify","dryRun","addItems","adjustOrderLines","updateShippingAddress","updateBillingAddress","addedLines","addedVariants","productVariantId","price","priceWithTax","addressCustomFields","snapshot","paramMap","destroy$","couponCodes","couponCodesControl","setValue","surchargeForm","description","sku","priceIncludesTax","taxRate","taxDescription","shippingAddressForm","fullName","shippingAddress","company","streetLine1","streetLine2","city","province","postalCode","countryCode","phoneNumber","addAddressCustomFieldsFormGroup","billingAddressForm","P","billingAddress","S","Se","Ne","Je","Ue","Qe","De","ke","orderLineCustomFieldsFormArray","Oe","Ee","Te","valueChanges","Ae","di","availableCouponCodes$","co","couponCodeInput$","promotion","getPromotions","contains","promotionName","addItemCustomFieldsFormArray","addItemCustomFieldsForm","availableCountries$","getAvailableCountries","countries","so","take","previousState","canPreviewChanges","dirty","isLineModified","splice","indexOf","trackByProductVariantId","getSelectedItemPrice","addItemToOrder","isMatchingAddItemRow","reset","addItemSelectedVariant","removeAt","getSurchargePrices","round","addSurcharge","options","recalculateShipping","modifyOrder","_e","selectFilterPreset","orderStates","setQueryFn","getOrders","skip","refetchOnChannelChange","orders","createQueryOptions","searchOrderCodeControl","searchLastNameControl","queryParamMap","localStorageService","setQueryParam","replaceUrl","activePreset$","rt","Le","refresh","customFilterForm","getAll","placedAtStart","placedAtEnd","page","applyCustomFilters","filterPresets","in","orderPlacedAt","between","start","end","after","before","customerLastName","updatedAt","getShippingNames","join","ge","total","w","it","path","component","breadcrumb","resolve","canDeactivate","Pe","lt","breadcrumbKey","slice","link","concat","fe"],"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 <ng-container *ngIf=\"order.active !== true\">\r\n <clr-radio-wrapper>\r\n <input\r\n type=\"radio\"\r\n clrRadio\r\n [value]=\"true\"\r\n [(ngModel)]=\"cancelAll\"\r\n name=\"options\"\r\n (ngModelChange)=\"radioChanged()\"\r\n />\r\n <label>{{ 'order.cancel-entire-order' | translate }}</label>\r\n </clr-radio-wrapper>\r\n <clr-radio-wrapper>\r\n <input\r\n type=\"radio\"\r\n clrRadio\r\n [value]=\"false\"\r\n [(ngModel)]=\"cancelAll\"\r\n name=\"options\"\r\n (ngModelChange)=\"radioChanged()\"\r\n />\r\n <label>{{ 'order.cancel-specified-items' | translate }}</label>\r\n </clr-radio-wrapper>\r\n </ng-container>\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';\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\nimport {\n CancelOrderInput,\n Dialog,\n getAppConfig,\n I18nService,\n OrderDetailFragment,\n OrderLineInput,\n} from '@vendure/admin-ui/core';\n\n@Component({\n selector: 'vdr-cancel-order-dialog',\n templateUrl: './cancel-order-dialog.component.html',\n styleUrls: ['./cancel-order-dialog.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CancelOrderDialogComponent implements OnInit, Dialog<CancelOrderInput> {\n order: OrderDetailFragment;\n cancelAll = true;\n resolveWith: (result?: CancelOrderInput) => void;\n reason: string;\n lineQuantities: { [lineId: string]: number } = {};\n reasons: string[] = getAppConfig().cancellationReasons ?? [\n _('order.cancel-reason-customer-request'),\n _('order.cancel-reason-not-available'),\n ];\n\n get selectionCount(): number {\n return Object.values(this.lineQuantities).reduce((sum, n) => sum + n, 0);\n }\n\n constructor(private i18nService: I18nService) {\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\n }\n\n ngOnInit() {\n this.lineQuantities = this.order.lines.reduce((result, line) => {\n return { ...result, [line.id]: line.quantity };\n }, {});\n }\n\n radioChanged() {\n if (this.cancelAll) {\n for (const line of this.order.lines) {\n this.lineQuantities[line.id] = line.quantity;\n }\n } else {\n for (const line of this.order.lines) {\n this.lineQuantities[line.id] = 0;\n }\n }\n }\n\n checkIfAllSelected() {\n for (const [lineId, quantity] of Object.entries(this.lineQuantities)) {\n const quantityInOrder = this.order.lines.find(line => line.id === lineId)?.quantity;\n if (quantityInOrder && quantity < quantityInOrder) {\n return;\n }\n }\n // If we got here, all of the selected quantities are equal to the order\n // line quantities, i.e. everything is selected.\n this.cancelAll = true;\n }\n\n select() {\n this.resolveWith({\n orderId: this.order.id,\n lines: this.getLineInputs(),\n reason: this.reason,\n cancelShipping: this.cancelAll,\n });\n }\n\n cancel() {\n this.resolveWith();\n }\n\n private getLineInputs(): OrderLineInput[] | undefined {\n if (this.order.active) {\n return;\n }\n return Object.entries(this.lineQuantities)\n .map(([orderLineId, quantity]) => ({\n orderLineId,\n quantity,\n }))\n .filter(l => 0 < l.quantity);\n }\n}\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 quantity-col\">\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\" [class.faded]=\"!isRefunding() && !isCancelling()\">\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';\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\nimport {\n CancelOrderInput,\n Dialog,\n getAppConfig,\n I18nService,\n OrderDetailFragment,\n OrderLineInput,\n RefundOrderInput,\n} from '@vendure/admin-ui/core';\nimport { summate } from '@vendure/common/lib/shared-utils';\n\ntype SelectionLine = { quantity: number; refund: boolean; cancel: boolean };\ntype Payment = NonNullable<OrderDetailFragment['payments']>[number];\n\n@Component({\n selector: 'vdr-refund-order-dialog',\n templateUrl: './refund-order-dialog.component.html',\n styleUrls: ['./refund-order-dialog.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RefundOrderDialogComponent\n implements OnInit, Dialog<{ cancel: CancelOrderInput; refund: RefundOrderInput }>\n{\n order: OrderDetailFragment;\n resolveWith: (result?: { cancel: CancelOrderInput; refund: RefundOrderInput }) => void;\n reason: string;\n settledPayments: Payment[];\n selectedPayment: Payment;\n lineQuantities: { [lineId: string]: SelectionLine } = {};\n refundShipping = false;\n adjustment = 0;\n reasons = getAppConfig().cancellationReasons ?? [\n _('order.refund-reason-customer-request'),\n _('order.refund-reason-not-available'),\n ];\n\n constructor(private i18nService: I18nService) {\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\n }\n\n get refundTotal(): number {\n const itemTotal = this.order.lines.reduce((total, line) => {\n const lineRef = this.lineQuantities[line.id];\n const refundCount = (lineRef.refund && lineRef.quantity) || 0;\n return total + line.proratedUnitPriceWithTax * refundCount;\n }, 0);\n return itemTotal + (this.refundShipping ? this.order.shippingWithTax : 0) + this.adjustment;\n }\n\n get settledPaymentsTotal(): number {\n return this.settledPayments\n .map(payment => {\n const paymentTotal = payment.amount;\n const alreadyRefundedTotal = summate(\n payment.refunds.filter(r => r.state !== 'Failed') as Array<\n Required<Payment['refunds'][number]>\n >,\n 'total',\n );\n return paymentTotal - alreadyRefundedTotal;\n })\n .reduce((sum, amount) => sum + amount, 0);\n }\n\n lineCanBeRefundedOrCancelled(line: OrderDetailFragment['lines'][number]): boolean {\n const refunds =\n this.order.payments?.reduce(\n (all, payment) => [...all, ...payment.refunds],\n [] as Payment['refunds'],\n ) ?? [];\n\n const refundable = line.items.filter(i => {\n if (i.cancelled) {\n return false;\n }\n if (i.refundId == null) {\n return true;\n }\n const refund = refunds.find(r => r.id === i.refundId);\n return refund?.state === 'Failed';\n });\n return 0 < refundable.length;\n }\n\n ngOnInit() {\n this.lineQuantities = this.order.lines.reduce((result, line) => {\n return {\n ...result,\n [line.id]: {\n quantity: 0,\n refund: false,\n cancel: false,\n },\n };\n }, {});\n this.settledPayments = (this.order.payments || []).filter(p => p.state === 'Settled');\n if (this.settledPayments.length) {\n this.selectedPayment = this.settledPayments[0];\n }\n }\n\n handleZeroQuantity(line?: SelectionLine) {\n if (line?.quantity === 0) {\n line.cancel = false;\n line.refund = false;\n }\n }\n\n isRefunding(): boolean {\n const result = Object.values(this.lineQuantities).reduce((isRefunding, line) => {\n return isRefunding || (0 < line.quantity && line.refund);\n }, false);\n return result;\n }\n\n isCancelling(): boolean {\n const result = Object.values(this.lineQuantities).reduce((isCancelling, line) => {\n return isCancelling || (0 < line.quantity && line.cancel);\n }, false);\n return result;\n }\n\n canSubmit(): boolean {\n if (this.isRefunding()) {\n return !!(\n this.selectedPayment &&\n this.reason &&\n 0 < this.refundTotal &&\n this.refundTotal <= this.settledPaymentsTotal\n );\n } else if (this.isCancelling()) {\n return !!this.reason;\n }\n return false;\n }\n\n select() {\n const payment = this.selectedPayment;\n if (payment) {\n const refundLines = this.getOrderLineInput(line => line.refund);\n const cancelLines = this.getOrderLineInput(line => line.cancel);\n\n this.resolveWith({\n refund: {\n lines: refundLines,\n reason: this.reason,\n shipping: this.refundShipping ? this.order.shippingWithTax : 0,\n adjustment: this.adjustment,\n paymentId: payment.id,\n },\n cancel: {\n lines: cancelLines,\n orderId: this.order.id,\n reason: this.reason,\n cancelShipping: this.refundShipping,\n },\n });\n }\n }\n\n cancel() {\n this.resolveWith();\n }\n\n private getOrderLineInput(filterFn: (line: SelectionLine) => boolean): OrderLineInput[] {\n return Object.entries(this.lineQuantities)\n .filter(([orderLineId, line]) => 0 < line.quantity && filterFn(line))\n .map(([orderLineId, line]) => ({\n orderLineId,\n quantity: line.quantity,\n }));\n }\n}\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 <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.set-coupon-codes' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <ng-select\r\n [items]=\"availableCouponCodes$ | async\"\r\n appendTo=\"body\"\r\n bindLabel=\"code\"\r\n bindValue=\"code\"\r\n [addTag]=\"false\"\r\n [multiple]=\"true\"\r\n [hideSelected]=\"true\"\r\n [minTermLength]=\"2\"\r\n typeToSearchText=\"\"\r\n [typeahead]=\"couponCodeInput$\"\r\n [formControl]=\"couponCodesControl\"\r\n >\r\n <ng-template ng-option-tmp let-item=\"item\">\r\n <vdr-chip>{{ item.code }}</vdr-chip> {{ item.promotionName }}\r\n </ng-template>\r\n </ng-select>\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';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport {\n AddItemInput,\n AdjustOrderLineInput,\n BaseDetailComponent,\n CustomFieldConfig,\n DataService,\n ErrorResult,\n GetAvailableCountriesQuery,\n HistoryEntryType,\n LanguageCode,\n ModalService,\n ModifyOrderInput,\n NotificationService,\n OrderAddressFragment,\n OrderDetailFragment,\n ProductSelectorSearchQuery,\n ServerConfigService,\n SortOrder,\n SurchargeInput,\n} from '@vendure/admin-ui/core';\nimport { assertNever, notNullOrUndefined } from '@vendure/common/lib/shared-utils';\nimport { concat, EMPTY, Observable, of, Subject } from 'rxjs';\nimport {\n distinctUntilChanged,\n map,\n mapTo,\n shareReplay,\n startWith,\n switchMap,\n takeUntil,\n} from 'rxjs/operators';\n\nimport { OrderTransitionService } from '../../providers/order-transition.service';\nimport {\n OrderEditResultType,\n OrderEditsPreviewDialogComponent,\n} from '../order-edits-preview-dialog/order-edits-preview-dialog.component';\n\ntype ProductSelectorItem = ProductSelectorSearchQuery['search']['items'][number];\n\ninterface AddedLine {\n productVariantId: string;\n productAsset?: ProductSelectorItem['productAsset'] | null;\n productVariantName: string;\n sku: string;\n priceWithTax: number;\n price: number;\n quantity: number;\n}\n\ntype ModifyOrderData = Omit<ModifyOrderInput, 'addItems' | 'adjustOrderLines'> & {\n addItems: Array<AddItemInput & { customFields?: any }>;\n adjustOrderLines: Array<AdjustOrderLineInput & { customFields?: any }>;\n};\n\n@Component({\n selector: 'vdr-order-editor',\n templateUrl: './order-editor.component.html',\n styleUrls: ['./order-editor.component.scss'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class OrderEditorComponent\n extends BaseDetailComponent<OrderDetailFragment>\n implements OnInit, OnDestroy\n{\n availableCountries$: Observable<GetAvailableCountriesQuery['countries']['items']>;\n availableCouponCodes$: Observable<Array<{ code: string; promotionName: string }>>;\n couponCodeInput$ = new Subject<string>();\n addressCustomFields: CustomFieldConfig[];\n detailForm = new FormGroup({});\n couponCodesControl = new FormControl();\n orderLineCustomFieldsFormArray: FormArray;\n addItemCustomFieldsFormArray: FormArray;\n addItemCustomFieldsForm: FormGroup;\n addItemSelectedVariant: ProductSelectorItem | undefined;\n orderLineCustomFields: CustomFieldConfig[];\n modifyOrderInput: ModifyOrderData = {\n dryRun: true,\n orderId: '',\n addItems: [],\n adjustOrderLines: [],\n surcharges: [],\n note: '',\n updateShippingAddress: {},\n updateBillingAddress: {},\n };\n surchargeForm: FormGroup;\n shippingAddressForm: FormGroup;\n billingAddressForm: FormGroup;\n note = '';\n recalculateShipping = true;\n previousState: string;\n private addedVariants = new Map<string, ProductSelectorItem>();\n\n constructor(\n router: Router,\n route: ActivatedRoute,\n serverConfigService: ServerConfigService,\n private changeDetector: ChangeDetectorRef,\n protected dataService: DataService,\n private notificationService: NotificationService,\n private modalService: ModalService,\n private orderTransitionService: OrderTransitionService,\n ) {\n super(route, router, serverConfigService, dataService);\n }\n\n get addedLines(): AddedLine[] {\n const getSinglePriceValue = (price: ProductSelectorItem['price']) =>\n price.__typename === 'SinglePrice' ? price.value : 0;\n return (this.modifyOrderInput.addItems || [])\n .map(row => {\n const variantInfo = this.addedVariants.get(row.productVariantId);\n if (variantInfo) {\n return {\n ...variantInfo,\n price: getSinglePriceValue(variantInfo.price),\n priceWithTax: getSinglePriceValue(variantInfo.priceWithTax),\n quantity: row.quantity,\n };\n }\n })\n .filter(notNullOrUndefined);\n }\n\n ngOnInit(): void {\n this.init();\n this.addressCustomFields = this.getCustomFieldConfig('Address');\n this.modifyOrderInput.orderId = this.route.snapshot.paramMap.get('id') as string;\n this.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\n this.entity$.pipe(takeUntil(this.destroy$)).subscribe(order => {\n if (order.couponCodes.length) {\n this.couponCodesControl.setValue(order.couponCodes);\n }\n this.surchargeForm = new FormGroup({\n description: new FormControl('', Validators.required),\n sku: new FormControl(''),\n price: new FormControl(0, Validators.required),\n priceIncludesTax: new FormControl(true),\n taxRate: new FormControl(0),\n taxDescription: new FormControl(''),\n });\n if (!this.shippingAddressForm) {\n this.shippingAddressForm = new FormGroup({\n fullName: new FormControl(order.shippingAddress?.fullName),\n company: new FormControl(order.shippingAddress?.company),\n streetLine1: new FormControl(order.shippingAddress?.streetLine1),\n streetLine2: new FormControl(order.shippingAddress?.streetLine2),\n city: new FormControl(order.shippingAddress?.city),\n province: new FormControl(order.shippingAddress?.province),\n postalCode: new FormControl(order.shippingAddress?.postalCode),\n countryCode: new FormControl(order.shippingAddress?.countryCode),\n phoneNumber: new FormControl(order.shippingAddress?.phoneNumber),\n });\n this.addAddressCustomFieldsFormGroup(this.shippingAddressForm, order.shippingAddress);\n }\n if (!this.billingAddressForm) {\n this.billingAddressForm = new FormGroup({\n fullName: new FormControl(order.billingAddress?.fullName),\n company: new FormControl(order.billingAddress?.company),\n streetLine1: new FormControl(order.billingAddress?.streetLine1),\n streetLine2: new FormControl(order.billingAddress?.streetLine2),\n city: new FormControl(order.billingAddress?.city),\n province: new FormControl(order.billingAddress?.province),\n postalCode: new FormControl(order.billingAddress?.postalCode),\n countryCode: new FormControl(order.billingAddress?.countryCode),\n phoneNumber: new FormControl(order.billingAddress?.phoneNumber),\n });\n this.addAddressCustomFieldsFormGroup(this.billingAddressForm, order.billingAddress);\n }\n this.orderLineCustomFieldsFormArray = new FormArray([]);\n for (const line of order.lines) {\n const formGroup = new FormGroup({});\n for (const { name } of this.orderLineCustomFields) {\n formGroup.addControl(name, new FormControl((line as any).customFields[name]));\n }\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\n let modifyRow = this.modifyOrderInput.adjustOrderLines.find(\n l => l.orderLineId === line.id,\n );\n if (!modifyRow) {\n modifyRow = {\n orderLineId: line.id,\n quantity: line.quantity,\n };\n this.modifyOrderInput.adjustOrderLines.push(modifyRow);\n }\n if (this.orderLineCustomFields.length) {\n modifyRow.customFields = value;\n }\n });\n this.orderLineCustomFieldsFormArray.push(formGroup);\n }\n });\n this.availableCouponCodes$ = concat(\n this.couponCodeInput$.pipe(\n distinctUntilChanged(),\n switchMap(\n term =>\n this.dataService.promotion.getPromotions(10, 0, {\n couponCode: { contains: term },\n }).single$,\n ),\n map(({ promotions }) =>\n // tslint:disable-next-line:no-non-null-assertion\n promotions.items.map(p => ({ code: p.couponCode!, promotionName: p.name })),\n ),\n startWith([]),\n ),\n );\n this.addItemCustomFieldsFormArray = new FormArray([]);\n this.addItemCustomFieldsForm = new FormGroup({});\n for (const customField of this.orderLineCustomFields) {\n this.addItemCustomFieldsForm.addControl(customField.name, new FormControl());\n }\n this.availableCountries$ = this.dataService.settings\n .getAvailableCountries()\n .mapSingle(result => result.countries.items)\n .pipe(shareReplay(1));\n this.dataService.order\n .getOrderHistory(this.id, {\n take: 1,\n sort: {\n createdAt: SortOrder.DESC,\n },\n filter: { type: { eq: HistoryEntryType.ORDER_STATE_TRANSITION } },\n })\n .single$.subscribe(({ order }) => {\n this.previousState = order?.history.items[0].data.from;\n });\n }\n\n ngOnDestroy(): void {\n this.destroy();\n }\n\n transitionToPriorState(order: OrderDetailFragment) {\n this.orderTransitionService\n .transitionToPreModifyingState(order.id, order.nextStates)\n .subscribe(result => {\n this.router.navigate(['..'], { relativeTo: this.route });\n });\n }\n\n canPreviewChanges(): boolean {\n const { addItems, adjustOrderLines, surcharges } = this.modifyOrderInput;\n return (\n !!addItems?.length ||\n !!surcharges?.length ||\n !!adjustOrderLines?.length ||\n (this.shippingAddressForm.dirty && this.shippingAddressForm.valid) ||\n (this.billingAddressForm.dirty && this.billingAddressForm.valid) ||\n this.couponCodesControl.dirty\n );\n }\n\n isLineModified(line: OrderDetailFragment['lines'][number]): boolean {\n return !!this.modifyOrderInput.adjustOrderLines?.find(\n l => l.orderLineId === line.id && l.quantity !== line.quantity,\n );\n }\n\n updateLineQuantity(line: OrderDetailFragment['lines'][number], quantity: string) {\n const { adjustOrderLines } = this.modifyOrderInput;\n let row = adjustOrderLines?.find(l => l.orderLineId === line.id);\n if (row && +quantity === line.quantity) {\n // Remove the modification if the quantity is the same as\n // the original order\n adjustOrderLines?.splice(adjustOrderLines?.indexOf(row), 1);\n }\n if (!row) {\n row = { orderLineId: line.id, quantity: +quantity };\n adjustOrderLines?.push(row);\n }\n row.quantity = +quantity;\n }\n\n updateAddedItemQuantity(item: AddedLine, quantity: string) {\n const row = this.modifyOrderInput.addItems?.find(l => l.productVariantId === item.productVariantId);\n if (row) {\n row.quantity = +quantity;\n }\n }\n\n trackByProductVariantId(index: number, item: AddedLine) {\n return item.productVariantId;\n }\n\n getSelectedItemPrice(result: ProductSelectorItem | undefined): number {\n switch (result?.priceWithTax.__typename) {\n case 'SinglePrice':\n return result.priceWithTax.value;\n default:\n return 0;\n }\n }\n\n addItemToOrder(result: ProductSelectorItem | undefined) {\n if (!result) {\n return;\n }\n const customFields = this.orderLineCustomFields.length\n ? this.addItemCustomFieldsForm.value\n : undefined;\n let row = this.modifyOrderInput.addItems?.find(l =>\n this.isMatchingAddItemRow(l, result, customFields),\n );\n if (!row) {\n row = { productVariantId: result.productVariantId, quantity: 1 };\n if (customFields) {\n row.customFields = customFields;\n }\n this.modifyOrderInput.addItems?.push(row);\n } else {\n row.quantity++;\n }\n if (customFields) {\n const formGroup = new FormGroup({});\n for (const [key, value] of Object.entries(customFields)) {\n formGroup.addControl(key, new FormControl(value));\n }\n this.addItemCustomFieldsFormArray.push(formGroup);\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\n if (row) {\n row.customFields = value;\n }\n });\n }\n this.addItemCustomFieldsForm.reset({});\n this.addItemSelectedVariant = undefined;\n this.addedVariants.set(result.productVariantId, result);\n }\n\n private isMatchingAddItemRow(\n row: ModifyOrderData['addItems'][number],\n result: ProductSelectorItem,\n customFields: any,\n ): boolean {\n return (\n row.productVariantId === result.productVariantId &&\n JSON.stringify(row.customFields) === JSON.stringify(customFields)\n );\n }\n\n removeAddedItem(index: number) {\n this.modifyOrderInput.addItems.splice(index, 1);\n if (-1 < index) {\n this.addItemCustomFieldsFormArray.removeAt(index);\n }\n }\n\n getSurchargePrices(surcharge: SurchargeInput) {\n const priceWithTax = surcharge.priceIncludesTax\n ? surcharge.price\n : Math.round(surcharge.price * ((100 + (surcharge.taxRate || 0)) / 100));\n const price = surcharge.priceIncludesTax\n ? Math.round(surcharge.price / ((100 + (surcharge.taxRate || 0)) / 100))\n : surcharge.price;\n return {\n price,\n priceWithTax,\n };\n }\n\n addSurcharge(value: any) {\n this.modifyOrderInput.surcharges?.push(value);\n this.surchargeForm.reset({\n price: 0,\n priceIncludesTax: true,\n taxRate: 0,\n });\n }\n\n removeSurcharge(index: number) {\n this.modifyOrderInput.surcharges?.splice(index, 1);\n }\n\n previewAndModify(order: OrderDetailFragment) {\n const input: ModifyOrderInput = {\n ...this.modifyOrderInput,\n ...(this.billingAddressForm.dirty ? { updateBillingAddress: this.billingAddressForm.value } : {}),\n ...(this.shippingAddressForm.dirty\n ? { updateShippingAddress: this.shippingAddressForm.value }\n : {}),\n dryRun: true,\n couponCodes: this.couponCodesControl.dirty ? this.couponCodesControl.value : undefined,\n note: this.note ?? '',\n options: {\n recalculateShipping: this.recalculateShipping,\n },\n };\n const originalTotalWithTax = order.totalWithTax;\n this.dataService.order\n .modifyOrder(input)\n .pipe(\n switchMap(({ modifyOrder }) => {\n switch (modifyOrder.__typename) {\n case 'Order':\n return this.modalService.fromComponent(OrderEditsPreviewDialogComponent, {\n size: 'xl',\n closable: false,\n locals: {\n originalTotalWithTax,\n order: modifyOrder,\n orderLineCustomFields: this.orderLineCustomFields,\n modifyOrderInput: input,\n },\n });\n case 'InsufficientStockError':\n case 'NegativeQuantityError':\n case 'NoChangesSpecifiedError':\n case 'OrderLimitError':\n case 'OrderModificationStateError':\n case 'PaymentMethodMissingError':\n case 'RefundPaymentIdMissingError':\n case 'CouponCodeLimitError':\n case 'CouponCodeExpiredError':\n case 'CouponCodeInvalidError': {\n this.notificationService.error(modifyOrder.message);\n return of(false as const);\n }\n case null:\n case undefined:\n return of(false as const);\n default:\n assertNever(modifyOrder);\n }\n }),\n switchMap(result => {\n if (!result || result.result === OrderEditResultType.Cancel) {\n // re-fetch so that the preview values get overwritten in the cache.\n return this.dataService.order.getOrder(this.id).mapSingle(() => false);\n } else {\n // Do the modification\n const wetRunInput = {\n ...input,\n dryRun: false,\n };\n if (result.result === OrderEditResultType.Refund) {\n wetRunInput.refund = {\n paymentId: result.refundPaymentId,\n reason: result.refundNote,\n };\n }\n return this.dataService.order.modifyOrder(wetRunInput).pipe(\n switchMap(({ modifyOrder }) => {\n if (modifyOrder.__typename === 'Order') {\n const priceDelta = modifyOrder.totalWithTax - originalTotalWithTax;\n const nextState =\n 0 < priceDelta ? 'ArrangingAdditionalPayment' : this.previousState;\n\n return this.dataService.order\n .transitionToState(order.id, nextState)\n .pipe(mapTo(true));\n } else {\n this.notificationService.error((modifyOrder as ErrorResult).message);\n return EMPTY;\n }\n }),\n );\n }\n }),\n )\n .subscribe(result => {\n if (result) {\n this.router.navigate(['../'], { relativeTo: this.route });\n }\n });\n }\n\n private addAddressCustomFieldsFormGroup(\n parentFormGroup: FormGroup,\n address?: OrderAddressFragment | null,\n ) {\n if (address && this.addressCustomFields.length) {\n const addressCustomFieldsFormGroup = new FormGroup({});\n for (const customFieldDef of this.addressCustomFields) {\n const name = customFieldDef.name;\n const value = (address as any).customFields?.[name];\n addressCustomFieldsFormGroup.addControl(name, new FormControl(value));\n }\n parentFormGroup.addControl('customFields', addressCustomFieldsFormGroup);\n }\n }\n\n protected setFormValues(entity: OrderDetailFragment, languageCode: LanguageCode): void {\n /* not used */\n }\n}\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.cc032ddf77c67cc3.js"}