| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- var com_github_culmat_jsTreeTable = (function(){
- function depthFirst(tree, func, childrenAttr) {
- childrenAttr = childrenAttr || 'children'
- function i_depthFirst(node) {
- if (node[childrenAttr]) {
- $.each(node[childrenAttr], function(i, child) {
- i_depthFirst(child)
- })
- }
- func(node)
- }
- $.each(tree, function(i, root) {
- i_depthFirst(root)
- })
- return tree
- }
-
- /*
- * make a deep copy of the object
- */
- function copy(data){
- return JSON.parse(JSON.stringify(data))
- }
-
- function makeTree (data, idAttr, refAttr, childrenAttr) {
- var data_tmp = data
- idAttr = idAttr || 'id'
- refAttr = refAttr || 'parent'
- childrenAttr = childrenAttr || 'children'
-
- var byName = []
- $.each(data_tmp, function(i, entry) {
- byName[entry[idAttr]] = entry
- })
- var tree = []
- $.each(data_tmp, function(i, entry) {
- var parents = entry[refAttr]
- if(!$.isArray(parents)){
- parents = [parents]
- }
- if(parents.length == 0){
- tree.push(entry)
- } else {
- var inTree = false;
- $.each(parents, function(i,parentID){
- var parent = byName[parentID]
- if (parent) {
- if (!parent[childrenAttr]) {
- parent[childrenAttr] = []
- }
- if($.inArray(entry, parent[childrenAttr])< 0)
- parent[childrenAttr].push(entry)
- inTree = true
- }
- })
- if(!inTree){
- tree.push(entry)
- }
- }
- })
- return tree
- }
-
- function renderTree(tree, childrenAttr, idAttr, attrs, renderer, tableAttributes) {
- childrenAttr = childrenAttr || 'children'
- idAttr = idAttr || 'id'
- tableAttributes = tableAttributes || {}
- var maxLevel = 0;
- var ret = []
-
- var table = $("<table>")
- $.each(tableAttributes, function(key, value){
- if(key == 'class' && value != 'jsTT') {
- table.addClass(value)
- } else {
- table.attr(key, value)
- }
- })
- var thead = $("<thead>")
- var tr = $("<tr>")
- var tbody = $("<tbody>")
-
- table.append(thead)
- thead.append(tr)
- table.append(tbody)
- if (attrs) {
- $.each(attrs, function(attr, desc) {
- $(tr).append($('<th>' + desc + '</th>'))
- })
- } else {
- $(tr).append($('<th>' + idAttr + '</th>'))
- $.each(tree[0], function(key, value) {
- if (key != childrenAttr && key != idAttr)
- $(tr).append($('<th>' + key + '</th>'))
- })
- }
-
- function render(node, parent) {
- var tr = $("<tr>")
- $(tr).attr('data-tt-id', node[idAttr])
- $(tr).attr('data-tt-level', node['data-tt-level'])
- if(!node[childrenAttr] || node[childrenAttr].length == 0)
- $(tr).attr('data-tt-isleaf', true)
- else
- $(tr).attr('data-tt-isnode', true)
- if (parent) {
- $(tr).attr('data-tt-parent-id', parent[idAttr])
- }
- if (renderer) {
- renderer($(tr), node)
- }else if (attrs) {
- $.each(attrs, function(attr, desc) {
- $(tr).append($('<td>' + node[attr] + '</td>'))
- })
- } else {
- $(tr).append($('<td>' + node[idAttr] + '</td>'))
- $.each(node, function(key, value) {
- if (key != childrenAttr && key != idAttr && key != 'data-tt-level')
- $(tr).append($('<td>' + value + '</td>'))
- })
- }
- tbody.append(tr)
- }
-
- function i_renderTree(subTree, childrenAttr, level, parent) {
- maxLevel = Math.max(maxLevel, level)
- $.each(subTree, function(i, node) {
- node['data-tt-level'] = level
- render(node, parent)
- if (node[childrenAttr]) {
- $.each(node[childrenAttr], function(i, child) {
- i_renderTree([ child ], childrenAttr, level + 1, node)
- })
- }
- })
- }
- i_renderTree(tree, childrenAttr, 1)
- if (tree[0])
- tree[0].maxLevel = maxLevel
- return table
- }
-
- function attr2attr(nodes, attrs){
- $.each(nodes, function(i, node) {
- $.each(attrs, function(j, at) {
- node[at] = $(node).attr(at)
- })
- })
- return nodes
- }
-
- function treeTable(table){
- table.addClass('jsTT')
- table.expandLevel = function (n) {
- $("tr[data-tt-level]", table).each(function(index) {
- var level = parseInt($(this).attr('data-tt-level'))
- if (level > n-1) {
- this.trCollapse(true)
- } else if (level == n-1){
- this.trExpand(true)
- }
- })
- }
- function getLevel(node){
- var level = node.attr('data-tt-level')
- if(level != undefined ) return parseInt(level)
- var parentID = node.attr('data-tt-parent-id')
- if( parentID == undefined){
- return 0
- } else {
- return getLevel($('tr[data-tt-id="'+parentID+'"]', table).first()) + 1
- }
- }
- $("tr[data-tt-id]", table).each(function(i,node){
- node = $(node)
- node.attr('data-tt-level', getLevel(node))
- })
- var dat = $("tr[data-tt-level]", table).get()
- $.each(dat, function(j, d) {
- d.trChildrenVisible = true
- d.trChildren = []
- })
- dat = attr2attr(dat, ['data-tt-id', 'data-tt-parent-id'])
- dat = makeTree(dat, 'data-tt-id', 'data-tt-parent-id', 'trChildren')
-
- var imgExpand = ""
- var imgCollapse = ""
- $("tr[data-tt-level]", table).each(function(index, tr) {
- var level = $(tr).attr('data-tt-level')
- var td = $("td",tr).first()
- if(tr.trChildren.length>0){
- td.prepend($('<img id="state" style="cursor:pointer" src="'+imgCollapse+'"/>'))
- } else {
- td.prepend($('<span style="padding-left:16px;" /></span>'))
- }
- td.prepend($('<span style="padding-left:'+(15*parseInt(level-1))+'px;" /></span>'))
- // td.css('white-space','nowrap')
- tr.trExpand = function(changeState){
- if(this.trChildren.length < 1) return
- if(changeState) {
- this.trChildrenVisible = true
- $('#state', this).get(0).src= imgCollapse
- }
- var doit = changeState || this.trChildrenVisible
- $.each(this.trChildren, function(i, ctr) {
- if(doit) $(ctr).css('display', 'table-row')
- ctr.trExpand()
- })
- }
- tr.trCollapse = function(changeState){
- if(this.trChildren.length < 1) return
- if(changeState) {
- this.trChildrenVisible = false
- $('#state', this).get(0).src= imgExpand
- }
- $.each(this.trChildren, function(i, ctr) {
- $(ctr).css('display', 'none')
- ctr.trCollapse()
- })
- }
- $(tr).click(function() {
- this.trChildrenVisible ? this.trCollapse(true) : this.trExpand(true)
- })
- })
- return table
- }
-
- function appendTreetable(tree, options) {
- function inALine(nodes) {
- var tr = $('<tr>')
- $.each(nodes, function(i, node){
- tr.append($('<td style="padding-right: 20px;">').append(node))
- })
- return $('<table border="0"/>').append(tr)
-
- }
- options = options || {}
- options.idAttr = (options.idAttr || 'id')
- options.childrenAttr = (options.childrenAttr || 'children')
- var controls = (options.controls || [])
-
- if (!options.mountPoint)
- options.mountPoint = $('body')
-
- if (options.depthFirst)
- depthFirst(tree, options.depthFirst, options.childrenAttr)
- var rendered = renderTree(tree, options.childrenAttr, options.idAttr,
- options.renderedAttr, options.renderer, options.tableAttributes)
-
- treeTable(rendered)
- if (options.replaceContent) {
- options.mountPoint.html('')
- }
- var initialExpandLevel = options.initialExpandLevel ? parseInt(options.initialExpandLevel) : -1
- initialExpandLevel = Math.min(initialExpandLevel, tree[0].maxLevel)
- rendered.expandLevel(initialExpandLevel)
- if(options.slider){
- var slider = $('<div style="margin-right: 15px;">')
- slider.width('200px')
- slider.slider({
- min : 1,
- max : tree[0].maxLevel,
- range : "min",
- value : initialExpandLevel,
- slide : function(event, ui) {
- rendered.expandLevel(ui.value)
- }
- })
- controls = [slider].concat(options.controls)
- }
-
- if(controls.length >0){
- options.mountPoint.append(inALine(controls))
- }
- options.mountPoint.append(rendered)
- return rendered
- }
-
- return {
- depthFirst : depthFirst,
- makeTree : makeTree,
- renderTree : renderTree,
- attr2attr : attr2attr,
- treeTable : treeTable,
- appendTreetable : appendTreetable,
- jsTreeTable : '1.0',
- register : function(target){
- $.each(this, function(key, value){ if(key != 'register') target[key] = value})
- }
- }
- })();
|