Author: Maya Venkatraman

The first section in this document describes the parts of the tree controls and its salient states. The second section looks at the behaviors, actions and patterns that this control should support. The third section discusses how to make all the parts and actions within the control accessible by keyboard.

1.1 CHARACTERISTICS of a TREE CONTROL

 

 

 

 

By default a custom tree cell should provide one Icon and Node Name text. In addition, it should be possible for the application developer to add a checkbox and at least two more icons for each node.

 

1.2 Input Actions Associated with Parts of the Tree Cell

 

2. COMMON BEHAVIORS and ACTIONS

2.1 Nodes should Open and Close

 

The default state, where the application developer has not specified anything additional should map to a state where the expanded nodes are remembered.

 

2.2 The list component should be able to support horizontal and vertical scrolling


2.3 Should be able to select one or more items

 

2.4 The tree control should support customized context menus when right clicking on a node

Sometimes, in addition to the right click menu (or instead of it) these actions are invoked via a pull down menu placed in the Title bar of the tree control. Actions may also be shown as buttons, icons or links in the cell that are revealed on hover (or mouseover). 
UX Rationale for contextual menu: Common UX usage that needs to be supported

2.5 Should support Drag and Drop of nodes

Usage Note: Drop action can result in Copy, Move or other outcome (such as connect or apply). The tree control itself should not in any way prevent an application from using all such semantic outcomes from the drop action.

 

2.6 Showing loading data (locally and globally across nodes)

The tree component may need to convey to the user that the data in the tree is still loading. This can be at the level for the child node, parent node, several nodes, or globally. Spinners are animated icons shown when parts of the tree is still loading. Several cases are illustrated in the mock ups here:

Note: The child nodes need to be shown as spinners only if there is a lag in determining the exact icon to display. The appropriate icon should be shown as soon as it is available.

 

2.7 Adding, Removing and Changing Properties of Nodes

The tree component should have in place all the functionality that can support an application that will need to support users changing properties associated with nodes, adding nodes or removing nodes.

 

2.8 Inline Editing of Node Names

On some platforms, users will be able to make a gesture (double click , or click and pause) to indicate that they need to edit the node text. The node will assume the editable state and the user will be able to edit the node name inline. When the edit task is completed the user will click enter to return to normal mode. This should be supported by the default tree custom cell and the cross-component specification for custom cell may cover more details.

 

2.9 System generated changes in focus - best practice

The tree control should be able to support application developers who want to use a system generated change in the focused node. If the system causes the focus or selected item on the control to change, the application developer should be able to show the end user that the new tree-node that has focus. It should be displayed in the view area of the tree, and all the nodes that contain this node should be expanded or opened out so that this node with the selection is visible. A RIA interface should use animated transitions to clearly convey such a change to the user.

 

2.10 Custom Highlighting of Nodes

It should be possible for the application to highlight an arbitrary node or nodes. For instance, if the user searches a tree, all the hits in the search will need to be highlighted. The component should make it possible for the application developer to do this.

 

2.11 Sorting

The tree component should support the ability for the app to sort the nodes in some orders (alpha, order of creation, or by some other node-property)

 

3. KEYBOARD NAVIGATION

Main Control Actions and how to invoke them via the keyboard:

