2020-09-06 09:46:27 +10:00
|
|
|
function expandChildren(node) {
|
|
|
|
if (node.data.autoExpand && !node.isExpanded()) {
|
|
|
|
node.setExpanded(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.children && node.children.length > 0) {
|
|
|
|
try {
|
|
|
|
node.children.forEach(expandChildren);
|
|
|
|
} catch (error) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$(document).ready(function() {
|
2020-09-13 21:30:04 +10:00
|
|
|
// If our bases have been set, we'll render them directly
|
|
|
|
if (typeof basedn !== 'undefined') {
|
|
|
|
sources = basedn;
|
|
|
|
} else {
|
|
|
|
sources = { url: 'api/bases' };
|
|
|
|
}
|
|
|
|
|
2020-09-06 09:46:27 +10:00
|
|
|
// Attach the fancytree widget to an existing <div id="tree"> element
|
|
|
|
// and pass the tree options as an argument to the fancytree() function:
|
|
|
|
$('#tree').fancytree({
|
|
|
|
clickFolderMode: 3,
|
|
|
|
extensions: ['glyph'],
|
|
|
|
autoCollapse: true, // Automatically collapse all siblings, when a node is expanded.
|
|
|
|
autoScroll: true, // Automatically scroll nodes into visible area.
|
|
|
|
focusOnSelect: true, // Set focus when node is checked by a mouse click
|
2020-09-13 21:30:04 +10:00
|
|
|
click: function(event,data) {
|
|
|
|
if (data.targetType == 'title') {
|
|
|
|
$.ajax({
|
2021-12-08 23:26:12 +11:00
|
|
|
url: 'dn',
|
2020-09-13 21:30:04 +10:00
|
|
|
method: 'POST',
|
|
|
|
data: { key: data.node.data.item },
|
|
|
|
dataType: 'html',
|
2020-09-19 00:08:00 +10:00
|
|
|
beforeSend: function() {
|
|
|
|
content = $('.main-content').contents();
|
|
|
|
$('.main-content').empty().append('<div class="fa-3x"><i class="fas fa-spinner fa-pulse"></i></div>');
|
|
|
|
}
|
2020-09-13 21:30:04 +10:00
|
|
|
|
|
|
|
}).done(function(html) {
|
|
|
|
$('.main-content').empty().append(html);
|
|
|
|
|
2023-03-02 09:56:09 +11:00
|
|
|
}).fail(function(item) {
|
|
|
|
switch(item.status) {
|
|
|
|
case 404:
|
|
|
|
$('.main-content').empty().append(item.responseText);
|
|
|
|
break;
|
|
|
|
case 419:
|
|
|
|
alert('Session has expired, reloading the page and try again...');
|
|
|
|
location.reload();
|
|
|
|
break;
|
|
|
|
case 500:
|
|
|
|
$('.main-content').empty().append(item.responseText);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
alert(item.status+': Well that didnt work?');
|
|
|
|
}
|
2020-09-13 21:30:04 +10:00
|
|
|
});
|
|
|
|
}
|
2020-09-06 09:46:27 +10:00
|
|
|
},
|
2020-09-13 21:30:04 +10:00
|
|
|
source: sources,
|
2020-09-06 09:46:27 +10:00
|
|
|
lazyLoad: function(event,data) {
|
|
|
|
data.result = {
|
2020-09-20 23:29:22 +10:00
|
|
|
url: '/api/children',
|
2020-09-06 09:46:27 +10:00
|
|
|
data: {key: data.node.data.item,depth: 1}
|
|
|
|
};
|
|
|
|
|
|
|
|
expandChildren(data.tree.rootNode);
|
|
|
|
},
|
|
|
|
keydown: function(event, data){
|
|
|
|
switch( $.ui.fancytree.eventToString(data.originalEvent) ) {
|
2020-09-14 21:08:55 +10:00
|
|
|
case 'return':
|
|
|
|
case 'space':
|
2020-09-06 09:46:27 +10:00
|
|
|
data.node.toggleExpanded();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|