This is a shopping cart implementation for SvelteKit applications at Deckweiss.
pnpm i @deckweiss/cart
// src/hooks.server.ts
import { handle } from '@deckweiss/cart'
export { handle }
// +layout.server.ts
export const load: LayoutServerLoad = function (event) {
return { cart: event.locals.cart.cart };
};
// +layout.svelte
<script lang="ts">
import { setCartContext } from '@deckweiss/cart';
let { data, children } = $props();
setCartContext(data.cart);
</script>
{@render children()}
<script lang="ts">
import { useCart } from '@deckweiss/cart'
let cart = useCart()
</script>
<button on:click={() => cart.addProduct('id1', 1)}>Add product 1</button>
<button on:click={() => cart.addProduct('id2', 1)}>Add product 2</button>
<button on:click={() => cart.clear()}>Clear cart</button>
{#each cart.cart.products as product}
<div>
<h3>{product.id}</h3>
<p>Amount: {product.amount}</p>
<button on:click={() => cart.removeProduct(product.id)}>Remove product</button>
</div>
{:else}
<p>Cart is empty</p>
{/each}
The types CartMetaData
and CartProductMetaData
support to be extended/augmented via TypeScript. This means, your editor will recognize the custom types and give you intellisense.
// src/app.d.ts
declare module '@deckweiss/cart' {
interface CartMetaData {
userId?: string
note?: string
discountCode?: string
}
interface CartProductMetaData {
type?: 'food' | 'tool' | 'book'
}
}