Rework js tree drilldown to just directly insert new rows instead of using nested tables, to fix issues with uneven table widths
[gitphp.git] / js / tree.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * GitPHP javascript tree
 * 
 * Load subtree data into tree page asynchronously
 *
 * @author Christopher Han <xiphux@gmail.com>
 * @copyright Copyright (c) 2010 Christopher Han
 * @package GitPHP
 * @subpackage Javascript
 */
 
function initTree() {
        var project = window.location.href.match(/p=([^&]+)/);
        if (!project) {
                return;
        }
        project = unescape(project[1]);
 
        $('a.jsTree').live('click', function() {
                var treeHash = $(this).attr('href').match(/h=([0-9a-fA-F]{40}|HEAD)/);
                if (!treeHash) {
                        return;
                }
 
                treeHash = treeHash[1];
 
                var treeRows = $('.' + treeHash);
                if (treeRows && treeRows.size() > 0) {
                        if (treeRows.is(':visible'))
                                treeRows.hide();
                        else
                                treeRows.show();
                } else {
                        var cell = $(this).parent();
                        var row = cell.parent();
                        var indent = cell.html().match(/^(—+)/);
                        if (indent)
                                indent = indent[1];
                        else
                                indent = '';
                        indent += '—';
 
                        $.get($(this).attr('href'), { o: 'js' },
                        function(data) {
                                var subRows = jQuery(data);
 
                                subRows.addClass(treeHash);
 
                                var classList = row.attr('class').split(/\s+/);
                                $.each(classList, function(index, item) {
                                        if (item.match(/[0-9a-fA-F]{40}/)) {
                                                subRows.addClass(item);
                                        }
                                });
 
                                subRows.find('td.fileName').prepend(indent);
 
                                row.after(subRows);
                        });
                }
 
                return false;
        });
}
 
$(document).ready(function() {
        initTree();
});
 
comments