@medusajs/draft-order 2.10.2-preview-20250909031450 → 2.10.2-preview-20250909060155
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.
- package/.medusa/server/src/admin/index.js +209 -209
- package/.medusa/server/src/admin/index.mjs +209 -209
- package/package.json +16 -16
|
@@ -9573,95 +9573,6 @@ const ID = () => {
|
|
|
9573
9573
|
/* @__PURE__ */ jsxRuntime.jsx(reactRouterDom.Outlet, {})
|
|
9574
9574
|
] });
|
|
9575
9575
|
};
|
|
9576
|
-
const CustomItems = () => {
|
|
9577
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
9578
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Header, { children: /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Custom Items" }) }) }),
|
|
9579
|
-
/* @__PURE__ */ jsxRuntime.jsx(CustomItemsForm, {})
|
|
9580
|
-
] });
|
|
9581
|
-
};
|
|
9582
|
-
const CustomItemsForm = () => {
|
|
9583
|
-
const form = reactHookForm.useForm({
|
|
9584
|
-
resolver: zod.zodResolver(schema$5)
|
|
9585
|
-
});
|
|
9586
|
-
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(KeyboundForm, { className: "flex flex-1 flex-col", children: [
|
|
9587
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, {}),
|
|
9588
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9589
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9590
|
-
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", children: "Save" })
|
|
9591
|
-
] }) })
|
|
9592
|
-
] }) });
|
|
9593
|
-
};
|
|
9594
|
-
const schema$5 = objectType({
|
|
9595
|
-
email: stringType().email()
|
|
9596
|
-
});
|
|
9597
|
-
const Email = () => {
|
|
9598
|
-
const { id } = reactRouterDom.useParams();
|
|
9599
|
-
const { order, isPending, isError, error } = useOrder(id, {
|
|
9600
|
-
fields: "+email"
|
|
9601
|
-
});
|
|
9602
|
-
if (isError) {
|
|
9603
|
-
throw error;
|
|
9604
|
-
}
|
|
9605
|
-
const isReady = !isPending && !!order;
|
|
9606
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
9607
|
-
/* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer.Header, { children: [
|
|
9608
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Email" }) }),
|
|
9609
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("span", { className: "sr-only", children: "Edit the email for the draft order" }) })
|
|
9610
|
-
] }),
|
|
9611
|
-
isReady && /* @__PURE__ */ jsxRuntime.jsx(EmailForm, { order })
|
|
9612
|
-
] });
|
|
9613
|
-
};
|
|
9614
|
-
const EmailForm = ({ order }) => {
|
|
9615
|
-
const form = reactHookForm.useForm({
|
|
9616
|
-
defaultValues: {
|
|
9617
|
-
email: order.email ?? ""
|
|
9618
|
-
},
|
|
9619
|
-
resolver: zod.zodResolver(schema$4)
|
|
9620
|
-
});
|
|
9621
|
-
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9622
|
-
const { handleSuccess } = useRouteModal();
|
|
9623
|
-
const onSubmit = form.handleSubmit(async (data) => {
|
|
9624
|
-
await mutateAsync(
|
|
9625
|
-
{ email: data.email },
|
|
9626
|
-
{
|
|
9627
|
-
onSuccess: () => {
|
|
9628
|
-
handleSuccess();
|
|
9629
|
-
},
|
|
9630
|
-
onError: (error) => {
|
|
9631
|
-
ui.toast.error(error.message);
|
|
9632
|
-
}
|
|
9633
|
-
}
|
|
9634
|
-
);
|
|
9635
|
-
});
|
|
9636
|
-
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
9637
|
-
KeyboundForm,
|
|
9638
|
-
{
|
|
9639
|
-
className: "flex flex-1 flex-col overflow-hidden",
|
|
9640
|
-
onSubmit,
|
|
9641
|
-
children: [
|
|
9642
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
9643
|
-
Form$2.Field,
|
|
9644
|
-
{
|
|
9645
|
-
control: form.control,
|
|
9646
|
-
name: "email",
|
|
9647
|
-
render: ({ field }) => /* @__PURE__ */ jsxRuntime.jsxs(Form$2.Item, { children: [
|
|
9648
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Label, { children: "Email" }),
|
|
9649
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Control, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Input, { ...field }) }),
|
|
9650
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.ErrorMessage, {})
|
|
9651
|
-
] })
|
|
9652
|
-
}
|
|
9653
|
-
) }),
|
|
9654
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9655
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9656
|
-
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
9657
|
-
] }) })
|
|
9658
|
-
]
|
|
9659
|
-
}
|
|
9660
|
-
) });
|
|
9661
|
-
};
|
|
9662
|
-
const schema$4 = objectType({
|
|
9663
|
-
email: stringType().email()
|
|
9664
|
-
});
|
|
9665
9576
|
const BillingAddress = () => {
|
|
9666
9577
|
const { id } = reactRouterDom.useParams();
|
|
9667
9578
|
const { order, isPending, isError, error } = useOrder(id, {
|
|
@@ -9694,7 +9605,7 @@ const BillingAddressForm = ({ order }) => {
|
|
|
9694
9605
|
postal_code: ((_i = order.billing_address) == null ? void 0 : _i.postal_code) ?? "",
|
|
9695
9606
|
phone: ((_j = order.billing_address) == null ? void 0 : _j.phone) ?? ""
|
|
9696
9607
|
},
|
|
9697
|
-
resolver: zod.zodResolver(schema$
|
|
9608
|
+
resolver: zod.zodResolver(schema$5)
|
|
9698
9609
|
});
|
|
9699
9610
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9700
9611
|
const { handleSuccess } = useRouteModal();
|
|
@@ -9851,7 +9762,96 @@ const BillingAddressForm = ({ order }) => {
|
|
|
9851
9762
|
}
|
|
9852
9763
|
) });
|
|
9853
9764
|
};
|
|
9854
|
-
const schema$
|
|
9765
|
+
const schema$5 = addressSchema;
|
|
9766
|
+
const CustomItems = () => {
|
|
9767
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
9768
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Header, { children: /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Custom Items" }) }) }),
|
|
9769
|
+
/* @__PURE__ */ jsxRuntime.jsx(CustomItemsForm, {})
|
|
9770
|
+
] });
|
|
9771
|
+
};
|
|
9772
|
+
const CustomItemsForm = () => {
|
|
9773
|
+
const form = reactHookForm.useForm({
|
|
9774
|
+
resolver: zod.zodResolver(schema$4)
|
|
9775
|
+
});
|
|
9776
|
+
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(KeyboundForm, { className: "flex flex-1 flex-col", children: [
|
|
9777
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, {}),
|
|
9778
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9779
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9780
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", children: "Save" })
|
|
9781
|
+
] }) })
|
|
9782
|
+
] }) });
|
|
9783
|
+
};
|
|
9784
|
+
const schema$4 = objectType({
|
|
9785
|
+
email: stringType().email()
|
|
9786
|
+
});
|
|
9787
|
+
const Email = () => {
|
|
9788
|
+
const { id } = reactRouterDom.useParams();
|
|
9789
|
+
const { order, isPending, isError, error } = useOrder(id, {
|
|
9790
|
+
fields: "+email"
|
|
9791
|
+
});
|
|
9792
|
+
if (isError) {
|
|
9793
|
+
throw error;
|
|
9794
|
+
}
|
|
9795
|
+
const isReady = !isPending && !!order;
|
|
9796
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
9797
|
+
/* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer.Header, { children: [
|
|
9798
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Email" }) }),
|
|
9799
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("span", { className: "sr-only", children: "Edit the email for the draft order" }) })
|
|
9800
|
+
] }),
|
|
9801
|
+
isReady && /* @__PURE__ */ jsxRuntime.jsx(EmailForm, { order })
|
|
9802
|
+
] });
|
|
9803
|
+
};
|
|
9804
|
+
const EmailForm = ({ order }) => {
|
|
9805
|
+
const form = reactHookForm.useForm({
|
|
9806
|
+
defaultValues: {
|
|
9807
|
+
email: order.email ?? ""
|
|
9808
|
+
},
|
|
9809
|
+
resolver: zod.zodResolver(schema$3)
|
|
9810
|
+
});
|
|
9811
|
+
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9812
|
+
const { handleSuccess } = useRouteModal();
|
|
9813
|
+
const onSubmit = form.handleSubmit(async (data) => {
|
|
9814
|
+
await mutateAsync(
|
|
9815
|
+
{ email: data.email },
|
|
9816
|
+
{
|
|
9817
|
+
onSuccess: () => {
|
|
9818
|
+
handleSuccess();
|
|
9819
|
+
},
|
|
9820
|
+
onError: (error) => {
|
|
9821
|
+
ui.toast.error(error.message);
|
|
9822
|
+
}
|
|
9823
|
+
}
|
|
9824
|
+
);
|
|
9825
|
+
});
|
|
9826
|
+
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
9827
|
+
KeyboundForm,
|
|
9828
|
+
{
|
|
9829
|
+
className: "flex flex-1 flex-col overflow-hidden",
|
|
9830
|
+
onSubmit,
|
|
9831
|
+
children: [
|
|
9832
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
9833
|
+
Form$2.Field,
|
|
9834
|
+
{
|
|
9835
|
+
control: form.control,
|
|
9836
|
+
name: "email",
|
|
9837
|
+
render: ({ field }) => /* @__PURE__ */ jsxRuntime.jsxs(Form$2.Item, { children: [
|
|
9838
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Label, { children: "Email" }),
|
|
9839
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Control, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Input, { ...field }) }),
|
|
9840
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.ErrorMessage, {})
|
|
9841
|
+
] })
|
|
9842
|
+
}
|
|
9843
|
+
) }),
|
|
9844
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9845
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9846
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
9847
|
+
] }) })
|
|
9848
|
+
]
|
|
9849
|
+
}
|
|
9850
|
+
) });
|
|
9851
|
+
};
|
|
9852
|
+
const schema$3 = objectType({
|
|
9853
|
+
email: stringType().email()
|
|
9854
|
+
});
|
|
9855
9855
|
const NumberInput = React.forwardRef(
|
|
9856
9856
|
({
|
|
9857
9857
|
value,
|
|
@@ -11453,6 +11453,112 @@ function getPromotionIds(items, shippingMethods) {
|
|
|
11453
11453
|
}
|
|
11454
11454
|
return Array.from(promotionIds);
|
|
11455
11455
|
}
|
|
11456
|
+
const SalesChannel = () => {
|
|
11457
|
+
const { id } = reactRouterDom.useParams();
|
|
11458
|
+
const { draft_order, isPending, isError, error } = useDraftOrder(
|
|
11459
|
+
id,
|
|
11460
|
+
{
|
|
11461
|
+
fields: "+sales_channel_id"
|
|
11462
|
+
},
|
|
11463
|
+
{
|
|
11464
|
+
enabled: !!id
|
|
11465
|
+
}
|
|
11466
|
+
);
|
|
11467
|
+
if (isError) {
|
|
11468
|
+
throw error;
|
|
11469
|
+
}
|
|
11470
|
+
const ISrEADY = !!draft_order && !isPending;
|
|
11471
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
11472
|
+
/* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer.Header, { children: [
|
|
11473
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Sales Channel" }) }),
|
|
11474
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("span", { className: "sr-only", children: "Update which sales channel the draft order is associated with" }) })
|
|
11475
|
+
] }),
|
|
11476
|
+
ISrEADY && /* @__PURE__ */ jsxRuntime.jsx(SalesChannelForm, { order: draft_order })
|
|
11477
|
+
] });
|
|
11478
|
+
};
|
|
11479
|
+
const SalesChannelForm = ({ order }) => {
|
|
11480
|
+
const form = reactHookForm.useForm({
|
|
11481
|
+
defaultValues: {
|
|
11482
|
+
sales_channel_id: order.sales_channel_id || ""
|
|
11483
|
+
},
|
|
11484
|
+
resolver: zod.zodResolver(schema$2)
|
|
11485
|
+
});
|
|
11486
|
+
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
11487
|
+
const { handleSuccess } = useRouteModal();
|
|
11488
|
+
const onSubmit = form.handleSubmit(async (data) => {
|
|
11489
|
+
await mutateAsync(
|
|
11490
|
+
{
|
|
11491
|
+
sales_channel_id: data.sales_channel_id
|
|
11492
|
+
},
|
|
11493
|
+
{
|
|
11494
|
+
onSuccess: () => {
|
|
11495
|
+
ui.toast.success("Sales channel updated");
|
|
11496
|
+
handleSuccess();
|
|
11497
|
+
},
|
|
11498
|
+
onError: (error) => {
|
|
11499
|
+
ui.toast.error(error.message);
|
|
11500
|
+
}
|
|
11501
|
+
}
|
|
11502
|
+
);
|
|
11503
|
+
});
|
|
11504
|
+
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
11505
|
+
KeyboundForm,
|
|
11506
|
+
{
|
|
11507
|
+
className: "flex flex-1 flex-col overflow-hidden",
|
|
11508
|
+
onSubmit,
|
|
11509
|
+
children: [
|
|
11510
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsxRuntime.jsx(SalesChannelField, { control: form.control, order }) }),
|
|
11511
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
11512
|
+
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
11513
|
+
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
11514
|
+
] }) })
|
|
11515
|
+
]
|
|
11516
|
+
}
|
|
11517
|
+
) });
|
|
11518
|
+
};
|
|
11519
|
+
const SalesChannelField = ({ control, order }) => {
|
|
11520
|
+
const salesChannels = useComboboxData({
|
|
11521
|
+
queryFn: async (params) => {
|
|
11522
|
+
return await sdk.admin.salesChannel.list(params);
|
|
11523
|
+
},
|
|
11524
|
+
queryKey: ["sales-channels"],
|
|
11525
|
+
getOptions: (data) => {
|
|
11526
|
+
return data.sales_channels.map((salesChannel) => ({
|
|
11527
|
+
label: salesChannel.name,
|
|
11528
|
+
value: salesChannel.id
|
|
11529
|
+
}));
|
|
11530
|
+
},
|
|
11531
|
+
defaultValue: order.sales_channel_id || void 0
|
|
11532
|
+
});
|
|
11533
|
+
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
11534
|
+
Form$2.Field,
|
|
11535
|
+
{
|
|
11536
|
+
control,
|
|
11537
|
+
name: "sales_channel_id",
|
|
11538
|
+
render: ({ field }) => {
|
|
11539
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(Form$2.Item, { children: [
|
|
11540
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Label, { children: "Sales Channel" }),
|
|
11541
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Control, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
11542
|
+
Combobox,
|
|
11543
|
+
{
|
|
11544
|
+
options: salesChannels.options,
|
|
11545
|
+
fetchNextPage: salesChannels.fetchNextPage,
|
|
11546
|
+
isFetchingNextPage: salesChannels.isFetchingNextPage,
|
|
11547
|
+
searchValue: salesChannels.searchValue,
|
|
11548
|
+
onSearchValueChange: salesChannels.onSearchValueChange,
|
|
11549
|
+
placeholder: "Select sales channel",
|
|
11550
|
+
...field
|
|
11551
|
+
}
|
|
11552
|
+
) }),
|
|
11553
|
+
/* @__PURE__ */ jsxRuntime.jsx(Form$2.ErrorMessage, {})
|
|
11554
|
+
] });
|
|
11555
|
+
}
|
|
11556
|
+
}
|
|
11557
|
+
);
|
|
11558
|
+
};
|
|
11559
|
+
const schema$2 = objectType({
|
|
11560
|
+
sales_channel_id: stringType().min(1)
|
|
11561
|
+
});
|
|
11456
11562
|
const STACKED_FOCUS_MODAL_ID = "shipping-form";
|
|
11457
11563
|
const Shipping = () => {
|
|
11458
11564
|
var _a;
|
|
@@ -12292,7 +12398,7 @@ const ShippingAddressForm = ({ order }) => {
|
|
|
12292
12398
|
postal_code: ((_i = order.shipping_address) == null ? void 0 : _i.postal_code) ?? "",
|
|
12293
12399
|
phone: ((_j = order.shipping_address) == null ? void 0 : _j.phone) ?? ""
|
|
12294
12400
|
},
|
|
12295
|
-
resolver: zod.zodResolver(schema$
|
|
12401
|
+
resolver: zod.zodResolver(schema$1)
|
|
12296
12402
|
});
|
|
12297
12403
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12298
12404
|
const { handleSuccess } = useRouteModal();
|
|
@@ -12462,7 +12568,7 @@ const ShippingAddressForm = ({ order }) => {
|
|
|
12462
12568
|
}
|
|
12463
12569
|
) });
|
|
12464
12570
|
};
|
|
12465
|
-
const schema$
|
|
12571
|
+
const schema$1 = addressSchema;
|
|
12466
12572
|
const TransferOwnership = () => {
|
|
12467
12573
|
const { id } = reactRouterDom.useParams();
|
|
12468
12574
|
const { draft_order, isPending, isError, error } = useDraftOrder(id, {
|
|
@@ -12486,7 +12592,7 @@ const TransferOwnershipForm = ({ order }) => {
|
|
|
12486
12592
|
defaultValues: {
|
|
12487
12593
|
customer_id: order.customer_id || ""
|
|
12488
12594
|
},
|
|
12489
|
-
resolver: zod.zodResolver(schema
|
|
12595
|
+
resolver: zod.zodResolver(schema)
|
|
12490
12596
|
});
|
|
12491
12597
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12492
12598
|
const { handleSuccess } = useRouteModal();
|
|
@@ -12936,114 +13042,8 @@ const Illustration = () => {
|
|
|
12936
13042
|
}
|
|
12937
13043
|
);
|
|
12938
13044
|
};
|
|
12939
|
-
const schema$1 = objectType({
|
|
12940
|
-
customer_id: stringType().min(1)
|
|
12941
|
-
});
|
|
12942
|
-
const SalesChannel = () => {
|
|
12943
|
-
const { id } = reactRouterDom.useParams();
|
|
12944
|
-
const { draft_order, isPending, isError, error } = useDraftOrder(
|
|
12945
|
-
id,
|
|
12946
|
-
{
|
|
12947
|
-
fields: "+sales_channel_id"
|
|
12948
|
-
},
|
|
12949
|
-
{
|
|
12950
|
-
enabled: !!id
|
|
12951
|
-
}
|
|
12952
|
-
);
|
|
12953
|
-
if (isError) {
|
|
12954
|
-
throw error;
|
|
12955
|
-
}
|
|
12956
|
-
const ISrEADY = !!draft_order && !isPending;
|
|
12957
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer, { children: [
|
|
12958
|
-
/* @__PURE__ */ jsxRuntime.jsxs(RouteDrawer.Header, { children: [
|
|
12959
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Heading, { children: "Edit Sales Channel" }) }),
|
|
12960
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx("span", { className: "sr-only", children: "Update which sales channel the draft order is associated with" }) })
|
|
12961
|
-
] }),
|
|
12962
|
-
ISrEADY && /* @__PURE__ */ jsxRuntime.jsx(SalesChannelForm, { order: draft_order })
|
|
12963
|
-
] });
|
|
12964
|
-
};
|
|
12965
|
-
const SalesChannelForm = ({ order }) => {
|
|
12966
|
-
const form = reactHookForm.useForm({
|
|
12967
|
-
defaultValues: {
|
|
12968
|
-
sales_channel_id: order.sales_channel_id || ""
|
|
12969
|
-
},
|
|
12970
|
-
resolver: zod.zodResolver(schema)
|
|
12971
|
-
});
|
|
12972
|
-
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12973
|
-
const { handleSuccess } = useRouteModal();
|
|
12974
|
-
const onSubmit = form.handleSubmit(async (data) => {
|
|
12975
|
-
await mutateAsync(
|
|
12976
|
-
{
|
|
12977
|
-
sales_channel_id: data.sales_channel_id
|
|
12978
|
-
},
|
|
12979
|
-
{
|
|
12980
|
-
onSuccess: () => {
|
|
12981
|
-
ui.toast.success("Sales channel updated");
|
|
12982
|
-
handleSuccess();
|
|
12983
|
-
},
|
|
12984
|
-
onError: (error) => {
|
|
12985
|
-
ui.toast.error(error.message);
|
|
12986
|
-
}
|
|
12987
|
-
}
|
|
12988
|
-
);
|
|
12989
|
-
});
|
|
12990
|
-
return /* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
12991
|
-
KeyboundForm,
|
|
12992
|
-
{
|
|
12993
|
-
className: "flex flex-1 flex-col overflow-hidden",
|
|
12994
|
-
onSubmit,
|
|
12995
|
-
children: [
|
|
12996
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsxRuntime.jsx(SalesChannelField, { control: form.control, order }) }),
|
|
12997
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
12998
|
-
/* @__PURE__ */ jsxRuntime.jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
12999
|
-
/* @__PURE__ */ jsxRuntime.jsx(ui.Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
13000
|
-
] }) })
|
|
13001
|
-
]
|
|
13002
|
-
}
|
|
13003
|
-
) });
|
|
13004
|
-
};
|
|
13005
|
-
const SalesChannelField = ({ control, order }) => {
|
|
13006
|
-
const salesChannels = useComboboxData({
|
|
13007
|
-
queryFn: async (params) => {
|
|
13008
|
-
return await sdk.admin.salesChannel.list(params);
|
|
13009
|
-
},
|
|
13010
|
-
queryKey: ["sales-channels"],
|
|
13011
|
-
getOptions: (data) => {
|
|
13012
|
-
return data.sales_channels.map((salesChannel) => ({
|
|
13013
|
-
label: salesChannel.name,
|
|
13014
|
-
value: salesChannel.id
|
|
13015
|
-
}));
|
|
13016
|
-
},
|
|
13017
|
-
defaultValue: order.sales_channel_id || void 0
|
|
13018
|
-
});
|
|
13019
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
13020
|
-
Form$2.Field,
|
|
13021
|
-
{
|
|
13022
|
-
control,
|
|
13023
|
-
name: "sales_channel_id",
|
|
13024
|
-
render: ({ field }) => {
|
|
13025
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(Form$2.Item, { children: [
|
|
13026
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Label, { children: "Sales Channel" }),
|
|
13027
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.Control, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
13028
|
-
Combobox,
|
|
13029
|
-
{
|
|
13030
|
-
options: salesChannels.options,
|
|
13031
|
-
fetchNextPage: salesChannels.fetchNextPage,
|
|
13032
|
-
isFetchingNextPage: salesChannels.isFetchingNextPage,
|
|
13033
|
-
searchValue: salesChannels.searchValue,
|
|
13034
|
-
onSearchValueChange: salesChannels.onSearchValueChange,
|
|
13035
|
-
placeholder: "Select sales channel",
|
|
13036
|
-
...field
|
|
13037
|
-
}
|
|
13038
|
-
) }),
|
|
13039
|
-
/* @__PURE__ */ jsxRuntime.jsx(Form$2.ErrorMessage, {})
|
|
13040
|
-
] });
|
|
13041
|
-
}
|
|
13042
|
-
}
|
|
13043
|
-
);
|
|
13044
|
-
};
|
|
13045
13045
|
const schema = objectType({
|
|
13046
|
-
|
|
13046
|
+
customer_id: stringType().min(1)
|
|
13047
13047
|
});
|
|
13048
13048
|
const widgetModule = { widgets: [] };
|
|
13049
13049
|
const routeModule = {
|
|
@@ -13065,6 +13065,10 @@ const routeModule = {
|
|
|
13065
13065
|
handle,
|
|
13066
13066
|
loader,
|
|
13067
13067
|
children: [
|
|
13068
|
+
{
|
|
13069
|
+
Component: BillingAddress,
|
|
13070
|
+
path: "/draft-orders/:id/billing-address"
|
|
13071
|
+
},
|
|
13068
13072
|
{
|
|
13069
13073
|
Component: CustomItems,
|
|
13070
13074
|
path: "/draft-orders/:id/custom-items"
|
|
@@ -13073,10 +13077,6 @@ const routeModule = {
|
|
|
13073
13077
|
Component: Email,
|
|
13074
13078
|
path: "/draft-orders/:id/email"
|
|
13075
13079
|
},
|
|
13076
|
-
{
|
|
13077
|
-
Component: BillingAddress,
|
|
13078
|
-
path: "/draft-orders/:id/billing-address"
|
|
13079
|
-
},
|
|
13080
13080
|
{
|
|
13081
13081
|
Component: Items,
|
|
13082
13082
|
path: "/draft-orders/:id/items"
|
|
@@ -13089,6 +13089,10 @@ const routeModule = {
|
|
|
13089
13089
|
Component: Promotions,
|
|
13090
13090
|
path: "/draft-orders/:id/promotions"
|
|
13091
13091
|
},
|
|
13092
|
+
{
|
|
13093
|
+
Component: SalesChannel,
|
|
13094
|
+
path: "/draft-orders/:id/sales-channel"
|
|
13095
|
+
},
|
|
13092
13096
|
{
|
|
13093
13097
|
Component: Shipping,
|
|
13094
13098
|
path: "/draft-orders/:id/shipping"
|
|
@@ -13100,10 +13104,6 @@ const routeModule = {
|
|
|
13100
13104
|
{
|
|
13101
13105
|
Component: TransferOwnership,
|
|
13102
13106
|
path: "/draft-orders/:id/transfer-ownership"
|
|
13103
|
-
},
|
|
13104
|
-
{
|
|
13105
|
-
Component: SalesChannel,
|
|
13106
|
-
path: "/draft-orders/:id/sales-channel"
|
|
13107
13107
|
}
|
|
13108
13108
|
]
|
|
13109
13109
|
}
|
|
@@ -9567,95 +9567,6 @@ const ID = () => {
|
|
|
9567
9567
|
/* @__PURE__ */ jsx(Outlet, {})
|
|
9568
9568
|
] });
|
|
9569
9569
|
};
|
|
9570
|
-
const CustomItems = () => {
|
|
9571
|
-
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
9572
|
-
/* @__PURE__ */ jsx(RouteDrawer.Header, { children: /* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Custom Items" }) }) }),
|
|
9573
|
-
/* @__PURE__ */ jsx(CustomItemsForm, {})
|
|
9574
|
-
] });
|
|
9575
|
-
};
|
|
9576
|
-
const CustomItemsForm = () => {
|
|
9577
|
-
const form = useForm({
|
|
9578
|
-
resolver: zodResolver(schema$5)
|
|
9579
|
-
});
|
|
9580
|
-
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(KeyboundForm, { className: "flex flex-1 flex-col", children: [
|
|
9581
|
-
/* @__PURE__ */ jsx(RouteDrawer.Body, {}),
|
|
9582
|
-
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9583
|
-
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9584
|
-
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", children: "Save" })
|
|
9585
|
-
] }) })
|
|
9586
|
-
] }) });
|
|
9587
|
-
};
|
|
9588
|
-
const schema$5 = objectType({
|
|
9589
|
-
email: stringType().email()
|
|
9590
|
-
});
|
|
9591
|
-
const Email = () => {
|
|
9592
|
-
const { id } = useParams();
|
|
9593
|
-
const { order, isPending, isError, error } = useOrder(id, {
|
|
9594
|
-
fields: "+email"
|
|
9595
|
-
});
|
|
9596
|
-
if (isError) {
|
|
9597
|
-
throw error;
|
|
9598
|
-
}
|
|
9599
|
-
const isReady = !isPending && !!order;
|
|
9600
|
-
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
9601
|
-
/* @__PURE__ */ jsxs(RouteDrawer.Header, { children: [
|
|
9602
|
-
/* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Email" }) }),
|
|
9603
|
-
/* @__PURE__ */ jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Edit the email for the draft order" }) })
|
|
9604
|
-
] }),
|
|
9605
|
-
isReady && /* @__PURE__ */ jsx(EmailForm, { order })
|
|
9606
|
-
] });
|
|
9607
|
-
};
|
|
9608
|
-
const EmailForm = ({ order }) => {
|
|
9609
|
-
const form = useForm({
|
|
9610
|
-
defaultValues: {
|
|
9611
|
-
email: order.email ?? ""
|
|
9612
|
-
},
|
|
9613
|
-
resolver: zodResolver(schema$4)
|
|
9614
|
-
});
|
|
9615
|
-
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9616
|
-
const { handleSuccess } = useRouteModal();
|
|
9617
|
-
const onSubmit = form.handleSubmit(async (data) => {
|
|
9618
|
-
await mutateAsync(
|
|
9619
|
-
{ email: data.email },
|
|
9620
|
-
{
|
|
9621
|
-
onSuccess: () => {
|
|
9622
|
-
handleSuccess();
|
|
9623
|
-
},
|
|
9624
|
-
onError: (error) => {
|
|
9625
|
-
toast.error(error.message);
|
|
9626
|
-
}
|
|
9627
|
-
}
|
|
9628
|
-
);
|
|
9629
|
-
});
|
|
9630
|
-
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(
|
|
9631
|
-
KeyboundForm,
|
|
9632
|
-
{
|
|
9633
|
-
className: "flex flex-1 flex-col overflow-hidden",
|
|
9634
|
-
onSubmit,
|
|
9635
|
-
children: [
|
|
9636
|
-
/* @__PURE__ */ jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsx(
|
|
9637
|
-
Form$2.Field,
|
|
9638
|
-
{
|
|
9639
|
-
control: form.control,
|
|
9640
|
-
name: "email",
|
|
9641
|
-
render: ({ field }) => /* @__PURE__ */ jsxs(Form$2.Item, { children: [
|
|
9642
|
-
/* @__PURE__ */ jsx(Form$2.Label, { children: "Email" }),
|
|
9643
|
-
/* @__PURE__ */ jsx(Form$2.Control, { children: /* @__PURE__ */ jsx(Input, { ...field }) }),
|
|
9644
|
-
/* @__PURE__ */ jsx(Form$2.ErrorMessage, {})
|
|
9645
|
-
] })
|
|
9646
|
-
}
|
|
9647
|
-
) }),
|
|
9648
|
-
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9649
|
-
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9650
|
-
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
9651
|
-
] }) })
|
|
9652
|
-
]
|
|
9653
|
-
}
|
|
9654
|
-
) });
|
|
9655
|
-
};
|
|
9656
|
-
const schema$4 = objectType({
|
|
9657
|
-
email: stringType().email()
|
|
9658
|
-
});
|
|
9659
9570
|
const BillingAddress = () => {
|
|
9660
9571
|
const { id } = useParams();
|
|
9661
9572
|
const { order, isPending, isError, error } = useOrder(id, {
|
|
@@ -9688,7 +9599,7 @@ const BillingAddressForm = ({ order }) => {
|
|
|
9688
9599
|
postal_code: ((_i = order.billing_address) == null ? void 0 : _i.postal_code) ?? "",
|
|
9689
9600
|
phone: ((_j = order.billing_address) == null ? void 0 : _j.phone) ?? ""
|
|
9690
9601
|
},
|
|
9691
|
-
resolver: zodResolver(schema$
|
|
9602
|
+
resolver: zodResolver(schema$5)
|
|
9692
9603
|
});
|
|
9693
9604
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9694
9605
|
const { handleSuccess } = useRouteModal();
|
|
@@ -9845,7 +9756,96 @@ const BillingAddressForm = ({ order }) => {
|
|
|
9845
9756
|
}
|
|
9846
9757
|
) });
|
|
9847
9758
|
};
|
|
9848
|
-
const schema$
|
|
9759
|
+
const schema$5 = addressSchema;
|
|
9760
|
+
const CustomItems = () => {
|
|
9761
|
+
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
9762
|
+
/* @__PURE__ */ jsx(RouteDrawer.Header, { children: /* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Custom Items" }) }) }),
|
|
9763
|
+
/* @__PURE__ */ jsx(CustomItemsForm, {})
|
|
9764
|
+
] });
|
|
9765
|
+
};
|
|
9766
|
+
const CustomItemsForm = () => {
|
|
9767
|
+
const form = useForm({
|
|
9768
|
+
resolver: zodResolver(schema$4)
|
|
9769
|
+
});
|
|
9770
|
+
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(KeyboundForm, { className: "flex flex-1 flex-col", children: [
|
|
9771
|
+
/* @__PURE__ */ jsx(RouteDrawer.Body, {}),
|
|
9772
|
+
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9773
|
+
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9774
|
+
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", children: "Save" })
|
|
9775
|
+
] }) })
|
|
9776
|
+
] }) });
|
|
9777
|
+
};
|
|
9778
|
+
const schema$4 = objectType({
|
|
9779
|
+
email: stringType().email()
|
|
9780
|
+
});
|
|
9781
|
+
const Email = () => {
|
|
9782
|
+
const { id } = useParams();
|
|
9783
|
+
const { order, isPending, isError, error } = useOrder(id, {
|
|
9784
|
+
fields: "+email"
|
|
9785
|
+
});
|
|
9786
|
+
if (isError) {
|
|
9787
|
+
throw error;
|
|
9788
|
+
}
|
|
9789
|
+
const isReady = !isPending && !!order;
|
|
9790
|
+
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
9791
|
+
/* @__PURE__ */ jsxs(RouteDrawer.Header, { children: [
|
|
9792
|
+
/* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Email" }) }),
|
|
9793
|
+
/* @__PURE__ */ jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Edit the email for the draft order" }) })
|
|
9794
|
+
] }),
|
|
9795
|
+
isReady && /* @__PURE__ */ jsx(EmailForm, { order })
|
|
9796
|
+
] });
|
|
9797
|
+
};
|
|
9798
|
+
const EmailForm = ({ order }) => {
|
|
9799
|
+
const form = useForm({
|
|
9800
|
+
defaultValues: {
|
|
9801
|
+
email: order.email ?? ""
|
|
9802
|
+
},
|
|
9803
|
+
resolver: zodResolver(schema$3)
|
|
9804
|
+
});
|
|
9805
|
+
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
9806
|
+
const { handleSuccess } = useRouteModal();
|
|
9807
|
+
const onSubmit = form.handleSubmit(async (data) => {
|
|
9808
|
+
await mutateAsync(
|
|
9809
|
+
{ email: data.email },
|
|
9810
|
+
{
|
|
9811
|
+
onSuccess: () => {
|
|
9812
|
+
handleSuccess();
|
|
9813
|
+
},
|
|
9814
|
+
onError: (error) => {
|
|
9815
|
+
toast.error(error.message);
|
|
9816
|
+
}
|
|
9817
|
+
}
|
|
9818
|
+
);
|
|
9819
|
+
});
|
|
9820
|
+
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(
|
|
9821
|
+
KeyboundForm,
|
|
9822
|
+
{
|
|
9823
|
+
className: "flex flex-1 flex-col overflow-hidden",
|
|
9824
|
+
onSubmit,
|
|
9825
|
+
children: [
|
|
9826
|
+
/* @__PURE__ */ jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsx(
|
|
9827
|
+
Form$2.Field,
|
|
9828
|
+
{
|
|
9829
|
+
control: form.control,
|
|
9830
|
+
name: "email",
|
|
9831
|
+
render: ({ field }) => /* @__PURE__ */ jsxs(Form$2.Item, { children: [
|
|
9832
|
+
/* @__PURE__ */ jsx(Form$2.Label, { children: "Email" }),
|
|
9833
|
+
/* @__PURE__ */ jsx(Form$2.Control, { children: /* @__PURE__ */ jsx(Input, { ...field }) }),
|
|
9834
|
+
/* @__PURE__ */ jsx(Form$2.ErrorMessage, {})
|
|
9835
|
+
] })
|
|
9836
|
+
}
|
|
9837
|
+
) }),
|
|
9838
|
+
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
9839
|
+
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
9840
|
+
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
9841
|
+
] }) })
|
|
9842
|
+
]
|
|
9843
|
+
}
|
|
9844
|
+
) });
|
|
9845
|
+
};
|
|
9846
|
+
const schema$3 = objectType({
|
|
9847
|
+
email: stringType().email()
|
|
9848
|
+
});
|
|
9849
9849
|
const NumberInput = forwardRef(
|
|
9850
9850
|
({
|
|
9851
9851
|
value,
|
|
@@ -11447,6 +11447,112 @@ function getPromotionIds(items, shippingMethods) {
|
|
|
11447
11447
|
}
|
|
11448
11448
|
return Array.from(promotionIds);
|
|
11449
11449
|
}
|
|
11450
|
+
const SalesChannel = () => {
|
|
11451
|
+
const { id } = useParams();
|
|
11452
|
+
const { draft_order, isPending, isError, error } = useDraftOrder(
|
|
11453
|
+
id,
|
|
11454
|
+
{
|
|
11455
|
+
fields: "+sales_channel_id"
|
|
11456
|
+
},
|
|
11457
|
+
{
|
|
11458
|
+
enabled: !!id
|
|
11459
|
+
}
|
|
11460
|
+
);
|
|
11461
|
+
if (isError) {
|
|
11462
|
+
throw error;
|
|
11463
|
+
}
|
|
11464
|
+
const ISrEADY = !!draft_order && !isPending;
|
|
11465
|
+
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
11466
|
+
/* @__PURE__ */ jsxs(RouteDrawer.Header, { children: [
|
|
11467
|
+
/* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Sales Channel" }) }),
|
|
11468
|
+
/* @__PURE__ */ jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Update which sales channel the draft order is associated with" }) })
|
|
11469
|
+
] }),
|
|
11470
|
+
ISrEADY && /* @__PURE__ */ jsx(SalesChannelForm, { order: draft_order })
|
|
11471
|
+
] });
|
|
11472
|
+
};
|
|
11473
|
+
const SalesChannelForm = ({ order }) => {
|
|
11474
|
+
const form = useForm({
|
|
11475
|
+
defaultValues: {
|
|
11476
|
+
sales_channel_id: order.sales_channel_id || ""
|
|
11477
|
+
},
|
|
11478
|
+
resolver: zodResolver(schema$2)
|
|
11479
|
+
});
|
|
11480
|
+
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
11481
|
+
const { handleSuccess } = useRouteModal();
|
|
11482
|
+
const onSubmit = form.handleSubmit(async (data) => {
|
|
11483
|
+
await mutateAsync(
|
|
11484
|
+
{
|
|
11485
|
+
sales_channel_id: data.sales_channel_id
|
|
11486
|
+
},
|
|
11487
|
+
{
|
|
11488
|
+
onSuccess: () => {
|
|
11489
|
+
toast.success("Sales channel updated");
|
|
11490
|
+
handleSuccess();
|
|
11491
|
+
},
|
|
11492
|
+
onError: (error) => {
|
|
11493
|
+
toast.error(error.message);
|
|
11494
|
+
}
|
|
11495
|
+
}
|
|
11496
|
+
);
|
|
11497
|
+
});
|
|
11498
|
+
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(
|
|
11499
|
+
KeyboundForm,
|
|
11500
|
+
{
|
|
11501
|
+
className: "flex flex-1 flex-col overflow-hidden",
|
|
11502
|
+
onSubmit,
|
|
11503
|
+
children: [
|
|
11504
|
+
/* @__PURE__ */ jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsx(SalesChannelField, { control: form.control, order }) }),
|
|
11505
|
+
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
11506
|
+
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
11507
|
+
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
11508
|
+
] }) })
|
|
11509
|
+
]
|
|
11510
|
+
}
|
|
11511
|
+
) });
|
|
11512
|
+
};
|
|
11513
|
+
const SalesChannelField = ({ control, order }) => {
|
|
11514
|
+
const salesChannels = useComboboxData({
|
|
11515
|
+
queryFn: async (params) => {
|
|
11516
|
+
return await sdk.admin.salesChannel.list(params);
|
|
11517
|
+
},
|
|
11518
|
+
queryKey: ["sales-channels"],
|
|
11519
|
+
getOptions: (data) => {
|
|
11520
|
+
return data.sales_channels.map((salesChannel) => ({
|
|
11521
|
+
label: salesChannel.name,
|
|
11522
|
+
value: salesChannel.id
|
|
11523
|
+
}));
|
|
11524
|
+
},
|
|
11525
|
+
defaultValue: order.sales_channel_id || void 0
|
|
11526
|
+
});
|
|
11527
|
+
return /* @__PURE__ */ jsx(
|
|
11528
|
+
Form$2.Field,
|
|
11529
|
+
{
|
|
11530
|
+
control,
|
|
11531
|
+
name: "sales_channel_id",
|
|
11532
|
+
render: ({ field }) => {
|
|
11533
|
+
return /* @__PURE__ */ jsxs(Form$2.Item, { children: [
|
|
11534
|
+
/* @__PURE__ */ jsx(Form$2.Label, { children: "Sales Channel" }),
|
|
11535
|
+
/* @__PURE__ */ jsx(Form$2.Control, { children: /* @__PURE__ */ jsx(
|
|
11536
|
+
Combobox,
|
|
11537
|
+
{
|
|
11538
|
+
options: salesChannels.options,
|
|
11539
|
+
fetchNextPage: salesChannels.fetchNextPage,
|
|
11540
|
+
isFetchingNextPage: salesChannels.isFetchingNextPage,
|
|
11541
|
+
searchValue: salesChannels.searchValue,
|
|
11542
|
+
onSearchValueChange: salesChannels.onSearchValueChange,
|
|
11543
|
+
placeholder: "Select sales channel",
|
|
11544
|
+
...field
|
|
11545
|
+
}
|
|
11546
|
+
) }),
|
|
11547
|
+
/* @__PURE__ */ jsx(Form$2.ErrorMessage, {})
|
|
11548
|
+
] });
|
|
11549
|
+
}
|
|
11550
|
+
}
|
|
11551
|
+
);
|
|
11552
|
+
};
|
|
11553
|
+
const schema$2 = objectType({
|
|
11554
|
+
sales_channel_id: stringType().min(1)
|
|
11555
|
+
});
|
|
11450
11556
|
const STACKED_FOCUS_MODAL_ID = "shipping-form";
|
|
11451
11557
|
const Shipping = () => {
|
|
11452
11558
|
var _a;
|
|
@@ -12286,7 +12392,7 @@ const ShippingAddressForm = ({ order }) => {
|
|
|
12286
12392
|
postal_code: ((_i = order.shipping_address) == null ? void 0 : _i.postal_code) ?? "",
|
|
12287
12393
|
phone: ((_j = order.shipping_address) == null ? void 0 : _j.phone) ?? ""
|
|
12288
12394
|
},
|
|
12289
|
-
resolver: zodResolver(schema$
|
|
12395
|
+
resolver: zodResolver(schema$1)
|
|
12290
12396
|
});
|
|
12291
12397
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12292
12398
|
const { handleSuccess } = useRouteModal();
|
|
@@ -12456,7 +12562,7 @@ const ShippingAddressForm = ({ order }) => {
|
|
|
12456
12562
|
}
|
|
12457
12563
|
) });
|
|
12458
12564
|
};
|
|
12459
|
-
const schema$
|
|
12565
|
+
const schema$1 = addressSchema;
|
|
12460
12566
|
const TransferOwnership = () => {
|
|
12461
12567
|
const { id } = useParams();
|
|
12462
12568
|
const { draft_order, isPending, isError, error } = useDraftOrder(id, {
|
|
@@ -12480,7 +12586,7 @@ const TransferOwnershipForm = ({ order }) => {
|
|
|
12480
12586
|
defaultValues: {
|
|
12481
12587
|
customer_id: order.customer_id || ""
|
|
12482
12588
|
},
|
|
12483
|
-
resolver: zodResolver(schema
|
|
12589
|
+
resolver: zodResolver(schema)
|
|
12484
12590
|
});
|
|
12485
12591
|
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12486
12592
|
const { handleSuccess } = useRouteModal();
|
|
@@ -12930,114 +13036,8 @@ const Illustration = () => {
|
|
|
12930
13036
|
}
|
|
12931
13037
|
);
|
|
12932
13038
|
};
|
|
12933
|
-
const schema$1 = objectType({
|
|
12934
|
-
customer_id: stringType().min(1)
|
|
12935
|
-
});
|
|
12936
|
-
const SalesChannel = () => {
|
|
12937
|
-
const { id } = useParams();
|
|
12938
|
-
const { draft_order, isPending, isError, error } = useDraftOrder(
|
|
12939
|
-
id,
|
|
12940
|
-
{
|
|
12941
|
-
fields: "+sales_channel_id"
|
|
12942
|
-
},
|
|
12943
|
-
{
|
|
12944
|
-
enabled: !!id
|
|
12945
|
-
}
|
|
12946
|
-
);
|
|
12947
|
-
if (isError) {
|
|
12948
|
-
throw error;
|
|
12949
|
-
}
|
|
12950
|
-
const ISrEADY = !!draft_order && !isPending;
|
|
12951
|
-
return /* @__PURE__ */ jsxs(RouteDrawer, { children: [
|
|
12952
|
-
/* @__PURE__ */ jsxs(RouteDrawer.Header, { children: [
|
|
12953
|
-
/* @__PURE__ */ jsx(RouteDrawer.Title, { asChild: true, children: /* @__PURE__ */ jsx(Heading, { children: "Edit Sales Channel" }) }),
|
|
12954
|
-
/* @__PURE__ */ jsx(RouteDrawer.Description, { asChild: true, children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Update which sales channel the draft order is associated with" }) })
|
|
12955
|
-
] }),
|
|
12956
|
-
ISrEADY && /* @__PURE__ */ jsx(SalesChannelForm, { order: draft_order })
|
|
12957
|
-
] });
|
|
12958
|
-
};
|
|
12959
|
-
const SalesChannelForm = ({ order }) => {
|
|
12960
|
-
const form = useForm({
|
|
12961
|
-
defaultValues: {
|
|
12962
|
-
sales_channel_id: order.sales_channel_id || ""
|
|
12963
|
-
},
|
|
12964
|
-
resolver: zodResolver(schema)
|
|
12965
|
-
});
|
|
12966
|
-
const { mutateAsync, isPending } = useUpdateDraftOrder(order.id);
|
|
12967
|
-
const { handleSuccess } = useRouteModal();
|
|
12968
|
-
const onSubmit = form.handleSubmit(async (data) => {
|
|
12969
|
-
await mutateAsync(
|
|
12970
|
-
{
|
|
12971
|
-
sales_channel_id: data.sales_channel_id
|
|
12972
|
-
},
|
|
12973
|
-
{
|
|
12974
|
-
onSuccess: () => {
|
|
12975
|
-
toast.success("Sales channel updated");
|
|
12976
|
-
handleSuccess();
|
|
12977
|
-
},
|
|
12978
|
-
onError: (error) => {
|
|
12979
|
-
toast.error(error.message);
|
|
12980
|
-
}
|
|
12981
|
-
}
|
|
12982
|
-
);
|
|
12983
|
-
});
|
|
12984
|
-
return /* @__PURE__ */ jsx(RouteDrawer.Form, { form, children: /* @__PURE__ */ jsxs(
|
|
12985
|
-
KeyboundForm,
|
|
12986
|
-
{
|
|
12987
|
-
className: "flex flex-1 flex-col overflow-hidden",
|
|
12988
|
-
onSubmit,
|
|
12989
|
-
children: [
|
|
12990
|
-
/* @__PURE__ */ jsx(RouteDrawer.Body, { className: "flex flex-col gap-y-6 overflow-y-auto", children: /* @__PURE__ */ jsx(SalesChannelField, { control: form.control, order }) }),
|
|
12991
|
-
/* @__PURE__ */ jsx(RouteDrawer.Footer, { children: /* @__PURE__ */ jsxs("div", { className: "flex justify-end gap-2", children: [
|
|
12992
|
-
/* @__PURE__ */ jsx(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { size: "small", variant: "secondary", children: "Cancel" }) }),
|
|
12993
|
-
/* @__PURE__ */ jsx(Button, { size: "small", type: "submit", isLoading: isPending, children: "Save" })
|
|
12994
|
-
] }) })
|
|
12995
|
-
]
|
|
12996
|
-
}
|
|
12997
|
-
) });
|
|
12998
|
-
};
|
|
12999
|
-
const SalesChannelField = ({ control, order }) => {
|
|
13000
|
-
const salesChannels = useComboboxData({
|
|
13001
|
-
queryFn: async (params) => {
|
|
13002
|
-
return await sdk.admin.salesChannel.list(params);
|
|
13003
|
-
},
|
|
13004
|
-
queryKey: ["sales-channels"],
|
|
13005
|
-
getOptions: (data) => {
|
|
13006
|
-
return data.sales_channels.map((salesChannel) => ({
|
|
13007
|
-
label: salesChannel.name,
|
|
13008
|
-
value: salesChannel.id
|
|
13009
|
-
}));
|
|
13010
|
-
},
|
|
13011
|
-
defaultValue: order.sales_channel_id || void 0
|
|
13012
|
-
});
|
|
13013
|
-
return /* @__PURE__ */ jsx(
|
|
13014
|
-
Form$2.Field,
|
|
13015
|
-
{
|
|
13016
|
-
control,
|
|
13017
|
-
name: "sales_channel_id",
|
|
13018
|
-
render: ({ field }) => {
|
|
13019
|
-
return /* @__PURE__ */ jsxs(Form$2.Item, { children: [
|
|
13020
|
-
/* @__PURE__ */ jsx(Form$2.Label, { children: "Sales Channel" }),
|
|
13021
|
-
/* @__PURE__ */ jsx(Form$2.Control, { children: /* @__PURE__ */ jsx(
|
|
13022
|
-
Combobox,
|
|
13023
|
-
{
|
|
13024
|
-
options: salesChannels.options,
|
|
13025
|
-
fetchNextPage: salesChannels.fetchNextPage,
|
|
13026
|
-
isFetchingNextPage: salesChannels.isFetchingNextPage,
|
|
13027
|
-
searchValue: salesChannels.searchValue,
|
|
13028
|
-
onSearchValueChange: salesChannels.onSearchValueChange,
|
|
13029
|
-
placeholder: "Select sales channel",
|
|
13030
|
-
...field
|
|
13031
|
-
}
|
|
13032
|
-
) }),
|
|
13033
|
-
/* @__PURE__ */ jsx(Form$2.ErrorMessage, {})
|
|
13034
|
-
] });
|
|
13035
|
-
}
|
|
13036
|
-
}
|
|
13037
|
-
);
|
|
13038
|
-
};
|
|
13039
13039
|
const schema = objectType({
|
|
13040
|
-
|
|
13040
|
+
customer_id: stringType().min(1)
|
|
13041
13041
|
});
|
|
13042
13042
|
const widgetModule = { widgets: [] };
|
|
13043
13043
|
const routeModule = {
|
|
@@ -13059,6 +13059,10 @@ const routeModule = {
|
|
|
13059
13059
|
handle,
|
|
13060
13060
|
loader,
|
|
13061
13061
|
children: [
|
|
13062
|
+
{
|
|
13063
|
+
Component: BillingAddress,
|
|
13064
|
+
path: "/draft-orders/:id/billing-address"
|
|
13065
|
+
},
|
|
13062
13066
|
{
|
|
13063
13067
|
Component: CustomItems,
|
|
13064
13068
|
path: "/draft-orders/:id/custom-items"
|
|
@@ -13067,10 +13071,6 @@ const routeModule = {
|
|
|
13067
13071
|
Component: Email,
|
|
13068
13072
|
path: "/draft-orders/:id/email"
|
|
13069
13073
|
},
|
|
13070
|
-
{
|
|
13071
|
-
Component: BillingAddress,
|
|
13072
|
-
path: "/draft-orders/:id/billing-address"
|
|
13073
|
-
},
|
|
13074
13074
|
{
|
|
13075
13075
|
Component: Items,
|
|
13076
13076
|
path: "/draft-orders/:id/items"
|
|
@@ -13083,6 +13083,10 @@ const routeModule = {
|
|
|
13083
13083
|
Component: Promotions,
|
|
13084
13084
|
path: "/draft-orders/:id/promotions"
|
|
13085
13085
|
},
|
|
13086
|
+
{
|
|
13087
|
+
Component: SalesChannel,
|
|
13088
|
+
path: "/draft-orders/:id/sales-channel"
|
|
13089
|
+
},
|
|
13086
13090
|
{
|
|
13087
13091
|
Component: Shipping,
|
|
13088
13092
|
path: "/draft-orders/:id/shipping"
|
|
@@ -13094,10 +13098,6 @@ const routeModule = {
|
|
|
13094
13098
|
{
|
|
13095
13099
|
Component: TransferOwnership,
|
|
13096
13100
|
path: "/draft-orders/:id/transfer-ownership"
|
|
13097
|
-
},
|
|
13098
|
-
{
|
|
13099
|
-
Component: SalesChannel,
|
|
13100
|
-
path: "/draft-orders/:id/sales-channel"
|
|
13101
13101
|
}
|
|
13102
13102
|
]
|
|
13103
13103
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@medusajs/draft-order",
|
|
3
|
-
"version": "2.10.2-preview-
|
|
3
|
+
"version": "2.10.2-preview-20250909060155",
|
|
4
4
|
"description": "A starter for Medusa plugins.",
|
|
5
5
|
"author": "Medusa (https://medusajs.com)",
|
|
6
6
|
"license": "MIT",
|
|
@@ -36,7 +36,7 @@
|
|
|
36
36
|
"dependencies": {
|
|
37
37
|
"@ariakit/react": "^0.4.15",
|
|
38
38
|
"@hookform/resolvers": "3.4.2",
|
|
39
|
-
"@medusajs/js-sdk": "2.10.2-preview-
|
|
39
|
+
"@medusajs/js-sdk": "2.10.2-preview-20250909060155",
|
|
40
40
|
"@tanstack/react-query": "5.64.2",
|
|
41
41
|
"@uiw/react-json-view": "^2.0.0-alpha.17",
|
|
42
42
|
"date-fns": "^3.6.0",
|
|
@@ -45,14 +45,14 @@
|
|
|
45
45
|
"react-hook-form": "7.49.1"
|
|
46
46
|
},
|
|
47
47
|
"devDependencies": {
|
|
48
|
-
"@medusajs/admin-sdk": "2.10.2-preview-
|
|
49
|
-
"@medusajs/cli": "2.10.2-preview-
|
|
50
|
-
"@medusajs/framework": "2.10.2-preview-
|
|
51
|
-
"@medusajs/icons": "2.10.2-preview-
|
|
52
|
-
"@medusajs/test-utils": "2.10.2-preview-
|
|
53
|
-
"@medusajs/types": "2.10.2-preview-
|
|
54
|
-
"@medusajs/ui": "4.0.22-preview-
|
|
55
|
-
"@medusajs/ui-preset": "2.10.2-preview-
|
|
48
|
+
"@medusajs/admin-sdk": "2.10.2-preview-20250909060155",
|
|
49
|
+
"@medusajs/cli": "2.10.2-preview-20250909060155",
|
|
50
|
+
"@medusajs/framework": "2.10.2-preview-20250909060155",
|
|
51
|
+
"@medusajs/icons": "2.10.2-preview-20250909060155",
|
|
52
|
+
"@medusajs/test-utils": "2.10.2-preview-20250909060155",
|
|
53
|
+
"@medusajs/types": "2.10.2-preview-20250909060155",
|
|
54
|
+
"@medusajs/ui": "4.0.22-preview-20250909060155",
|
|
55
|
+
"@medusajs/ui-preset": "2.10.2-preview-20250909060155",
|
|
56
56
|
"@mikro-orm/cli": "6.5.2",
|
|
57
57
|
"@mikro-orm/core": "6.5.2",
|
|
58
58
|
"@mikro-orm/knex": "6.5.2",
|
|
@@ -76,12 +76,12 @@
|
|
|
76
76
|
"yalc": "^1.0.0-pre.53"
|
|
77
77
|
},
|
|
78
78
|
"peerDependencies": {
|
|
79
|
-
"@medusajs/admin-sdk": "2.10.2-preview-
|
|
80
|
-
"@medusajs/cli": "2.10.2-preview-
|
|
81
|
-
"@medusajs/framework": "2.10.2-preview-
|
|
82
|
-
"@medusajs/icons": "2.10.2-preview-
|
|
83
|
-
"@medusajs/test-utils": "2.10.2-preview-
|
|
84
|
-
"@medusajs/ui": "4.0.22-preview-
|
|
79
|
+
"@medusajs/admin-sdk": "2.10.2-preview-20250909060155",
|
|
80
|
+
"@medusajs/cli": "2.10.2-preview-20250909060155",
|
|
81
|
+
"@medusajs/framework": "2.10.2-preview-20250909060155",
|
|
82
|
+
"@medusajs/icons": "2.10.2-preview-20250909060155",
|
|
83
|
+
"@medusajs/test-utils": "2.10.2-preview-20250909060155",
|
|
84
|
+
"@medusajs/ui": "4.0.22-preview-20250909060155",
|
|
85
85
|
"@mikro-orm/cli": "6.5.2",
|
|
86
86
|
"@mikro-orm/core": "6.5.2",
|
|
87
87
|
"@mikro-orm/knex": "6.5.2",
|