jquerytreetable

How to get JQuery TreeTable and show/hide working together?


I am using the great JQuery TreeTable, I am very happy with it.

I would like to make certain rows in the table ("retired" terms in our controlled vocabulary) appear and disappear when the "show retired terms" checkbox is selected.

Ideally would work seamlessly with the tree's status, so expand and collapse would work as normal, but simply ignoring the hidden rows when the checkbox is selected.

Normally this type of thing could be done easily with JQuery's built-in show() and hide() functions. But when I use those on TreeTable rows, it messes up the table: hide() works fine, but when I try to show() them again, they appear at the top level of the tree, and don't inherit the expand/collapse state of their parent.

I've tried removing/renaming the data-tt-id attribute, calling the internal TreeTable render() function after using hide, and neither seems to help.

$("#mytree").treetable({ expandable: true });
$("#show-retired").change(function() {
    if ($(this).is(':checked')) {
        $("tr.retired").each(function() {
            if (!$(this).is(":hidden")) {
                $(this).show();
            }
        });
    } else {
        $("tr.retired").each(function() {
            $(this).hide();
        });
    }
});
table.treetable tr.collapsed span.indenter a {
  background-image: url();
}
table.treetable tr.expanded span.indenter a {
  background-image: url();
}
<!DOCTYPE html>
<html lang="en">
<head>
<link href="https://cdnjs.cloudflare.com/ajax/libs/jquery-treetable/3.2.0/css/jquery.treetable.css" rel="stylesheet" type="text/css" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<p><input type="checkbox" id="show-retired" />Show retired terms</p>

<table id="mytree" class="treetable">
<tbody>
<tr data-tt-id="1">
<td>Item 1</td>
</tr>
<tr data-tt-id="1.1" data-tt-parent-id="1" class="retired">
<td>Item 1.1 (retired)</td>
</tr>
<tr data-tt-id="1.2" data-tt-parent-id="1">
<td>Item 1.2</td>
</tr>
<tr data-tt-id="1.3" data-tt-parent-id="1" class="retired">
<td>Item 1.3 (retired)</td>
</tr>
<tr data-tt-id="2">
<td>Item 2</td>
</tr>
<tr data-tt-id="2.1" data-tt-parent-id="2">
<td>Item 2.1</td>
</tr>
<tr data-tt-id="2.2" data-tt-parent-id="2" class="retired">
<td>Item 2.2 (retired)</td>
</tr>
<tr data-tt-id="2.3" data-tt-parent-id="2">
<td>Item 2.3</td>
</tr>
</tbody>
</table>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-treetable/3.2.0/jquery.treetable.js"></script>
</body>
</html>

Any ideas?


Solution

  • For anyone who stumbles upon this question in the future, I ended up patching JQuery TreeTable to solve my problem.

    I added two functions, makeInvisible and its opposite makeVisible, which can remove/restore given rows in the table irrespective of whether that row is expanded or collapsed.

    My patched version is at https://github.com/bquinn/jquery-treetable