The main tasks that users will need to do within the tree component (and therefore the tasks that will have to be supported by keyboard access are:

- Moving through the nodes of the tree

- Opening and closing nodes

- invoking the right click menu

- skip between sections of the control (title bar, body and footer)

 

The diagram and table below discuss how these actions can be performed using the keyboard and tab traversal. After that we look at the mobile and TV platforms.

Keyboard Operation (Win)Keyboard Operation (Mac)Action
Right ArrowRight ArrowExpand current selection (or go to first child node)
Left ArrowLeft ArrowCollapse current selection (or go to parent node)
Up ArrowUp ArrowMove selection up one node
Down ArrowDown ArrowMove selection down one node
HomeHomeMove selection to the first node in the tree
EndEndMove selection to the last node in the tree
Page UpPage UpMove the selection up on the first fully visible item on the current page. If the first fully visible item is selected, move the selection on the first fully visible item on the previous page.
Page DownPage DownMove selection down on the last fully visible item on the current page. If the last fully visible item is selected, move the selection on the last fully visible item on the next page.
Ctrl-PgDnCmd-PgDnMove focus down on the last fully visible item on the current page. If the last fully visible item is focused, move focus on the last fully visible item on the next page.
Ctrl-PgUpCmd-PgUpMove focus up on the first fully visible item on the current page. If the first fully visible item is focused, move focus on the first fully visible item on the previous page.
Ctrl-ACmd-ASelect all nodes in the tree. Focus remains on the same item.
Shift-Up ArrowShift-Up Arrow

Extend selection up one node

In single selection mode, Shift key should be ignored and only Up Arrow key should be processed. See description of Up Arrow behavior for more details.

Shift-Down ArrowShift-Down Arrow

Extend selection down one node

In single selection mode, Shift key should be ignored and only Down Arrow key should be processed. See description of Down Arrow behavior for more details.

Shift-HomeShift-Home

Extend selection to the top of the tree

In single selection mode, Shift key should be ignored and only Home key should be processed. See description of Home behavior for more details.

Shift-EndShift-End

Extend selection to the bottom of the tree

In single selection mode, Shift key should be ignored and only End key should be processed. See description of End behavior for more details.

Shift-PgUpShift-PgUp

Select all items between anchor and the first fully visible item on the current page. If the first fully visible item is already included in the selection, extend the selection to the first fully visible item on the previous page.

All previous selections, if applicable, are canceled. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only PgUp key should be processed. See description of PgUp behavior for more details.

Shift-PgDnShift-PgDn

Select all items between anchor and the last fully visible item on the current page. If the last fully visible item is already included in the selection, extend the selection to the last fully visible item on the next page.

All previous selections, if applicable, are canceled. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only PgDn key should be processed. See description of PgDn behavior for more details.

F2F2Rename selected node
EnterEnterSave changes made to the selected node
EscEscCancel changes made to the selected node
Ctrl-Up ArrowCmd-Up ArrowMove focus up one node
Ctrl-Down ArrowCmd-Down ArrowMove focus down one node
Ctrl-HomeCmd-HomeMove focus to the first node in the tree
Ctrl-EndCmd-EndMove selection to the last node in the tree
SpaceSpaceSelect a single node, create anchor.
Ctrl-SpaceCtrl-Cmd-SpaceSelect/Deselect a single node, create anchor.
Shift-SpaceShift-Space

Select a range of nodes

In single selection mode, Shift key should be ignored and only Space key should be processed. See description of Space behavior for more details.

* (numlock)* (numlock)Expand everything
+ (numlock)+ (numlock)Expand current selection
- (numlock)- (numlock)Collapse current selection
Ctrl-Shift-UpCmd-Shift-Up

Expands selection up by one item. Only in multi-selection modes.

If focus is on an unselected item, pressing Ctrl-Shift-Up selects all items between anchor and the item which is right above the focused item. The item which is right above the focused item is also included in the selection. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-Up (Cmd-Up) should be processed. See description of Ctrl-Up behavior for more details.

Ctrl-Shift-DownCmd-Shift-Down

Expands selection down by one item. Only in multi-selection modes.

If focus is on an unselected item, pressing Ctrl-Shift-Down selects all items between anchor and the item which is right below the focused item. The item which is right below the focused item is also included in the selection. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-Down (Cmd-Down) should be processed. See description of Ctrl-Down behavior for more details.

Ctrl-Shift-SpaceCmd-Shift-Space

Selects all items between anchor and focused item. Focused item is also included in the selection. Create anchor. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-Space (Cmd-Space) should be processed. See description of Ctrl-Space behavior for more details.

Ctrl-Shift-HomeCmd-Shift-Home

Selects all items between anchor and the first item. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-Home (Cmd-Home) should be processed. See description of Ctrl-Home behavior for more details.

Ctrl-Shift-EndCmd-Shift-End

Selects all items between anchor and the last item. Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-End (Cmd-End) should be processed. See description of Ctrl-End behavior for more details.

Ctrl-Shift-PageUpCmd-Shift-PageUp

Select all items between anchor and the first fully visible item on the current page. If the first fully visible item is already included in the selection, extend the selection to the first fully visible item on the previous page.

Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-PageUp (Cmd-PageUp) should be processed. See description of Ctrl-PageUp behavior for more details.

Ctrl-Shift-PageDownCmd-Shift-PageDown

Select all items between anchor and the last fully visible item on the current page. If the last fully visible item is already included in the selection, extend the selection to the last fully visible item on the next page.

Available in multi-selection mode only.

In single selection mode, Shift key should be ignored and only Ctrl-PageDown (Cmd-PageDown) should be processed. See description of Ctrl-PageDown behavior for more details.

 

4. OPEN ISSUES