orgchart
Version:
Simple and direct organization chart(tree-like hierarchy) plugin based on pure DOM and jQuery.
82 lines (77 loc) • 2.6 kB
HTML
<html lang="en">
<head>
<meta charset="utf-8">
<title>Organization Chart Plugin</title>
<link rel="icon" href="img/logo.png">
<link rel="stylesheet" href="css/jquery.orgchart.css">
<link rel="stylesheet" href="css/style.css">
<style type="text/css">
.orgchart { background: white; }
</style>
</head>
<body>
<div id="chart-container"></div>
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/jquery.orgchart.js"></script>
<script type="text/javascript">
$(function() {
var datascource = {
'name': 'Lao Lao',
'title': 'general manager',
'children': [
{ 'name': 'Bo Miao', 'title': 'department manager' },
{ 'name': 'Su Miao', 'title': 'department manager',
'children': [
{ 'name': 'Tie Hua', 'title': 'senior engineer' },
{ 'name': 'Hei Hei', 'title': 'senior engineer',
'children': [
{ 'name': 'Pang Pang', 'title': 'engineer' },
{ 'name': 'Dan Zai', 'title': 'UE engineer',
'children': [
{ 'name': 'Er Dan Zai', 'title': 'engineer',
'children': [
{ 'name': 'AAA', 'title': 'Intern' },
{ 'name': 'BBB', 'title': 'Intern' }
]
}
]
}
]
}
]
},
{ 'name': 'Hong Miao', 'title': 'department manager' },
{ 'name': 'Chun Miao', 'title': 'department manager' }
]
};
var showDescendents = function(node, visibleLevel) {
if (visibleLevel === 1) {
return false;
}
$(node).closest('tr').siblings(':last').children().find('.node:first').each(function(index, node) {
var $temp = $(node).closest('tr').siblings().removeClass('hidden');
var $children = $temp.last().children().find('.node:first');
if ($children.length) {
$children[0].style.offsetWidth = $children[0].offsetWidth;
}
$children.removeClass('slide-up');
showDescendents(node, visibleLevel--);
});
};
$('#chart-container').orgchart({
'visibleLevel': 2,
'data' : datascource,
'nodeContent': 'title',
'createNode': function($node, data) {
$node.on('click', '.edge', function (event) {
if ($(event.target).is('.fa-chevron-down')) {
showDescendents(this, 3);
}
});
}
});
});
</script>
</body>
</html>