schon/storefront/composables/user/useUserBaseData.ts
Alexandr SaVBaD Waltz 52b32bd608 Features: 1) Introduce useUserBaseData composable to fetch and manage user's wishlist, orders, and promocodes; 2) Add reusable useOrders and useOrderOverwrite composables with advanced filtering and pagination; 3) Implement order.vue component for detailed order displays with UI enhancements;
Fixes: 1) Replace deprecated context usage in `useAvatarUpload` mutation; 2) Resolve incorrect locale parsing in `useDate` utility and fix non-reactive cart state in `profile/cart.vue`; 3) Update stale imports and standardize type naming across composables;

Extra: 1) Refactor i18n strings including order status and search-related texts; 2) Replace temporary workarounds with `apollo-upload-client` configuration and add `apollo-upload-link.ts` plugin; 3) Cleanup redundant files, comments, and improve SCSS structure with new variables and placeholders.
2025-07-11 18:39:13 +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 promocodesStore = usePromocodeStore();
const { document, variables } = getUserBaseData(
{
userEmail,
status: orderStatuses.PENDING
},
);
const { data, error } = await useAsyncQuery<IUserBaseDataResponse>(
document,
variables
);
if (data.value?.wishlists.edges) {
wishlistStore.setWishlist(data.value.wishlists.edges[0].node);
}
if (data.value?.orders.edges) {
cartStore.setCurrentOrders(data.value?.orders.edges[0].node);
}
if (data.value?.promocodes.edges) {
promocodesStore.setPromocodes(data.value.promocodes.edges);
}
watch(error, (err) => {
if (err) {
console.error('useUserBaseData error:', err);
}
});
return {
};
}