Notes/apps/client/src/widgets/containers/left_pane_container.ts

32 lines
1017 B
TypeScript
Raw Normal View History

import options from "../../services/options.js";
2020-02-07 22:19:35 +01:00
import FlexContainer from "./flex_container.js";
import appContext, { type EventData } from "../../components/app_context.js";
import type Component from "../../components/component.js";
export default class LeftPaneContainer extends FlexContainer<Component> {
2021-05-22 21:35:25 +02:00
constructor() {
2025-01-09 18:07:02 +02:00
super("column");
2025-01-09 18:07:02 +02:00
this.id("left-pane");
this.css("height", "100%");
2021-06-13 22:55:31 +02:00
this.collapsible();
}
isEnabled() {
2025-01-09 18:07:02 +02:00
return super.isEnabled() && options.is("leftPaneVisible");
}
entitiesReloadedEvent({ loadResults }: EventData<"entitiesReloaded">) {
2021-05-22 21:35:25 +02:00
if (loadResults.isOptionReloaded("leftPaneVisible")) {
const visible = this.isEnabled();
this.toggleInt(visible);
if (visible) {
2025-01-22 21:55:42 +02:00
this.triggerEvent("focusTree", {});
} else {
2025-03-03 21:02:18 +01:00
this.triggerEvent("focusOnDetail", { ntxId: appContext.tabManager.getActiveContext()?.ntxId });
}
}
}
}