A modern template designed for online stores with a mobile-friendly interface, customizable theme, and an integrated payments using Stripe.
Paginated list of products with featured picture, name, price, and available discount. Products can be sorted by multiple parameters, or filtered by categories.
Product gallery with detailed description and ability to configure and select variations. Product can be added to the cart, or purchased with 1 click.
Slideover cart with overview of products, price summary, and ability to modify quantity of products in cart. Checkout button to continue to payment step.
Stripe-managed page with all payment and delivery views. The receipt is sent by email automatically after a successful payment.
BlurHash technology (commonly known from Wolt app) optimizes application experience and looks while images are still loading. A very useful improvement for use on mobile devices with limited internet access and speed.
Theme toggle in footer allows visitors to switch to dark theme when browsing during night. Developer can easily enforce a theme, set default theme, or remove the feature all-together.
Near-perfect Lighthouse score to ensure great accessability for people with disabilities, and SEO optimizations to ensure search engines can scan the website with ease.
- Site settings: src/routes/store.ts
- Products list: src/utils/products.ts
- Products pictures: static/images/products
- Site footer: src/lib/components/footer/Footer.svelte
- Logo: static/logo.svg and static/favicon.ico
- OG image (preview thumbnail): static/thumbnail.png
We use Svelte and SvelteKit as a web framework with TypeScript codebase.
CSS framework TailwindCSS and UI library shadcn-svelte are used for all styling needs.
Financial and payments infrastructure Stripe to collect (not only) card payments, generate invoices, send receipt, calculate VAT, make reports, and much more.
All of backend needs such as saving the cart contents, or validating cart before payment is covered by Appwrite.
- Product description supports Markdown syntax
- Convert product images to
.webp
or.avif
formats for best loading speed of your site - Never use images with resolution greater than 1080p
- Before production use, connect to analytics tool such as Plausible or Google Analytics
- Install dependencies with
npm install
(orpnpm install
oryarn
) - Start a development server with
npm run dev
(orpnpm dev
oryarn dev
) - Visit localhost:5173
When used with Appwrite, all changes to main
branch are automatically deployed to production.
Otherwise, use npm run build
(or pnpm build
or yarn build
), and deploy as Node.js server with entrypoint ./build/index.js
.