mirror of
https://github.com/vercel/commerce.git
synced 2025-05-19 07:56:59 +00:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
import Cookies from 'js-cookie'
|
|
import { decode } from 'jsonwebtoken'
|
|
import { SWRHook } from '@commerce/utils/types'
|
|
import useCustomer, { UseCustomer } from '@commerce/customer/use-customer'
|
|
import { CUSTOMER_COOKIE, API_URL } from '../constants'
|
|
import type { CustomerHook } from '../types/customer'
|
|
|
|
export default useCustomer as UseCustomer<typeof handler>
|
|
export const handler: SWRHook<CustomerHook> = {
|
|
fetchOptions: {
|
|
query: 'customer',
|
|
method: '_request',
|
|
},
|
|
async fetcher({ options, fetch }) {
|
|
const token = Cookies.get(CUSTOMER_COOKIE)
|
|
if (!token) {
|
|
return null
|
|
}
|
|
|
|
const decodedToken = decode(token) as { cid: string }
|
|
const customer = await fetch({
|
|
query: options.query,
|
|
method: options.method,
|
|
variables: [
|
|
`${API_URL}/customers/${decodedToken.cid}`,
|
|
'get',
|
|
null,
|
|
{},
|
|
token,
|
|
],
|
|
})
|
|
return customer
|
|
},
|
|
useHook:
|
|
({ useData }) =>
|
|
(input) => {
|
|
return useData({
|
|
swrOptions: {
|
|
revalidateOnFocus: false,
|
|
...input?.swrOptions,
|
|
},
|
|
})
|
|
},
|
|
}
|