schon/storefront/composables/orders/useOrders.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

79 lines
No EOL
1.7 KiB
TypeScript

import {GET_ORDERS} from "~/graphql/queries/standalone/orders";
import type {IOrdersResponse} from "~/types";
import {orderStatuses} from "~/config/constants";
interface IOrdersArguments {
userEmail: string,
status?: string,
after?: string,
search: string
}
interface IOrderVars {
status: string,
userEmail: string,
first: number,
after?: string,
search: string
}
export async function useOrders(args: IOrdersArguments) {
const cartStore = useCartStore();
const variables = reactive<IOrderVars>({
status: args.status || '',
userEmail: args.userEmail,
first: 10,
after: args.after,
search: args.search
});
const { pending, data, error, refresh } = await useAsyncQuery<IOrdersResponse>(
GET_ORDERS,
variables
);
const orders = ref(data.value?.orders.edges.filter((order) => order.node.status !== orderStatuses.PENDING) ?? []);
const pageInfo = computed(() => data.value?.orders.pageInfo ?? null);
if (!error.value && data.value?.orders.edges) {
if (args.status === orderStatuses.PENDING) {
cartStore.setCurrentOrders(data.value?.orders.edges[0].node);
}
}
watch(
() => variables.after,
async (newCursor, oldCursor) => {
if (!newCursor || newCursor === oldCursor) return;
await refresh();
const newEdges = data.value?.orders.edges ?? [];
orders.value.push(...newEdges);
}
);
watch(
[
() => variables.status,
() => variables.search
],
async () => {
variables.after = '';
await refresh();
orders.value = data.value?.orders.edges ?? [];
}
);
watch(error, (err) => {
if (err) {
console.error('useOrders error:', err);
}
});
return {
pending,
orders,
pageInfo,
variables
};
}