Select Bool
<et2-select-bool> | Et2SelectBool
Slots
Name | Description |
---|---|
(default) |
Reflected into listbox options. Must be
|
prefix
|
Used to prepend a presentational icon or similar element to the combobox. |
help-text
|
Text that describes how to use the input. Alternatively, you can use the
help-text attribute.
|
Learn more about using slots.
Properties
Name | Description | Reflects | Type | Default |
---|---|---|---|---|
accesskey
|
Accesskey provides a hint for generating a keyboard shortcut for the current element. The attribute value must consist of a single printable character. |
|
string
|
- |
align
|
Used by Et2Box to determine alignment. Allowed values are left, right |
|
string
|
- |
autofocus
|
Have browser focus this input on load. Overrides etemplate2.focusOnFirstInput(), use only once per page https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attributes |
|
boolean
|
- |
class
|
CSS Class. This class is applied to the outside, on the web component itself. Due to how WebComponents work, this might not change anything inside the component. |
|
string
|
- |
clearable
|
Adds a clear button when the select is not empty. |
boolean
|
false
|
|
data
|
Set the dataset from a CSV |
string
|
- | |
deferredProperties
|
Any attribute that refers to row content cannot be resolved immediately, but some like booleans cannot stay a string because it’s a boolean attribute. We store them for later, and parse when they’re fully in their row. If you are creating a widget that can go in a nextmatch row, and it has boolean attributes that can change for each row, add those attributes into deferredProperties | - | - | |
disabled
|
Disables the select control. |
|
boolean
|
false
|
dom_id
|
Get the actual DOM ID, which has been prefixed to make sure it’s unique. |
string
|
- | |
emptyLabel
|
Textual label for first row, eg: ‘All’ or ‘None’. It’s value will be ″ |
String
|
""
|
|
hasFeedbackFor
|
Get a list of feedback types |
string[]
|
- | |
helpText
help-text
|
The select’s help text. If you need to display HTML, use the help-text slot instead.
|
string
|
''
|
|
hidden
|
The widget is not visible. As far as the user is concerned, the widget does not exist. Widgets hidden with an attribute in the template may not be created in the DOM, and will not return a value. Widgets can be hidden after creation, and they may return a value if hidden this way. |
|
boolean
|
- |
id
|
Get the ID of the widget |
string
|
- | |
label
|
The select’s label. If you need to display HTML, use the label slot instead. |
string
|
''
|
|
multiple
|
Allows more than one option to be selected. |
|
boolean
|
false
|
noLang
|
Disable any translations for the widget |
boolean
|
- | |
onTagClick
|
Click handler for individual tags instead of the select as a whole. Only used if multiple=true so we have tags |
function
|
- | |
parentId
|
Parent is different than what is specified in the template / hierarchy. Widget ID of another node to insert this node into instead of the normal location |
string
|
- | |
placeholder
|
Placeholder text to show as a hint when the select is empty. |
string
|
''
|
|
placement
|
The preferred placement of the select’s menu. Note that the actual placement may vary as needed to keep the listbox inside of the viewport. |
|
'top' | 'bottom'
|
'bottom'
|
select_options
|
Select box options Will be found automatically based on ID and type, or can be set explicitly in the template using |
SelectOption[]
|
- | |
shoelaceValue
|
Shoelace select uses space as multiple separator, so our values cannot have a space in them. We replace spaces with “___” before passing the value to SlSelect |
string | string[]
|
- | |
statustext
|
Tooltip which is shown for this element on hover |
|
string
|
- |
styles
|
WebComponent * | - | - | |
tagTag
|
Tag used for rendering tags when multiple=true Used for creating, finding & filtering options. |
StaticValue
|
- | |
translate
|
List of properties that get translated | - | - | |
value
|
Boolean option values are “0” and “1″, so change boolean to those | - | - | |
_optionRenderPromise
|
When we create the select option elements, it takes a while. If we don’t wait for them, it causes issues in SlSelect |
Promise
|
- | |
_optionTargetNode
|
Get the node where we’re putting the options If this were a normal selectbox, this would be just the |
HTMLElement
|
- | |
_tagsHidden
|
If the select is limited to 1 row, we show the number of tags not visible |
number
|
0
|
|
needed
|
Compatibility for deprecated name “needed”
use required instead |
- | - | |
options
|
Get property-values as object
use widget methods |
object
|
- | |
readOnly
|
Lion mapping
true |
- | - | |
supportedWidgetClasses
|
et2_widget compatability
Legacy compatability. Some legacy widgets check their parent to see whats allowed |
array
|
[]
|
|
updateComplete |
A read-only promise that resolves when the component has finished updating. |
Learn more about attributes and properties.
Events
Name | React Event | Description | Event Detail |
---|---|---|---|
change |
Emitted when the control’s value changes. |
Event
|
|
sl-clear |
Emitted when the control’s value is cleared. | - | |
sl-input |
Emitted when the control receives input. | - | |
sl-focus |
Emitted when the control gains focus. | - | |
sl-blur |
Emitted when the control loses focus. | - | |
sl-show |
Emitted when the suggestion menu opens. | - | |
sl-after-show |
Emitted after the suggestion menu opens and all animations are complete. | - | |
sl-hide |
Emitted when the suggestion menu closes. | - | |
sl-after-hide |
Emitted after the suggestion menu closes and all animations are complete. | - |
Learn more about events.
Methods
Name | Description | Arguments |
---|---|---|
checkCreateNamespace()
|
Checks whether a namespace exists for this element in the content array. If yes, an own perspective of the content array is created. If not, the parent content manager is used. Constructor attributes are passed in case a child needs to make decisions | - |
clone()
|
Creates a copy of this widget. |
_parent: et2_widget
|
createElementFromNode()
|
Create a et2_widget from an XML node. First the type and attributes are read from the node. Then the readonly & modifications arrays are checked for changes specific to the loaded data. Then the appropriate constructor is called. After the constructor returns, the widget has a chance to further initialize itself from the XML node when the widget’s loadFromXML() method is called with the node. |
_node: , _name:
|
et2HandleFocus()
|
When input receives focus, clear any validation errors. If the value is the same on blur, we’ll put them back The ones from the server (ManualMessage) can interfere with submitting. Named et2HandleFocus to avoid overwriting handleFocus() in Shoelace components |
_ev: FocusEvent
|
filterOutMissingOptions()
|
Check a value for missing options and remove them. We’ll warn about it in the helpText, and if they save the change will be made. This is to avoid the server-side validation error, which the user can’t do much about. |
value: string[]
|
fix_bad_value()
|
Handle the case where there is no value set, or the value provided is not an option. If this happens, we choose the first option or empty label. Careful when this is called. We change the value here, so an infinite loop is possible if the widget has onchange. | - |
getArrayMgr()
|
Returns the array manager object for the given part |
managed_array_type: string
|
getArrayMgrs()
|
Returns an associative array containing the top-most array managers. |
_mgrs: object
|
getChildren()
|
Get child widgets Use |
- |
getInputNode()
|
Get input to e.g. set aria-attributes | - |
getInstanceManager()
|
Returns the instance manager | - |
getPath()
|
Returns the path into the data array. By default, array manager takes care of this, but some extensions need to override this | - |
getRoot()
|
Returns the base widget Usually this is the same as getInstanceManager().widgetContainer | - |
hide()
|
Hides the listbox. | - |
isValid()
|
Used by etemplate2 to determine if we can submit or not |
messages:
|
loadFromXML()
|
Additional customisations from the XET node |
_node: Element
|
loadingFinished()
|
Needed for legacy compatability. |
promises: Promise[]
|
optionSearch()
|
Search options for a given value, returning the first matching option |
value: string, options: SelectOption[], searchKey: string, childKey: string
|
parseXMLAttrs()
|
The parseXMLAttrs function takes an XML DOM attributes object and adds the given attributes to the _target associative array. This function also parses the legacyOptions. N.B. This is only used for legacy widgets. WebComponents use transformAttributes() and do their own handling of attributes. |
_attrsObj: , _target: object, _proto: et2_widget
|
set_label()
|
NOT the setter, since we cannot add to the DOM before connectedCallback() TODO: This is not best practice. Should just set property, DOM modification should be done in render https://lit-element.polymer-project.org/guide/templates#design-a-performant-template |
value: string
|
setArrayMgr()
|
Sets the array manager for the given part |
_part: string, _mgr: object
|
setArrayMgrs()
|
Sets all array manager objects - this function can be used to set the root array managers of the container object. |
_mgrs: object
|
setInstanceManager()
|
Set the instance manager Normally this is not needed as it’s set on the top-level container, and we just return that reference |
manager: etemplate2
|
show()
|
Shows the listbox. | - |
submit()
|
Called whenever the template gets submitted. We return false if the widget is not valid, which cancels the submission. |
_values:
|
validate()
|
Massively simplified validate, as compared to what ValidatorMixin gives us, since ValidatorMixin extends FormControlMixin which breaks SlSelect’s render() We take all validators for the widget, and if there’s a value (or field is required) we check the value with each validator. For array values we check each element with each validator. If the value does not pass the validator, we collect the message and display feedback to the user. We handle validation errors from the server with ManualMessages, which always “fail”. If the value is empty, we only validate if the field is required. |
skipManual:
|
_emptyLabelTemplate()
|
Used for the “no value” option for single select Placeholder is used for multi-select with no value | - |
_extraTemplate()
|
Additional customisation template Override if needed. Added after select options. | - |
_handleClick()
|
Click handler calling custom handler set via onclick attribute to this.onclick |
_ev: MouseEvent
|
_handleTagOverflow()
|
Callback for the intersection observer so we know when tags don’t fit Here we set the flag to show how many more tags are hidden, but this only happens when there are more tags than space. |
entries: IntersectionObserverEntry[]
|
_iconTemplate()
|
Get the icon for the select option |
option: SelectOption
|
_labelTemplate()
|
Common sub-template to add a label. This goes inside the form control wrapper div, before and at the same depth as the input controls. | - |
_oldChange()
|
Change handler calling custom handler set via onchange attribute |
_ev: Event
|
_optionsTemplate()
|
Iterate over all the options | - |
_optionTemplate()
|
Used to render each option into the select Override for custom select options. Note that spaces are
not allowed in option values, and sl-select requires options to be |
option: SelectOption
|
_set_label()
|
Do some fancy stuff on the label, splitting it up if there’s a %s in it Normally called from updated(), the “normal” setter stuff has already been run before this is called. We only override our special cases (%s) because the normal label has been set by the parent |
value: string
|
_setAriaAttributes()
|
Set aria-attributes on our input node | - |
_styleTemplate()
|
Custom, dynamic styling Put as much as you can in static styles for performance reasons Override this for custom dynamic styles | - |
_tagTemplate()
|
Custom tag Override this to customise display when multiple=true. There is no restriction on the tag used, unlike _optionTemplate() |
option: Et2Option, index: number
|
destroy()
|
et2_widget compatability
true |
- |
set_class()
|
Set the widget class
Use this.class or this.classList instead |
new_class: string
|
set_disabled()
|
Wrapper on this.disabled because legacy had it.
Use widget.disabled for visually disabled, widget.hidden for visually hidden. Widgets that are hidden from the server via attribute or $readonlys will not be created. Widgets that are disabled from the server will not return a value to the application code. |
value: boolean
|
set_select_options()
|
Set select options
assign to select_options |
new_options: SelectOption[] | { [key : string] : string }[]
|
set_statustext()
|
supports legacy set_statustext
use this.statustext |
value: string
|
Learn more about methods.
Parts
Name | Description |
---|---|
prefix |
The container that wraps the prefix slot. |
tags |
The container that houses option tags when multiselect is used. |
display-input |
The element that displays the selected option’s label, an element. |
expand-icon |
The container that wraps the expand icon. |
combobox |
The container the wraps the prefix, combobox, clear icon, and expand button. |
listbox |
The listbox container where options are slotted. |
option |
The options in the listbox container |
icon |
Icon in the option |
emptyLabel |
Wrapper around the label shown when there is no option selected |
tag__prefix |
The container that wraps the option prefix |
tag__suffix |
The container that wraps the option suffix |
tag__limit |
Element that is shown when the number of selected options exceeds maxOptionsVisible |
Learn more about customizing CSS parts.