-
-
Notifications
You must be signed in to change notification settings - Fork 731
Product amounts units
Spree provides a rather flexible but clunky interface for defining variants of a product. The admin can define some system-wide option types (eg. Weight) and option values (eg. "1 kg"), apply the option types to a product, and then select values for these for the variants.
This interface is confusing to learn, and slow and difficult to use, which is a problem when we will have many enterprise users adopting the system.
Additionally, the way that Spree manages stock control does not always reflect reality. Take the case where we, selling flour, have a bulk store of 1 ton, and we package it into 1 kg and 10 kg bags as we receive orders. Spree provides stock control at the variant level, but then each variant will have its own stock level instead of taking the stock from one central pool for the product.
As an admin user, I go to the bulk product edit page. For each product, I see two new fields:
- Single resource? (checkbox)
- Units (select field)
"Single resource" controls whether the stock comes from a central pool (when enabled) or if each variant has its own stock level (when disabled). Single resource only appears as an option, and can only be selected when the product has variants. When single resource is selected, only the count on hand for the product is editable. The count on hand for its variants are calculated in real time (based on amount avail in total on hand), but uneditable. When single resource is not selected, only the count on hand for the variants are editable. The count on hand for the product is blank.
"Units" sets the units from the following options:
- Weight: g; kg; t
- Volume: mL; L; ML
- Items: type of items (eg. dozens, bunches, bags, loaves, packets, etc.)
- Size
- Animals: (?)
- [Could we have a Unit option that is 'Custom', which lets the user name it?]
and then I update "On Hand" or select "On Demand".
At this stage the user picks a scale of unit (ie. mL vs L). This is used for entering amounts for all variants. They may need to enter values crossing several scales (ie. .25 L, 1 L, 10 L). On the front end, these will automatically be converted to human-friendly values (ie. 250 mL, 1 L, 10 L).
The user can click an Add Variants link on a product row, which adds a row for the variant. Each variant then has an additional field:
- Value (float - shared resource or weight/volume units; text - if not shared resource or items resource)
"Value" then describes or quantifies the variant. If the product is a "shared resource" or if the product's unit is in weight or volume, then this field is a float field, enabling it to be used for calculations. In this case it can be fractional (eg. 0.5 dozen). If the product is NOT a "shared resource" and the product's unit is not weight or volume, value is a text field enabling a high level of user flexibility. For example, with the unit "Size" selected, the user can enter values such as "Small", "Medium" and "Large".
"On Hand" sets the amount available for this variant if not a shared resource (ie. 5 kg). If it is a shared resource, this field can only be set at the product level.
When the admin sets these fields for a variant and clicks Save, the option type and value for that unit/value is looked up (or created if absent) and assigned to the variant.
If the admin wishes to add additional option types to a product, they can do so using the traditional Spree interface. [Full product editing to be refined later]
The interface described above for setting variant units and values will also be available from the non-bulk product edit screen.
If a product is a shared resource, the user can only set its MSQ at the product level. Otherwise, each variant can have a MSQ.
- This might be a lot of work, since the existing products don't conform to this system.
- This amount of work will only grow as we get more products on the system.
I'm not sure how relevant this old document is, but here's a visual of how the fields are currently used and displayed in the admin interface:
And a diagram of the relationship between fields:
Note:
- These diagrams are missing
spree_products.variant_unit_name
, which appears when you choose "Items". It is different tounit_description
. - Product unit fields are scheduled to be moved to the variant (https://github.com/openfoodfoundation/openfoodnetwork/issues/9069)
Development environment setup
- Pipeline development process
- Bug severity
- Feature template (epic)
- Internationalisation (i18n)
- Dependency updates
Development
- Developer Guidelines
- The process of review, test, merge and deploy
- Making a great commit
- Making a great pull request
- Code Conventions
- Database migrations
- Testing and Rspec Tips
- Automated Testing Gotchas
- Rubocop
- Angular and OFN
- Feature toggles
- Stimulus and Turbo
Testing
- Testing process
- OFN Testing Documentation (Handbooks)
- Continuous Integration
- Parallelized test suite with knapsack
- Karma
Releasing
Specific features
Data and APIs
Instance-specific configuration
External services
Design