mac: close panel on second click
This commit is contained in:
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user