See it action: Vue Storefront - Spree demo
This repository contains an Spree integration for Vue Storefront 2.
This integration is being developed and maintained by Upside
- Node 14.15+
- Spree-based store with V2 API available. Some API endpoints used by the integration are only available in Spree 4.2+, so you may need to either upgrade the store or backport these features to your backend.
- Clone this repository
git clone /~https://github.com/vendo-dev/vuestorefront.git
- Install all required dependencies:
yarn install
- Set backend URL via env variable
export BACKEND_URL=https://demo.spreecommerce.org
- (optional) Then you can verify if everything works properly by building all three projects:
yarn build
- If everything built properly, you can start working on your new frontend with:
yarn dev
Some features that are either provided by Spree's extensions or that are only available in newer versions, need to be manually enabled in the configuration file. To do that, open the packages/theme/middleware.config.js
and update the configuration to desired state
module.exports = {
integrations: {
spree: {
location: '@vue-storefront/spree-api/server',
configuration: {
backendUrl: process.env.BACKEND_URL,
spreeFeatures: {
// Associate guest cart after the customer logs in. Requires Spree 4.3+
associateGuestCart: false,
// Fetch basic information about products from the `primary_variant` relationship. Requires Spree 4.3+
fetchPrimaryVariant: false
}
}
}
}
};
The monorepo contains three submodules:
- api-client - low level backend API connector, utilizing Spree's v2 Storefront API
- composables - reusable business logic
- theme - Nuxt.js-based frontend application
For more details, refer to the official architecture diagram.
Feature | Status | Notes |
---|---|---|
Sign in | Available | |
Sign up | Available | |
Product catalog | Available | Default implementation uses /v2/storefront/products endpoint for filtering, it's advisable to use ElasticSearch for best performance |
Account | Partial | Requires Spree 4.2 |
Account - saved addresses | Available | Requires Spree 4.2 |
Account - reset password | Available | URL from password reset emails should point to: /resetPassword?token=... |
Account - order history | Available | |
Cart | Available | Fully functional. Associating guest orders upon login requires Spree 4.3 and needs to be enable via configuration |
Checkout | Available | |
Checkout - Shipping methods | Available | |
Checkout - Payment methods | Partial | Only "Cash" supported out of the box. Additional changes need to be made in backend to support OOB support for providers like Stripe. This will be available in the next version of Spree's API. |
Wishlists | Coming soon | This will be integrated with the API provided by the latest version of spree_wishlist |
Multi-currency support | Partial |
V2 API endpoints include built-in cache.
In Spree < 4.3, API endpoints aren't cached out of the box. To ensure smooth operation of the frontend, you need to add caching to GET actions of the API. Putting e.g. AWS Cloudfront in front of the API is a fairly simple option and can do wonders in that regard. If your application uses custom logic (e.g. different price for each user), remember to make sure that your cache keys reflect that.
- Vue Storefront - Spree demo - demo instance connected to https://demo.spreecommerce.org APIs