schon/storefront/composables/user/useUserBaseData.ts
Alexandr SaVBaD Waltz 40ae24a04c Features: 1) Add SEO-related fragments to GraphQL queries including SEOMETA_FRAGMENT usage in brands, categories, and products queries; 2) Enable localized and dynamic SEO metadata handling in category pages with Vue composables and useSeoMeta; 3) Replace obsolete client-only wrapper with native Nuxt components like nuxt-marquee for enhanced rendering;
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.
2025-09-13 12:53:06 +03:00

41 lines
No EOL
1 KiB
TypeScript

import type {IUserBaseDataResponse} from "~/types";
import {getUserBaseData} from "~/graphql/queries/combined/userBaseData";
import {orderStatuses} from "~/config/constants";
export async function useUserBaseData(userEmail: string) {
const wishlistStore = useWishlistStore();
const cartStore = useCartStore();
const promocodeStore = usePromocodeStore();
const { document, variables } = getUserBaseData(
{
userEmail,
status: orderStatuses.PENDING
},
);
const { mutate, error } = useMutation<IUserBaseDataResponse>(document);
const result = await mutate(variables);
const data = result?.data;
if (data?.wishlists.edges) {
wishlistStore.setWishlist(data.wishlists.edges[0].node);
}
if (data?.orders.edges) {
cartStore.setCurrentOrders(data.orders.edges[0].node);
}
if (data?.promocodes.edges) {
promocodeStore.setPromocodes(data.promocodes.edges);
}
watch(error, (err) => {
if (err) {
console.error('useUserBaseData error:', err);
}
});
return {
};
}