mac: close panel on second click

This commit is contained in:
Peter Steinberger
2025-12-09 23:25:49 +01:00
parent 6d91dad8e4
commit d5347176e1

View File

@@ -443,6 +443,7 @@ final class WebChatManager {
private var windowController: WebChatWindowController? private var windowController: WebChatWindowController?
private var panelController: WebChatWindowController? private var panelController: WebChatWindowController?
var onPanelVisibilityChanged: ((Bool) -> Void)? var onPanelVisibilityChanged: ((Bool) -> Void)?
private var isPanelVisible = false
func show(sessionKey: String) { func show(sessionKey: String) {
self.closePanel() self.closePanel()
@@ -461,6 +462,11 @@ final class WebChatManager {
} }
func togglePanel(sessionKey: String, anchorProvider: @escaping () -> NSRect?) { func togglePanel(sessionKey: String, anchorProvider: @escaping () -> NSRect?) {
if self.isPanelVisible {
self.closePanel()
return
}
if let controller = self.panelController { if let controller = self.panelController {
if controller.window?.isVisible == true { if controller.window?.isVisible == true {
controller.closePanel() controller.closePanel()
@@ -478,14 +484,19 @@ final class WebChatManager {
self?.panelHidden() self?.panelHidden()
} }
controller.onVisibilityChanged = { [weak self] visible in controller.onVisibilityChanged = { [weak self] visible in
self?.onPanelVisibilityChanged?(visible) guard let self else { return }
self.isPanelVisible = visible
self.onPanelVisibilityChanged?(visible)
} }
controller.presentAnchoredPanel(anchorProvider: anchorProvider) controller.presentAnchoredPanel(anchorProvider: anchorProvider)
// visibility will be reported by the controller callback
} }
func closePanel() { func closePanel() {
guard let controller = self.panelController else { return } guard let controller = self.panelController else { return }
controller.closePanel() controller.closePanel()
self.isPanelVisible = false
self.onPanelVisibilityChanged?(false)
} }
func preferredSessionKey() -> String { func preferredSessionKey() -> String {
@@ -517,6 +528,7 @@ final class WebChatManager {
} }
private func panelHidden() { private func panelHidden() {
self.isPanelVisible = false
self.onPanelVisibilityChanged?(false) self.onPanelVisibilityChanged?(false)
self.panelController = nil self.panelController = nil
} }