NCShare.swift 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. //
  2. // NCShare.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 17/07/2019.
  6. // Copyright © 2019 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Marino Faggiana <marino.faggiana@nextcloud.com>
  9. //
  10. // This program is free software: you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation, either version 3 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. //
  23. import Foundation
  24. import Parchment
  25. class NCSharePaging: UIViewController {
  26. private let pagingViewController = NCShareHeaderViewController()
  27. @objc var metadata: tableMetadata?
  28. override func viewDidLoad() {
  29. super.viewDidLoad()
  30. pagingViewController.metadata = metadata
  31. // Navigation Controller
  32. var image = CCGraphics.changeThemingColorImage(UIImage(named: "exit")!, width: 40, height: 40, color: UIColor.gray)
  33. image = image?.withRenderingMode(.alwaysOriginal)
  34. self.navigationItem.rightBarButtonItem = UIBarButtonItem(image: image, style:.plain, target: self, action: #selector(exitTapped))
  35. // Pagination
  36. addChild(pagingViewController)
  37. view.addSubview(pagingViewController.view)
  38. pagingViewController.didMove(toParent: self)
  39. pagingViewController.selectedTextColor = .black
  40. pagingViewController.indicatorColor = .black
  41. pagingViewController.indicatorOptions = .visible(
  42. height: 1,
  43. zIndex: Int.max,
  44. spacing: .zero,
  45. insets: .zero
  46. )
  47. // Contrain the paging view to all edges.
  48. pagingViewController.view.translatesAutoresizingMaskIntoConstraints = false
  49. NSLayoutConstraint.activate([
  50. pagingViewController.view.topAnchor.constraint(equalTo: view.topAnchor),
  51. pagingViewController.view.bottomAnchor.constraint(equalTo: view.bottomAnchor),
  52. pagingViewController.view.leadingAnchor.constraint(equalTo: view.leadingAnchor),
  53. pagingViewController.view.trailingAnchor.constraint(equalTo: view.trailingAnchor),
  54. ])
  55. // Set our data source and delegate.
  56. pagingViewController.dataSource = self
  57. }
  58. @objc func exitTapped() {
  59. self.dismiss(animated: true, completion: nil)
  60. }
  61. }
  62. extension NCSharePaging: PagingViewControllerDataSource {
  63. func pagingViewController<T>(_ pagingViewController: PagingViewController<T>, viewControllerForIndex index: Int) -> UIViewController {
  64. let height = pagingViewController.options.menuHeight + NCSharePagingView.HeaderHeight
  65. switch index {
  66. case 0:
  67. let viewController = UIStoryboard(name: "NCActivity", bundle: nil).instantiateInitialViewController() as! NCActivity
  68. viewController.insets = UIEdgeInsets(top: height, left: 0, bottom: 0, right: 0)
  69. viewController.refreshControlEnable = false
  70. viewController.didSelectItemEnable = false
  71. viewController.filterFileID = metadata!.fileID
  72. return viewController
  73. case 1:
  74. let viewController = UIStoryboard(name: "NCShare", bundle: nil).instantiateViewController(withIdentifier: "comments") as! NCShareComments
  75. viewController.metadata = metadata!
  76. return viewController
  77. case 2:
  78. let viewController = UIStoryboard(name: "NCShare", bundle: nil).instantiateViewController(withIdentifier: "sharing") as! NCShare
  79. viewController.metadata = metadata!
  80. viewController.height = height
  81. return viewController
  82. default:
  83. return UIViewController()
  84. }
  85. }
  86. func pagingViewController<T>(_ pagingViewController: PagingViewController<T>, pagingItemForIndex index: Int) -> T {
  87. switch index {
  88. case 0:
  89. return PagingIndexItem(index: index, title: NSLocalizedString("_activity_", comment: "")) as! T
  90. case 1:
  91. return PagingIndexItem(index: index, title: NSLocalizedString("_comments_", comment: "")) as! T
  92. case 2:
  93. return PagingIndexItem(index: index, title: NSLocalizedString("_sharing_", comment: "")) as! T
  94. default:
  95. return PagingIndexItem(index: index, title: "") as! T
  96. }
  97. }
  98. func numberOfViewControllers<T>(in: PagingViewController<T>) -> Int{
  99. return 3
  100. }
  101. }
  102. class NCShareHeaderViewController: PagingViewController<PagingIndexItem> {
  103. public var image: UIImage?
  104. public var metadata: tableMetadata?
  105. override func loadView() {
  106. view = NCSharePagingView(
  107. options: options,
  108. collectionView: collectionView,
  109. pageView: pageViewController.view,
  110. metadata: metadata
  111. )
  112. }
  113. }
  114. class NCSharePagingView: PagingView {
  115. static let HeaderHeight: CGFloat = 200
  116. var metadata: tableMetadata?
  117. var headerHeightConstraint: NSLayoutConstraint?
  118. public init(options: Parchment.PagingOptions, collectionView: UICollectionView, pageView: UIView, metadata: tableMetadata?) {
  119. super.init(options: options, collectionView: collectionView, pageView: pageView)
  120. self.metadata = metadata
  121. }
  122. required init?(coder: NSCoder) {
  123. fatalError("init(coder:) has not been implemented")
  124. }
  125. override func setupConstraints() {
  126. let headerView = Bundle.main.loadNibNamed("NCShareHeaderView", owner: self, options: nil)?.first as! NCShareHeaderView
  127. if FileManager.default.fileExists(atPath: CCUtility.getDirectoryProviderStorageIconFileID(metadata!.fileID, fileNameView: metadata!.fileNameView)) {
  128. headerView.imageView.image = UIImage.init(contentsOfFile: CCUtility.getDirectoryProviderStorageIconFileID(metadata!.fileID, fileNameView: metadata!.fileNameView))
  129. } else {
  130. if metadata!.iconName.count > 0 {
  131. headerView.imageView.image = UIImage.init(named: metadata!.iconName)
  132. } else if metadata!.directory {
  133. let image = UIImage.init(named: "folder")!
  134. headerView.imageView.image = CCGraphics.changeThemingColorImage(image, width: image.size.width*2, height: image.size.height*2, color: NCBrandColor.sharedInstance.brandElement)
  135. } else {
  136. headerView.imageView.image = UIImage.init(named: "file")
  137. }
  138. }
  139. headerView.fileName.text = metadata?.fileNameView
  140. if metadata!.favorite {
  141. headerView.favorite.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "favorite"), width: 40, height: 40, color: NCBrandColor.sharedInstance.yellowFavorite), for: .normal)
  142. } else {
  143. headerView.favorite.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "favorite"), width: 40, height: 40, color: NCBrandColor.sharedInstance.textInfo), for: .normal)
  144. }
  145. headerView.info.text = CCUtility.transformedSize(metadata!.size) + ", " + CCUtility.dateDiff(metadata!.date as Date)
  146. addSubview(headerView)
  147. pageView.translatesAutoresizingMaskIntoConstraints = false
  148. collectionView.translatesAutoresizingMaskIntoConstraints = false
  149. headerView.translatesAutoresizingMaskIntoConstraints = false
  150. headerHeightConstraint = headerView.heightAnchor.constraint(
  151. equalToConstant: NCSharePagingView.HeaderHeight
  152. )
  153. headerHeightConstraint?.isActive = true
  154. NSLayoutConstraint.activate([
  155. collectionView.leadingAnchor.constraint(equalTo: leadingAnchor),
  156. collectionView.trailingAnchor.constraint(equalTo: trailingAnchor),
  157. collectionView.heightAnchor.constraint(equalToConstant: options.menuHeight),
  158. collectionView.topAnchor.constraint(equalTo: headerView.bottomAnchor),
  159. headerView.topAnchor.constraint(equalTo: topAnchor),
  160. headerView.leadingAnchor.constraint(equalTo: leadingAnchor),
  161. headerView.trailingAnchor.constraint(equalTo: trailingAnchor),
  162. pageView.leadingAnchor.constraint(equalTo: leadingAnchor),
  163. pageView.trailingAnchor.constraint(equalTo: trailingAnchor),
  164. pageView.bottomAnchor.constraint(equalTo: bottomAnchor),
  165. pageView.topAnchor.constraint(equalTo: topAnchor)
  166. ])
  167. }
  168. }
  169. class NCShareHeaderView: UIView {
  170. @IBOutlet weak var imageView: UIImageView!
  171. @IBOutlet weak var fileName: UILabel!
  172. @IBOutlet weak var info: UILabel!
  173. @IBOutlet weak var favorite: UIButton!
  174. }
  175. // MARK: - Comments
  176. class NCShareComments: UIViewController {
  177. var metadata: tableMetadata?
  178. private let appDelegate = UIApplication.shared.delegate as! AppDelegate
  179. override func viewDidLoad() {
  180. super.viewDidLoad()
  181. OCNetworking.sharedManager()?.getCommentsWithAccount(appDelegate.activeAccount, fileID: metadata?.fileID, completion: { (account, list, message, errorCode) in
  182. print("ciao")
  183. })
  184. }
  185. }
  186. // MARK: - Share
  187. class NCShare: UIViewController, UIGestureRecognizerDelegate {
  188. var metadata: tableMetadata?
  189. private let appDelegate = UIApplication.shared.delegate as! AppDelegate
  190. public var height: CGFloat = 0
  191. private let iconShare: CGFloat = 200
  192. private var viewMenuShareLink: UIView?
  193. private var shareLinkMenuView: NCShareLinkMenuView?
  194. private var sharesTable: [tableShare]?
  195. @IBOutlet weak var viewContainerConstraint: NSLayoutConstraint!
  196. @IBOutlet weak var searchField: UITextField!
  197. @IBOutlet weak var returnSearchButton: UIButton!
  198. @IBOutlet weak var shareLinkImage: UIImageView!
  199. @IBOutlet weak var shareLinkLabel: UILabel!
  200. @IBOutlet weak var addShareLinkButton: UIButton!
  201. @IBOutlet weak var tableView: UITableView!
  202. override func viewDidLoad() {
  203. super.viewDidLoad()
  204. viewContainerConstraint.constant = height
  205. searchField.placeholder = NSLocalizedString("_shareLinksearch_placeholder_", comment: "")
  206. returnSearchButton.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "arrowRight"), width: 40, height: 40, color: UIColor.gray), for: .normal)
  207. shareLinkLabel.text = NSLocalizedString("_share_link_", comment: "")
  208. addShareLinkButton.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "add"), width: 40, height: 40, color: UIColor.gray), for: .normal)
  209. let bottomImage = CCGraphics.changeThemingColorImage(UIImage.init(named: "circle"), width: 200, height: 200, color: NCBrandColor.sharedInstance.customer)
  210. let topImage = CCGraphics.changeThemingColorImage(UIImage.init(named: "sharebylink"), width: 200, height: 200, color: UIColor.white)
  211. UIGraphicsBeginImageContextWithOptions(CGSize(width: iconShare, height: iconShare), false, 0.0)
  212. bottomImage?.draw(in: CGRect(origin: CGPoint.zero, size: CGSize(width: iconShare, height: iconShare)))
  213. topImage?.draw(in: CGRect(origin: CGPoint(x: iconShare/4, y: iconShare/4), size: CGSize(width: iconShare/2, height: iconShare/2)))
  214. shareLinkImage.image = UIGraphicsGetImageFromCurrentImageContext()
  215. UIGraphicsEndImageContext()
  216. tableView.dataSource = self
  217. tableView.delegate = self
  218. }
  219. override func viewWillTransition(to size: CGSize, with coordinator: UIViewControllerTransitionCoordinator) {
  220. viewMenuShareLink?.removeFromSuperview()
  221. }
  222. }
  223. extension NCShare: UITableViewDelegate {
  224. func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
  225. return 60
  226. }
  227. }
  228. extension NCShare: UITableViewDataSource {
  229. func numberOfSections(in tableView: UITableView) -> Int {
  230. return 1
  231. }
  232. func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
  233. var numOfRows = 0
  234. let shares = NCManageDatabase.sharedInstance.getTableSharesV2(metadata: metadata!)
  235. if shares.share != nil {
  236. numOfRows = shares.share!.count
  237. }
  238. return numOfRows
  239. }
  240. func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
  241. let shares = NCManageDatabase.sharedInstance.getTableSharesV2(metadata: metadata!)
  242. let tableShare = shares.share![indexPath.row]
  243. if let cell = tableView.dequeueReusableCell(withIdentifier: "tableCell", for: indexPath) as? activityTableViewCell {
  244. return cell
  245. }
  246. return UITableViewCell()
  247. }
  248. }
  249. // MARK: - AddShareLink
  250. extension NCShare {
  251. @IBAction func touchUpInsideAddShareLink(_ sender: Any) {
  252. let globalPoint = self.view!.superview?.convert(self.view.frame.origin, to: nil)
  253. let window = UIApplication.shared.keyWindow!
  254. viewMenuShareLink = UIView(frame: window.bounds)
  255. window.addSubview(viewMenuShareLink!)
  256. let shareLinkMenuView = Bundle.main.loadNibNamed("NCShareLinkMenuView", owner: self, options: nil)?.first as? NCShareLinkMenuView
  257. let shareLinkMenuViewX = self.view.bounds.width - (shareLinkMenuView?.frame.width)! - 40 + globalPoint!.x
  258. var shareLinkMenuViewY = height + 10 + globalPoint!.y
  259. if (self.view.bounds.height - (height + 10)) < shareLinkMenuView!.height {
  260. shareLinkMenuViewY = shareLinkMenuViewY - height
  261. }
  262. shareLinkMenuView?.frame = CGRect(x: shareLinkMenuViewX, y: shareLinkMenuViewY, width: shareLinkMenuView!.width, height: shareLinkMenuView!.height)
  263. viewMenuShareLink?.addSubview(shareLinkMenuView!)
  264. let tap = UITapGestureRecognizer(target: self, action: #selector(tapHandler))
  265. tap.delegate = self
  266. viewMenuShareLink?.addGestureRecognizer(tap)
  267. }
  268. @objc func tapHandler(gesture: UITapGestureRecognizer) {
  269. viewMenuShareLink?.removeFromSuperview()
  270. }
  271. func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool {
  272. return gestureRecognizer.view == touch.view
  273. }
  274. }
  275. // MARK: - hareLinkMenuView
  276. class NCShareLinkMenuView: UIView {
  277. @IBOutlet weak var switchAllowEditing: UISwitch!
  278. @IBOutlet weak var labelAllowEditing: UILabel!
  279. @IBOutlet weak var switchHideDownload: UISwitch!
  280. @IBOutlet weak var labelHideDownload: UILabel!
  281. @IBOutlet weak var switchPasswordProtect: UISwitch!
  282. @IBOutlet weak var labelPasswordProtect: UILabel!
  283. @IBOutlet weak var fieldPasswordProtect: UITextField!
  284. @IBOutlet weak var switchSetExpirationDate: UISwitch!
  285. @IBOutlet weak var labelSetExpirationDate: UILabel!
  286. @IBOutlet weak var fieldSetExpirationDate: UITextField!
  287. @IBOutlet weak var imageNoteToRecipient: UIImageView!
  288. @IBOutlet weak var labelNoteToRecipient: UILabel!
  289. @IBOutlet weak var textViewNoteToRecipient: UITextView!
  290. @IBOutlet weak var buttonDeleteShareLink: UIButton!
  291. @IBOutlet weak var labelDeleteShareLink: UILabel!
  292. @IBOutlet weak var buttonAddAnotherLink: UIButton!
  293. @IBOutlet weak var labelAddAnotherLink: UILabel!
  294. public let width: CGFloat = 250
  295. public let height: CGFloat = 470
  296. override func awakeFromNib() {
  297. self.frame.size.width = width
  298. self.frame.size.height = height
  299. layer.borderColor = UIColor.lightGray.cgColor
  300. layer.borderWidth = 0.5
  301. layer.cornerRadius = 5
  302. layer.masksToBounds = false
  303. layer.shadowOffset = CGSize(width: 2, height: 2)
  304. layer.shadowOpacity = 0.2
  305. layer.cornerRadius = 5
  306. switchAllowEditing.transform = CGAffineTransform(scaleX: 0.75, y: 0.75)
  307. switchHideDownload.transform = CGAffineTransform(scaleX: 0.75, y: 0.75)
  308. switchPasswordProtect.transform = CGAffineTransform(scaleX: 0.75, y: 0.75)
  309. switchSetExpirationDate.transform = CGAffineTransform(scaleX: 0.75, y: 0.75)
  310. imageNoteToRecipient.image = CCGraphics.changeThemingColorImage(UIImage.init(named: "file_txt"), width: 100, height: 100, color: UIColor.black)
  311. buttonDeleteShareLink.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "trash"), width: 100, height: 100, color: UIColor.black), for: .normal)
  312. buttonAddAnotherLink.setImage(CCGraphics.changeThemingColorImage(UIImage.init(named: "add"), width: 100, height: 100, color: UIColor.black), for: .normal)
  313. }
  314. }