mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-27 10:08:11 +08:00
93 lines
2.8 KiB
JavaScript
93 lines
2.8 KiB
JavaScript
/**
|
|
* The functions here are global because they need to be
|
|
* accesed from outside (in reports view).
|
|
*/
|
|
|
|
/* global PerfectSb */
|
|
|
|
var Sidebar = (function() {
|
|
const SIDEBAR_ID = '#slide-panel';
|
|
const STORAGE_TREE_KEY = 'scinote-sidebar-tree-state';
|
|
const STORAGE_SCROLL_TREE_KEY = 'scinote-sidebar-tree-scroll-state';
|
|
|
|
function toggleTree($treeChildren) {
|
|
$treeChildren.toggleClass('hidden');
|
|
$.each($treeChildren, (i, treeChild) => {
|
|
$(treeChild).closest('.branch').find('.tree-toggle').first()
|
|
.toggleClass('fa-caret-down')
|
|
.toggleClass('fa-caret-right');
|
|
});
|
|
}
|
|
|
|
function saveCurrentState() {
|
|
var config = [];
|
|
$.each($(SIDEBAR_ID).find('.tree-child:not(:hidden)'), (i, branch) => {
|
|
config.push(`[data-branch-id=${branch.dataset.branchId}]`);
|
|
});
|
|
sessionStorage.setItem(STORAGE_TREE_KEY, config.join(','));
|
|
}
|
|
|
|
function loadLastState() {
|
|
var currentProject = $(SIDEBAR_ID).attr('data-current-project');
|
|
var currentExperiment = $(SIDEBAR_ID).attr('data-current-experiment');
|
|
var currentTask = $(SIDEBAR_ID).attr('data-current-task');
|
|
|
|
if (currentProject) {
|
|
let projectBranch = $(`.tree-child[data-branch-id="pro${currentProject}"]`).attr('data-active', 'true');
|
|
projectBranch.prev().addClass('active');
|
|
if (!currentExperiment) projectBranch.closest('.branch').addClass('active');
|
|
}
|
|
|
|
if (currentExperiment) {
|
|
let experimentBranch = $(`.tree-child[data-branch-id="exp${currentExperiment}"]`).attr('data-active', 'true');
|
|
experimentBranch.prev().addClass('active');
|
|
if (!currentTask) {
|
|
experimentBranch.closest('.branch')
|
|
.addClass('show-canvas-handler')
|
|
.addClass('active');
|
|
}
|
|
}
|
|
|
|
if (currentTask) {
|
|
$(`.leaf[data-module-id="${currentTask}"]`).addClass('active');
|
|
}
|
|
|
|
|
|
toggleTree($(SIDEBAR_ID).find('.tree-child[data-active="true"]'));
|
|
toggleTree($(SIDEBAR_ID).find('.tree-child.hidden').filter(sessionStorage.getItem(STORAGE_TREE_KEY)));
|
|
PerfectSb().update_all();
|
|
$(SIDEBAR_ID).find('.tree').scrollTo(sessionStorage.getItem(STORAGE_SCROLL_TREE_KEY));
|
|
}
|
|
|
|
function initSideBar() {
|
|
$(SIDEBAR_ID).on('click', '.tree-toggle', function() {
|
|
var $treeChild = $(this).closest('.branch').find('.tree-child').first();
|
|
toggleTree($treeChild);
|
|
saveCurrentState();
|
|
PerfectSb().update_all();
|
|
});
|
|
|
|
$(SIDEBAR_ID).find('.tree').scroll(function() {
|
|
sessionStorage.setItem(STORAGE_SCROLL_TREE_KEY, $(this).scrollTop());
|
|
});
|
|
|
|
$('#wrapper').show();
|
|
loadLastState();
|
|
}
|
|
|
|
return {
|
|
init: () => {
|
|
if ($(SIDEBAR_ID).length) {
|
|
initSideBar();
|
|
}
|
|
},
|
|
|
|
loadLastState: () => {
|
|
loadLastState();
|
|
}
|
|
};
|
|
}());
|
|
|
|
$(document).on('turbolinks:load', function() {
|
|
Sidebar.init();
|
|
});
|