Files
hossein-por-shop/frontend/composables/api/blog/useGetArticle.ts
T
marzban-dev 2106f3f40b Updated
2025-03-22 23:43:49 +03:30

39 lines
947 B
TypeScript

// imports
import { useQuery } from "@tanstack/vue-query";
import { API_ENDPOINTS, QUERY_KEYS } from "~/constants";
import sanitizeHtml from 'sanitize-html';
// types
export type GetArticleResponse = Article;
const useGetArticle = (id: number | string | undefined) => {
// state
const { $axios: axios } = useNuxtApp();
// methods
const handleGetArticle = async () => {
const { data } = await axios.get<GetArticleResponse>(`${API_ENDPOINTS.blog.article}/${id}`);
return data;
};
return useQuery({
queryKey: [QUERY_KEYS.article, id],
queryFn: () => handleGetArticle(),
select: (article) => {
const copyOfArticle = { ...article };
copyOfArticle.summery = sanitizeHtml(copyOfArticle.summery);
copyOfArticle.content = sanitizeHtml(copyOfArticle.content);
return copyOfArticle;
}
});
};
export default useGetArticle;