Claude-code-plugins shopify-storefront-headless
git clone https://github.com/jeremylongshore/claude-code-plugins-plus-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/jeremylongshore/claude-code-plugins-plus-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/saas-packs/shopify-pack/skills/shopify-storefront-headless" ~/.claude/skills/jeremylongshore-claude-code-plugins-shopify-storefront-headless && rm -rf "$T"
plugins/saas-packs/shopify-pack/skills/shopify-storefront-headless/SKILL.mdShopify Storefront & Headless Commerce
Overview
The Storefront API is Shopify's public-facing GraphQL API for customer experiences. Unlike the Admin API (server-side, privileged), it uses a public access token safe for client-side code. Paired with the Cart API, it powers headless storefronts, mobile apps, and custom buying experiences.
Prerequisites
- Shopify store with a Storefront API access token (Headless channel or custom app)
- For Hydrogen: Node.js 18+ and Shopify CLI 3.x+
- Storefront API scopes:
,unauthenticated_read_productsunauthenticated_read_collections
Instructions
Step 1: Storefront API Client Setup
import { createStorefrontApiClient } from "@shopify/storefront-api-client"; const client = createStorefrontApiClient({ storeDomain: "my-store.myshopify.com", apiVersion: LATEST_API_VERSION, publicAccessToken: "your-storefront-public-token", // Safe in browser });
Step 2: Cart Operations
const { data } = await client.request(CART_CREATE, { variables: { input: { lines: [{ merchandiseId: "gid://shopify/ProductVariant/123", quantity: 2 }], buyerIdentity: { email: "customer@example.com", countryCode: "US" }, }, }, }); // Redirect to data.cartCreate.cart.checkoutUrl to complete purchase
Full cart mutations (
cartLinesAdd, cartLinesUpdate, cartLinesRemove, cartDiscountCodesUpdate) in cart-api.md.
Step 3: Query Products (Storefront Schema)
// Storefront API schema differs from Admin API — field names are NOT the same const { data } = await client.request(` query { products(first: 10) { edges { node { id title handle availableForSale priceRange { minVariantPrice { amount currencyCode } } variants(first: 5) { edges { node { id title availableForSale price { amount currencyCode } // MoneyV2 object, not a string selectedOptions { name value } }}} }}}} `);
Step 4: Storefront vs Admin API Decision Guide
| Concern | Storefront API | Admin API |
|---|---|---|
| Token type | Public (safe in browser) | Private (server-only) |
| Rate limiting | Request-based | Query cost-based (1000 pts/sec) |
| Cart/Checkout | Full cart + checkout URL | No cart operations |
| Product data | Customer-facing fields only | Full data + inventory |
| Mutations | Cart, customer, checkout | Full CRUD on all resources |
Detailed comparison in storefront-vs-admin.md. Hydrogen framework setup in hydrogen-patterns.md.
Output
- Storefront API client configured with public access token
- Cart created with line items and checkout URL
- Product catalog queryable from client-side code
- Clear separation of Storefront (public) vs Admin (privileged) API usage
Error Handling
| Error | Cause | Solution |
|---|---|---|
| Token missing, expired, or wrong store | Regenerate in Shopify admin under Headless channel |
| Exceeded request rate limit | Retry with backoff; cache product data |
| Product not published to Headless channel | Publish product to the Headless sales channel |
| Cart ID expired (10-day inactivity) | Create a new cart; don't persist IDs long-term |
Examples
Building a Custom Cart Experience
Create a cart, add line items, apply discount codes, and redirect to Shopify's hosted checkout using the Storefront Cart API.
See Cart API for the complete cart lifecycle mutations and response shapes.
Scaffolding a Hydrogen Storefront
Set up a new Hydrogen project with Remix loaders, Storefront client configuration, and server-side product queries.
See Hydrogen Patterns for the framework setup and loader patterns.
Choosing Between Storefront and Admin APIs
Decide which API to use based on token type, rate limiting model, available mutations, and data access scope.
See Storefront vs Admin for the detailed comparison.