Tree view
A tree view widget presents a hierarchical list. Any item in the hierarchy can have child items, and items that have children can be expanded or collapsed to show or hide the children.
Use cases:
- creating a file system navigator that uses a tree view to display folders and files. An item representing a folder can be expanded to reveal the contents of the folder, which may be files, folders, or both
- creating a hierarchical diagram of profiles
Example
The example shows the component in action. Item 1 and Item 2 both have two children, which you can click to view. Item 3 has no children.
- Genesis
- React
- Angular
Declaration
<rapid-tree-view>
<rapid-tree-item></rapid-tree-item>
</rapid-tree-view>
Usage
@customElement({
name: 'my-element',
template: html<MyElement>`
<rapid-tree-view>
Root
<rapid-tree-item>
Item 1
<rapid-tree-item>Sub-item 1-1</rapid-tree-item>
<rapid-tree-item>Sub-item 1-2</rapid-tree-item>
<rapid-tree-item>
Item 2
<rapid-tree-item>Sub-item 2-1</rapid-tree-item>
<rapid-tree-item>Sub-item 2-2</rapid-tree-item>
</rapid-tree-item>
</rapid-tree-item>
<rapid-tree-item>Item 3</rapid-tree-item>
</rapid-tree-view>
`,
})
export class MyElement extends GenesisElement { }
Declaration
<rapid-tree-view>
<rapid-tree-item></rapid-tree-item>
</rapid-tree-view>
Usage
export function MyComponent() {
return (
<rapid-tree-view>
Root
<rapid-tree-item>
Item 1
<rapid-tree-item>Sub-item 1-1</rapid-tree-item>
<rapid-tree-item>Sub-item 1-2</rapid-tree-item>
<rapid-tree-item>
Item 2
<rapid-tree-item>Sub-item 2-1</rapid-tree-item>
<rapid-tree-item>Sub-item 2-2</rapid-tree-item>
</rapid-tree-item>
</rapid-tree-item>
<rapid-tree-item>Item 3</rapid-tree-item>
</rapid-tree-view>)
}
Declaration
<rapid-tree-view>
<rapid-tree-item></rapid-tree-item>
</rapid-tree-view>
Usage
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
@Component({
selector: 'my-component',
template: `
<rapid-tree-view>
Root
<rapid-tree-item>
Item 1
<rapid-tree-item>Sub-item 1-1</rapid-tree-item>
<rapid-tree-item>Sub-item 1-2</rapid-tree-item>
<rapid-tree-item>
Item 2
<rapid-tree-item>Sub-item 2-1</rapid-tree-item>
<rapid-tree-item>Sub-item 2-2</rapid-tree-item>
</rapid-tree-item>
</rapid-tree-item>
<rapid-tree-item>Item 3</rapid-tree-item>
</rapid-tree-view>
`,
standalone: true,
schemas: [CUSTOM_ELEMENTS_SCHEMA],
})
export class MyComponent { }
Tree View API
API examples shown with Genesis component syntax, and closing tag omitted.
Attributes
Attribute | Type | Description | Example |
---|---|---|---|
render-collapsed-nodes | boolean | If set true the tree view will appear expanded as if by being expanded by the user |
|
Properties
Property | Type | Description | Example |
---|---|---|---|
currentSelected | HTMLElement | TreeItem | null | The currently selected tree item. It is likely you'll want to read this value instead of writing to it. |
|
Slots
Slot | Description |
---|---|
Default | The default slot for content or (<rapid-tree-item> ) |
Parts
This component doesn't have any parts.
Events fired
This component doesn't fire any events.
Events listened to
This component doesn't listen to any events.
Tree item API
API examples shown with Genesis component syntax, and closing tag omitted.
Attributes
Attribute | Type | Description | Example |
---|---|---|---|
expanded | boolean | When true, the control will appear expanded by user interaction. Emits expanded-change event when changed. Note: is not set when the user interacts with the item, so only use this attribute to pre-expand the item open rather than read the state. |
|
selected | boolean | When true, the control will appear selected by user interaction. Emits selected-change event when changed. Note: is not set when the user interacts with the item, so only use this attribute to pre-select the item open rather than read the state. |
|
disabled | boolean | When true, the control will be immutable by user interaction. |
|
Properties
This component doesn't have any properties that are not also controlled via attributes.
Slots
Slot | Description |
---|---|
Default | The default slot for tree item text content |
start | Content which can be provided before the tree item content |
end | Content which can be provided after the tree item content |
item | The slot for tree items (<rapid-tree-item> manage this assignment themselves) |
expand-collapse-button | The expand/collapse button |
Parts
Part | Description |
---|---|
positioning-region | The element used to position the tree item content with exception of any child nodes |
content-region | The element containing the expand/collapse, start, and end slots |
items | The element wrapping any child items |
expand-collapse-button | The expand/collapse button |
Events fired
Event | Type | Description | Example |
---|---|---|---|
expanded-change | boolean | Emitted when the expanded attribute is changed |
|
selected-change | boolean | Emitted when the selected attribute is changed |
|
Events listened to
This component doesn't listen to any events.