orgchart
Version:
Simple and direct organization chart(tree-like hierarchy) plugin based on pure DOM and jQuery.
151 lines (139 loc) • 5.14 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">
</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" src="js/jquery.mockjax.min.js"></script>
<script type="text/javascript">
$(function() {
$.mockjax({
url: '/orgchart/ancestors/n1',
contentType: 'application/json',
responseTime: 1000,
responseText: {
'id': 'n0',
'name': 'Lao Lao',
'title': 'general manager', 'relationship': '001',
'children': [
{ 'id': 'n10','name': 'Bo Miao', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n11', 'name': 'Yu Jie', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n12', 'name': 'Yu Li', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n13', 'name': 'Hong Miao', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n14', 'name': 'Yu Wei', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n15', 'name': 'Chun Miao', 'title': 'department engineer', 'relationship': '110' },
{ 'id': 'n16', 'name': 'Yu Tie', 'title': 'department engineer', 'relationship': '110' }
]
}
});
$.mockjax({
url: '/orgchart/descendants/n2',
contentType: 'application/json',
responseTime: 1000,
responseText: [
{ 'id': 'n4', 'name': 'Xiang Xiang', 'title': 'engineer', 'relationship': '110' }
]
});
$.mockjax({
url: '/orgchart/descendants/n3',
contentType: 'application/json',
responseTime: 1000,
responseText: [
{ 'id': 'n5', 'name': 'Pang Pang', 'title': 'engineer', 'relationship': '111',
'children': [
{ 'id': 'n6', 'name': 'Er Dan', 'title': 'UE engineer', 'relationship': '110'}
]
},
{ 'id': 'n7', 'name': 'Dan Dan', 'title': 'engineer', 'relationship': '110' }
]
});
var datascource = {
'id': 'n1',
'name': 'Su Miao',
'title': 'department manager',
'relationship': '111',
'children': [
{ 'id': 'n2','name': 'Tie Hua', 'title': 'senior engineer', 'relationship': '111' },
{ 'id': 'n3','name': 'Hei Hei', 'title': 'senior engineer', 'relationship': '111' }
]
};
var ajaxURLs = {
'children': '/orgchart/children/',
'parent': '/orgchart/parent/',
'siblings': function(nodeData) {
return '/orgchart/siblings/' + nodeData.id;
},
'families': function(nodeData) {
return '/orgchart/families/' + nodeData.id;
}
};
var oc = $('#chart-container').orgchart({
'data' : datascource,
'nodeContent': 'title',
'nodeId': 'id'
});
oc.$chart.on('click', '.topEdge, .horizontalEdge', function(e) {
var $chart = oc.$chart;
var $topEdge = $(e.target);
var $node = $topEdge.parent();
var parentState = oc.getNodeState($node, 'parent');
if (!parentState.exist) {
if (!($chart.data('inAjax') === true)) {
$topEdge.addClass('hidden');
$node.append(`<i class="oci oci-spinner spinner"></i>`)
$node.children().not('.spinner').css('opacity', 0.2);
$chart.data('inAjax', true);
$.ajax({
'url': '/orgchart/ancestors/' + $node.data('nodeData').id,
'dataType': 'json'
})
.done(function(data, textStatus, jqXHR) {
oc.addAncestors(data, 'n0');
})
.always(function() {
$topEdge.removeClass('hidden');
$node.children('.spinner').remove();
$node.children().removeAttr('style');
$chart.data('inAjax', false);
});
}
}
});
oc.$chart.on('click', '.bottomEdge', function(e) {
var $chart = oc.$chart;
var $bottomEdge = $(e.target);
var $node = $bottomEdge.parent();
var childrenState = oc.getNodeState($node, 'children');
if (!childrenState.exist) {
if (!($chart.data('inAjax') === true)) {
$bottomEdge.addClass('hidden');
$node.append(`<i class="oci oci-spinner spinner"></i>`)
$node.children().not('.spinner').css('opacity', 0.2);
$chart.data('inAjax', true);
$.ajax({
'url': '/orgchart/descendants/' + $node.data('nodeData').id,
'dataType': 'json'
})
.done(function(data, textStatus, jqXHR) {
oc.addDescendants(data, $node);
})
.always(function() {
$bottomEdge.removeClass('hidden');
$node.children('.spinner').remove();
$node.children().removeAttr('style');
$chart.data('inAjax', false);
});
}
}
});
});
</script>
</body>
</html>