Fix options view disappearing when clicking create button in share view controller

Signed-off-by: Claudio Cambra <claudio.cambra@nextcloud.com>
This commit is contained in:
Claudio Cambra 2024-03-19 20:08:14 +08:00
parent d2242ea9a4
commit bab3b4181c
4 changed files with 22 additions and 12 deletions

View file

@ -274,7 +274,7 @@ class ShareOptionsView: NSView {
dataSource.uiDelegate?.showError("Error creating: \(error.errorDescription)")
setAllFields(enabled: true)
} else {
dataSource.uiDelegate?.hideOptions()
dataSource.uiDelegate?.hideOptions(self)
await dataSource.reload()
}
return
@ -306,7 +306,7 @@ class ShareOptionsView: NSView {
dataSource?.uiDelegate?.showError("Error updating share: \(error.errorDescription)")
setAllFields(enabled: true)
} else {
dataSource?.uiDelegate?.hideOptions()
dataSource?.uiDelegate?.hideOptions(self)
await dataSource?.reload()
}
}
@ -315,7 +315,7 @@ class ShareOptionsView: NSView {
@IBAction func delete(_ sender: Any) {
Task { @MainActor in
guard !createMode else {
dataSource?.uiDelegate?.hideOptions()
dataSource?.uiDelegate?.hideOptions(self)
reset()
return
}

View file

@ -238,7 +238,7 @@ class ShareTableViewDataSource: NSObject, NSTableViewDataSource, NSTableViewDele
@objc func tableViewSelectionDidChange(_ notification: Notification) {
guard let selectedRow = sharesTableView?.selectedRow, selectedRow >= 0 else {
Task { @MainActor in uiDelegate?.hideOptions() }
Task { @MainActor in uiDelegate?.hideOptions(self) }
return
}
let share = shares[selectedRow]

View file

@ -57,7 +57,7 @@ class ShareViewController: NSViewController, ShareViewDataSourceUIDelegate {
override func viewDidLoad() {
dismissError(self)
hideOptions()
hideOptions(self)
}
@IBAction func closeAction(_ sender: Any) {
@ -111,10 +111,12 @@ class ShareViewController: NSViewController, ShareViewDataSourceUIDelegate {
}
@IBAction func createShare(_ sender: Any) {
tableView.deselectAll(self)
optionsView.createMode = true
splitView.addArrangedSubview(optionsView)
optionsView.isHidden = false
tableView.deselectAll(self)
if !splitView.arrangedSubviews.contains(optionsView) {
splitView.addArrangedSubview(optionsView)
optionsView.isHidden = false
}
}
func fetchStarted() {
@ -127,16 +129,24 @@ class ShareViewController: NSViewController, ShareViewDataSourceUIDelegate {
loadingIndicator.stopAnimation(self)
}
func hideOptions() {
func hideOptions(_ sender: Any) {
if sender as? ShareTableViewDataSource == shareDataSource, optionsView.createMode {
// Do not hide options if the table view has had everything deselected when we set the
// options view to be in create mode
return
}
splitView.removeArrangedSubview(optionsView)
optionsView.isHidden = true
}
func showOptions(share: NKShare) {
guard let kit = shareDataSource.kit else { return }
optionsView.controller = ShareController(share: share, kit: kit)
splitView.addArrangedSubview(optionsView)
optionsView.isHidden = false
if !splitView.arrangedSubviews.contains(optionsView) {
splitView.addArrangedSubview(optionsView)
optionsView.isHidden = false
}
}
func showError(_ errorString: String) {

View file

@ -11,7 +11,7 @@ import NextcloudKit
protocol ShareViewDataSourceUIDelegate {
func fetchStarted()
func fetchFinished()
func hideOptions()
func hideOptions(_ sender: Any)
func showOptions(share: NKShare)
func showError(_ errorString: String)
}