UNPKG

orgchart

Version:

Simple and direct organization chart(tree-like hierarchy) plugin based on pure DOM and jQuery.

82 lines (77 loc) 2.6 kB
<!DOCTYPE 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>