UserOrgGroupSelect
Overview
The UserOrgGroupSelect component allows the user to select user, organization, and group.
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 | 
| icon | string | "" | Picker icon type | iconis used to set the main icon displayed on the right side of the toggle partDisplays different icons based on different values of iconAvailable options: | 
| id | string | "" | Component id name | |
| label | string | "" | Label for the component | Label is not displayed if unspecified or empty | 
| placeholder | string | "" | Placeholder text displayed in the input field | |
| 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 | 
| value | Array<string> | [] | Selected value | No option will be selected if the valueare unspecifiedWill result an error if the value is not an array | 
Item
| Name | Type | Default | Description | Remark | 
|---|---|---|---|---|
| label | string | null | Text label for each option | If Item.labelis unspecified, the value ofItem.valueis displayed on the UI | 
| type | string | "" | Icon type of each option | Item.typedetermines the small icon type displayed for each option in both the toggle menu and the selected items listDisplays different icons based on different values of the Item.typeAvailable options: | 
| value | string | null | Value of each option | Will result an error if setting 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 when used in event.detail event.detail.oldValue : Value before the change event.detail.value : Value after the change | 
| click-picker-icon | function | Event handler when the picker icon is clicked | It will pass the event object as the argument | 
Constructor
UserOrgGroupSelect(options)
Here is a list of available constructors:
Parameter
| Name | Type | Default | Description | Remark | 
|---|---|---|---|---|
| options | object | {} | Object that includes component properties | 
Sample Code
tip
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 userSelect = new Kuc.UserOrgGroupSelect({
  label: 'Assignees',
  items: [
    { label: 'Alice Johnson', value: 'alice', type: 'user', disabled: false },
    { label: 'Bob Smith', value: 'bob', type: 'user', disabled: false },
    { label: 'Charlie Lee', value: 'charlie', type: 'user', disabled: true },
    { label: 'Marketing Group', value: 'marketing-group', type: 'group', disabled: false },
    { label: 'Sales Team', value: 'sales-team', type: 'group', disabled: false },
    { label: 'Engineering Team', value: 'engineering-team', type: 'group', disabled: false },
    { label: 'Acme Corporation', value: 'acme-corp', type: 'org', disabled: false },
    { label: 'New York Office', value: 'ny-office', type: 'org', disabled: false },
  ],
  value: ['alice', 'marketing-group', 'acme-corp'],
  requiredIcon: true,
  error: 'Error occurred!',
  className: 'options-class',
  icon: 'user',
  id: 'options-id',
  placeholder: 'Please select assignees',
  visible: true,
  disabled: false
});
space.appendChild(userSelect);
userSelect.addEventListener('change', event => {
  console.log(event);
});
userSelect.addEventListener('click-picker-icon', event => {
  console.log(event);
});