2024-02-23 21:34:33 -05:00
|
|
|
import { Controller } from "@hotwired/stimulus";
|
|
|
|
|
|
|
|
// Connects to data-controller="tabs"
|
|
|
|
export default class extends Controller {
|
2025-02-21 11:57:59 -05:00
|
|
|
static classes = ["active", "inactive"];
|
2024-02-23 21:34:33 -05:00
|
|
|
static targets = ["btn", "tab"];
|
2025-02-21 11:57:59 -05:00
|
|
|
static values = { defaultTab: String, localStorageKey: String };
|
2024-02-23 21:34:33 -05:00
|
|
|
|
|
|
|
connect() {
|
2025-02-21 11:57:59 -05:00
|
|
|
const selectedTab = this.hasLocalStorageKeyValue
|
|
|
|
? this.getStoredTab() || this.defaultTabValue
|
|
|
|
: this.defaultTabValue;
|
|
|
|
|
|
|
|
this.updateClasses(selectedTab);
|
2024-03-11 22:42:18 +01:00
|
|
|
document.addEventListener("turbo:load", this.onTurboLoad);
|
2024-02-23 21:34:33 -05:00
|
|
|
}
|
|
|
|
|
2024-03-01 17:14:06 -05:00
|
|
|
disconnect() {
|
2024-03-11 22:42:18 +01:00
|
|
|
document.removeEventListener("turbo:load", this.onTurboLoad);
|
2024-02-23 21:34:33 -05:00
|
|
|
}
|
2024-03-01 17:14:06 -05:00
|
|
|
|
|
|
|
select(event) {
|
2024-04-18 17:05:37 -04:00
|
|
|
const element = event.target.closest("[data-id]");
|
|
|
|
if (element) {
|
2025-02-21 11:57:59 -05:00
|
|
|
const selectedId = element.dataset.id;
|
|
|
|
this.updateClasses(selectedId);
|
|
|
|
if (this.hasLocalStorageKeyValue) {
|
|
|
|
this.storeTab(selectedId);
|
|
|
|
}
|
2024-04-18 17:05:37 -04:00
|
|
|
}
|
2024-03-01 17:14:06 -05:00
|
|
|
}
|
|
|
|
|
2024-03-11 22:42:18 +01:00
|
|
|
onTurboLoad = () => {
|
2025-02-21 11:57:59 -05:00
|
|
|
const selectedTab = this.hasLocalStorageKeyValue
|
|
|
|
? this.getStoredTab() || this.defaultTabValue
|
|
|
|
: this.defaultTabValue;
|
|
|
|
|
|
|
|
this.updateClasses(selectedTab);
|
2024-03-28 13:23:54 -04:00
|
|
|
};
|
2024-03-11 22:42:18 +01:00
|
|
|
|
2025-02-21 11:57:59 -05:00
|
|
|
getStoredTab() {
|
|
|
|
const tabs = JSON.parse(localStorage.getItem("tabs") || "{}");
|
|
|
|
return tabs[this.localStorageKeyValue];
|
|
|
|
}
|
|
|
|
|
|
|
|
storeTab(selectedId) {
|
|
|
|
const tabs = JSON.parse(localStorage.getItem("tabs") || "{}");
|
|
|
|
tabs[this.localStorageKeyValue] = selectedId;
|
|
|
|
localStorage.setItem("tabs", JSON.stringify(tabs));
|
|
|
|
}
|
|
|
|
|
2024-03-11 22:42:18 +01:00
|
|
|
updateClasses = (selectedId) => {
|
2025-02-21 11:57:59 -05:00
|
|
|
this.btnTargets.forEach((btn) => {
|
|
|
|
btn.classList.remove(...this.activeClasses);
|
|
|
|
btn.classList.remove(...this.inactiveClasses);
|
|
|
|
});
|
|
|
|
|
2024-03-01 17:14:06 -05:00
|
|
|
this.tabTargets.forEach((tab) => tab.classList.add("hidden"));
|
|
|
|
|
|
|
|
this.btnTargets.forEach((btn) => {
|
|
|
|
if (btn.dataset.id === selectedId) {
|
2024-03-28 13:23:54 -04:00
|
|
|
btn.classList.add(...this.activeClasses);
|
2025-02-21 11:57:59 -05:00
|
|
|
} else {
|
|
|
|
btn.classList.add(...this.inactiveClasses);
|
2024-03-01 17:14:06 -05:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
this.tabTargets.forEach((tab) => {
|
|
|
|
if (tab.id === selectedId) {
|
|
|
|
tab.classList.remove("hidden");
|
|
|
|
}
|
|
|
|
});
|
2024-03-28 13:23:54 -04:00
|
|
|
};
|
2024-02-23 21:34:33 -05:00
|
|
|
}
|