mirror of
https://github.com/nextcloud/desktop.git
synced 2024-11-24 05:55:59 +03:00
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:
parent
d2242ea9a4
commit
bab3b4181c
4 changed files with 22 additions and 12 deletions
|
@ -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
|
||||
}
|
||||
|
|
|
@ -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]
|
||||
|
|
|
@ -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) {
|
||||
|
|
|
@ -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)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue