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 aSalesUnit
object, but can also beNone
. 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 orNone
. 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.