Dropdown
Overview
The Dropdown component allows the user to select one out of several options.
Specification
Property
Here is a list of properties that can be used for modifying the component:
Name | Type | Default | Description | Remark |
---|---|---|---|---|
className | string | "" | Component class name | |
error | string | "" | Text to be displayed in error | Error will not be displayed if unspecified or empty |
id | string | "" | Component id name | |
label | string | "" | Label for the component | Label is not displayed if unspecified or empty |
value *1 | string | "" | Selected value | No option will be selected if the value and selectedIndex are unspecifiedIf setting duplicated value and not setting selectedIndex , the first mapped value item in Item.value will be selected and selectedIndex will be the index numberWill result an error if the value is not a string |
selectedIndex *1 | number | -1 | Index of selected item | It supports specifying which duplicated Item.value will be selected if there is duplicated Item.value in items If value is not set and selectedIndex is valid, item that has the index number will be selectedIf value is set with duplicated Item.value and selectedIndex value maps with duplicated Item.value specified in value , the item that has the index number will be selectedWill result an error if the value of selectedIndex is not a number |
disabled | boolean | false | Enable/Disable the component | |
requiredIcon | boolean | false | Show/Hide the required icon | |
visible | boolean | true | Show/Hide the component | |
items | Array<Item> | [] | List of options to display | Will result an error if the value of items is not an array |
*1: You can set duplicated value in Item.value
. In case setting duplicated value, you can handle selected item using value
and selectedIndex
property.
Example: When setting items = [{label: 'Orange', value: 'fruit'}, {label: 'Apple', value: 'fruit'}, {label: 'Carrot', value: 'vegetable'}]
-
If setting
value
and not settingselectedIndex
as follows:- value = 'fruit': The first item will be selected.
- value = 'other': No item will be selected.
-
If not setting
value
and settingselectedIndex
as follows:- selectedIndex = 1: The second item will be selected.
- selectedIndex = 99: No item will be selected.
Item
Name | Type | Default | Description | Remark |
---|---|---|---|---|
label | string | null | Text label for each option | If Item.label is unspecified, the value of Item.value is displayed on the UI |
value | string | null | Value of each option | Can set duplicated value in Item.value |
disabled | boolean | false | Enable/Disable each option |
Event
Here is a list of events that can be specified:
Name | Type | Description | Remark |
---|---|---|---|
change | function | Event handler when the value has been changed | It will pass the event object as the argument You can receive the following values in event.detail event.detail.oldValue : Value before the change event.detail.value : Value after changing |
Constructor
Dropdown(options)
Here is a list of available constructors:
Parameter
Name | Type | Default | Description | Remark |
---|---|---|---|---|
options | object | {} | Object that includes component properties |
Custom CSS
Please check Custom CSS feature guide at first.
Here is a list of properties that can be used for modifying component style:
"toggle" means the area of the Dropdown button.
Property
Name |
---|
--kuc-dropdown-font-size |
--kuc-dropdown-toggle-width |
--kuc-dropdown-toggle-height |
--kuc-dropdown-toggle-color |
--kuc-dropdown-menu-color |
--kuc-dropdown-menu-color-selected |
--kuc-dropdown-menu-max-height |
Sample Code
Please check the package installation method first.
Here is a sample code when all parameters are specified:
const Kuc = Kucs['1.x.x'];
const space = kintone.app.record.getSpaceElement('space');
const dropdown = new Kuc.Dropdown({
label: 'Fruit',
requiredIcon: true,
items: [
{
label: 'orange',
value: 'Orange'
},
{
label: 'apple',
value: 'Apple'
},
{
label: 'banana',
value: 'Banana',
disabled: true
}
],
value: 'Orange',
selectedIndex: 0,
error: 'Error occurred!',
className: 'options-class',
id: 'options-id',
visible: true,
disabled: false
});
space.appendChild(dropdown);
dropdown.addEventListener('change', event => {
console.log(event);
});