feat(medusa, medusa-js, medusa-react): Implement Sales Channel creation (#1795)

This commit is contained in:
Frane Polić
2022-07-06 22:18:05 +02:00
committed by GitHub
parent 428a801293
commit 0d1624cf6a
14 changed files with 274 additions and 60 deletions

View File

@@ -1,16 +1,41 @@
import { useMutation, UseMutationOptions, useQueryClient } from "react-query"
import {
AdminPostSalesChannelsReq,
AdminSalesChannelsRes,
AdminPostSalesChannelsSalesChannelReq,
} from "@medusajs/medusa"
import { Response } from "@medusajs/medusa-js"
import { useMutation, UseMutationOptions, useQueryClient } from "react-query"
import { useMedusa } from "../../../contexts"
import { buildOptions } from "../../utils/buildOptions"
import { adminSalesChannelsKeys } from "./queries"
/**
* Hook provides a mutation function for creating sales channel.
*
* @experimental This feature is under development and may change in the future.
* To use this feature please enable the corresponding feature flag in your medusa backend project.
*/
export const useAdminCreateSalesChannel = (
options?: UseMutationOptions<
Response<AdminSalesChannelsRes>,
Error,
AdminPostSalesChannelsReq
>
) => {
const { client } = useMedusa()
const queryClient = useQueryClient()
return useMutation(
(payload: AdminPostSalesChannelsReq) =>
client.admin.salesChannels.create(payload),
buildOptions(queryClient, [adminSalesChannelsKeys.list()], options)
)
}
/** update a sales channel
* @experimental This feature is under development and may change in the future.
* To use this feature please enable featureflag `sales_channels` in your medusa backend project.
* To use this feature please enable feature flag `sales_channels` in your medusa backend project.
* @description updates a sales channel
* @returns the updated medusa sales channel
*/
@@ -34,35 +59,3 @@ export const useAdminUpdateSalesChannel = (
)
)
}
/*export const useAdminCreateSalesChannel = (
options?: UseMutationOptions<
Response<AdminSalesChannelsRes>,
Error,
AdminPostSalesChannelsReq
>
) => {
const { client } = useMedusa()
const queryClient = useQueryClient()
return useMutation(
(payload: AdminPostSalesChannelsReq) => client.admin.salesChannels.create(payload),
buildOptions(queryClient, adminSalesChannelsKeys.lists(), options)
)
}*/
/*export const useAdminDeleteSalesChannel = (
id: string,
options?: UseMutationOptions<Response<AdminSalesChannelsDeleteRes>, Error, void>
) => {
const { client } = useMedusa()
const queryClient = useQueryClient()
return useMutation(
() => client.admin.salesChannels.delete(id),
buildOptions(
queryClient,
[adminSalesChannelsKeys.lists(), adminSalesChannelsKeys.detail(id)],
options
)
)
}*/

View File

@@ -15,7 +15,7 @@ type SalesChannelsQueryKeys = typeof adminSalesChannelsKeys
/** retrieve a sales channel
* @experimental This feature is under development and may change in the future.
* To use this feature please enable featureflag `sales_channels` in your medusa backend project.
* To use this feature please enable feature flag `sales_channels` in your medusa backend project.
* @description gets a sales channel
* @returns a medusa sales channel
*/