You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

44 lines
1.1 KiB

/**
* GET /api/cart
*
* Get the current user's shopping cart with all items
*
* Features:
* - Returns cart for authenticated users (by userId)
* - Returns cart for guest users (by sessionId)
* - Automatically removes unavailable products (inactive or out of stock)
* - Calculates totals and subtotals
* - Returns list of removed items if any were auto-cleaned
*
* Response:
* {
* cart: { id, userId, sessionId, createdAt, updatedAt },
* items: [{ id, product, quantity, subtotal, addedAt }],
* total: number,
* itemCount: number,
* removedItems?: string[] // Names of removed products
* }
*/
export default defineEventHandler(async (event) => {
try {
// Get or create cart for current user/session
const cart = await getOrCreateCart(event)
// Get cart with items (auto-cleans unavailable products)
const cartSummary = await getCartWithItems(cart.id)
return cartSummary
} catch (error) {
// Log error for debugging
console.error('Error fetching cart:', error)
// Return empty cart on error
return {
cart: null,
items: [],
total: 0,
itemCount: 0,
}
}
})