Fixes: 1) Correct file path imports by removing `.js` extensions in GraphQL fragments; 2) Resolve typo in `usePromocodeStore` composables to ensure consistent store usage; 3) Add missing `:type="submit"` to login form button for proper form submission handling; Extra: 1) Remove unused `.idea` and `README.md` files for repository cleanup; 2) Delete extraneous dependencies from `package-lock.json` for streamlined package management; 3) Refactor category slug handling with improved composable logic for cleaner route parameters and SEO alignment.
38 lines
No EOL
764 B
TypeScript
38 lines
No EOL
764 B
TypeScript
import type {IPostResponse} from '~/types';
|
|
import {GET_POST_BY_SLUG} from "~/graphql/queries/standalone/blog";
|
|
|
|
export async function usePostBySlug(slug: string) {
|
|
const { locale } = useI18n();
|
|
|
|
const variables = reactive({
|
|
slug: slug,
|
|
first: 1
|
|
});
|
|
|
|
const { data, error, refresh } = await useAsyncQuery<IPostResponse>(
|
|
GET_POST_BY_SLUG,
|
|
variables
|
|
);
|
|
|
|
const post = computed(() => data.value?.posts.edges[0]?.node ?? null);
|
|
|
|
watch(locale, async () => {
|
|
if (variables.first >= 100) {
|
|
variables.first = 0;
|
|
} else {
|
|
variables.first += 1;
|
|
}
|
|
await refresh();
|
|
});
|
|
|
|
watch(error, (err) => {
|
|
if (err) {
|
|
console.error('usePostBySlug error:', err)
|
|
}
|
|
});
|
|
|
|
return {
|
|
post,
|
|
refresh
|
|
};
|
|
} |