diff options
author | marinofaggiana <ios@nextcloud.com> | 2022-08-02 19:41:44 +0300 |
---|---|---|
committer | marinofaggiana <ios@nextcloud.com> | 2022-08-02 19:41:44 +0300 |
commit | c79ca138f5db0a95cfd8f336c937fe286dda51aa (patch) | |
tree | 1254fbf115a010b553139334f867c6a168a0bb27 | |
parent | ef0090cfd241e22590cc00d74dfbf4226a07d578 (diff) |
add extensions
Signed-off-by: marinofaggiana <ios@nextcloud.com>
6 files changed, 148 insertions, 0 deletions
diff --git a/Nextcloud.xcodeproj/project.pbxproj b/Nextcloud.xcodeproj/project.pbxproj index cf95bc3c3..875d0a48e 100644 --- a/Nextcloud.xcodeproj/project.pbxproj +++ b/Nextcloud.xcodeproj/project.pbxproj @@ -282,6 +282,9 @@ F77B0F611D118A16002130FE /* Acknowledgements.rtf in Resources */ = {isa = PBXBuildFile; fileRef = F7ACE42B1BAC0268006C0017 /* Acknowledgements.rtf */; }; F77B0F631D118A16002130FE /* Localizable.strings in Resources */ = {isa = PBXBuildFile; fileRef = F7E70DE91A24DE4100E1B66A /* Localizable.strings */; }; F77B0F7D1D118A16002130FE /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = F7F67BB81A24D27800EE80DA /* Images.xcassets */; }; + F77BB746289984CA0090FC19 /* UIViewController+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = F77BB745289984CA0090FC19 /* UIViewController+Extension.swift */; }; + F77BB748289985270090FC19 /* UITabBarController+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = F77BB747289985270090FC19 /* UITabBarController+Extension.swift */; }; + F77BB74A2899857B0090FC19 /* UINavigationController+Extension.swift in Sources */ = {isa = PBXBuildFile; fileRef = F77BB7492899857B0090FC19 /* UINavigationController+Extension.swift */; }; F78071091EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.m in Sources */ = {isa = PBXBuildFile; fileRef = F78071081EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.m */; }; F780710A1EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.m in Sources */ = {isa = PBXBuildFile; fileRef = F78071081EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.m */; }; F78295311F962EFA00A572F5 /* NCEndToEndEncryption.m in Sources */ = {isa = PBXBuildFile; fileRef = F70CAE391F8CF31A008125FD /* NCEndToEndEncryption.m */; }; @@ -769,6 +772,9 @@ F77910A425DD517B00CEDB9E /* Settings.bundle */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.plug-in"; path = Settings.bundle; sourceTree = "<group>"; }; F77910AA25DD53C700CEDB9E /* NCSettingsBundleHelper.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NCSettingsBundleHelper.swift; sourceTree = "<group>"; }; F77A697C250A0FBC00FF1708 /* NCCollectionViewCommon+Menu.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "NCCollectionViewCommon+Menu.swift"; sourceTree = "<group>"; }; + F77BB745289984CA0090FC19 /* UIViewController+Extension.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "UIViewController+Extension.swift"; sourceTree = "<group>"; }; + F77BB747289985270090FC19 /* UITabBarController+Extension.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "UITabBarController+Extension.swift"; sourceTree = "<group>"; }; + F77BB7492899857B0090FC19 /* UINavigationController+Extension.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "UINavigationController+Extension.swift"; sourceTree = "<group>"; }; F78071071EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = "NSNotificationCenter+MainThread.h"; sourceTree = "<group>"; }; F78071081EDAB65800EAFFF6 /* NSNotificationCenter+MainThread.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = "NSNotificationCenter+MainThread.m"; sourceTree = "<group>"; }; F785EE9C246196DF00B3F945 /* NCNetworkingE2EE.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NCNetworkingE2EE.swift; sourceTree = "<group>"; }; @@ -1448,6 +1454,9 @@ F70CEF5523E9C7E50007035B /* UIColor+Extensions.swift */, F79B645F26CA661600838ACA /* UIControl+Extensions.swift */, F7F4F10F27ECDC4A008676F9 /* UIDevice+Extensions.swift */, + F77BB747289985270090FC19 /* UITabBarController+Extension.swift */, + F77BB745289984CA0090FC19 /* UIViewController+Extension.swift */, + F77BB7492899857B0090FC19 /* UINavigationController+Extension.swift */, F7F4F11127ECDC52008676F9 /* UIFont+Extension.swift */, F713FEFE2472764000214AF6 /* UIImage+animatedGIF.h */, F713FEFF2472764100214AF6 /* UIImage+animatedGIF.m */, @@ -2524,6 +2533,7 @@ 371B5A2E23D0B04500FAFAE9 /* NCMenu.swift in Sources */, F79EDAA326B004980007D134 /* NCPlayerToolBar.swift in Sources */, F77444F8222816D5000D5EB0 /* NCPickerViewController.swift in Sources */, + F77BB74A2899857B0090FC19 /* UINavigationController+Extension.swift in Sources */, F72A47EC2487B06B005AD489 /* NCOperationQueue.swift in Sources */, F769454622E9F1B0000A798A /* NCShareCommon.swift in Sources */, F738E8421F90FFD100F95C8E /* NCManageEndToEndEncryption.m in Sources */, @@ -2547,6 +2557,7 @@ F704B5E92430C0B800632F5F /* NCCreateFormUploadConflictCell.swift in Sources */, F72D404923D2082500A97FD0 /* NCViewerNextcloudText.swift in Sources */, AFCE353927E5DE0500FEA6C2 /* NCShare+Helper.swift in Sources */, + F77BB746289984CA0090FC19 /* UIViewController+Extension.swift in Sources */, F700510522DF6A89003A3356 /* NCShare.swift in Sources */, F72D1007210B6882009C96B7 /* NCPushNotificationEncryption.m in Sources */, F785EE9D246196DF00B3F945 /* NCNetworkingE2EE.swift in Sources */, @@ -2639,6 +2650,7 @@ F704B5E52430AA8000632F5F /* NCCreateFormUploadConflict.swift in Sources */, F765608F23BF813600765969 /* NCContentPresenter.swift in Sources */, F70CEF5623E9C7E50007035B /* UIColor+Extensions.swift in Sources */, + F77BB748289985270090FC19 /* UITabBarController+Extension.swift in Sources */, F75AC2431F1F62450073EC19 /* NCManageAutoUploadFileName.swift in Sources */, F7C7B489245EBA4100D93E60 /* NCViewerQuickLook.swift in Sources */, F758B45E212C569D00515F55 /* NCScanCell.swift in Sources */, diff --git a/iOSClient/Extensions/UINavigationController+Extension.swift b/iOSClient/Extensions/UINavigationController+Extension.swift new file mode 100644 index 000000000..e0e987df6 --- /dev/null +++ b/iOSClient/Extensions/UINavigationController+Extension.swift @@ -0,0 +1,32 @@ +// +// UINavigationController+Extension.swift +// Nextcloud +// +// Created by Marino Faggiana on 02/08/2022. +// Copyright © 2022 Marino Faggiana. All rights reserved. +// +// Author Marino Faggiana <marino.faggiana@nextcloud.com> +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// + +import Foundation + +extension UINavigationController { + + // https://stackoverflow.com/questions/6131205/how-to-find-topmost-view-controller-on-ios + override func topMostViewController() -> UIViewController { + return self.visibleViewController!.topMostViewController() + } +} diff --git a/iOSClient/Extensions/UITabBarController+Extension.swift b/iOSClient/Extensions/UITabBarController+Extension.swift new file mode 100644 index 000000000..66e57c535 --- /dev/null +++ b/iOSClient/Extensions/UITabBarController+Extension.swift @@ -0,0 +1,32 @@ +// +// UITabBarController+Extension.swift +// Nextcloud +// +// Created by Marino Faggiana on 02/08/2022. +// Copyright © 2022 Marino Faggiana. All rights reserved. +// +// Author Marino Faggiana <marino.faggiana@nextcloud.com> +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// + +import Foundation + +extension UITabBarController { + + // https://stackoverflow.com/questions/6131205/how-to-find-topmost-view-controller-on-ios + override func topMostViewController() -> UIViewController { + return self.selectedViewController!.topMostViewController() + } +} diff --git a/iOSClient/Extensions/UIViewController+Extension.swift b/iOSClient/Extensions/UIViewController+Extension.swift new file mode 100644 index 000000000..172dccb03 --- /dev/null +++ b/iOSClient/Extensions/UIViewController+Extension.swift @@ -0,0 +1,64 @@ +// +// UIViewController+Extension.swift +// Nextcloud +// +// Created by Marino Faggiana on 02/08/2022. +// Copyright © 2022 Marino Faggiana. All rights reserved. +// +// Author Marino Faggiana <marino.faggiana@nextcloud.com> +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. +// + +import Foundation + +extension UIViewController { + + // https://stackoverflow.com/questions/6131205/how-to-find-topmost-view-controller-on-ios + @objc func topMostViewController() -> UIViewController { + // Handling Modal views + if let presentedViewController = self.presentedViewController { + return presentedViewController.topMostViewController() + } + // Handling UIViewController's added as subviews to some other views. + else { + for view in self.view.subviews { + // Key property which most of us are unaware of / rarely use. + if let subViewController = view.next { + if subViewController is UIViewController { + if let viewController = subViewController as? UIViewController { + return viewController.topMostViewController() + } + } + } + } + return self + } + } + + // https://stackoverflow.com/questions/23620276/how-to-check-if-a-view-controller-is-presented-modally-or-pushed-on-a-navigation + var isModal: Bool { + if let index = navigationController?.viewControllers.firstIndex(of: self), index > 0 { + return false + } else if presentingViewController != nil { + return true + } else if navigationController?.presentingViewController?.presentedViewController == navigationController { + return true + } else if tabBarController?.presentingViewController is UITabBarController { + return true + } else { + return false + } + } +} diff --git a/iOSClient/Main/AudioRecorder/NCAudioRecorderViewController.swift b/iOSClient/Main/AudioRecorder/NCAudioRecorderViewController.swift index 940389d16..c7835f016 100644 --- a/iOSClient/Main/AudioRecorder/NCAudioRecorderViewController.swift +++ b/iOSClient/Main/AudioRecorder/NCAudioRecorderViewController.swift @@ -63,6 +63,10 @@ class NCAudioRecorderViewController: UIViewController, NCAudioRecorderDelegate { super.viewWillAppear(animated) } + override func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + } + override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) { super.traitCollectionDidChange(previousTraitCollection) } diff --git a/iOSClient/Main/NCFunctionCenter.swift b/iOSClient/Main/NCFunctionCenter.swift index d15b19ac9..a075e346e 100644 --- a/iOSClient/Main/NCFunctionCenter.swift +++ b/iOSClient/Main/NCFunctionCenter.swift @@ -459,7 +459,11 @@ import Photos var topNavigationController: UINavigationController? var pushServerUrl = NCUtilityFileSystem.shared.getHomeServer(account: appDelegate.account) + let mostViewController = UIApplication.shared.keyWindow!.rootViewController!.topMostViewController() + let isPresented = mostViewController.presentedViewController + appDelegate.activeViewController?.navigationController?.popToRootViewController(animated: false) + if let tabBarController = appDelegate.window?.rootViewController as? UITabBarController { tabBarController.selectedIndex = 0 if let navigationController = tabBarController.viewControllers?.first as? UINavigationController { |