schon/storefront/composables/store/useStore.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

72 lines
No EOL
1.6 KiB
TypeScript

import { GET_PRODUCTS } from '~/graphql/queries/standalone/products';
import type {IProductResponse} from '~/types';
interface IProdVars {
first: number,
categoriesSlugs: string,
attributes?: string,
orderBy?: string,
minPrice?: number,
maxPrice?: number,
productAfter?: string
}
export async function useStore(
slug: string,
attributes?: string,
orderBy?: string,
minPrice?: number,
maxPrice?: number,
productAfter?: string
) {
const variables = reactive<IProdVars>({
first: 15,
categoriesSlugs: slug,
attributes,
orderBy,
minPrice,
maxPrice,
productAfter
});
const { pending, data, error, refresh } = await useAsyncQuery<IProductResponse>(
GET_PRODUCTS,
variables
);
const products = ref(data.value?.products.edges ?? []);
const pageInfo = computed(() => data.value?.products.pageInfo ?? null);
watch(error, e => e && console.error('useStore products error', e));
watch(
() => variables.productAfter,
async (newCursor, oldCursor) => {
if (!newCursor || newCursor === oldCursor) return;
await refresh();
const newEdges = data.value?.products.edges ?? [];
products.value.push(...newEdges);
}
);
watch(
[
() => variables.attributes,
() => variables.orderBy,
() => variables.minPrice,
() => variables.maxPrice
],
async () => {
variables.productAfter = '';
await refresh();
products.value = data.value?.products.edges ?? [];
}
);
return {
pending,
products,
pageInfo,
variables
};
}