Interface: OptionSetBlock
Defines the structure and behavior of an option selection block.
An OptionSetBlock represents a configurable aspect of the product, such as a material choice, color selection, or component option. Each block contains settings for how options should be displayed and how they affect the product.
Extended by
Properties
allowEmpty?
optional
allowEmpty:boolean
If true
, this block can have no selection and still be valid.
If false
, a selection is required for valid configuration.
blockColor
blockColor:
string
The background color for this block in the UI. Used to visually differentiate blocks in the configurator.
blockName
blockName:
string
Unique name of the block, used for identification in the system.
clearable?
optional
clearable:boolean
If true
, users can clear their selection for this block, returning it to an unselected state.
If false
, once an option is selected, users must choose a different option but cannot deselect entirely.
collectionSetId?
optional
collectionSetId:string
ID of the collection set this block belongs to, if applicable. Only used when type is MATERIAL_COLLECTION.
colorSettings?
optional
colorSettings:CustomColorOption
Configuration for custom color selection functionality. Only used when mode is COLOR.
componentId?
optional
componentId:string
ID of the component this block is associated with, if applicable. Used in hybrid modular products to link blocks with specific components.
engrave?
optional
engrave:BlockEngraveSettings
Configuration for text engraving functionality. Only used when mode is ENGRAVE.
filterWidgetType
filterWidgetType:
FilterWidgetType
The type of filtering widget to use for this block, if applicable. Only relevant when widgetType is FILTER or FILTER_GROUPS.
globalOptionSetId?
optional
globalOptionSetId:string
ID of a global option set associated with this block, if applicable. Global option sets can be shared across products for consistent options.
hideDivider?
optional
hideDivider:boolean
If true
, the divider between this block and others will be hidden.
Useful for creating visually connected blocks in the interface.
hideHeader?
optional
hideHeader:boolean
If true
, the block header will be hidden in the UI.
The block's options will still be displayed, but without the block title.
hideInOptionPanel?
optional
hideInOptionPanel:boolean
If true
, this block will be hidden in the option panel.
The block will still affect the configuration but won't be visible in the UI.
hideInPdf?
optional
hideInPdf:boolean
If true
, this block will be hidden in PDF exports.
Allows excluding certain configuration options from generated documentation.
id
id:
string
Unique identifier for this block.
imageSettings?
optional
imageSettings:CustomImageOption
Configuration for custom image upload functionality. Only used when mode is IMAGE.
initialValue?
optional
initialValue:string
Initial value for this block when the configurator loads. If provided, this option will be pre-selected.
inputSettings?
optional
inputSettings:InputOption
Configuration for input field functionality. Only used when mode is INPUT.
instanceId?
optional
instanceId:string
Instance ID for this block, when used in a modular product. Uniquely identifies the block instance across multiple components.
isHidden?
optional
isHidden:boolean
If true
, this block is hidden from users but can still affect the configuration.
Hidden blocks are typically used for system-level settings or automated configurations.
letterMappings
letterMappings:
LetterMappings
Maps option set IDs to letters used in configuration code generation. Each option set in the block is assigned a unique letter identifier. When generating configuration codes, this letter is combined with the selected option's ordinal number to form part of the product's overall configuration code (e.g., "a3" for the 3rd option in option set "a").
messageBackground?
optional
messageBackground:string
Background color for message blocks. Only applicable when mode is MESSAGE.
messageContent?
optional
messageContent:string
|RawDraftContentState
Content for message blocks. Can be plain text or rich text. Only used when mode is MESSAGE.
messageIcon?
optional
messageIcon:YesNoValue
Whether to show an icon with a message block. Only applicable when mode is MESSAGE.
messageIconColor?
optional
messageIconColor:string
Color for the icon in message blocks. Only applicable when mode is MESSAGE.
messageIconType?
optional
messageIconType:string
The type of icon to use in message blocks. Only applicable when mode is MESSAGE.
messageStroke?
optional
messageStroke:string
Stroke color for message blocks. Only applicable when mode is MESSAGE.
messageType?
optional
messageType:string
The type or category of the message. Can be used to display different message styling (info, warning, error, etc). Only applicable when mode is MESSAGE.
mobileThumbColumns?
optional
mobileThumbColumns:1
|2
|3
|4
|"AUTO"
|5
|6
Number of columns to display for thumbnail options on mobile devices. "AUTO" allows the system to determine the optimal layout for smaller screens.
mode
mode:
OptionSetMode
The mode that determines how options are sourced and what widget functionality is available. This defines whether the block uses linked option sets, manual options, or specialized widgets like image upload, engraving, color picker, etc.
name
name:
string
Display name of the block shown to users.
nextLetter
nextLetter:
string
The next available letter to assign when adding new option sets to this block. Maintains unique letter assignments across option sets in the configuration system.
optionSetIds
optionSetIds:
string
[]
IDs of option sets associated with this block. For MATERIAL_COLLECTION type, these are automatically populated based on the collection. For OPTION_SET type, these are manually specified.
printOnDemandSettings?
optional
printOnDemandSettings:PrintOnDemandOption
Configuration for print-on-demand functionality. Only used when mode is PRINT_ON_DEMAND.
thumbBorder?
optional
thumbBorder:YesNoValue
Whether to display borders around thumbnails.
When YES
, adds a visual border to each thumbnail for better separation.
thumbCaption?
optional
thumbCaption:YesNoValue
Whether to show captions beneath thumbnails.
When YES
, displays option names under the thumbnail images.
thumbColumns?
optional
thumbColumns:1
|2
|3
|4
|"AUTO"
|5
|6
Number of columns to display for thumbnail options. "AUTO" allows the system to determine the optimal layout based on available space and number of options.
thumbStyle?
optional
thumbStyle:ThumbStyle
The visual style to use for thumbnail options. Determines corner rounding and overall appearance of thumbnail images.
type
type:
OptionSetType
The source type for options in this block when in LINKED mode. Determines whether options come from material collections or specific option sets.
widgetType
widgetType:
WidgetType
The type of UI widget to use for rendering this block's options. Determines the visual presentation and interaction model for the options.