> snipcart
Add e-commerce to any website with Snipcart. Use when a user asks to add a shopping cart to a static site, sell products from a JAMstack site, add buy buttons to any HTML page, or integrate e-commerce without a backend.
curl "https://skillshub.wtf/TerminalSkills/skills/snipcart?format=md"Snipcart
Overview
Snipcart adds a full shopping cart to any website with just HTML attributes. No backend needed — it works with static sites, JAMstack, and any HTML page. Handles checkout, payments, shipping, taxes, and inventory.
Instructions
Step 1: Add to Any Page
<!-- Add Snipcart scripts to your page -->
<link rel="stylesheet" href="https://cdn.snipcart.com/themes/v3.4.1/default/snipcart.css" />
<script async src="https://cdn.snipcart.com/themes/v3.4.1/default/snipcart.js"></script>
<div hidden id="snipcart" data-api-key="YOUR_PUBLIC_API_KEY"></div>
<!-- Product buy button — just HTML attributes -->
<button class="snipcart-add-item"
data-item-id="tshirt-001"
data-item-name="Premium T-Shirt"
data-item-price="29.99"
data-item-url="/products/tshirt"
data-item-image="/images/tshirt.jpg"
data-item-description="100% organic cotton"
data-item-custom1-name="Size"
data-item-custom1-options="S|M|L|XL">
Add to Cart — $29.99
</button>
<!-- Cart summary button -->
<button class="snipcart-checkout">
Cart (<span class="snipcart-items-count">0</span>)
</button>
Step 2: Astro/Next.js Integration
---
// components/ProductCard.astro — Product card for static site
const { product } = Astro.props
---
<div class="product-card">
<img src={product.image} alt={product.name} />
<h3>{product.name}</h3>
<p class="price">${product.price}</p>
<button class="snipcart-add-item"
data-item-id={product.id}
data-item-name={product.name}
data-item-price={product.price}
data-item-url={`/products/${product.slug}`}
data-item-image={product.image}>
Add to Cart
</button>
</div>
Step 3: JavaScript API
// Customize cart behavior with Snipcart JS API
document.addEventListener('snipcart.ready', () => {
Snipcart.api.cart.items.added((item) => {
console.log('Item added:', item.name)
// Track in analytics
})
Snipcart.api.cart.confirmed((order) => {
console.log('Order confirmed:', order.token)
// Send to CRM, trigger email, etc.
})
})
Guidelines
- Snipcart takes 2% transaction fee + payment processor fees. No monthly fee.
- Products are validated against your HTML — Snipcart crawls the product URL to verify prices.
- Works with any SSG (Astro, Hugo, 11ty, Gatsby) — perfect for JAMstack e-commerce.
- Supports subscriptions, digital products, and multi-currency.
> related_skills --same-repo
> zustand
You are an expert in Zustand, the small, fast, and scalable state management library for React. You help developers manage global state without boilerplate using Zustand's hook-based stores, selectors for performance, middleware (persist, devtools, immer), computed values, and async actions — replacing Redux complexity with a simple, un-opinionated API in under 1KB.
> zod
You are an expert in Zod, the TypeScript-first schema declaration and validation library. You help developers define schemas that validate data at runtime AND infer TypeScript types at compile time — eliminating the need to write types and validators separately. Used for API input validation, form validation, environment variables, config files, and any data boundary.
> xero-accounting
Integrate with the Xero accounting API to sync invoices, expenses, bank transactions, and contacts — and generate financial reports like P&L and balance sheet. Use when: connecting apps to Xero, automating bookkeeping workflows, syncing accounting data, or pulling financial reports programmatically.
> windsurf-rules
Configure Windsurf AI coding assistant with .windsurfrules and workspace rules. Use when: customizing Windsurf for a project, setting AI coding standards, creating team-shared Windsurf configurations, or tuning Cascade AI behavior.