# Install this plugin
npm install @pinelab/vendure-plugin-limited-products
Vendure Limited Products Plugin
This plugin allows you to:
- Limit the amount of a specific product per order. I.E. A customer is only allowed to buy 1 of product "Limited art t-shirt X" per order.
- Only allow a product to be purchased in multiples of X. E.g. only per 4 items.
Getting started
- Add the following config to your
vendure-config.ts
:
import { LimitedProductsPlugin } from "@pinelab/vendure-plugin-limited-products"
plugins: [
LimitedProductsPlugin,
AdminUiPlugin.init({
port: 3002,
route: 'admin',
app: compileUiExtensions({
outputPath: path.join(__dirname, '__admin-ui'),
extensions: [
// Include the admin UI extensions of this plugin
LimitedProductsPlugin.uiExtensions
],
}),
];
- Run a database migration to add the custom fields.
- Start Vendure, login and go to the product you want to limit.
- Set the custom field
Maximum amount per order
andMultiple of per order
on a variant and update the product - Customers can now only buy X amount of the variant per order. The same customer can still order the product again in a new order.
You can fetch product.limitPurchasePerMultipleOf
and product.maxQuantityPerOrder
via the Shop API to display messages on your storefront accordingly.
Migrating to V3.x
V3 removes the fields from the variant and places them on a Product, in a different format. This plugin isn't used much, so there is no migration script available. We do it manually:
- Back up all values of the variants before installing the plugin.
- Install V4 of this plugin, and run a database migration.
- Start the server and set the values on the parent products via the Admin UI