82 lines
2.1 KiB
JavaScript
Raw Normal View History

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({
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 = {
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) ) {
case 'return':
case 'space':
2020-09-06 09:46:27 +10:00
data.node.toggleExpanded();
break;
}
}
});
});