4
0
forked from crowetic/commerce
commerce/components/cart/actions.ts

70 lines
1.4 KiB
TypeScript
Raw Normal View History

'use server';
2023-07-24 21:40:29 -05:00
import { addToCart, createCart, getCart, removeFromCart, updateCart } from 'lib/shopify';
import { cookies } from 'next/headers';
2023-08-04 22:21:57 -05:00
export const addItem = async (variantId: string | undefined): Promise<String | undefined> => {
2023-07-24 21:40:29 -05:00
let cartId = cookies().get('cartId')?.value;
let cart;
if (cartId) {
cart = await getCart(cartId);
}
if (!cartId || !cart) {
cart = await createCart();
cartId = cart.id;
cookies().set('cartId', cartId);
}
2023-07-24 21:40:29 -05:00
if (!variantId) {
2023-08-04 22:21:57 -05:00
return 'Missing product variant ID';
}
2023-08-04 22:21:57 -05:00
try {
await addToCart(cartId, [{ merchandiseId: variantId, quantity: 1 }]);
} catch (e) {
2023-08-04 22:21:57 -05:00
return 'Error adding item to cart';
}
};
2023-08-04 22:21:57 -05:00
export const removeItem = async (lineId: string): Promise<String | undefined> => {
const cartId = cookies().get('cartId')?.value;
if (!cartId) {
2023-08-04 22:21:57 -05:00
return 'Missing cart ID';
}
try {
await removeFromCart(cartId, [lineId]);
} catch (e) {
2023-08-04 22:21:57 -05:00
return 'Error removing item from cart';
}
};
export const updateItemQuantity = async ({
lineId,
variantId,
quantity
}: {
lineId: string;
variantId: string;
quantity: number;
2023-08-04 22:21:57 -05:00
}): Promise<String | undefined> => {
const cartId = cookies().get('cartId')?.value;
if (!cartId) {
2023-08-04 22:21:57 -05:00
return 'Missing cart ID';
}
try {
await updateCart(cartId, [
{
id: lineId,
merchandiseId: variantId,
quantity
}
]);
} catch (e) {
2023-08-04 22:21:57 -05:00
return 'Error updating item quantity';
}
};