From a86ae5b36110dcc1baf9a8a0517f024addc93f7a Mon Sep 17 00:00:00 2001 From: Michal Rentka Date: Mon, 2 Dec 2024 16:24:22 +0100 Subject: [PATCH] Fixed disabling active annotation tool --- .../Views/HtmlEpubDocumentViewController.swift | 3 ++- .../Detail/ParentWithSidebarController.swift | 15 ++++++++++----- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/Zotero/Scenes/Detail/HTML:EPUB/Views/HtmlEpubDocumentViewController.swift b/Zotero/Scenes/Detail/HTML:EPUB/Views/HtmlEpubDocumentViewController.swift index 26b74f250..092747226 100644 --- a/Zotero/Scenes/Detail/HTML:EPUB/Views/HtmlEpubDocumentViewController.swift +++ b/Zotero/Scenes/Detail/HTML:EPUB/Views/HtmlEpubDocumentViewController.swift @@ -274,6 +274,7 @@ class HtmlEpubDocumentViewController: UIViewController { extension HtmlEpubDocumentViewController: ParentWithSidebarDocumentController { func disableAnnotationTools() { - set(tool: nil) + guard let tool = viewModel.state.activeTool else { return } + viewModel.process(action: .toggleTool(tool)) } } diff --git a/Zotero/Scenes/Detail/ParentWithSidebarController.swift b/Zotero/Scenes/Detail/ParentWithSidebarController.swift index e5eb8756f..42a8154e4 100644 --- a/Zotero/Scenes/Detail/ParentWithSidebarController.swift +++ b/Zotero/Scenes/Detail/ParentWithSidebarController.swift @@ -59,8 +59,7 @@ extension ParentWithSidebarController { checkbox.rx.controlEvent(.touchUpInside) .subscribe(onNext: { [weak self, weak checkbox] _ in guard let self, let checkbox else { return } - checkbox.isSelected = !checkbox.isSelected - annotationToolbarHandler?.set(hidden: !checkbox.isSelected, animated: true) + setAnnotationToolbar(hidden: checkbox.isSelected) }) .disposed(by: disposeBag) let barButton = UIBarButtonItem(customView: checkbox) @@ -71,10 +70,16 @@ extension ParentWithSidebarController { return barButton } + private func setAnnotationToolbar(hidden: Bool) { + (toolbarButton.customView as? CheckboxButton)?.isSelected = !hidden + annotationToolbarHandler?.set(hidden: hidden, animated: true) + if hidden { + documentController?.disableAnnotationTools() + } + } + func closeAnnotationToolbar() { - (toolbarButton.customView as? CheckboxButton)?.isSelected = false - annotationToolbarHandler?.set(hidden: true, animated: true) - documentController?.disableAnnotationTools() + setAnnotationToolbar(hidden: true) } func toggleSidebar(animated: Bool, sidebarButtonTag: Int) {