Product Units in ShuupΒΆ

Commonly web shops sell products which are prepackaged units and their quantities are measured in pieces. However it is sometimes needed to be able to sell products in non-integral quantities, like kilograms or ounces. In Shuup, this can be handled with sales units and display units.

Each product in Shuup has a sales unit which determines how quantities of the product are represented and if non-integral quantities are allowed. However it is possible that the sales unit has an attached display unit which overrides the representation part. This allows, for example, the internal quantities to be stored in kilograms but be displayed as grams to the customer.

Product.sales_unit
Sales unit of a Product. Usually a SalesUnit object, but can also be None. This is the internal unit which is used to store the quantities, like quantities in the order lines or stock amounts. Quantities shown to the customer should not use the sales unit, but rather a display unit, see ShopProduct.display_unit and or SalesUnit.display_unit.
SalesUnit.name
Name of SalesUnit. Usually shown only in Admin when managing units or when selecting sales unit for a product.
SalesUnit.symbol
Symbol used when rendering values of the sales unit.
SalesUnit.decimals
Number of decimals to use for values in this unit.
SalesUnit.display_unit
The default display unit of the sales unit. This property returns a DisplayUnit object, which has the sales unit as its internal unit and is marked as a default, or if there is no default display unit for the sales unit, then this will return a proxy object. The proxy object has the same display unit interface and mirrors the properties of the sales unit, such as symbol and decimals.
ShopProduct.display_unit
Display unit of a shop product, a DisplayUnit object or None.
ShopProduct.unit
The unit of the shop product as UnitInterface.
ShopProduct.display_quantity_step
Quantity step of the shop product in the display unit.
ShopProduct..display_quantity_minimum
Quantity minimum of the shop product in the display unit.
DisplayUnit.name
Name of the display unit.
DisplayUnit.symbol
Symbol of the display unit, used when rendering quantity values in the display unit.
DisplayUnit.internal_unit
The SalesUnit object which acts as the internal unit for the display unit.
DisplayUnit.ratio
Ratio between the display unit and its internal unit. E.g. if internal unit is a kilogram and display unit is gram, then this should be 0.001.
DisplayUnit.decimals
Number of decimals to use when representing quantity values in the display unit.
DisplayUnit.comparison_value
Value to use for comparison purposes. E.g. if the display unit is a gram with symbol “g” and this is 100, then the unit prices should be rendered as “$5.95 per 100g”.
DisplayUnit.allow_bare_number
If this boolean is true, then values of this unit can be shown without the symbol occasionally. Usually wanted if the unit is a Piece, i.e. showing just “$5,95” in product listings rather than “$5,95 per pc.”.
DisplayUnit.default
Use this display unit as the default display unit for its internal unit. If there is several default display units for an internal unit, then its undetermined which will be used.
UnitInterface
Interface for unit related information and functionality. Bound to a single display unit and its internal unit. Can be used for rendering and converting product quantities in the display unit or in the internal unit. Or for accessing data of either unit. See the API documentation of the UnitInterface for details.