Using Product Options
Product options provide a convenient and flexible way to customize products. Using options, you can add selectable or editable fields to products sold in your site. Your customers can then choose from product variants, bundles, and more.
To start using options, create and configure an option template. Then, depending on your template’s configuration, add values to it. Once created, you can apply the template to a product and configure its settings and values at a product level, without affecting the global template.
Creating an Option Template
-
Open the Global Menu () and navigate to Commerce → Options.
-
Click Add ().
-
Enter a name in the Name field and select an Option Field Type. There are several field types available.
Field Type Descrtipion Example Select From List Adds a drop-down list of text values for the customer to choose from Choose different variants of a product (a smartphone with different RAM + storage configurations) Text Adds a blank field for customers to enter text Add a custom message to a product (t-shirt, mugs, etc.) Single Selection Adds a radio button list for the Option’s values Choose a complimentary gift from several options Multiple Selection Adds a checkbox list for the Option’s values, allowing customers to select multiple values Add a screen guard and case to a smartphone Date Adds a field for customers to enter a date Choose a date for product delivery Numeric Adds a blank field for customers to enter an integer Add a custom number to a product (t-shirt, mugs, etc.) Boolean Adds a Boolean checkbox for the Option Choose from a yes/no option, for instance, adding insurance to a product. Liferay DXP 2024.Q2+/Portal 7.4 GA120+ Select Date from List Adds a drop-down list of dates for the customer to choose from Choose from different time slots available for the product, for instance, a concert, live class, etc. The Key field is generated automatically to match the name, but you can manually change it if needed.
-
Click Save.
This opens a new configuration page for the created option.
-
(Optional) You can add a description in the Description text box.
-
(Optional) Enable the Use in Faceted Navigation toggle to use the option as a search filter for products.
-
(Optional) Enable the Required toggle to enforce option selection before adding the product to the customer’s cart.
-
(Optional) Enable the SKU Contributor toggle to use the option’s values to create SKUs. Customers must select from the available option values.
ImportantYou can only enable the SKU Contributor toggle with the Single Selection and Select from List field types.
-
Click Save.
Now you can add generic values to the option template or skip this step and apply the option to individual products.
Alternatively, you can create basic option templates via the Products page. Open the Global Menu () and go to Commerce → Products. Select a product and go to the Options tab. In the Add Option field, enter a name for your new option and click Create New. This creates and applies the option template to the product.
Adding Values to Option Templates
If an option uses one of these field types, you must add values to it.
- Select from List
- Single Selection
- Multiple Selection
- Liferay DXP 2024.Q2+/Portal 7.4 GA120+ Select Date from List
-
Open the Global Menu () and navigate to Commerce → Options.
-
Select an option template and scroll down to the Values section.
-
Click Add ().
-
Enter a Name for the value. A Key is generated automatically to match the name, but you can change it manually if needed.
-
Set the value’s Position to determine the order in which it’s listed.
-
Click Submit to add the value to the option template.
You can add as many generic values to the option as needed.
Adding Values for Select Date from List
Liferay DXP 2024.Q2+/Portal 7.4 GA120+
-
Select the Select Date from List option template.
-
Scroll down to the Values section and click Add ().
-
Enter information for the option value based on the following fields:
Field Description Date Specifies the date for the option value. The default value is the current date. Time Specifies the time for the option value. The default value is the current time in UTC. Time Zone Specifies the time zone for the option value. The default time zone is UTC. Duration Specifies an integer value for the duration. Duration Type Specifies the duration type between hours and days. The default duration type is hours. Label Specifies the label for the option value. This field is non-editable. It is generated in the format: Date, Time (Time Zone), Duration Duration Type Position Specifies the option value’s priority to determine its display order. The default value is 0
. -
Click Submit.
After adding values, you cannot change the option type. You can use this type as an SKU contributor, and only one option can be selected when buying a product. The date/time values shown in the storefront use the user’s locale. If the user doesn’t have a locale, it uses the site’s locale.
This feature was released behind a release feature flag in Liferay DXP 2024.Q2/Portal 7.4 GA120. It was made Generally Available (GA) in 2024.Q3/GA132.
Applying an Option Template to a Product
-
Open the Global Menu (), and navigate to Commerce → Products.
-
Select a product and go to the Options tab.
-
Enter a name in the Add Options field, and click Create New. If there’s an option template already created, click Select.
The option is applied immediately to the product. If choosing an existing option template, all values from the template are included. You can choose to add, remove, or edit values without affecting the template values.
If desired, you can add multiple options to the same product. See Creating SKUs for Product Variants for more information.
If you enable the SKU Contributor toggle, you must generate SKUs manually for the option’s values after they’re created. To do this, go to the product’s SKUs tab, click Add (), and select Generate All SKU Combinations. Unique SKUs are generated immediately for each value. If no SKUs are generated, the option’s field doesn’t display its values.
Configuring Options and Values Applied to Products
Once an option is applied to a product, you can access additional configuration settings for the option and its values.
Changes made to a product’s option do not affect the option template and vice versa.
Additional Option Settings
Select an option from the Options section to view additional settings.
Name: Set the option’s name.
Description: Set an optional option description.
Position: Set the option’s priority to determine its display order, beginning with 0.0
.
Field Type: Set the option’s field type.
Price Type: Set the price type used for the options’s values, Dynamic or Static.
-
Dynamic - Requires linking values to SKUs and uses the linked product’s price for the value’s own price.
-
Static - Uses a fixed price for the option’s values. If the value is linked to a product, the static price overrides the product’s price without affecting its list price.
The price type attribute is only compatible with the Single Selection and Select from List field types.
Additional Value Settings
Default: Use the toggle to set the option value as the default for the option.
Delta Price (for static pricing only): Set a specific price for the value.
Product: Link an existing SKU to the value and specify its quantity.
Products can only be linked to options with the price type attribute.
See Commerce 2.1 and below: Using Product Options to learn how to use product options with earlier versions of Liferay.