Keyboard Navigation#
TL;DR
Wunderbaum tree and treegrid is navigable using keyboard shortcuts. Different navigation modes are available.
The option keyboard: true
enables standard keyboard navigation.
See also
See also a live demo and use the keyboard to navigate, expand, and edit grid cells.
General Keyboard Navigation#
We distinguish node states 'focused', 'active', and 'selected'.
setFocus()
only sets a dotted border around the node. When autoActivate
is enabled (which is on by default), the node also gets activated.
A node becomes 'selected', when the checkbox is checked.
A tree can have one of two navigation modes. We can toggle using the keyboard:
Row Mode ↔ Cell-Nav Mode
The initial mode, and if modes can be switched, is controlled by the
navigationModeOption
option:
If the tree has only one column, or if navigationModeOption is "row"
,
Row Mode is obligatory.
If the value is "cell"
, Cell-Nav Mode is obligatory.
A value of "startCell"
or "startRow"
allows switching.
Navigation in Row Mode#
In row mode, Wunderbaum behaves like a simple tree. Even if multiple columns are present, always the whole row is highlighted.
Windows | macOS | Function |
---|---|---|
AlphaNum | Jump to next matching node, i.e. title starts with this character (if `quicksearch` is true). | |
Tab, Shift + Tab | Leave the Wunderbaum tree control and focus next/previous control on the page. | |
+ / - | Expand/collapse node | |
Space | Toggle selected status if checkbox option is on. | |
F2 | Edit node title. | |
Enter |
If node is active and expandable: toggle expansion. Note: Behaves as alias for F2 on macOS if edit.trigger option list contains "macEnter". |
|
Escape | Discard edit title operation if any. | |
Backspace | Set focus to parent node. | |
ArrowLeft | If expanded: collapse. Otherwise set focus to parent node. | |
ArrowRight |
If collapsed: expand. Otherwise switch to →Cell-Nav Mode. |
|
ArrowUp | Set focus to previous sibling (or parent if already on first sibling). | |
ArrowDown | Set focus to next visible node. | |
Ctrl + Arrow… | ⌘ + Arrow… | Same as plain Arrow…, but only sets the focus, even if autoActivate option is on. |
Home | Fn + ArrowLeft | — |
End | Fn + ArrowRight | — |
PageUp | Fn + ArrowUp | Select top row in viewport or scroll one page upwards if we are already at the top. |
PageDown | Fn + ArrowDown | Select bottom row in viewport or scroll one page down if we are already at the bottom. |
Ctrl + Home, Ctrl + End |
⌘ + ArrowUp, ⌘ + ArrowDown |
Select first / last row. |
Navigation in Cell-Nav Mode#
Cell-Nav mode is only available, when multiple columns are defined.
In this mode we navigate the single grid cells in read-only mode mostly.
However, if the cell contains an embedded <input>
element,
we can focus that control and edit its content.
Windows | macOS | Function |
---|---|---|
+ / - | Expand/collapse node if the title column is highlighted. | |
ArrowUp, ArrowDown, ArrowLeft, ArrowRight |
Navigate to adjacent cell. ArrowLeft on the leftmost column switches to →Row Mode. |
|
Tab, Shift + Tab | Move to adjacent cell. | |
Escape |
If the focus is inside an embedded <input> element:
discard changes and set focus to the outer cell.Otherwise switch to →Row Mode. |
|
F2 | Edit the current grid cell. If the title column is highlighted, edit the node title. | |
Enter |
If on the first column and node is expandable: toggle expansion. If the cell contains an embedded <input> element:
set focus into that input control.If the input control already had the focus, accept the entered data. Note: Enter behaves as alias for F2 on macOS if the edit.trigger option list contains "macEnter". |
|
AlphaNum |
If the cell contains an embedded <input> element:
start editing its value.
|
|
Space | Toggle value if current cell contains a checkbox. Toggle node selection if current cell is in the title column. | |
Home | Fn + ArrowLeft | Select leftmost cell. |
End | Fn + ArrowRight | Select rightmost cell. |
PageUp | Fn + ArrowUp | Select top cell in viewport or scroll one page upwards if we are already at the top. |
PageDown | Fn + ArrowDown | Select bottom cell in viewport or scroll one page down if we are already at the bottom. |
Ctrl + Home, Ctrl + End |
⌘ + ArrowUp, ⌘ + ArrowDown |
Select top / bottom tree cell. |
Configuration and Customization#
Related Tree Options#
const tree = new Wunderbaum({
...
enable: true,
autoActivate: true,
checkbox: true,
navigationModeOption: "startRow", // | "cell" | "startCell" | "row"
quicksearch: true,
...
// --- Events ---
keydown: (e) => {
// Return false to prevent default behavior
}
...
edit: {
trigger: ["F2", "macEnter", ...],
...
},
});
Related Methods#
tree.setNavigationOption(mode: NavModeEnum)
tree.setColumn(colIdx: number|string, options?: SetColumnOptions)
tree.setEnabled(flag: boolean)
Related CSS Rules#
div.wunderbaum.wb-grid.wb-cell-mode div.wb-row.wb-active span.wb-col.wb-active {
/* Highlighted cell in cell-nav mode */
}
Code Hacks#