34 lines
810 B
TypeScript
34 lines
810 B
TypeScript
// imports
|
|
|
|
import { useQuery } from "@tanstack/vue-query";
|
|
import { useAppParams } from "~/composables/global/useAppParams";
|
|
import { API_ENDPOINTS, QUERY_KEYS } from "~/constants";
|
|
|
|
// types
|
|
|
|
export type GetTransactionResponse = Transaction;
|
|
|
|
const useGetTransaction = () => {
|
|
// state
|
|
|
|
const { $axios: axios } = useNuxtApp();
|
|
|
|
const { tracking_code } = useAppParams();
|
|
|
|
// methods
|
|
|
|
const handleGetTransaction = async () => {
|
|
const { data } = await axios.get<GetTransactionResponse>(
|
|
`${API_ENDPOINTS.orders.checkout.transaction}/${tracking_code.value}`
|
|
);
|
|
return data;
|
|
};
|
|
|
|
return useQuery({
|
|
queryKey: [QUERY_KEYS.transaction, tracking_code],
|
|
queryFn: () => handleGetTransaction(),
|
|
});
|
|
};
|
|
|
|
export default useGetTransaction;
|