Custom Rendering#
TL;DR
Wunderbaum is rendered as nested <div>
/<span>
element structure.
It can be customized by applying CSS styles.
Node icons are created from customizable icon fonts.
This chapter describes different ways to customize the appearance of the tree.
See also
See also the Grid Tutorial for rendering of grid cell content and Edit Tutorial for rendering embedded input controls in grid cells.
Custom Style Sheets#
It is possible to customize the appearance of the tree by adding specific CSS rules.
For example, to change the background color of the active grid cell:
div.wunderbaum.wb-grid.wb-cell-mode div.wb-row.wb-active span.wb-col.wb-active {
/* Highlighted cell in cell-nav mode */
}
See also
See the Styling Tutorial for details.
Custom Icons#
This example uses Font Awesome Icons instead of the default Bootstrap Icons icon font:
<html>
<head>
<link
rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css"
/>
...
</head>
</html>
const tree = new mar10.Wunderbaum({
element: document.getElementById("demo-tree"),
source: "get/root/nodes",
iconMap: "fontawesome6", // <-- use Font Awesome Icons
...
});
iconMap
can also be a custom map of icon names, for example:
const tree = new mar10.Wunderbaum({
...
iconMap: {
error: "bi bi-exclamation-triangle",
loading: "bi bi-chevron-right wb-busy",
noData: "bi bi-question-circle",
expanderExpanded: "bi bi-chevron-down",
expanderCollapsed: "bi bi-chevron-right",
expanderLazy: "bi bi-chevron-right wb-helper-lazy-expander",
checkChecked: "bi bi-check-square",
checkUnchecked: "bi bi-square",
checkUnknown: "bi bi-dash-square-dotted",
radioChecked: "bi bi-circle-fill",
radioUnchecked: "bi bi-circle",
radioUnknown: "bi bi-record-circle",
folder: "bi bi-folder2",
folderOpen: "bi bi-folder2-open",
folderLazy: "bi bi-folder-symlink",
doc: "bi bi-file-earmark",
colSortable: "bi bi-arrow-down-up",
colSortAsc: "bi bi-arrow-down",
colSortDesc: "bi bi-arrow-up",
colFilter: "bi bi-filter",
colFilterActive: "bi bi-filter-square-fill",
colMenu: "bi bi-three-dots-vertical",
},
...
});
Custom Markup#
Using the render
Event#
The render(e)
event is called for each node that needs to be rendered, i.e. that
is materialized in the viewport.
It is called after the node's row markup has been created, for example:
<div class="wb-row" style="top: 22px;">
<span class="wb-node wb-col wb-active" style="left: 0px; width: 1368px;">
<i class="wb-indent"></i>
<i class="wb-expander wb-indent"></i>
<i class="wb-icon bi bi-file-earmark"></i>
<span class="wb-title" style="width: 1301px;">Node 1.1</span>
</span>
</div>
For treegrids with multiple columns, the row markup looks like this:
<div class="wb-row wb-active wb-focus" style="top: 66px;">
<span
class="wb-node wb-col wb-active"
draggable="true"
style="left: 0px; width: 250px;"
>
<i class="wb-checkbox bi bi-square"></i>
<i class="wb-indent"></i>
<i class="wb-expander wb-indent"></i>
<i class="wb-icon bi bi-file-earmark"></i>
<span class="wb-title" style="width: 163px;">The Little Prince</span>
</span>
<span class="wb-col" style="left: 250px; width: 234.75px;">
Antoine de Saint-Exupery
</span>
<span class="wb-col" style="left: 484.75px; width: 50px;">1943</span>
<span class="wb-col" style="left: 534.75px; width: 50px;">2946</span>
<span class="wb-col" style="left: 584.75px; width: 80px;">6.82</span>
<span class="wb-col" style="left: 664.75px; width: 703.25px;"></span>
</div>
The e.nodeElem
property contains the HTML span element that represents the
node title, and prefix icons:
<span class="wb-node wb-col"> ... </span>
Info
See WbRenderEventType for an overview of all event properties.
const tree = new Wunderbaum({
...
render: function (e) {
const node = e.node;
const nodeElement = e.nodeElement; // HTMLSpanElement
console.log(e.type, e.isNew, e);
nodeElement.innerText = `${node.title}!`;
},
});
Info
The render event is especially useful to render the content of grid cells in treegrids. See also the Grid Tutorial and the Edit Tutorial for rendering of embedded input controls in grids.
Badges#
Badges are small icons that can be displayed near the node title.
Example: Display the number of selected subnodes in the badge of collapsed parent:
const tree = new Wunderbaum({
...
iconBadge: (e) => {
const node = e.node;
if (node.expanded || !node.children) {
return;
}
const count = node.children && node.getSelectedNodes().length;
return {
badge: count,
badgeTooltip: `${count} selected`,
badgeClass: "selection-count",
};
},
...
});
div.wunderbaum span.wb-badge.selection-count {
color: white;
background-color: green;
}
See also
See also WbIconBadgeEventType and WbIconBadgeEventResultType.
<!-- ### Related Tree Options
Related Methods#
util.toggleCheckbox()
Related CSS Rules#
Code Hacks#
``` -->
```