Wt examples
3.3.0
|
Example implementation of a single tree list node. More...
#include <TreeNode.h>
Public Member Functions | |
TreeNode (const std::string labelText, Wt::TextFormat labelFormat, IconPair *labelIcon, Wt::WContainerWidget *parent=0) | |
Construct a tree node with the given label. More... | |
void | addChildNode (TreeNode *node) |
Adds a child node. More... | |
void | removeChildNode (TreeNode *node) |
Removes a child node. More... | |
const std::vector< TreeNode * > & | childNodes () const |
Returns the list of children. More... | |
void | collapse () |
Collapses this node. More... | |
void | expand () |
Expands this node. More... | |
Private Types | |
enum | ImageIndex { Middle = 0, Last = 1 } |
Two sets of images, for a normal node, and for the last node. More... | |
Private Member Functions | |
void | adjustExpandIcon () |
Adjust the expand icon. More... | |
bool | isLastChildNode () const |
Returns if is the last child within its parent (is rendered differently) More... | |
void | childNodesChanged () |
Rerender when children have changed. More... | |
void | undoCollapse () |
Undo function for prelearning collapse() More... | |
void | undoExpand () |
Undo function for prelearning expand() More... | |
Private Attributes | |
std::vector< TreeNode * > | childNodes_ |
List of child nodes. More... | |
TreeNode * | parentNode_ |
The parent node. More... | |
Wt::WTable * | layout_ |
Layout (2x2 table). More... | |
IconPair * | expandIcon_ |
The icon for expanding or collapsing. More... | |
Wt::WImage * | noExpandIcon_ |
The single image shown instead of the expand/collapse icon when no children. More... | |
IconPair * | labelIcon_ |
The icon next to the label. More... | |
Wt::WText * | labelText_ |
The label. More... | |
Wt::WText * | childCountLabel_ |
The children count '(x)' for x children. More... | |
Wt::WContainerWidget * | expandedContent_ |
The container in which the children are managed. More... | |
bool | wasCollapsed_ |
Was collapsed (for undo of prelearned collapse() and expand() slots. More... | |
Static Private Attributes | |
static std::string | imageLine_ [] |
static std::string | imagePlus_ [] |
static std::string | imageMin_ [] |
Additional Inherited Members | |
![]() | |
virtual void | enableAjax ()=0 |
virtual void | propagateSetEnabled (bool enabled)=0 |
virtual void | render (WFlags< RenderFlag > flags) |
Example implementation of a single tree list node.
This is an example of a basic treelist implementation. As of version 1.1.8, a more flexible treenode implementation is included as part of the library: WTreeNode.
A tree list is constructed by nesting TreeNode objects in a tree hierarchy.
A TreeNode has a label, and optionally a two-state label icon, which defines a different image depending on the state of the node (expanded or collapsed). When the node has any children, a child count is also indicated.
Next to the icons, two style classes determine the look of a TreeNode: the label has style "treenodelabel", and the child count has as style "treenodechildcount".
Use CSS nested selectors to apply different styles to different treenodes. For example, to style the treenode with style class "mynode":
The behaviour of the tree node is to collapse all children when the node is expanded (this is similar to how most tree node implementations work).
The widget uses a number of images which must be available in an "icons/" folder (see the Wt treelist examples).
This widget is part of the Wt treelist example.
Definition at line 55 of file TreeNode.h.
|
private |
Two sets of images, for a normal node, and for the last node.
Enumerator | |
---|---|
Middle | |
Last |
Definition at line 139 of file TreeNode.h.
TreeNode::TreeNode | ( | const std::string | labelText, |
Wt::TextFormat | labelFormat, | ||
IconPair * | labelIcon, | ||
Wt::WContainerWidget * | parent = 0 |
||
) |
Construct a tree node with the given label.
The label is formatted in a WText with the given formatting. The labelIcon (if not 0) will appear next to the label and its state will reflect the expand/collapse state of the node.
Optionally, a userContent widget may be associated with the node. When expanded, this widget will be shown below the widget, but above any of the children nodes.
Definition at line 26 of file TreeNode.C.
void TreeNode::addChildNode | ( | TreeNode * | node | ) |
|
private |
|
inline |
|
private |
void TreeNode::collapse | ( | ) |
void TreeNode::expand | ( | ) |
|
private |
Returns if is the last child within its parent (is rendered differently)
Definition at line 78 of file TreeNode.C.
void TreeNode::removeChildNode | ( | TreeNode * | node | ) |
|
private |
|
private |
|
private |
The children count '(x)' for x children.
Definition at line 115 of file TreeNode.h.
|
private |
List of child nodes.
Definition at line 94 of file TreeNode.h.
|
private |
The container in which the children are managed.
Definition at line 118 of file TreeNode.h.
|
private |
The icon for expanding or collapsing.
Definition at line 103 of file TreeNode.h.
|
staticprivate |
Definition at line 141 of file TreeNode.h.
|
staticprivate |
Definition at line 143 of file TreeNode.h.
|
staticprivate |
Definition at line 142 of file TreeNode.h.
|
private |
The icon next to the label.
Definition at line 109 of file TreeNode.h.
|
private |
The label.
Definition at line 112 of file TreeNode.h.
|
private |
Layout (2x2 table).
Definition at line 100 of file TreeNode.h.
|
private |
The single image shown instead of the expand/collapse icon when no children.
Definition at line 106 of file TreeNode.h.
|
private |
The parent node.
Definition at line 97 of file TreeNode.h.
|
private |
Was collapsed (for undo of prelearned collapse() and expand() slots.
Definition at line 130 of file TreeNode.h.