-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpanel-controller.js
More file actions
45 lines (40 loc) · 1.19 KB
/
panel-controller.js
File metadata and controls
45 lines (40 loc) · 1.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// Panel Controller for handling panel visibility
document.addEventListener("DOMContentLoaded", function () {
// Initialize all panels as hidden
const panels = document.querySelectorAll(".nav-panel");
panels.forEach((panel) => {
if (!panel.classList.contains("hidden")) {
panel.classList.add("hidden");
}
});
// Show the info panel by default
const infoPanel = document.getElementById("info-panel");
if (infoPanel) {
infoPanel.classList.remove("hidden");
}
// Set up close button event listeners
const closeButtons = document.querySelectorAll(".close-btn");
closeButtons.forEach((button) => {
button.addEventListener("click", function (e) {
// Find the parent panel
const panel = e.target.closest(".nav-panel");
if (panel) {
panel.classList.add("hidden");
}
});
});
});
// Helper function to toggle panel visibility
window.togglePanel = function (panelId) {
const panels = document.querySelectorAll(".nav-panel");
const panel = document.getElementById(panelId);
if (!panel) return;
// Hide all other panels first
panels.forEach((p) => {
if (p.id !== panelId) {
p.classList.add("hidden");
}
});
// Toggle the target panel
panel.classList.toggle("hidden");
};