@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
@@ -0,0 +1 @@
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","ue","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","me","_e","availableCouponCodes$","ot","couponCodeInput$","pipe","h","promotion","getPromotions","couponCode","contains","single$","promotions","code","promotionName","name","control","couponCodes","G","lt","Ps","d","addressForm","formBuilder","group","fullName","currentAddress","company","streetLine1","c","streetLine2","_","u","city","y","x","province","O","A","postalCode","ie","oe","countryCode","ae","le","phoneNumber","de","ce","useExisting","customerId","addresses$","query","customer","F","T","addresses","selectedAddress","se","V","length","createNew","availableCountries$","getAvailableCountries","countries","trackByFn","addressIdFn","country","valid","W","customerForm","title","firstName","lastName","emailAddress","customers$","input$","Be","Ve","isLoading","getCustomerList","mapStream","customers","q","selectedCustomer","ge","currentSelectionId","selectedMethod","eligibleShippingMethods","methodIdFn","fe","selectedState","he","transitionToPreModifyingState","getPreModifyingState","nextStates","message","state","cancellable","retry","transitionToStateOrThrow","st","manuallyTransitionToState","modalService","fromComponent","locals","closable","size","P","Error","ut","r","rn","on","getOrderHistory","type","eq","sort","createdAt","history","data","to","from","transitionToState","transitionOrderToState","__typename","notificationService","error","transitionError","N","factory","addItemClick","selectedVariant$","selectedVariantId$","product","getProductVariant","productVariant","orderLineCustomFields","customFieldsFormGroup","addControl","addItem","emit","productVariantId","customFields","next","reset","xe","getRefundedCount","payments","refunds","line","refundId","cancelled","Y","ngOnChanges","fulfilledCount","getDeliveredCount","fulfillmentStatus","getFulfillmentStatus","fulfillments","getFulfillments","summary","orderLine","count","fulfillment","oxw","draftInputBlur","remove","K","visibleOrderLineCustomFields","orderLineCustomFieldsVisible","showElided","getLineCustomFields","adjust","lineId","toggleOrderLineCustomFields","getLineDiscounts","discounts","config","formGroup","customFieldsForLine","getPromotionLink","adjustmentSource","split","getCouponCodeForAdjustment","getShippingNames","shippingLines","shippingMethod","join","j","onUpdateClick","onCancelClick","customFieldForm","customFieldsConfig","customFieldValues","updateClick","markAsPristine","editable","dirty","dialog","buttons","label","returnValue","subscribe","completeOrder","deleteOrder","applyCouponCode","removeCouponCode","addItemToOrder","adjustOrderLine","removeOrderLine","setCustomer","setBillingAddress","setShippingAddress","setShippingMethod","updateCustomFields","z","super","init","getCustomFieldConfig","eligibleShippingMethods$","entity$","getDraftOrderEligibleShippingMethods","eligibleShippingMethodsForDraftOrder","ngOnDestroy","destroy","addItemToDraftOrder","adjustDraftOrderLine","removeDraftOrderLine","getOrderAddressLines","hasId","setCustomerForDraftOrder","input","D","shippingAddress","setDraftOrderShippingAddress","billingAddress","setDraftOrderBillingAddress","applyCouponCodeToDraftOrder","removeCouponCodeFromDraftOrder","Ut","currencyCode","setDraftOrderShippingMethod","updateOrderCustomFields","deleteDraftOrder","result","success","entity","router","navigate","setFormValues","ee","getGlobalSettings","globalSettings","fulfillmentQuantities","getFulfillableCount","trackInventory","fulfillCount","max","changeDetector","markForCheck","getShippingMethodOperations","fulfillmentHandlers","fulfillmentHandlerDef","fulfillmentHandlerCode","fulfillmentHandler","fulfillmentHandlerControl","patchValue","stockOnHand","getUnfulfilledCount","Math","min","flat","canSubmit","handler","ve","chipColorType","Ce","$","customFieldConfig","serverConfigService","getCustomFieldsFor","buildCustomFieldsFormGroup","fulfillmentId","customFieldFormGroup","customFieldIsObject","Array","isArray","R","te","transitionState","nextSuggestedState","includes","nextOtherStates","ye","Map","added","removed","getModifiedLines","addedItems","removedItems","getSurcharge","surcharges","getAddedItems","getRemovedItems","modification","orderItems","getOrderLineAndItem","item","get","set","Ze","et","ze","isCancellable","node","active$","getPos","elementRef","nativeElement","getBoundingClientRect","querySelector","height","index","getStyle","ne","asObservable","Qe","activeTarget$","abs","sqrt","transform","onMouseOver","onMouseOut","be","outerHeight","nodes","setActiveState$","initialState","activeState$","populateNodes","ngAfterViewInit","setTimeout","populateEdges","getNodeFor","nodeComponents","states","push","edges","Ae","getOrderProcessStates","Oe","refundTotal","refund","proratedUnitPriceWithTax","refundShipping","shippingWithTax","adjustment","settledPaymentsTotal","settledPayments","amount","lineCanBeRefundedOrCancelled","selectedPayment","handleZeroQuantity","isRefunding","isCancelling","getOrderLineInput","shipping","paymentId","Te","Ie","re","updateNote","deleteNote","getDisplayType","getTimelineIcon","isFeatured","getFulfillment","getPayment","getCancelledItems","orderItemIds","getModification","modifications","getName","administrator","addNoteToOrder","addNote","note","isPublic","noteIsPrivate","Le","qe","settleRefund","Fe","refundHasMetadata","keys","metadata","payment","addManualPayment","transitionToModifying","cancelOrRefund","we","openStateDiagram","fulfillOrder","settlePayment","transitionPaymentState","transitionFulfillment","relativeTo","route","history$","fetchHistory","nextStates$","S","defaultStates","activeState","orderTransitionService","getOrder","cancelPayment","paymentErrorMessage","transitionPaymentToState","canAddFulfillment","hasUnsettledModifications","outstandingPaymentAmount","isSettled","getOutstandingModificationAmount","totalWithTax","outstandingAmount","addManualPaymentToOrder","Ke","refetchOrder","createFulfillment","addFulfillmentToOrder","fulfillmentHandlerError","JSON","stringify","transitionFulfillmentToState","orderHasSettledPayments","refundOrder","cancelOrder","displayPrivacyControls","updateOrderNote","noteId","isPrivate","body","deleteOrderNote","Se","J","priceDifference","originalTotalWithTax","refundNote","modifyOrderInput","Cancel","Payment","Refund","refundPaymentId","PriceUnchanged","Me","transitionToPriorState","updateLineQuantity","updateAddedItemQuantity","removeAddedItem","removeSurcharge","previewAndModify","dryRun","addItems","adjustOrderLines","updateShippingAddress","updateBillingAddress","addedLines","addedVariants","price","priceWithTax","addressCustomFields","snapshot","paramMap","destroy$","couponCodesControl","setValue","surchargeForm","description","sku","priceIncludesTax","taxRate","taxDescription","shippingAddressForm","addAddressCustomFieldsFormGroup","billingAddressForm","orderLineCustomFieldsFormArray","valueChanges","$e","ml","addItemCustomFieldsFormArray","addItemCustomFieldsForm","Ct","take","previousState","canPreviewChanges","isLineModified","splice","indexOf","trackByProductVariantId","getSelectedItemPrice","isMatchingAddItemRow","addItemSelectedVariant","removeAt","getSurchargePrices","round","addSurcharge","mi","options","recalculateShipping","modifyOrder","Ne","selectFilterPreset","orderStates","setQueryFn","getOrders","skip","refetchOnChannelChange","orders","createQueryOptions","searchControl","queryParamMap","localStorageService","setQueryParam","replaceUrl","canCreateDraftOrder","filterPresets","activePreset$","Zt","refresh","customFilterForm","getAll","placedAtStart","placedAtEnd","page","applyCustomFilters","in","orderPlacedAt","between","start","end","after","before","customerLastName","updatedAt","filterOperator","Je","resolve","events","nt","C","component","U","canActivate","url","createDraftOrder","parseUrl","H","bt","path","breadcrumb","canDeactivate","Re","At","breadcrumbKey","slice","link","concat","Ue"],"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/coupon-code-selector/coupon-code-selector.component.html","./src/lib/order/src/components/coupon-code-selector/coupon-code-selector.component.ts","./src/lib/order/src/components/select-address-dialog/select-address-dialog.graphql.ts","./src/lib/order/src/components/select-address-dialog/select-address-dialog.component.html","./src/lib/order/src/components/select-address-dialog/select-address-dialog.component.ts","./src/lib/order/src/components/select-customer-dialog/select-customer-dialog.component.html","./src/lib/order/src/components/select-customer-dialog/select-customer-dialog.component.ts","./src/lib/order/src/components/select-shipping-method-dialog/select-shipping-method-dialog.component.html","./src/lib/order/src/components/select-shipping-method-dialog/select-shipping-method-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/draft-order-variant-selector/draft-order-variant-selector.component.html","./src/lib/order/src/components/draft-order-variant-selector/draft-order-variant-selector.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/line-fulfillment/line-fulfillment.component.html","./src/lib/order/src/components/line-fulfillment/line-fulfillment.component.ts","./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/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/draft-order-detail/draft-order-detail.component.html","./src/lib/order/src/components/draft-order-detail/draft-order-detail.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/modification-detail/modification-detail.component.html","./src/lib/order/src/components/modification-detail/modification-detail.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/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/providers/routing/order.guard.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';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n CancelOrderInput,\r\n Dialog,\r\n getAppConfig,\r\n I18nService,\r\n OrderDetailFragment,\r\n OrderLineInput,\r\n} from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-cancel-order-dialog',\r\n templateUrl: './cancel-order-dialog.component.html',\r\n styleUrls: ['./cancel-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class CancelOrderDialogComponent implements OnInit, Dialog<CancelOrderInput> {\r\n order: OrderDetailFragment;\r\n cancelAll = true;\r\n resolveWith: (result?: CancelOrderInput) => void;\r\n reason: string;\r\n lineQuantities: { [lineId: string]: number } = {};\r\n reasons: string[] = getAppConfig().cancellationReasons ?? [\r\n _('order.cancel-reason-customer-request'),\r\n _('order.cancel-reason-not-available'),\r\n ];\r\n\r\n get selectionCount(): number {\r\n return Object.values(this.lineQuantities).reduce((sum, n) => sum + n, 0);\r\n }\r\n\r\n constructor(private i18nService: I18nService) {\r\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\r\n }\r\n\r\n ngOnInit() {\r\n this.lineQuantities = this.order.lines.reduce((result, line) => {\r\n return { ...result, [line.id]: line.quantity };\r\n }, {});\r\n }\r\n\r\n radioChanged() {\r\n if (this.cancelAll) {\r\n for (const line of this.order.lines) {\r\n this.lineQuantities[line.id] = line.quantity;\r\n }\r\n } else {\r\n for (const line of this.order.lines) {\r\n this.lineQuantities[line.id] = 0;\r\n }\r\n }\r\n }\r\n\r\n checkIfAllSelected() {\r\n for (const [lineId, quantity] of Object.entries(this.lineQuantities)) {\r\n const quantityInOrder = this.order.lines.find(line => line.id === lineId)?.quantity;\r\n if (quantityInOrder && quantity < quantityInOrder) {\r\n return;\r\n }\r\n }\r\n // If we got here, all of the selected quantities are equal to the order\r\n // line quantities, i.e. everything is selected.\r\n this.cancelAll = true;\r\n }\r\n\r\n select() {\r\n this.resolveWith({\r\n orderId: this.order.id,\r\n lines: this.getLineInputs(),\r\n reason: this.reason,\r\n cancelShipping: this.cancelAll,\r\n });\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n private getLineInputs(): OrderLineInput[] | undefined {\r\n if (this.order.active) {\r\n return;\r\n }\r\n return Object.entries(this.lineQuantities)\r\n .map(([orderLineId, quantity]) => ({\r\n orderLineId,\r\n quantity,\r\n }))\r\n .filter(l => 0 < l.quantity);\r\n }\r\n}\r\n","<ng-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]=\"control\"\r\n (add)=\"addCouponCode.emit($event.code)\"\r\n (remove)=\"removeCouponCode.emit($event.value?.code)\"\r\n>\r\n <ng-template ng-option-tmp let-item=\"item\">\r\n <vdr-chip>{{ item.code }}</vdr-chip>\r\n {{ item.promotionName }}\r\n </ng-template>\r\n</ng-select>\r\n","import { Component, OnInit, ChangeDetectionStrategy, Input, Output, EventEmitter } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { DataService } from '@vendure/admin-ui/core';\r\nimport { concat, Observable, Subject } from 'rxjs';\r\nimport { distinctUntilChanged, map, startWith, switchMap } from 'rxjs/operators';\r\n\r\n@Component({\r\n selector: 'vdr-coupon-code-selector',\r\n templateUrl: './coupon-code-selector.component.html',\r\n styleUrls: ['./coupon-code-selector.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class CouponCodeSelectorComponent implements OnInit {\r\n @Input() couponCodes: string[];\r\n @Input() control: FormControl | undefined;\r\n @Output() addCouponCode = new EventEmitter<string>();\r\n @Output() removeCouponCode = new EventEmitter<string>();\r\n availableCouponCodes$: Observable<Array<{ code: string; promotionName: string }>>;\r\n couponCodeInput$ = new Subject<string>();\r\n constructor(private dataService: DataService) {}\r\n\r\n ngOnInit(): void {\r\n this.availableCouponCodes$ = concat(\r\n this.couponCodeInput$.pipe(\r\n distinctUntilChanged(),\r\n switchMap(\r\n term =>\r\n this.dataService.promotion.getPromotions(10, 0, {\r\n couponCode: { contains: term },\r\n }).single$,\r\n ),\r\n map(({ promotions }) =>\r\n // tslint:disable-next-line:no-non-null-assertion\r\n promotions.items.map(p => ({ code: p.couponCode!, promotionName: p.name })),\r\n ),\r\n startWith([]),\r\n ),\r\n );\r\n if (!this.control) {\r\n this.control = new FormControl(this.couponCodes ?? []);\r\n }\r\n }\r\n}\r\n","import { ADDRESS_FRAGMENT } from '@vendure/admin-ui/core';\r\nimport { gql } from 'apollo-angular';\r\n\r\nexport const GET_CUSTOMER_ADDRESSES = gql`\r\n query GetCustomerAddresses($customerId: ID!) {\r\n customer(id: $customerId) {\r\n id\r\n addresses {\r\n ...Address\r\n }\r\n }\r\n }\r\n ${ADDRESS_FRAGMENT}\r\n`;\r\n","<ng-template vdrDialogTitle>{{ 'order.select-address' | translate }}</ng-template>\r\n\r\n<clr-tabs *ngIf=\"addresses$ | async as addresses\">\r\n <clr-tab *ngIf=\"customerId && addresses.length\">\r\n <button clrTabLink>{{ 'order.existing-address' | translate }}</button>\r\n <ng-template [(clrIfActive)]=\"useExisting\">\r\n <clr-tab-content>\r\n <vdr-radio-card-fieldset\r\n class=\"block mt4\"\r\n [idFn]=\"addressIdFn\"\r\n [selectedItemId]=\"selectedAddress && addressIdFn(selectedAddress)\"\r\n (selectItem)=\"selectedAddress = $event\"\r\n >\r\n <vdr-radio-card *ngFor=\"let address of addresses\" [item]=\"address\">\r\n <vdr-formatted-address [address]=\"address\"></vdr-formatted-address>\r\n </vdr-radio-card>\r\n </vdr-radio-card-fieldset>\r\n </clr-tab-content>\r\n </ng-template>\r\n </clr-tab>\r\n <clr-tab>\r\n <button clrTabLink>{{ 'customer.create-new-address' | translate }}</button>\r\n\r\n <ng-template [(clrIfActive)]=\"createNew\">\r\n <clr-tab-content>\r\n <vdr-address-form\r\n [formGroup]=\"addressForm\"\r\n [availableCountries]=\"availableCountries$ | async\"\r\n ></vdr-address-form>\r\n </clr-tab-content>\r\n </ng-template>\r\n </clr-tab>\r\n</clr-tabs>\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]=\"(useExisting && !selectedAddress) || (createNew && addressForm.invalid)\"\r\n class=\"btn btn-primary\"\r\n >\r\n {{ 'common.okay' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport {\r\n AddressFragment,\r\n CreateAddressInput,\r\n CreateCustomerInput,\r\n DataService,\r\n Dialog,\r\n GetAvailableCountriesQuery,\r\n GetCustomerAddressesQuery,\r\n GetCustomerAddressesQueryVariables,\r\n OrderAddressFragment,\r\n} from '@vendure/admin-ui/core';\r\nimport { pick } from '@vendure/common/lib/pick';\r\nimport { Observable, of } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\n\r\nimport { Customer } from '../select-customer-dialog/select-customer-dialog.component';\r\n\r\nimport { GET_CUSTOMER_ADDRESSES } from './select-address-dialog.graphql';\r\n\r\n@Component({\r\n selector: 'vdr-select-address-dialog',\r\n templateUrl: './select-address-dialog.component.html',\r\n styleUrls: ['./select-address-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SelectAddressDialogComponent implements OnInit, Dialog<CreateAddressInput> {\r\n resolveWith: (result?: CreateAddressInput) => void;\r\n availableCountries$: Observable<GetAvailableCountriesQuery['countries']['items']>;\r\n addresses$: Observable<AddressFragment[]>;\r\n customerId: string | undefined;\r\n currentAddress: OrderAddressFragment | undefined;\r\n addressForm: FormGroup;\r\n selectedAddress: AddressFragment | undefined;\r\n useExisting = true;\r\n createNew = false;\r\n\r\n constructor(private dataService: DataService, private formBuilder: FormBuilder) {}\r\n\r\n ngOnInit(): void {\r\n this.addressForm = this.formBuilder.group({\r\n fullName: [this.currentAddress?.fullName ?? ''],\r\n company: [this.currentAddress?.company ?? ''],\r\n streetLine1: [this.currentAddress?.streetLine1 ?? '', Validators.required],\r\n streetLine2: [this.currentAddress?.streetLine2 ?? ''],\r\n city: [this.currentAddress?.city ?? '', Validators.required],\r\n province: [this.currentAddress?.province ?? ''],\r\n postalCode: [this.currentAddress?.postalCode ?? '', Validators.required],\r\n countryCode: [this.currentAddress?.countryCode ?? '', Validators.required],\r\n phoneNumber: [this.currentAddress?.phoneNumber ?? ''],\r\n });\r\n this.useExisting = !!this.customerId;\r\n this.addresses$ = this.customerId\r\n ? this.dataService\r\n .query<GetCustomerAddressesQuery, GetCustomerAddressesQueryVariables>(\r\n GET_CUSTOMER_ADDRESSES,\r\n { customerId: this.customerId },\r\n )\r\n .mapSingle(({ customer }) => customer?.addresses ?? [])\r\n .pipe(\r\n tap(addresses => {\r\n if (this.currentAddress) {\r\n this.selectedAddress = addresses.find(\r\n a =>\r\n a.streetLine1 === this.currentAddress?.streetLine1 &&\r\n a.postalCode === this.currentAddress?.postalCode,\r\n );\r\n }\r\n if (addresses.length === 0) {\r\n this.createNew = true;\r\n this.useExisting = false;\r\n }\r\n }),\r\n )\r\n : of([]);\r\n this.availableCountries$ = this.dataService.settings\r\n .getAvailableCountries()\r\n .mapSingle(({ countries }) => countries.items);\r\n }\r\n\r\n trackByFn(item: Customer) {\r\n return item.id;\r\n }\r\n\r\n addressIdFn(item: AddressFragment) {\r\n return item.streetLine1 + item.postalCode;\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n select() {\r\n if (this.useExisting && this.selectedAddress) {\r\n this.resolveWith({\r\n ...pick(this.selectedAddress, [\r\n 'fullName',\r\n 'company',\r\n 'streetLine1',\r\n 'streetLine2',\r\n 'city',\r\n 'province',\r\n 'phoneNumber',\r\n 'postalCode',\r\n ]),\r\n countryCode: this.selectedAddress.country.code,\r\n });\r\n }\r\n if (this.createNew && this.addressForm.valid) {\r\n const formValue = this.addressForm.value;\r\n this.resolveWith(formValue);\r\n }\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.set-customer-for-order' | translate }}</ng-template>\r\n\r\n<clr-tabs>\r\n <clr-tab>\r\n <button clrTabLink>{{ 'order.existing-customer' | translate }}</button>\r\n\r\n <ng-template [(clrIfActive)]=\"useExisting\">\r\n <clr-tab-content>\r\n <ng-select\r\n [items]=\"customers$ | async\"\r\n appendTo=\"body\"\r\n bindLabel=\"name\"\r\n [addTag]=\"false\"\r\n [multiple]=\"true\"\r\n [hideSelected]=\"true\"\r\n [trackByFn]=\"trackByFn\"\r\n [minTermLength]=\"2\"\r\n [loading]=\"isLoading\"\r\n [typeahead]=\"input$\"\r\n [(ngModel)]=\"selectedCustomer\"\r\n class=\"mt4\"\r\n >\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <clr-icon shape=\"user\" class=\"is-solid\"></clr-icon\r\n ><span class=\"ml2 mr2\">{{ item.firstName }} {{ item.lastName }}</span>\r\n <vdr-chip>{{ item.emailAddress }}</vdr-chip>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\">\r\n <clr-icon shape=\"user\" class=\"is-solid\"></clr-icon\r\n ><span class=\"ml2 mr2\">{{ item.firstName }} {{ item.lastName }}</span>\r\n <vdr-chip>{{ item.emailAddress }}</vdr-chip>\r\n </ng-template>\r\n </ng-select>\r\n </clr-tab-content>\r\n </ng-template>\r\n </clr-tab>\r\n <clr-tab>\r\n <button clrTabLink>{{ 'customer.create-new-customer' | translate }}</button>\r\n\r\n <ng-template [(clrIfActive)]=\"createNew\">\r\n <clr-tab-content>\r\n <form [formGroup]=\"customerForm\">\r\n <vdr-form-field [label]=\"'customer.title' | translate\" for=\"title\">\r\n <input id=\"title\" type=\"text\" formControlName=\"title\" />\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'customer.first-name' | translate\" for=\"firstName\">\r\n <input id=\"firstName\" type=\"text\" formControlName=\"firstName\" />\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'customer.last-name' | translate\" for=\"lastName\">\r\n <input id=\"lastName\" type=\"text\" formControlName=\"lastName\" />\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'customer.email-address' | translate\" for=\"emailAddress\">\r\n <input id=\"emailAddress\" type=\"text\" formControlName=\"emailAddress\" />\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'customer.phone-number' | translate\" for=\"phoneNumber\">\r\n <input id=\"phoneNumber\" type=\"text\" formControlName=\"phoneNumber\" />\r\n </vdr-form-field>\r\n </form>\r\n </clr-tab-content>\r\n </ng-template>\r\n </clr-tab>\r\n</clr-tabs>\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]=\"(useExisting && selectedCustomer.length === 0) || (createNew && customerForm.invalid)\"\r\n class=\"btn btn-primary\"\r\n >\r\n {{ 'common.okay' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { CreateCustomerInput, DataService, Dialog, GetCustomerListQuery } from '@vendure/admin-ui/core';\r\nimport { concat, Observable, of, Subject } from 'rxjs';\r\nimport { catchError, debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\r\n\r\nexport type Customer = GetCustomerListQuery['customers']['items'][number];\r\n\r\n@Component({\r\n selector: 'vdr-select-customer-dialog',\r\n templateUrl: './select-customer-dialog.component.html',\r\n styleUrls: ['./select-customer-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SelectCustomerDialogComponent implements OnInit, Dialog<Customer | CreateCustomerInput> {\r\n resolveWith: (result?: Customer | CreateCustomerInput) => void;\r\n customerForm: FormGroup;\r\n customers$: Observable<Customer[]>;\r\n isLoading = false;\r\n input$ = new Subject<string>();\r\n selectedCustomer: Customer[] = [];\r\n useExisting = true;\r\n createNew = false;\r\n\r\n constructor(private dataService: DataService, private formBuilder: FormBuilder) {\r\n this.customerForm = this.formBuilder.group({\r\n title: '',\r\n firstName: ['', Validators.required],\r\n lastName: ['', Validators.required],\r\n phoneNumber: '',\r\n emailAddress: ['', [Validators.required, Validators.email]],\r\n });\r\n }\r\n\r\n ngOnInit(): void {\r\n this.customers$ = concat(\r\n of([]), // default items\r\n this.input$.pipe(\r\n debounceTime(200),\r\n distinctUntilChanged(),\r\n tap(() => (this.isLoading = true)),\r\n switchMap(term =>\r\n this.dataService.customer\r\n .getCustomerList(10, 0, term)\r\n .mapStream(({ customers }) => customers.items)\r\n .pipe(\r\n catchError(() => of([])), // empty list on error\r\n tap(() => (this.isLoading = false)),\r\n ),\r\n ),\r\n ),\r\n );\r\n }\r\n\r\n trackByFn(item: Customer) {\r\n return item.id;\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n select() {\r\n if (this.useExisting && this.selectedCustomer.length === 1) {\r\n this.resolveWith(this.selectedCustomer[0]);\r\n }\r\n if (this.createNew && this.customerForm.valid) {\r\n const formValue = this.customerForm.value;\r\n this.resolveWith(formValue);\r\n }\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.select-shipping-method' | translate }}</ng-template>\r\n<vdr-radio-card-fieldset\r\n [idFn]=\"methodIdFn\"\r\n [selectedItemId]=\"selectedMethod?.id\"\r\n (selectItem)=\"selectedMethod = $event\"\r\n>\r\n <vdr-radio-card *ngFor=\"let quote of eligibleShippingMethods\" [item]=\"quote\">\r\n <div class=\"result-details\">\r\n <vdr-labeled-data [label]=\"'settings.shipping-method' | translate\">\r\n {{ quote.name }}\r\n </vdr-labeled-data>\r\n <div class=\"price-row\">\r\n <vdr-labeled-data [label]=\"'common.price' | translate\">\r\n {{ quote.price | localeCurrency: currencyCode }}\r\n </vdr-labeled-data>\r\n <vdr-labeled-data [label]=\"'common.price-with-tax' | translate\">\r\n {{ quote.priceWithTax | localeCurrency: currencyCode }}\r\n </vdr-labeled-data>\r\n </div>\r\n <vdr-object-tree *ngIf=\"quote.metadata\" [value]=\"quote.metadata\"></vdr-object-tree>\r\n </div>\r\n </vdr-radio-card>\r\n</vdr-radio-card-fieldset>\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]=\"!selectedMethod\"\r\n class=\"btn btn-primary\"\r\n >\r\n {{ 'common.okay' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core';\r\nimport {\r\n CreateAddressInput,\r\n CurrencyCode,\r\n Dialog,\r\n DraftOrderEligibleShippingMethodsQuery,\r\n} from '@vendure/admin-ui/core';\r\n\r\ntype ShippingMethodQuote =\r\n DraftOrderEligibleShippingMethodsQuery['eligibleShippingMethodsForDraftOrder'][number];\r\n\r\n@Component({\r\n selector: 'vdr-select-shipping-method-dialog',\r\n templateUrl: './select-shipping-method-dialog.component.html',\r\n styleUrls: ['./select-shipping-method-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SelectShippingMethodDialogComponent implements OnInit, Dialog<string> {\r\n resolveWith: (result?: string) => void;\r\n eligibleShippingMethods: ShippingMethodQuote[];\r\n currentSelectionId: string;\r\n currencyCode: CurrencyCode;\r\n selectedMethod: ShippingMethodQuote | undefined;\r\n constructor() {}\r\n\r\n ngOnInit(): void {\r\n if (this.currentSelectionId) {\r\n this.selectedMethod = this.eligibleShippingMethods.find(m => m.id === this.currentSelectionId);\r\n }\r\n }\r\n\r\n methodIdFn(item: ShippingMethodQuote) {\r\n return item.id;\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n select() {\r\n if (this.selectedMethod) {\r\n this.resolveWith(this.selectedMethod.id);\r\n }\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","<div class=\"card\">\r\n <div class=\"card-block\">\r\n <h4 class=\"card-title\">{{ 'order.add-item-to-order' | translate }}</h4>\r\n <vdr-product-variant-selector\r\n (productSelected)=\"selectedVariantId$.next($event.productVariantId)\"\r\n ></vdr-product-variant-selector>\r\n </div>\r\n <div class=\"card-block\" *ngIf=\"selectedVariant$ | async as selectedVariant\">\r\n <div class=\"variant-details\">\r\n <img class=\"mr2\" [src]=\"selectedVariant.featuredAsset || selectedVariant.product.featuredAsset | assetPreview: 32\">\r\n <div class=\"details\">\r\n <div>{{ selectedVariant?.name }}</div>\r\n <div class=\"small\">{{ selectedVariant?.sku }}</div>\r\n </div>\r\n <div class=\"details ml4\">\r\n <div class=\"small\">\r\n {{ 'catalog.stock-on-hand' | translate }}: {{ selectedVariant.stockOnHand }}\r\n </div>\r\n <div class=\"small\">\r\n {{ 'catalog.stock-allocated' | translate }}: {{ selectedVariant.stockAllocated }}\r\n </div>\r\n </div>\r\n <div class=\"flex-spacer\"></div>\r\n <div class=\"details\">\r\n <div>{{ selectedVariant?.priceWithTax | localeCurrency: currencyCode }}</div>\r\n <div class=\"small\" [title]=\"'order.net-price' | translate\">\r\n {{ selectedVariant?.price | localeCurrency: currencyCode }}\r\n </div>\r\n </div>\r\n <div>\r\n <input [disabled]=\"!selectedVariant\" type=\"number\" min=\"0\" [(ngModel)]=\"quantity\" />\r\n </div>\r\n <button\r\n [disabled]=\"!selectedVariant\"\r\n class=\"btn btn-small btn-primary\"\r\n (click)=\"addItemClick(selectedVariant)\"\r\n >\r\n {{ 'order.add-item-to-order' | translate }}\r\n </button>\r\n </div>\r\n <ng-container *ngIf=\"orderLineCustomFields.length\">\r\n <div class=\"custom-field\" *ngFor=\"let field of orderLineCustomFields\">\r\n <vdr-custom-field-control\r\n [compact]=\"true\"\r\n [readonly]=\"false\"\r\n [customField]=\"field\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n ></vdr-custom-field-control>\r\n </div>\r\n </ng-container>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { CurrencyCode, CustomFieldConfig, DataService, GetProductVariantQuery } from '@vendure/admin-ui/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { switchMap } from 'rxjs/operators';\r\n\r\n@Component({\r\n selector: 'vdr-draft-order-variant-selector',\r\n templateUrl: './draft-order-variant-selector.component.html',\r\n styleUrls: ['./draft-order-variant-selector.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DraftOrderVariantSelectorComponent implements OnInit {\r\n @Input() currencyCode: CurrencyCode;\r\n @Input() orderLineCustomFields: CustomFieldConfig[];\r\n @Output() addItem = new EventEmitter<{ productVariantId: string; quantity: number; customFields: any }>();\r\n customFieldsFormGroup = new FormGroup({});\r\n selectedVariant$: Observable<GetProductVariantQuery['productVariant']>;\r\n selectedVariantId$ = new Subject<string | undefined>();\r\n quantity = 1;\r\n constructor(private dataService: DataService) {}\r\n\r\n ngOnInit(): void {\r\n this.selectedVariant$ = this.selectedVariantId$.pipe(\r\n switchMap(id => {\r\n if (id) {\r\n return this.dataService.product\r\n .getProductVariant(id)\r\n .mapSingle(({ productVariant }) => productVariant);\r\n } else {\r\n return [undefined];\r\n }\r\n }),\r\n );\r\n for (const customField of this.orderLineCustomFields) {\r\n this.customFieldsFormGroup.addControl(customField.name, new FormControl(''));\r\n }\r\n }\r\n\r\n addItemClick(selectedVariant: GetProductVariantQuery['productVariant']) {\r\n if (selectedVariant) {\r\n this.addItem.emit({\r\n productVariantId: selectedVariant.id,\r\n quantity: this.quantity,\r\n customFields: this.orderLineCustomFields.length\r\n ? this.customFieldsFormGroup.value\r\n : undefined,\r\n });\r\n this.selectedVariantId$.next(undefined);\r\n this.customFieldsFormGroup.reset();\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-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\nimport { unique } from '@vendure/common/lib/unique';\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 (\r\n line.fulfillments?.reduce(\r\n (sum, fulfillment) =>\r\n sum + (fulfillment.summary.find(s => s.orderLine.id === line.id)?.quantity ?? 0),\r\n 0,\r\n ) ?? 0\r\n );\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: NonNullable<OrderDetailFragment['fulfillments']>[number] }> {\r\n return (\r\n line.fulfillments?.map(fulfillment => {\r\n const summaryLine = fulfillment.summary.find(s => s.orderLine.id === line.id);\r\n return {\r\n count: summaryLine?.quantity ?? 0,\r\n fulfillment,\r\n };\r\n }) ?? []\r\n );\r\n }\r\n}\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>{{ '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 <ng-container *ngIf=\"!isDraft; else draft\">\r\n {{ line.quantity }}\r\n </ng-container>\r\n <ng-template #draft>\r\n <div class=\"flex\">\r\n <input\r\n class=\"draft-qty\"\r\n type=\"number\"\r\n min=\"0\"\r\n #qtyInput\r\n [value]=\"line.quantity\"\r\n (blur)=\"draftInputBlur(line, qtyInput.valueAsNumber)\"\r\n />\r\n <button class=\"icon-button\" (click)=\"remove.emit({ lineId: line.id })\">\r\n <clr-icon shape=\"trash\"></clr-icon>\r\n </button>\r\n </div>\r\n </ng-template>\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\">{{ getShippingNames(order) }}</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, EventEmitter, Input, OnInit, Output } 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 @Input() isDraft = false;\r\n @Output() adjust = new EventEmitter<{ lineId: string; quantity: number }>();\r\n @Output() remove = new EventEmitter<{ lineId: string }>();\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 draftInputBlur(line: OrderDetailFragment['lines'][number], quantity: number) {\r\n if (line.quantity !== quantity) {\r\n this.adjust.emit({ lineId: line.id, quantity });\r\n }\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 getShippingNames(order: OrderDetailFragment) {\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","<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 <vdr-tabbed-custom-fields\r\n entityName=\"Order\"\r\n [customFields]=\"customFieldsConfig\"\r\n [customFieldsFormGroup]=\"customFieldForm\"\r\n [readonly]=\"!editable\"\r\n [compact]=\"true\"\r\n ></vdr-tabbed-custom-fields>\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 <button\r\n class=\"btn btn-sm btn-secondary\"\r\n (click)=\"onCancelClick()\"\r\n *ngIf=\"editable\"\r\n >\r\n <clr-icon shape=\"times\"></clr-icon>\r\n {{ 'common.cancel' | 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 { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { CustomFieldConfig, ModalService } 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, private modalService: ModalService) {}\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 onCancelClick() {\r\n if (this.customFieldForm.dirty) {\r\n this.modalService\r\n .dialog({\r\n title: _('catalog.confirm-cancel'),\r\n buttons: [\r\n { type: 'secondary', label: _('common.keep-editing') },\r\n { type: 'danger', label: _('common.discard-changes'), returnValue: true },\r\n ],\r\n })\r\n .subscribe(result => {\r\n if (result) {\r\n this.customFieldForm.reset();\r\n this.customFieldForm.markAsPristine();\r\n this.editable = false;\r\n }\r\n });\r\n } else {\r\n this.editable = false;\r\n }\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\"></vdr-order-state-label>\r\n </div>\r\n </vdr-ab-left>\r\n\r\n <vdr-ab-right>\r\n <button\r\n class=\"btn btn-primary\"\r\n (click)=\"completeOrder()\"\r\n [disabled]=\"!order.customer || !order.lines.length || !order.shippingLines.length\"\r\n >\r\n <clr-icon shape=\"check\"></clr-icon>\r\n {{ 'order.complete-draft-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 <button type=\"button\" class=\"btn\" vdrDropdownItem (click)=\"deleteOrder()\">\r\n <clr-icon shape=\"trash\" class=\"is-danger\"></clr-icon>\r\n {{ 'order.delete-draft-order' | 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-draft-order-variant-selector\r\n [orderLineCustomFields]=\"orderLineCustomFields\"\r\n [currencyCode]=\"order.currencyCode\"\r\n (addItem)=\"addItemToOrder($event)\"\r\n ></vdr-draft-order-variant-selector>\r\n <vdr-order-table\r\n [order]=\"order\"\r\n [orderLineCustomFields]=\"orderLineCustomFields\"\r\n [isDraft]=\"true\"\r\n (adjust)=\"adjustOrderLine($event)\"\r\n (remove)=\"removeOrderLine($event)\"\r\n ></vdr-order-table>\r\n <div class=\"flex\">\r\n <button\r\n *ngIf=\"order.couponCodes.length === 0 && !displayCouponCodeInput\"\r\n class=\"btn btn-link btn-sm mr2\"\r\n (click)=\"displayCouponCodeInput = !displayCouponCodeInput\"\r\n >\r\n {{ 'order.set-coupon-codes' | translate }}\r\n </button>\r\n <div *ngIf=\"order.couponCodes.length || displayCouponCodeInput\">\r\n <label>{{ 'order.set-coupon-codes' | translate }}</label>\r\n <vdr-coupon-code-selector\r\n [couponCodes]=\"order.couponCodes\"\r\n (addCouponCode)=\"applyCouponCode($event)\"\r\n (removeCouponCode)=\"removeCouponCode($event)\"\r\n ></vdr-coupon-code-selector>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"order.taxSummary.length\">\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 </ng-container>\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 <clr-icon *ngIf=\"!order.customer\" shape=\"unknown-status\" class=\"is-warning\"></clr-icon>\r\n <clr-icon *ngIf=\"order.customer\" shape=\"check\" class=\"is-success\"></clr-icon>\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\r\n class=\"block mb2\"\r\n *ngIf=\"order.customer\"\r\n [customer]=\"order.customer\"\r\n ></vdr-customer-label>\r\n <button class=\"btn btn-link btn-sm\" (click)=\"setCustomer()\">\r\n {{ 'order.set-customer-for-order' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"card-block\">\r\n <h4 class=\"card-title\">\r\n <clr-icon\r\n *ngIf=\"!order.billingAddress.streetLine1\"\r\n shape=\"unknown-status\"\r\n class=\"is-warning\"\r\n ></clr-icon>\r\n <clr-icon\r\n *ngIf=\"order.billingAddress.streetLine1\"\r\n shape=\"check\"\r\n class=\"is-success\"\r\n ></clr-icon>\r\n {{ 'order.billing-address' | translate }}\r\n </h4>\r\n <div class=\"card-text\">\r\n <vdr-formatted-address\r\n class=\"block mb2\"\r\n *ngIf=\"order.billingAddress\"\r\n [address]=\"order.billingAddress\"\r\n ></vdr-formatted-address>\r\n <button class=\"btn btn-link btn-sm\" (click)=\"setBillingAddress()\">\r\n {{ 'order.set-billing-address' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n <clr-icon\r\n *ngIf=\"!order.shippingAddress.streetLine1 || !order.shippingLines.length\"\r\n shape=\"unknown-status\"\r\n class=\"is-warning\"\r\n ></clr-icon>\r\n <clr-icon\r\n *ngIf=\"order.shippingAddress.streetLine1 && order.shippingLines.length\"\r\n shape=\"check\"\r\n class=\"is-success\"\r\n ></clr-icon>\r\n {{ 'order.shipping' | translate }}\r\n </div>\r\n <div class=\"card-block\">\r\n <div class=\"card-text\">\r\n <vdr-formatted-address\r\n class=\"block mb2\"\r\n *ngIf=\"order.shippingAddress\"\r\n [address]=\"order.shippingAddress\"\r\n ></vdr-formatted-address>\r\n <button class=\"btn btn-link btn-sm\" (click)=\"setShippingAddress()\">\r\n {{ 'order.set-shipping-address' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"card-block\">\r\n <div class=\"card-text\">\r\n <div *ngFor=\"let shippingLine of order.shippingLines\">\r\n {{ shippingLine.shippingMethod.name }}\r\n </div>\r\n <button class=\"btn btn-link btn-sm\" (click)=\"setShippingMethod()\">\r\n {{ 'order.set-shipping-method' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\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>\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 CustomFieldConfig,\r\n DataService,\r\n DeletionResult,\r\n DraftOrderEligibleShippingMethodsQuery,\r\n ModalService,\r\n NotificationService,\r\n Order,\r\n OrderDetailFragment,\r\n ServerConfigService,\r\n} from '@vendure/admin-ui/core';\r\nimport { combineLatest, Observable, Subject } from 'rxjs';\r\nimport { switchMap, take } from 'rxjs/operators';\r\n\r\nimport { OrderTransitionService } from '../../providers/order-transition.service';\r\nimport { SelectAddressDialogComponent } from '../select-address-dialog/select-address-dialog.component';\r\nimport { SelectCustomerDialogComponent } from '../select-customer-dialog/select-customer-dialog.component';\r\nimport { SelectShippingMethodDialogComponent } from '../select-shipping-method-dialog/select-shipping-method-dialog.component';\r\n\r\n@Component({\r\n selector: 'vdr-draft-order-detail',\r\n templateUrl: './draft-order-detail.component.html',\r\n styleUrls: ['./draft-order-detail.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DraftOrderDetailComponent\r\n extends BaseDetailComponent<OrderDetailFragment>\r\n implements OnInit, OnDestroy\r\n{\r\n detailForm = new FormGroup({});\r\n eligibleShippingMethods$: Observable<\r\n DraftOrderEligibleShippingMethodsQuery['eligibleShippingMethodsForDraftOrder']\r\n >;\r\n nextStates$: Observable<string[]>;\r\n fetchHistory = new Subject<void>();\r\n customFields: CustomFieldConfig[];\r\n orderLineCustomFields: CustomFieldConfig[];\r\n displayCouponCodeInput = false;\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.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\r\n this.eligibleShippingMethods$ = this.entity$.pipe(\r\n switchMap(order =>\r\n this.dataService.order\r\n .getDraftOrderEligibleShippingMethods(order.id)\r\n .mapSingle(\r\n ({ eligibleShippingMethodsForDraftOrder }) => eligibleShippingMethodsForDraftOrder,\r\n ),\r\n ),\r\n );\r\n this.customFields = this.getCustomFieldConfig('Order');\r\n this.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\r\n }\r\n\r\n ngOnDestroy() {\r\n this.destroy();\r\n }\r\n\r\n addItemToOrder(event: { productVariantId: string; quantity: number; customFields: any }) {\r\n this.dataService.order.addItemToDraftOrder(this.id, event).subscribe(result => {\r\n if (result.addItemToDraftOrder.__typename !== 'Order') {\r\n this.notificationService.error((result.addItemToDraftOrder as any).message);\r\n }\r\n });\r\n }\r\n\r\n adjustOrderLine(event: { lineId: string; quantity: number }) {\r\n this.dataService.order\r\n .adjustDraftOrderLine(this.id, { orderLineId: event.lineId, quantity: event.quantity })\r\n .subscribe(result => {\r\n if (result.adjustDraftOrderLine.__typename !== 'Order') {\r\n this.notificationService.error((result.adjustDraftOrderLine as any).message);\r\n }\r\n });\r\n }\r\n\r\n removeOrderLine(event: { lineId: string }) {\r\n this.dataService.order.removeDraftOrderLine(this.id, event.lineId).subscribe(result => {\r\n if (result.removeDraftOrderLine.__typename !== 'Order') {\r\n this.notificationService.error((result.removeDraftOrderLine as any).message);\r\n }\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 setCustomer() {\r\n this.modalService.fromComponent(SelectCustomerDialogComponent).subscribe(result => {\r\n if (this.hasId(result)) {\r\n this.dataService.order\r\n .setCustomerForDraftOrder(this.id, { customerId: result.id })\r\n .subscribe();\r\n } else if (result) {\r\n this.dataService.order.setCustomerForDraftOrder(this.id, { input: result }).subscribe();\r\n }\r\n });\r\n }\r\n\r\n setShippingAddress() {\r\n this.entity$\r\n .pipe(\r\n take(1),\r\n switchMap(order => {\r\n return this.modalService.fromComponent(SelectAddressDialogComponent, {\r\n locals: {\r\n customerId: order.customer?.id,\r\n currentAddress: order.shippingAddress ?? undefined,\r\n },\r\n });\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.dataService.order.setDraftOrderShippingAddress(this.id, result).subscribe();\r\n }\r\n });\r\n }\r\n\r\n setBillingAddress() {\r\n this.entity$\r\n .pipe(\r\n take(1),\r\n switchMap(order => {\r\n return this.modalService.fromComponent(SelectAddressDialogComponent, {\r\n locals: {\r\n customerId: order.customer?.id,\r\n currentAddress: order.billingAddress ?? undefined,\r\n },\r\n });\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.dataService.order.setDraftOrderBillingAddress(this.id, result).subscribe();\r\n }\r\n });\r\n }\r\n\r\n applyCouponCode(couponCode: string) {\r\n this.dataService.order.applyCouponCodeToDraftOrder(this.id, couponCode).subscribe();\r\n }\r\n\r\n removeCouponCode(couponCode: string) {\r\n this.dataService.order.removeCouponCodeFromDraftOrder(this.id, couponCode).subscribe();\r\n }\r\n\r\n setShippingMethod() {\r\n combineLatest(this.entity$, this.eligibleShippingMethods$)\r\n .pipe(\r\n take(1),\r\n switchMap(([order, methods]) =>\r\n this.modalService.fromComponent(SelectShippingMethodDialogComponent, {\r\n locals: {\r\n eligibleShippingMethods: methods,\r\n currencyCode: order.currencyCode,\r\n currentSelectionId: order.shippingLines?.[0]?.shippingMethod.id,\r\n },\r\n }),\r\n ),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.dataService.order.setDraftOrderShippingMethod(this.id, result).subscribe();\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 }\r\n\r\n deleteOrder() {\r\n this.dataService.order.deleteDraftOrder(this.id).subscribe(({ deleteDraftOrder }) => {\r\n if (deleteDraftOrder.result === DeletionResult.DELETED) {\r\n this.notificationService.success(_('common.notify-delete-success'), {\r\n entity: 'Order',\r\n });\r\n this.router.navigate(['/orders']);\r\n } else if (deleteDraftOrder.message) {\r\n this.notificationService.error(deleteDraftOrder.message);\r\n }\r\n });\r\n }\r\n\r\n completeOrder() {\r\n this.dataService.order\r\n .transitionToState(this.id, 'ArrangingPayment')\r\n .subscribe(({ transitionOrderToState }) => {\r\n if (transitionOrderToState?.__typename === 'Order') {\r\n this.router.navigate(['/orders', this.id]);\r\n } else if (transitionOrderToState?.__typename === 'OrderStateTransitionError') {\r\n this.notificationService.error(transitionOrderToState.transitionError);\r\n }\r\n });\r\n }\r\n\r\n private hasId<T extends { id: string }>(input: T | any): input is { id: string } {\r\n return typeof input === 'object' && !!input.id;\r\n }\r\n\r\n protected setFormValues(entity: OrderDetailFragment): void {\r\n // empty\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.fulfill-order' | translate }}</ng-template>\r\n\r\n<div class=\"fulfillment-wrapper\">\r\n <div class=\"order-table\">\r\n <table class=\"table\">\r\n <thead>\r\n <tr>\r\n <th></th>\r\n <th>{{ 'order.product-name' | translate }}</th>\r\n <th>{{ 'order.product-sku' | translate }}</th>\r\n <th>{{ 'order.unfulfilled' | translate }}</th>\r\n <th>{{ 'catalog.stock-on-hand' | translate }}</th>\r\n <th>{{ 'order.fulfill' | translate }}</th>\r\n </tr>\r\n </thead>\r\n <tr\r\n *ngFor=\"let line of order.lines\"\r\n class=\"order-line\"\r\n [class.ignore]=\"getUnfulfilledCount(line) === 0\"\r\n >\r\n <td class=\"align-middle thumb\">\r\n <img *ngIf=\"line.featuredAsset\" [src]=\"line.featuredAsset | assetPreview: 'tiny'\" />\r\n </td>\r\n <td class=\"align-middle name\">{{ line.productVariant.name }}</td>\r\n <td class=\"align-middle sku\">{{ line.productVariant.sku }}</td>\r\n <td class=\"align-middle quantity\">{{ getUnfulfilledCount(line) }}</td>\r\n <td class=\"align-middle quantity\">{{ line.productVariant.stockOnHand }}</td>\r\n <td class=\"align-middle fulfil\">\r\n <input\r\n *ngIf=\"fulfillmentQuantities[line.id]\"\r\n [disabled]=\"getUnfulfilledCount(line) === 0\"\r\n [(ngModel)]=\"fulfillmentQuantities[line.id].fulfillCount\"\r\n type=\"number\"\r\n [max]=\"fulfillmentQuantities[line.id].max\"\r\n min=\"0\"\r\n />\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n <div class=\"shipping-details\">\r\n <vdr-formatted-address [address]=\"order.shippingAddress\"></vdr-formatted-address>\r\n <h6>{{ 'order.shipping-method' | translate }}</h6>\r\n {{ order.shippingLines[0]?.shippingMethod?.name }}\r\n <strong>{{ order.shipping | localeCurrency: order.currencyCode }}</strong>\r\n <vdr-configurable-input\r\n [operationDefinition]=\"fulfillmentHandlerDef\"\r\n [operation]=\"fulfillmentHandler\"\r\n [formControl]=\"fulfillmentHandlerControl\"\r\n [removable]=\"false\"\r\n ></vdr-configurable-input>\r\n </div>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"select()\" [disabled]=\"!canSubmit()\" class=\"btn btn-primary\">\r\n {{ 'order.create-fulfillment' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport {\r\n configurableDefinitionToInstance,\r\n ConfigurableOperation,\r\n ConfigurableOperationDefinition,\r\n configurableOperationValueIsValid,\r\n DataService,\r\n Dialog,\r\n FulfillOrderInput,\r\n GlobalFlag,\r\n OrderDetailFragment,\r\n toConfigurableOperationInput,\r\n} from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-fulfill-order-dialog',\r\n templateUrl: './fulfill-order-dialog.component.html',\r\n styleUrls: ['./fulfill-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FulfillOrderDialogComponent implements Dialog<FulfillOrderInput>, OnInit {\r\n resolveWith: (result?: FulfillOrderInput) => void;\r\n fulfillmentHandlerDef: ConfigurableOperationDefinition;\r\n fulfillmentHandler: ConfigurableOperation;\r\n fulfillmentHandlerControl = new FormControl();\r\n fulfillmentQuantities: { [lineId: string]: { fulfillCount: number; max: number } } = {};\r\n\r\n // Provided by modalService.fromComponent() call\r\n order: OrderDetailFragment;\r\n\r\n constructor(private dataService: DataService, private changeDetector: ChangeDetectorRef) {}\r\n\r\n ngOnInit(): void {\r\n this.dataService.settings.getGlobalSettings().single$.subscribe(({ globalSettings }) => {\r\n this.fulfillmentQuantities = this.order.lines.reduce((result, line) => {\r\n const fulfillCount = this.getFulfillableCount(line, globalSettings.trackInventory);\r\n return {\r\n ...result,\r\n [line.id]: { fulfillCount, max: fulfillCount },\r\n };\r\n }, {});\r\n this.changeDetector.markForCheck();\r\n });\r\n\r\n this.dataService.shippingMethod\r\n .getShippingMethodOperations()\r\n .mapSingle(data => data.fulfillmentHandlers)\r\n .subscribe(handlers => {\r\n this.fulfillmentHandlerDef =\r\n handlers.find(\r\n h => h.code === this.order.shippingLines[0]?.shippingMethod?.fulfillmentHandlerCode,\r\n ) || handlers[0];\r\n this.fulfillmentHandler = configurableDefinitionToInstance(this.fulfillmentHandlerDef);\r\n this.fulfillmentHandlerControl.patchValue(this.fulfillmentHandler);\r\n this.changeDetector.markForCheck();\r\n });\r\n }\r\n\r\n getFulfillableCount(line: OrderDetailFragment['lines'][number], globalTrackInventory: boolean): number {\r\n const { trackInventory, stockOnHand } = line.productVariant;\r\n const effectiveTracInventory =\r\n trackInventory === GlobalFlag.INHERIT ? globalTrackInventory : trackInventory === GlobalFlag.TRUE;\r\n\r\n const unfulfilledCount = this.getUnfulfilledCount(line);\r\n return effectiveTracInventory ? Math.min(unfulfilledCount, stockOnHand) : unfulfilledCount;\r\n }\r\n\r\n getUnfulfilledCount(line: OrderDetailFragment['lines'][number]): number {\r\n const fulfilled =\r\n line.fulfillments\r\n ?.map(f => f.summary)\r\n .flat()\r\n .filter(row => row.orderLine.id === line.id)\r\n .reduce((sum, row) => sum + row.quantity, 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 return (\r\n this.fulfillment?.summary.map(row => {\r\n return {\r\n name:\r\n this.order.lines.find(line => line.id === row.orderLine.id)?.productVariant.name ??\r\n '',\r\n quantity: row.quantity,\r\n };\r\n }) ?? []\r\n );\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-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","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';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport {\r\n CancelOrderInput,\r\n Dialog,\r\n getAppConfig,\r\n I18nService,\r\n OrderDetailFragment,\r\n OrderLineInput,\r\n RefundOrderInput,\r\n} from '@vendure/admin-ui/core';\r\nimport { summate } from '@vendure/common/lib/shared-utils';\r\n\r\ntype SelectionLine = { quantity: number; refund: boolean; cancel: boolean };\r\ntype Payment = NonNullable<OrderDetailFragment['payments']>[number];\r\n\r\n@Component({\r\n selector: 'vdr-refund-order-dialog',\r\n templateUrl: './refund-order-dialog.component.html',\r\n styleUrls: ['./refund-order-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class RefundOrderDialogComponent\r\n implements OnInit, Dialog<{ cancel: CancelOrderInput; refund: RefundOrderInput }>\r\n{\r\n order: OrderDetailFragment;\r\n resolveWith: (result?: { cancel: CancelOrderInput; refund: RefundOrderInput }) => void;\r\n reason: string;\r\n settledPayments: Payment[];\r\n selectedPayment: Payment;\r\n lineQuantities: { [lineId: string]: SelectionLine } = {};\r\n refundShipping = false;\r\n adjustment = 0;\r\n reasons = getAppConfig().cancellationReasons ?? [\r\n _('order.refund-reason-customer-request'),\r\n _('order.refund-reason-not-available'),\r\n ];\r\n\r\n constructor(private i18nService: I18nService) {\r\n this.reasons = this.reasons.map(r => this.i18nService.translate(r));\r\n }\r\n\r\n get refundTotal(): number {\r\n const itemTotal = this.order.lines.reduce((total, line) => {\r\n const lineRef = this.lineQuantities[line.id];\r\n const refundCount = (lineRef.refund && lineRef.quantity) || 0;\r\n return total + line.proratedUnitPriceWithTax * refundCount;\r\n }, 0);\r\n return itemTotal + (this.refundShipping ? this.order.shippingWithTax : 0) + this.adjustment;\r\n }\r\n\r\n get settledPaymentsTotal(): number {\r\n return this.settledPayments\r\n .map(payment => {\r\n const paymentTotal = payment.amount;\r\n const alreadyRefundedTotal = summate(\r\n payment.refunds.filter(r => r.state !== 'Failed') as Array<\r\n Required<Payment['refunds'][number]>\r\n >,\r\n 'total',\r\n );\r\n return paymentTotal - alreadyRefundedTotal;\r\n })\r\n .reduce((sum, amount) => sum + amount, 0);\r\n }\r\n\r\n lineCanBeRefundedOrCancelled(line: OrderDetailFragment['lines'][number]): boolean {\r\n const refunds =\r\n this.order.payments?.reduce(\r\n (all, payment) => [...all, ...payment.refunds],\r\n [] as Payment['refunds'],\r\n ) ?? [];\r\n\r\n const refundable = line.items.filter(i => {\r\n if (i.cancelled) {\r\n return false;\r\n }\r\n if (i.refundId == null) {\r\n return true;\r\n }\r\n const refund = refunds.find(r => r.id === i.refundId);\r\n return refund?.state === 'Failed';\r\n });\r\n return 0 < refundable.length;\r\n }\r\n\r\n ngOnInit() {\r\n this.lineQuantities = this.order.lines.reduce((result, line) => {\r\n return {\r\n ...result,\r\n [line.id]: {\r\n quantity: 0,\r\n refund: false,\r\n cancel: false,\r\n },\r\n };\r\n }, {});\r\n this.settledPayments = (this.order.payments || []).filter(p => p.state === 'Settled');\r\n if (this.settledPayments.length) {\r\n this.selectedPayment = this.settledPayments[0];\r\n }\r\n }\r\n\r\n handleZeroQuantity(line?: SelectionLine) {\r\n if (line?.quantity === 0) {\r\n line.cancel = false;\r\n line.refund = false;\r\n }\r\n }\r\n\r\n isRefunding(): boolean {\r\n const result = Object.values(this.lineQuantities).reduce((isRefunding, line) => {\r\n return isRefunding || (0 < line.quantity && line.refund);\r\n }, false);\r\n return result;\r\n }\r\n\r\n isCancelling(): boolean {\r\n const result = Object.values(this.lineQuantities).reduce((isCancelling, line) => {\r\n return isCancelling || (0 < line.quantity && line.cancel);\r\n }, false);\r\n return result;\r\n }\r\n\r\n canSubmit(): boolean {\r\n if (this.isRefunding()) {\r\n return !!(\r\n this.selectedPayment &&\r\n this.reason &&\r\n 0 < this.refundTotal &&\r\n this.refundTotal <= this.settledPaymentsTotal\r\n );\r\n } else if (this.isCancelling()) {\r\n return !!this.reason;\r\n }\r\n return false;\r\n }\r\n\r\n select() {\r\n const payment = this.selectedPayment;\r\n if (payment) {\r\n const refundLines = this.getOrderLineInput(line => line.refund);\r\n const cancelLines = this.getOrderLineInput(line => line.cancel);\r\n\r\n this.resolveWith({\r\n refund: {\r\n lines: refundLines,\r\n reason: this.reason,\r\n shipping: this.refundShipping ? this.order.shippingWithTax : 0,\r\n adjustment: this.adjustment,\r\n paymentId: payment.id,\r\n },\r\n cancel: {\r\n lines: cancelLines,\r\n orderId: this.order.id,\r\n reason: this.reason,\r\n cancelShipping: this.refundShipping,\r\n },\r\n });\r\n }\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n\r\n private getOrderLineInput(filterFn: (line: SelectionLine) => boolean): OrderLineInput[] {\r\n return Object.entries(this.lineQuantities)\r\n .filter(([orderLineId, line]) => 0 < line.quantity && filterFn(line))\r\n .map(([orderLineId, line]) => ({\r\n orderLineId,\r\n quantity: line.quantity,\r\n }));\r\n }\r\n}\r\n","<ng-template vdrDialogTitle>{{ 'order.settle-refund' | translate }}</ng-template>\r\n<p class=\"instruction\">\r\n {{ 'order.settle-refund-manual-instructions' | translate: { method: refund.method } }}\r\n</p>\r\n<clr-input-container>\r\n <label>{{ 'order.transaction-id' | translate }}</label>\r\n <input clrInput name=\"transactionId\" [(ngModel)]=\"transactionId\" />\r\n</clr-input-container>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"submit()\" [disabled]=\"!transactionId\" class=\"btn btn-primary\">\r\n {{ 'order.settle-refund' | translate }}\r\n </button>\r\n</ng-template>\r\n","import { ChangeDetectionStrategy, Component } from '@angular/core';\r\nimport { Dialog, OrderDetailFragment } from '@vendure/admin-ui/core';\r\n\r\n@Component({\r\n selector: 'vdr-settle-refund-dialog',\r\n templateUrl: './settle-refund-dialog.component.html',\r\n styleUrls: ['./settle-refund-dialog.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SettleRefundDialogComponent implements Dialog<string> {\r\n resolveWith: (result?: string) => void;\r\n transactionId = '';\r\n refund: NonNullable<OrderDetailFragment['payments']>[number]['refunds'][number];\r\n\r\n submit() {\r\n this.resolveWith(this.transactionId);\r\n }\r\n\r\n cancel() {\r\n this.resolveWith();\r\n }\r\n}\r\n","<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' && s !== 'Error');\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 order.state !== 'ArrangingPayment' &&\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 FulfillmentFragment,\r\n FulfillmentLineSummary,\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 { pick } from '@vendure/common/lib/pick';\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 if (state === 'Cancelled') {\r\n this.dataService.order.cancelPayment(payment.id).subscribe(({ cancelPayment }) => {\r\n switch (cancelPayment.__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(cancelPayment.transitionError);\r\n break;\r\n case 'CancelPaymentError':\r\n this.notificationService.error(cancelPayment.paymentErrorMessage);\r\n break;\r\n }\r\n });\r\n } else {\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(\r\n _('order.transitioned-payment-to-state-success'),\r\n {\r\n state,\r\n },\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\r\n canAddFulfillment(order: OrderDetailFragment): boolean {\r\n const allFulfillmentSummaryRows: FulfillmentFragment['summary'] = (order.fulfillments ?? []).reduce(\r\n (all, fulfillment) => [...all, ...fulfillment.summary],\r\n [] as FulfillmentFragment['summary'],\r\n );\r\n let allItemsFulfilled = true;\r\n for (const line of order.lines) {\r\n const totalFulfilledCount = allFulfillmentSummaryRows\r\n .filter(row => row.orderLine.id === line.id)\r\n .reduce((sum, row) => sum + row.quantity, 0);\r\n if (totalFulfilledCount < line.quantity) {\r\n allItemsFulfilled = false;\r\n }\r\n }\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 if (input.cancel.lines?.length) {\r\n return this.dataService.order.cancelOrder(input.cancel).pipe(\r\n map(res => {\r\n const result = res.cancelOrder;\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 return input;\r\n case 'CancelActiveOrderError':\r\n case 'QuantityTooGreatError':\r\n case 'MultipleOrderError':\r\n case 'OrderStateTransitionError':\r\n case 'EmptyOrderLineSelectionError':\r\n this.notificationService.error(result.message);\r\n return undefined;\r\n }\r\n }),\r\n );\r\n } else {\r\n return [input];\r\n }\r\n }),\r\n switchMap(input => {\r\n if (!input) {\r\n return of(undefined);\r\n }\r\n if (input.refund.lines.length) {\r\n return this.dataService.order\r\n .refundOrder(input.refund)\r\n .pipe(map(res => res.refundOrder));\r\n } else {\r\n return [undefined];\r\n }\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n switch (result.__typename) {\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 '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 <vdr-tabbed-custom-fields\r\n entityName=\"OrderLine\"\r\n [customFields]=\"orderLineCustomFields\"\r\n [customFieldsFormGroup]=\"orderLineCustomFieldsFormArray.get([i])\"\r\n [compact]=\"true\"\r\n ></vdr-tabbed-custom-fields>\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 <vdr-coupon-code-selector\r\n [control]=\"couponCodesControl\"\r\n ></vdr-coupon-code-selector>\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\"\r\n /></vdr-affixed-input>\r\n </vdr-form-field>\r\n <vdr-form-field [label]=\"'order.tax-description' | translate\" for=\"taxDescription\"\r\n ><input id=\"taxDescription\" type=\"text\" formControlName=\"taxDescription\"\r\n /></vdr-form-field>\r\n <button\r\n class=\"btn btn-secondary\"\r\n [disabled]=\"\r\n surchargeForm.invalid ||\r\n surchargeForm.pristine ||\r\n surchargeForm.get('price')?.value === 0\r\n \"\r\n >\r\n {{ 'order.add-surcharge' | translate }}\r\n </button>\r\n </form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.edit-shipping-address' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <vdr-address-form\r\n [formGroup]=\"shippingAddressForm\"\r\n [availableCountries]=\"availableCountries$ | async\"\r\n [customFields]=\"addressCustomFields\"\r\n ></vdr-address-form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n <clr-accordion-panel>\r\n <clr-accordion-title>{{ 'order.edit-billing-address' | translate }}</clr-accordion-title>\r\n <clr-accordion-content *clrIfExpanded>\r\n <vdr-address-form\r\n [formGroup]=\"billingAddressForm\"\r\n [availableCountries]=\"availableCountries$ | async\"\r\n [customFields]=\"addressCustomFields\"\r\n ></vdr-address-form>\r\n </clr-accordion-content>\r\n </clr-accordion-panel>\r\n </clr-accordion>\r\n </div>\r\n <div class=\"clr-col-lg-4 order-cards\">\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n {{ 'order.modification-summary' | translate }}\r\n </div>\r\n <div class=\"card-block\">\r\n <ul>\r\n <li *ngIf=\"modifyOrderInput.addItems?.length\">\r\n {{\r\n 'order.modification-adding-items'\r\n | translate: { count: modifyOrderInput.addItems?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"modifyOrderInput.adjustOrderLines?.length\">\r\n {{\r\n 'order.modification-adjusting-lines'\r\n | translate: { count: modifyOrderInput.adjustOrderLines?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"modifyOrderInput.surcharges?.length\">\r\n {{\r\n 'order.modification-adding-surcharges'\r\n | translate: { count: modifyOrderInput.surcharges?.length }\r\n }}\r\n </li>\r\n <li *ngIf=\"shippingAddressForm.dirty\">\r\n {{ 'order.modification-updating-shipping-address' | translate }}\r\n </li>\r\n <li *ngIf=\"billingAddressForm.dirty\">\r\n {{ 'order.modification-updating-billing-address' | translate }}\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"card-block\">\r\n <label class=\"clr-control-label\">{{ 'order.note' | translate }}</label>\r\n <textarea [(ngModel)]=\"note\" name=\"note\" clrTextarea required></textarea>\r\n <clr-checkbox-wrapper class=\"\">\r\n <input type=\"checkbox\" clrCheckbox [(ngModel)]=\"recalculateShipping\" />\r\n <label>{{ 'order.modification-recalculate-shipping' | translate }}</label>\r\n </clr-checkbox-wrapper>\r\n </div>\r\n <div class=\"card-footer\">\r\n <button\r\n class=\"btn btn-primary\"\r\n [disabled]=\"!canPreviewChanges()\"\r\n (click)=\"previewAndModify(order)\"\r\n >\r\n {{ 'order.preview-changes' | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n","import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport {\r\n AddItemInput,\r\n AdjustOrderLineInput,\r\n BaseDetailComponent,\r\n CustomFieldConfig,\r\n DataService,\r\n ErrorResult,\r\n GetAvailableCountriesQuery,\r\n HistoryEntryType,\r\n LanguageCode,\r\n ModalService,\r\n ModifyOrderInput,\r\n NotificationService,\r\n OrderAddressFragment,\r\n OrderDetailFragment,\r\n ProductSelectorSearchQuery,\r\n ServerConfigService,\r\n SortOrder,\r\n SurchargeInput,\r\n transformRelationCustomFieldInputs,\r\n} from '@vendure/admin-ui/core';\r\nimport { assertNever, notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport { simpleDeepClone } from '@vendure/common/lib/simple-deep-clone';\r\nimport { concat, EMPTY, Observable, of, Subject } from 'rxjs';\r\nimport {\r\n distinctUntilChanged,\r\n map,\r\n mapTo,\r\n shareReplay,\r\n startWith,\r\n switchMap,\r\n takeUntil,\r\n} from 'rxjs/operators';\r\n\r\nimport { OrderTransitionService } from '../../providers/order-transition.service';\r\nimport {\r\n OrderEditResultType,\r\n OrderEditsPreviewDialogComponent,\r\n} from '../order-edits-preview-dialog/order-edits-preview-dialog.component';\r\n\r\ntype ProductSelectorItem = ProductSelectorSearchQuery['search']['items'][number];\r\n\r\ninterface AddedLine {\r\n productVariantId: string;\r\n productAsset?: ProductSelectorItem['productAsset'] | null;\r\n productVariantName: string;\r\n sku: string;\r\n priceWithTax: number;\r\n price: number;\r\n quantity: number;\r\n}\r\n\r\ntype ModifyOrderData = Omit<ModifyOrderInput, 'addItems' | 'adjustOrderLines'> & {\r\n addItems: Array<AddItemInput & { customFields?: any }>;\r\n adjustOrderLines: Array<AdjustOrderLineInput & { customFields?: any }>;\r\n};\r\n\r\n@Component({\r\n selector: 'vdr-order-editor',\r\n templateUrl: './order-editor.component.html',\r\n styleUrls: ['./order-editor.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class OrderEditorComponent\r\n extends BaseDetailComponent<OrderDetailFragment>\r\n implements OnInit, OnDestroy\r\n{\r\n availableCountries$: Observable<GetAvailableCountriesQuery['countries']['items']>;\r\n addressCustomFields: CustomFieldConfig[];\r\n detailForm = new FormGroup({});\r\n couponCodesControl = new FormControl();\r\n orderLineCustomFieldsFormArray: FormArray;\r\n addItemCustomFieldsFormArray: FormArray;\r\n addItemCustomFieldsForm: FormGroup;\r\n addItemSelectedVariant: ProductSelectorItem | undefined;\r\n orderLineCustomFields: CustomFieldConfig[];\r\n modifyOrderInput: ModifyOrderData = {\r\n dryRun: true,\r\n orderId: '',\r\n addItems: [],\r\n adjustOrderLines: [],\r\n surcharges: [],\r\n note: '',\r\n updateShippingAddress: {},\r\n updateBillingAddress: {},\r\n };\r\n surchargeForm: FormGroup;\r\n shippingAddressForm: FormGroup;\r\n billingAddressForm: FormGroup;\r\n note = '';\r\n recalculateShipping = true;\r\n previousState: string;\r\n private addedVariants = new Map<string, ProductSelectorItem>();\r\n\r\n constructor(\r\n router: Router,\r\n route: ActivatedRoute,\r\n serverConfigService: ServerConfigService,\r\n private changeDetector: ChangeDetectorRef,\r\n protected dataService: DataService,\r\n private notificationService: NotificationService,\r\n private modalService: ModalService,\r\n private orderTransitionService: OrderTransitionService,\r\n ) {\r\n super(route, router, serverConfigService, dataService);\r\n }\r\n\r\n get addedLines(): AddedLine[] {\r\n const getSinglePriceValue = (price: ProductSelectorItem['price']) =>\r\n price.__typename === 'SinglePrice' ? price.value : 0;\r\n return (this.modifyOrderInput.addItems || [])\r\n .map(row => {\r\n const variantInfo = this.addedVariants.get(row.productVariantId);\r\n if (variantInfo) {\r\n return {\r\n ...variantInfo,\r\n price: getSinglePriceValue(variantInfo.price),\r\n priceWithTax: getSinglePriceValue(variantInfo.priceWithTax),\r\n quantity: row.quantity,\r\n };\r\n }\r\n })\r\n .filter(notNullOrUndefined);\r\n }\r\n\r\n ngOnInit(): void {\r\n this.init();\r\n this.addressCustomFields = this.getCustomFieldConfig('Address');\r\n this.modifyOrderInput.orderId = this.route.snapshot.paramMap.get('id') as string;\r\n this.orderLineCustomFields = this.getCustomFieldConfig('OrderLine');\r\n this.entity$.pipe(takeUntil(this.destroy$)).subscribe(order => {\r\n if (order.couponCodes.length) {\r\n this.couponCodesControl.setValue(order.couponCodes);\r\n }\r\n this.surchargeForm = new FormGroup({\r\n description: new FormControl('', Validators.required),\r\n sku: new FormControl(''),\r\n price: new FormControl(0, Validators.required),\r\n priceIncludesTax: new FormControl(true),\r\n taxRate: new FormControl(0),\r\n taxDescription: new FormControl(''),\r\n });\r\n if (!this.shippingAddressForm) {\r\n this.shippingAddressForm = new FormGroup({\r\n fullName: new FormControl(order.shippingAddress?.fullName),\r\n company: new FormControl(order.shippingAddress?.company),\r\n streetLine1: new FormControl(order.shippingAddress?.streetLine1),\r\n streetLine2: new FormControl(order.shippingAddress?.streetLine2),\r\n city: new FormControl(order.shippingAddress?.city),\r\n province: new FormControl(order.shippingAddress?.province),\r\n postalCode: new FormControl(order.shippingAddress?.postalCode),\r\n countryCode: new FormControl(order.shippingAddress?.countryCode),\r\n phoneNumber: new FormControl(order.shippingAddress?.phoneNumber),\r\n });\r\n this.addAddressCustomFieldsFormGroup(this.shippingAddressForm, order.shippingAddress);\r\n }\r\n if (!this.billingAddressForm) {\r\n this.billingAddressForm = new FormGroup({\r\n fullName: new FormControl(order.billingAddress?.fullName),\r\n company: new FormControl(order.billingAddress?.company),\r\n streetLine1: new FormControl(order.billingAddress?.streetLine1),\r\n streetLine2: new FormControl(order.billingAddress?.streetLine2),\r\n city: new FormControl(order.billingAddress?.city),\r\n province: new FormControl(order.billingAddress?.province),\r\n postalCode: new FormControl(order.billingAddress?.postalCode),\r\n countryCode: new FormControl(order.billingAddress?.countryCode),\r\n phoneNumber: new FormControl(order.billingAddress?.phoneNumber),\r\n });\r\n this.addAddressCustomFieldsFormGroup(this.billingAddressForm, order.billingAddress);\r\n }\r\n this.orderLineCustomFieldsFormArray = new FormArray([]);\r\n for (const line of order.lines) {\r\n const formGroup = new FormGroup({});\r\n for (const { name } of this.orderLineCustomFields) {\r\n formGroup.addControl(name, new FormControl((line as any).customFields[name]));\r\n }\r\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\r\n let modifyRow = this.modifyOrderInput.adjustOrderLines.find(\r\n l => l.orderLineId === line.id,\r\n );\r\n if (!modifyRow) {\r\n modifyRow = {\r\n orderLineId: line.id,\r\n quantity: line.quantity,\r\n };\r\n this.modifyOrderInput.adjustOrderLines.push(modifyRow);\r\n }\r\n if (this.orderLineCustomFields.length) {\r\n modifyRow.customFields = value;\r\n }\r\n });\r\n this.orderLineCustomFieldsFormArray.push(formGroup);\r\n }\r\n });\r\n\r\n this.addItemCustomFieldsFormArray = new FormArray([]);\r\n this.addItemCustomFieldsForm = new FormGroup({});\r\n for (const customField of this.orderLineCustomFields) {\r\n this.addItemCustomFieldsForm.addControl(customField.name, new FormControl());\r\n }\r\n this.availableCountries$ = this.dataService.settings\r\n .getAvailableCountries()\r\n .mapSingle(result => result.countries.items)\r\n .pipe(shareReplay(1));\r\n this.dataService.order\r\n .getOrderHistory(this.id, {\r\n take: 1,\r\n sort: {\r\n createdAt: SortOrder.DESC,\r\n },\r\n filter: { type: { eq: HistoryEntryType.ORDER_STATE_TRANSITION } },\r\n })\r\n .single$.subscribe(({ order }) => {\r\n this.previousState = order?.history.items[0].data.from;\r\n });\r\n }\r\n\r\n ngOnDestroy(): void {\r\n this.destroy();\r\n }\r\n\r\n transitionToPriorState(order: OrderDetailFragment) {\r\n this.orderTransitionService\r\n .transitionToPreModifyingState(order.id, order.nextStates)\r\n .subscribe(result => {\r\n this.router.navigate(['..'], { relativeTo: this.route });\r\n });\r\n }\r\n\r\n canPreviewChanges(): boolean {\r\n const { addItems, adjustOrderLines, surcharges } = this.modifyOrderInput;\r\n return (\r\n !!addItems?.length ||\r\n !!surcharges?.length ||\r\n !!adjustOrderLines?.length ||\r\n (this.shippingAddressForm.dirty && this.shippingAddressForm.valid) ||\r\n (this.billingAddressForm.dirty && this.billingAddressForm.valid) ||\r\n this.couponCodesControl.dirty\r\n );\r\n }\r\n\r\n isLineModified(line: OrderDetailFragment['lines'][number]): boolean {\r\n return !!this.modifyOrderInput.adjustOrderLines?.find(\r\n l => l.orderLineId === line.id && l.quantity !== line.quantity,\r\n );\r\n }\r\n\r\n updateLineQuantity(line: OrderDetailFragment['lines'][number], quantity: string) {\r\n const { adjustOrderLines } = this.modifyOrderInput;\r\n let row = adjustOrderLines?.find(l => l.orderLineId === line.id);\r\n if (row && +quantity === line.quantity) {\r\n // Remove the modification if the quantity is the same as\r\n // the original order\r\n adjustOrderLines?.splice(adjustOrderLines?.indexOf(row), 1);\r\n }\r\n if (!row) {\r\n row = { orderLineId: line.id, quantity: +quantity };\r\n adjustOrderLines?.push(row);\r\n }\r\n row.quantity = +quantity;\r\n }\r\n\r\n updateAddedItemQuantity(item: AddedLine, quantity: string) {\r\n const row = this.modifyOrderInput.addItems?.find(l => l.productVariantId === item.productVariantId);\r\n if (row) {\r\n row.quantity = +quantity;\r\n }\r\n }\r\n\r\n trackByProductVariantId(index: number, item: AddedLine) {\r\n return item.productVariantId;\r\n }\r\n\r\n getSelectedItemPrice(result: ProductSelectorItem | undefined): number {\r\n switch (result?.priceWithTax.__typename) {\r\n case 'SinglePrice':\r\n return result.priceWithTax.value;\r\n default:\r\n return 0;\r\n }\r\n }\r\n\r\n addItemToOrder(result: ProductSelectorItem | undefined) {\r\n if (!result) {\r\n return;\r\n }\r\n const customFields = this.orderLineCustomFields.length\r\n ? this.addItemCustomFieldsForm.value\r\n : undefined;\r\n let row = this.modifyOrderInput.addItems?.find(l =>\r\n this.isMatchingAddItemRow(l, result, customFields),\r\n );\r\n if (!row) {\r\n row = { productVariantId: result.productVariantId, quantity: 1 };\r\n if (customFields) {\r\n row.customFields = customFields;\r\n }\r\n this.modifyOrderInput.addItems?.push(row);\r\n } else {\r\n row.quantity++;\r\n }\r\n if (customFields) {\r\n const formGroup = new FormGroup({});\r\n for (const [key, value] of Object.entries(customFields)) {\r\n formGroup.addControl(key, new FormControl(value));\r\n }\r\n this.addItemCustomFieldsFormArray.push(formGroup);\r\n formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\r\n if (row) {\r\n row.customFields = value;\r\n }\r\n });\r\n }\r\n this.addItemCustomFieldsForm.reset({});\r\n this.addItemSelectedVariant = undefined;\r\n this.addedVariants.set(result.productVariantId, result);\r\n }\r\n\r\n private isMatchingAddItemRow(\r\n row: ModifyOrderData['addItems'][number],\r\n result: ProductSelectorItem,\r\n customFields: any,\r\n ): boolean {\r\n return (\r\n row.productVariantId === result.productVariantId &&\r\n JSON.stringify(row.customFields) === JSON.stringify(customFields)\r\n );\r\n }\r\n\r\n removeAddedItem(index: number) {\r\n this.modifyOrderInput.addItems.splice(index, 1);\r\n if (-1 < index) {\r\n this.addItemCustomFieldsFormArray.removeAt(index);\r\n }\r\n }\r\n\r\n getSurchargePrices(surcharge: SurchargeInput) {\r\n const priceWithTax = surcharge.priceIncludesTax\r\n ? surcharge.price\r\n : Math.round(surcharge.price * ((100 + (surcharge.taxRate || 0)) / 100));\r\n const price = surcharge.priceIncludesTax\r\n ? Math.round(surcharge.price / ((100 + (surcharge.taxRate || 0)) / 100))\r\n : surcharge.price;\r\n return {\r\n price,\r\n priceWithTax,\r\n };\r\n }\r\n\r\n addSurcharge(value: any) {\r\n this.modifyOrderInput.surcharges?.push(value);\r\n this.surchargeForm.reset({\r\n price: 0,\r\n priceIncludesTax: true,\r\n taxRate: 0,\r\n });\r\n }\r\n\r\n removeSurcharge(index: number) {\r\n this.modifyOrderInput.surcharges?.splice(index, 1);\r\n }\r\n\r\n previewAndModify(order: OrderDetailFragment) {\r\n const modifyOrderInput: ModifyOrderData = {\r\n ...this.modifyOrderInput,\r\n adjustOrderLines: this.modifyOrderInput.adjustOrderLines.map(line => {\r\n return transformRelationCustomFieldInputs(simpleDeepClone(line), this.orderLineCustomFields);\r\n }),\r\n };\r\n const input: ModifyOrderInput = {\r\n ...modifyOrderInput,\r\n ...(this.billingAddressForm.dirty ? { updateBillingAddress: this.billingAddressForm.value } : {}),\r\n ...(this.shippingAddressForm.dirty\r\n ? { updateShippingAddress: this.shippingAddressForm.value }\r\n : {}),\r\n dryRun: true,\r\n couponCodes: this.couponCodesControl.dirty ? this.couponCodesControl.value : undefined,\r\n note: this.note ?? '',\r\n options: {\r\n recalculateShipping: this.recalculateShipping,\r\n },\r\n };\r\n const originalTotalWithTax = order.totalWithTax;\r\n this.dataService.order\r\n .modifyOrder(input)\r\n .pipe(\r\n switchMap(({ modifyOrder }) => {\r\n switch (modifyOrder.__typename) {\r\n case 'Order':\r\n return this.modalService.fromComponent(OrderEditsPreviewDialogComponent, {\r\n size: 'xl',\r\n closable: false,\r\n locals: {\r\n originalTotalWithTax,\r\n order: modifyOrder,\r\n orderLineCustomFields: this.orderLineCustomFields,\r\n modifyOrderInput: input,\r\n },\r\n });\r\n case 'InsufficientStockError':\r\n case 'NegativeQuantityError':\r\n case 'NoChangesSpecifiedError':\r\n case 'OrderLimitError':\r\n case 'OrderModificationStateError':\r\n case 'PaymentMethodMissingError':\r\n case 'RefundPaymentIdMissingError':\r\n case 'CouponCodeLimitError':\r\n case 'CouponCodeExpiredError':\r\n case 'CouponCodeInvalidError': {\r\n this.notificationService.error(modifyOrder.message);\r\n return of(false as const);\r\n }\r\n case null:\r\n case undefined:\r\n return of(false as const);\r\n default:\r\n assertNever(modifyOrder);\r\n }\r\n }),\r\n switchMap(result => {\r\n if (!result || result.result === OrderEditResultType.Cancel) {\r\n // re-fetch so that the preview values get overwritten in the cache.\r\n return this.dataService.order.getOrder(this.id).mapSingle(() => false);\r\n } else {\r\n // Do the modification\r\n const wetRunInput = {\r\n ...input,\r\n dryRun: false,\r\n };\r\n if (result.result === OrderEditResultType.Refund) {\r\n wetRunInput.refund = {\r\n paymentId: result.refundPaymentId,\r\n reason: result.refundNote,\r\n };\r\n }\r\n return this.dataService.order.modifyOrder(wetRunInput).pipe(\r\n switchMap(({ modifyOrder }) => {\r\n if (modifyOrder.__typename === 'Order') {\r\n const priceDelta = modifyOrder.totalWithTax - originalTotalWithTax;\r\n const nextState =\r\n 0 < priceDelta ? 'ArrangingAdditionalPayment' : this.previousState;\r\n\r\n return this.dataService.order\r\n .transitionToState(order.id, nextState)\r\n .pipe(mapTo(true));\r\n } else {\r\n this.notificationService.error((modifyOrder as ErrorResult).message);\r\n return EMPTY;\r\n }\r\n }),\r\n );\r\n }\r\n }),\r\n )\r\n .subscribe(result => {\r\n if (result) {\r\n this.router.navigate(['../'], { relativeTo: this.route });\r\n }\r\n });\r\n }\r\n\r\n private addAddressCustomFieldsFormGroup(\r\n parentFormGroup: FormGroup,\r\n address?: OrderAddressFragment | null,\r\n ) {\r\n if (address && this.addressCustomFields.length) {\r\n const addressCustomFieldsFormGroup = new FormGroup({});\r\n for (const customFieldDef of this.addressCustomFields) {\r\n const name = customFieldDef.name;\r\n const value = (address as any).customFields?.[name];\r\n addressCustomFieldsFormGroup.addControl(name, new FormControl(value));\r\n }\r\n parentFormGroup.addControl('customFields', addressCustomFieldsFormGroup);\r\n }\r\n }\r\n\r\n protected setFormValues(entity: OrderDetailFragment, languageCode: LanguageCode): void {\r\n /* not used */\r\n }\r\n}\r\n","<vdr-action-bar>\r\n <vdr-ab-left>\r\n <div class=\"search-form\">\r\n <div class=\"filter-presets 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 <input\r\n type=\"text\"\r\n name=\"searchTerm\"\r\n [formControl]=\"searchControl\"\r\n [placeholder]=\"'order.search-by-order-filters' | 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\">{{\r\n item | stateI18nToken | translate\r\n }}</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\"\r\n >×</span\r\n >\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 <ng-container *ngIf=\"canCreateDraftOrder\">\r\n <a class=\"btn btn-primary mt1\" *vdrIfPermissions=\"['CreateOrder']\" [routerLink]=\"['./draft/create']\">\r\n <clr-icon shape=\"plus\"></clr-icon>\r\n {{ 'catalog.create-draft-order' | translate }}\r\n </a>\r\n </ng-container>\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.totalWithTax | 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]=\"\r\n order.state === 'Modifying'\r\n ? ['./', order.id, 'modify']\r\n : order.state === 'Draft'\r\n ? ['./draft', order.id]\r\n : ['./', order.id]\r\n \"\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 LogicalOperator,\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 searchControl = new FormControl('');\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' && s !== 'Draft',\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 name: 'draft',\r\n label: _('order.filter-preset-draft'),\r\n config: {\r\n active: false,\r\n states: ['Draft'],\r\n },\r\n },\r\n ];\r\n activePreset$: Observable<string>;\r\n canCreateDraftOrder = false;\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.searchControl.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 this.canCreateDraftOrder = !!this.serverConfigService\r\n .getOrderProcessStates()\r\n .find(state => state.name === 'Created')\r\n ?.to.includes('Draft');\r\n if (!this.canCreateDraftOrder) {\r\n this.filterPresets = this.filterPresets.filter(p => p.name !== 'draft');\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(this.searchControl.valueChanges).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 searchTerm: 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 let filter: any = {};\r\n let filterOperator: LogicalOperator = LogicalOperator.AND;\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 (searchTerm) {\r\n filter = {\r\n customerLastName: {\r\n contains: searchTerm,\r\n },\r\n transactionId: {\r\n contains: searchTerm,\r\n },\r\n code: {\r\n contains: searchTerm,\r\n },\r\n };\r\n filterOperator = LogicalOperator.OR;\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 filterOperator,\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 {\r\n ActivatedRouteSnapshot,\r\n ActivationStart,\r\n Resolve,\r\n Router,\r\n RouterStateSnapshot,\r\n} from '@angular/router';\r\nimport { DataService, OrderDetailFragment } from '@vendure/admin-ui/core';\r\nimport { notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport { EMPTY, Observable } from 'rxjs';\r\nimport { filter, map, shareReplay, switchMap, take, takeUntil } from 'rxjs/operators';\r\nimport { DraftOrderDetailComponent } from '../../components/draft-order-detail/draft-order-detail.component';\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 implements Resolve<Observable<OrderDetailFragment>> {\r\n constructor(private router: Router, private dataService: DataService) {}\r\n\r\n /** @internal */\r\n resolve(\r\n route: ActivatedRouteSnapshot,\r\n state: RouterStateSnapshot,\r\n ): Observable<Observable<OrderDetailFragment>> {\r\n const id = route.paramMap.get('id');\r\n\r\n // Complete the entity stream upon navigating away\r\n const navigateAway$ = this.router.events.pipe(filter(event => event instanceof ActivationStart));\r\n\r\n const stream = this.dataService.order\r\n .getOrder(id!)\r\n .mapStream(data => data.order)\r\n .pipe(\r\n switchMap(order => {\r\n if (order?.state === 'Draft' && route.component !== DraftOrderDetailComponent) {\r\n // Make sure Draft orders only get displayed with the DraftOrderDetailComponent\r\n this.router.navigate(['/orders/draft', id]);\r\n return EMPTY;\r\n } else {\r\n return [order];\r\n }\r\n }),\r\n takeUntil(navigateAway$),\r\n filter(notNullOrUndefined),\r\n shareReplay(1),\r\n );\r\n\r\n return stream.pipe(\r\n take(1),\r\n map(() => stream),\r\n );\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot, UrlTree } from '@angular/router';\r\nimport { DataService } from '@vendure/admin-ui/core';\r\nimport { EMPTY, Observable } from 'rxjs';\r\nimport { map, mergeMapTo, tap } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root',\r\n})\r\nexport class OrderGuard implements CanActivate {\r\n constructor(private dataService: DataService, private router: Router) {}\r\n\r\n canActivate(\r\n route: ActivatedRouteSnapshot,\r\n state: RouterStateSnapshot,\r\n ): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree {\r\n const isDraft = state.url.includes('orders/draft');\r\n const id = route.paramMap.get('id');\r\n if (isDraft) {\r\n if (id === 'create') {\r\n return this.dataService.order\r\n .createDraftOrder()\r\n .pipe(\r\n map(({ createDraftOrder }) =>\r\n this.router.parseUrl(`/orders/draft/${createDraftOrder.id}`),\r\n ),\r\n );\r\n } else {\r\n return true;\r\n }\r\n } else {\r\n return true;\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 detailBreadcrumb,\r\n OrderDetailFragment,\r\n} from '@vendure/admin-ui/core';\r\nimport { map } from 'rxjs/operators';\r\n\r\nimport { DraftOrderDetailComponent } from './components/draft-order-detail/draft-order-detail.component';\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\nimport { OrderGuard } from './providers/routing/order.guard';\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: 'draft/:id',\r\n component: DraftOrderDetailComponent,\r\n resolve: {\r\n entity: OrderResolver,\r\n },\r\n canActivate: [OrderGuard],\r\n canDeactivate: [CanDeactivateDetailGuard],\r\n data: {\r\n breadcrumb: orderBreadcrumb,\r\n },\r\n },\r\n {\r\n path: ':id',\r\n component: OrderDetailComponent,\r\n resolve: {\r\n entity: OrderResolver,\r\n },\r\n canActivate: [OrderGuard],\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: {\r\n entity: OrderResolver,\r\n },\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';\r\nimport { RouterModule } from '@angular/router';\r\nimport { SharedModule } from '@vendure/admin-ui/core';\r\n\r\nimport { AddManualPaymentDialogComponent } from './components/add-manual-payment-dialog/add-manual-payment-dialog.component';\r\nimport { CancelOrderDialogComponent } from './components/cancel-order-dialog/cancel-order-dialog.component';\r\nimport { DraftOrderDetailComponent } from './components/draft-order-detail/draft-order-detail.component';\r\nimport { DraftOrderVariantSelectorComponent } from './components/draft-order-variant-selector/draft-order-variant-selector.component';\r\nimport { FulfillOrderDialogComponent } from './components/fulfill-order-dialog/fulfill-order-dialog.component';\r\nimport { FulfillmentCardComponent } from './components/fulfillment-card/fulfillment-card.component';\r\nimport { FulfillmentDetailComponent } from './components/fulfillment-detail/fulfillment-detail.component';\r\nimport { FulfillmentStateLabelComponent } from './components/fulfillment-state-label/fulfillment-state-label.component';\r\nimport { LineFulfillmentComponent } from './components/line-fulfillment/line-fulfillment.component';\r\nimport { LineRefundsComponent } from './components/line-refunds/line-refunds.component';\r\nimport { ModificationDetailComponent } from './components/modification-detail/modification-detail.component';\r\nimport { OrderCustomFieldsCardComponent } from './components/order-custom-fields-card/order-custom-fields-card.component';\r\nimport { OrderDetailComponent } from './components/order-detail/order-detail.component';\r\nimport { OrderEditorComponent } from './components/order-editor/order-editor.component';\r\nimport { OrderEditsPreviewDialogComponent } from './components/order-edits-preview-dialog/order-edits-preview-dialog.component';\r\nimport { OrderHistoryComponent } from './components/order-history/order-history.component';\r\nimport { OrderListComponent } from './components/order-list/order-list.component';\r\nimport { OrderPaymentCardComponent } from './components/order-payment-card/order-payment-card.component';\r\nimport { OrderProcessGraphDialogComponent } from './components/order-process-graph-dialog/order-process-graph-dialog.component';\r\nimport { OrderProcessEdgeComponent } from './components/order-process-graph/order-process-edge.component';\r\nimport { OrderProcessGraphComponent } from './components/order-process-graph/order-process-graph.component';\r\nimport { OrderProcessNodeComponent } from './components/order-process-graph/order-process-node.component';\r\nimport { OrderStateSelectDialogComponent } from './components/order-state-select-dialog/order-state-select-dialog.component';\r\nimport { OrderTableComponent } from './components/order-table/order-table.component';\r\nimport { PaymentDetailComponent } from './components/payment-detail/payment-detail.component';\r\nimport { PaymentStateLabelComponent } from './components/payment-state-label/payment-state-label.component';\r\nimport { RefundOrderDialogComponent } from './components/refund-order-dialog/refund-order-dialog.component';\r\nimport { RefundStateLabelComponent } from './components/refund-state-label/refund-state-label.component';\r\nimport { SelectCustomerDialogComponent } from './components/select-customer-dialog/select-customer-dialog.component';\r\nimport { SettleRefundDialogComponent } from './components/settle-refund-dialog/settle-refund-dialog.component';\r\nimport { SimpleItemListComponent } from './components/simple-item-list/simple-item-list.component';\r\nimport { orderRoutes } from './order.routes';\r\nimport { SelectAddressDialogComponent } from './components/select-address-dialog/select-address-dialog.component';\r\nimport { CouponCodeSelectorComponent } from './components/coupon-code-selector/coupon-code-selector.component';\r\nimport { SelectShippingMethodDialogComponent } from './components/select-shipping-method-dialog/select-shipping-method-dialog.component';\r\n\r\n@NgModule({\r\n imports: [SharedModule, RouterModule.forChild(orderRoutes)],\r\n declarations: [\r\n OrderListComponent,\r\n OrderDetailComponent,\r\n FulfillOrderDialogComponent,\r\n LineFulfillmentComponent,\r\n RefundOrderDialogComponent,\r\n CancelOrderDialogComponent,\r\n PaymentStateLabelComponent,\r\n LineRefundsComponent,\r\n OrderPaymentCardComponent,\r\n RefundStateLabelComponent,\r\n SettleRefundDialogComponent,\r\n OrderHistoryComponent,\r\n FulfillmentDetailComponent,\r\n PaymentDetailComponent,\r\n SimpleItemListComponent,\r\n OrderCustomFieldsCardComponent,\r\n OrderProcessGraphComponent,\r\n OrderProcessNodeComponent,\r\n OrderProcessEdgeComponent,\r\n OrderProcessGraphDialogComponent,\r\n FulfillmentStateLabelComponent,\r\n FulfillmentCardComponent,\r\n OrderEditorComponent,\r\n OrderTableComponent,\r\n OrderEditsPreviewDialogComponent,\r\n ModificationDetailComponent,\r\n AddManualPaymentDialogComponent,\r\n OrderStateSelectDialogComponent,\r\n DraftOrderDetailComponent,\r\n DraftOrderVariantSelectorComponent,\r\n SelectCustomerDialogComponent,\r\n SelectAddressDialogComponent,\r\n CouponCodeSelectorComponent,\r\n SelectShippingMethodDialogComponent,\r\n ],\r\n})\r\nexport class OrderModule {}\r\n"],"sourceRoot":"webpack:///","file":"407.a3fde1da25c0935c.js"}