Interface: PreparedBlock
Represents a fully prepared block with all its options and metadata.
A PreparedBlock contains all the information needed to render a configurable block in the UI, including its available options, display settings, and current state. This is the primary interface used for rendering option blocks in the configurator.
Extends
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.
Inherited from
blockColor
blockColor:
string
The background color for this block in the UI. Used to visually differentiate blocks in the configurator.
Inherited from
blockName
blockName:
string
Unique name of the block, used for identification in the system.
Inherited from
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.
Inherited from
collectionSetId?
optional
collectionSetId:string
ID of the collection set this block belongs to, if applicable. Only used when type is MATERIAL_COLLECTION.
Inherited from
OptionSetBlock
.collectionSetId
colorSettings?
optional
colorSettings:CustomColorOption
Configuration for custom color selection functionality. Only used when mode is COLOR.
Inherited from
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.
Inherited from
disabledTooltipMessage?
optional
disabledTooltipMessage:string
Message to display as a tooltip when hovering over a disabled block. Explains to users why the block is currently unavailable.
engrave?
optional
engrave:BlockEngraveSettings
Configuration for text engraving functionality. Only used when mode is ENGRAVE.
Inherited from
filterWidgetType
filterWidgetType:
FilterWidgetType
The type of filtering widget to use for this block, if applicable. Only relevant when widgetType is FILTER or FILTER_GROUPS.
Inherited from
OptionSetBlock
.filterWidgetType
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.
Inherited from
OptionSetBlock
.globalOptionSetId
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.
Inherited from
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.
Inherited from
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.
Inherited from
OptionSetBlock
.hideInOptionPanel
hideInPdf?
optional
hideInPdf:boolean
If true
, this block will be hidden in PDF exports.
Allows excluding certain configuration options from generated documentation.
Inherited from
id
id:
string
Unique identifier for this block.
Inherited from
imageSettings?
optional
imageSettings:CustomImageOption
Configuration for custom image upload functionality. Only used when mode is IMAGE.
Inherited from
initialValue?
optional
initialValue:string
Initial value for this block when the configurator loads. If provided, this option will be pre-selected.
Inherited from
inputSettings?
optional
inputSettings:InputOption
Configuration for input field functionality. Only used when mode is INPUT.
Inherited from
instanceId?
optional
instanceId:string
Instance ID for this block, when used in a modular product. Uniquely identifies the block instance across multiple components.
Inherited from
isDisabled?
optional
isDisabled:boolean
If true
, this block is currently disabled and cannot be interacted with.
Disabled blocks might be shown with reduced opacity or other visual indicators.
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.
Inherited from
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").
Inherited from
messageBackground?
optional
messageBackground:string
Background color for message blocks. Only applicable when mode is MESSAGE.
Inherited from
OptionSetBlock
.messageBackground
messageContent?
optional
messageContent:string
|RawDraftContentState
Content for message blocks. Can be plain text or rich text. Only used when mode is MESSAGE.
Inherited from
messageIcon?
optional
messageIcon:YesNoValue
Whether to show an icon with a message block. Only applicable when mode is MESSAGE.
Inherited from
messageIconColor?
optional
messageIconColor:string
Color for the icon in message blocks. Only applicable when mode is MESSAGE.
Inherited from
OptionSetBlock
.messageIconColor
messageIconType?
optional
messageIconType:string
The type of icon to use in message blocks. Only applicable when mode is MESSAGE.
Inherited from
OptionSetBlock
.messageIconType
messageStroke?
optional
messageStroke:string
Stroke color for message blocks. Only applicable when mode is MESSAGE.
Inherited from
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.
Inherited from
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.
Inherited from
OptionSetBlock
.mobileThumbColumns
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.
Inherited from
name
name:
string
Display name of the block shown to users.
Overrides
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.
Inherited from
options?
optional
options:OptionSetOption
[]
Available options for this block. These are the selectable choices presented to users for this block.
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.
Inherited from
optionSetsData?
optional
optionSetsData:OptionSetData
[]
Data for the option sets contained within this block. Contains metadata and details about each option set associated with this block.
optionsLength
optionsLength:
number
The total number of options available in this block. This can be used for UI layout decisions or validation.
printOnDemandSettings?
optional
printOnDemandSettings:PrintOnDemandOption
Configuration for print-on-demand functionality. Only used when mode is PRINT_ON_DEMAND.
Inherited from
OptionSetBlock
.printOnDemandSettings
thumbBorder?
optional
thumbBorder:YesNoValue
Whether to display borders around thumbnails.
When YES
, adds a visual border to each thumbnail for better separation.
Inherited from
thumbCaption?
optional
thumbCaption:YesNoValue
Whether to show captions beneath thumbnails.
When YES
, displays option names under the thumbnail images.
Inherited from
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.
Inherited from
thumbStyle?
optional
thumbStyle:ThumbStyle
The visual style to use for thumbnail options. Determines corner rounding and overall appearance of thumbnail images.
Inherited from
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.
Inherited from
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.