// imports import { useQuery } from "@tanstack/vue-query"; import { API_ENDPOINTS, QUERY_KEYS } from "~/constants"; // types export type GetAllTicketsResponse = ApiPaginated>; export type GetAllTicketsRequest = { sort: string | undefined; status: string | undefined; page: string | string[]; }; const useGetAllTickets = (params: ComputedRef) => { // state const { $axios: axios } = useNuxtApp(); // methods const handleGetAllTickets = async (params: GetAllTicketsRequest) => { const { data } = await axios.get(API_ENDPOINTS.tickets.get_all, { params: { sort: params.sort, filter: params.status, offset: Number(params.page) * 7 - 7, limit: 7, }, }); return data; }; return useQuery({ queryKey: [QUERY_KEYS.tickets, params], queryFn: () => handleGetAllTickets(params.value), }); }; export default useGetAllTickets;