@shopify/shop-minis-react
Version:
React component library for Shopify Shop Minis with Tailwind CSS v4 support (source-only, requires TypeScript)
41 lines (35 loc) • 970 B
text/typescript
import {useShopActionInfiniteQuery} from '../../internal/reactQuery'
import {useShopActions} from '../../internal/useShopActions'
import {
PaginatedDataHookOptionsBase,
PaginatedDataHookReturnsBase,
ProductVariant,
} from '../../types'
export interface UseProductVariantsParams extends PaginatedDataHookOptionsBase {
/**
* The product ID to fetch variants for.
*/
id: string
}
interface UseProductVariantsReturns extends PaginatedDataHookReturnsBase {
/**
* The product variants returned from the query.
*/
variants: ProductVariant[] | null
}
export const useProductVariants = (
params: UseProductVariantsParams
): UseProductVariantsReturns => {
const {getProductVariants} = useShopActions()
const {skip = false, ...restParams} = params
const {data, ...rest} = useShopActionInfiniteQuery(
['productVariants', restParams],
getProductVariants,
restParams,
{skip}
)
return {
...rest,
variants: data,
}
}