NCShareCommon.swift 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. //
  2. // NCShareCommon.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 25/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. import Foundation
  23. import FSCalendar
  24. import DropDown
  25. class NCShareCommon: NSObject {
  26. @objc static let sharedInstance: NCShareCommon = {
  27. let instance = NCShareCommon()
  28. return instance
  29. }()
  30. func createLinkAvatar() -> UIImage? {
  31. let size: CGFloat = 200
  32. let bottomImage = CCGraphics.changeThemingColorImage(UIImage.init(named: "circle"), width: size, height: size, color: NCBrandColor.sharedInstance.brand)
  33. let topImage = CCGraphics.changeThemingColorImage(UIImage.init(named: "sharebylink"), width: size, height: size, color: UIColor.white)
  34. UIGraphicsBeginImageContextWithOptions(CGSize(width: size, height: size), false, 0.0)
  35. bottomImage?.draw(in: CGRect(origin: CGPoint.zero, size: CGSize(width: size, height: size)))
  36. topImage?.draw(in: CGRect(origin: CGPoint(x: size/4, y: size/4), size: CGSize(width: size/2, height: size/2)))
  37. let image = UIGraphicsGetImageFromCurrentImageContext()
  38. UIGraphicsEndImageContext()
  39. return image
  40. }
  41. func downloadAvatar(user: String, cell: NCShareUserCell) {
  42. let appDelegate = UIApplication.shared.delegate as! AppDelegate
  43. let fileNameLocalPath = CCUtility.getDirectoryUserData() + "/" + CCUtility.getStringUser(appDelegate.activeUser, activeUrl: appDelegate.activeUrl) + "-" + user + ".png"
  44. if FileManager.default.fileExists(atPath: fileNameLocalPath) {
  45. if let image = UIImage(contentsOfFile: fileNameLocalPath) {
  46. cell.imageItem.image = image
  47. }
  48. } else {
  49. DispatchQueue.global().async {
  50. let url = appDelegate.activeUrl + k_avatar + user + "/128"
  51. let encodedString = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
  52. OCNetworking.sharedManager()?.downloadContents(ofUrl: encodedString, completion: { (data, message, errorCode) in
  53. if errorCode == 0 && UIImage(data: data!) != nil {
  54. do {
  55. try data!.write(to: NSURL(fileURLWithPath: fileNameLocalPath) as URL, options: .atomic)
  56. } catch { return }
  57. cell.imageItem.image = UIImage(data: data!)
  58. } else {
  59. cell.imageItem.image = UIImage(named: "avatar")
  60. }
  61. })
  62. }
  63. }
  64. }
  65. func downloadAvatar(user: String, cell: NCShareUserDropDownCell) {
  66. let appDelegate = UIApplication.shared.delegate as! AppDelegate
  67. let fileNameLocalPath = CCUtility.getDirectoryUserData() + "/" + CCUtility.getStringUser(appDelegate.activeUser, activeUrl: appDelegate.activeUrl) + "-" + user + ".png"
  68. if FileManager.default.fileExists(atPath: fileNameLocalPath) {
  69. if let image = UIImage(contentsOfFile: fileNameLocalPath) {
  70. cell.imageItem.image = image
  71. }
  72. } else {
  73. DispatchQueue.global().async {
  74. let url = appDelegate.activeUrl + k_avatar + user + "/128"
  75. let encodedString = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
  76. OCNetworking.sharedManager()?.downloadContents(ofUrl: encodedString, completion: { (data, message, errorCode) in
  77. if errorCode == 0 && UIImage(data: data!) != nil {
  78. do {
  79. try data!.write(to: NSURL(fileURLWithPath: fileNameLocalPath) as URL, options: .atomic)
  80. } catch { return }
  81. cell.imageItem.image = UIImage(data: data!)
  82. } else {
  83. cell.imageItem.image = UIImage(named: "avatar")
  84. }
  85. })
  86. }
  87. }
  88. }
  89. func openViewMenuShareLink(view: UIView, tableShare: tableShare?, metadata: tableMetadata) -> (shareLinkMenuView: NCShareLinkMenuView, viewWindow: UIView) {
  90. var shareLinkMenuView: NCShareLinkMenuView
  91. let globalPoint = view.superview?.convert(view.frame.origin, to: nil)
  92. let window = UIApplication.shared.keyWindow!
  93. let viewWindow = UIView(frame: window.bounds)
  94. window.addSubview(viewWindow)
  95. if metadata.directory {
  96. shareLinkMenuView = Bundle.main.loadNibNamed("NCShareLinkFolderMenuView", owner: self, options: nil)?.first as! NCShareLinkMenuView
  97. } else {
  98. shareLinkMenuView = Bundle.main.loadNibNamed("NCShareLinkMenuView", owner: self, options: nil)?.first as! NCShareLinkMenuView
  99. }
  100. shareLinkMenuView.width = 250
  101. if metadata.directory {
  102. shareLinkMenuView.height = 540
  103. } else {
  104. shareLinkMenuView.height = 440
  105. }
  106. shareLinkMenuView.metadata = metadata
  107. shareLinkMenuView.viewWindow = viewWindow
  108. shareLinkMenuView.reloadData(idRemoteShared: tableShare?.idRemoteShared ?? 0)
  109. let shareLinkMenuViewX = view.bounds.width/2 - shareLinkMenuView.width/2 + globalPoint!.x
  110. let shareLinkMenuViewY = globalPoint!.y
  111. shareLinkMenuView.frame = CGRect(x: shareLinkMenuViewX, y: shareLinkMenuViewY, width: shareLinkMenuView.width, height: shareLinkMenuView.height)
  112. viewWindow.addSubview(shareLinkMenuView)
  113. return(shareLinkMenuView: shareLinkMenuView, viewWindow: viewWindow)
  114. }
  115. func openViewMenuUser(view: UIView, tableShare: tableShare?, metadata: tableMetadata) -> (shareUserMenuView: NCShareUserMenuView, viewWindow: UIView) {
  116. var shareUserMenuView: NCShareUserMenuView
  117. let globalPoint = view.superview?.convert(view.frame.origin, to: nil)
  118. let window = UIApplication.shared.keyWindow!
  119. let viewWindow = UIView(frame: window.bounds)
  120. window.addSubview(viewWindow)
  121. if metadata.directory {
  122. shareUserMenuView = Bundle.main.loadNibNamed("NCShareUserFolderMenuView", owner: self, options: nil)?.first as! NCShareUserMenuView
  123. } else {
  124. shareUserMenuView = Bundle.main.loadNibNamed("NCShareUserMenuView", owner: self, options: nil)?.first as! NCShareUserMenuView
  125. }
  126. shareUserMenuView.width = 250
  127. if metadata.directory {
  128. shareUserMenuView.height = 540
  129. } else {
  130. shareUserMenuView.height = 260
  131. }
  132. shareUserMenuView.metadata = metadata
  133. shareUserMenuView.viewWindow = viewWindow
  134. shareUserMenuView.reloadData(idRemoteShared: tableShare?.idRemoteShared ?? 0)
  135. let shareUserMenuViewX = view.bounds.width/2 - shareUserMenuView.width/2 + globalPoint!.x
  136. let shareUserMenuViewY = globalPoint!.y + 100
  137. shareUserMenuView.frame = CGRect(x: shareUserMenuViewX, y: shareUserMenuViewY, width: shareUserMenuView.width, height: shareUserMenuView.height)
  138. viewWindow.addSubview(shareUserMenuView)
  139. return(shareUserMenuView: shareUserMenuView, viewWindow: viewWindow)
  140. }
  141. func openCalendar(view: UIView, width: CGFloat, height: CGFloat) -> (calendarView: FSCalendar, viewWindow: UIView) {
  142. let globalPoint = view.superview?.convert(view.frame.origin, to: nil)
  143. let window = UIApplication.shared.keyWindow!
  144. let viewWindow = UIView(frame: window.bounds)
  145. window.addSubview(viewWindow)
  146. let calendar = FSCalendar(frame: CGRect(x: globalPoint!.x + 10, y: globalPoint!.y + 100, width: width - 20, height: 300))
  147. calendar.backgroundColor = .white
  148. calendar.placeholderType = .none
  149. calendar.appearance.headerMinimumDissolvedAlpha = 0.0
  150. calendar.layer.borderColor = UIColor.lightGray.cgColor
  151. calendar.layer.borderWidth = 0.5
  152. calendar.layer.masksToBounds = false
  153. calendar.layer.cornerRadius = 5
  154. calendar.layer.masksToBounds = false
  155. calendar.layer.shadowOffset = CGSize(width: 2, height: 2)
  156. calendar.layer.shadowOpacity = 0.2
  157. calendar.appearance.headerTitleColor = .black
  158. calendar.appearance.headerTitleFont = UIFont.systemFont(ofSize: 13)
  159. calendar.appearance.weekdayTextColor = UIColor(red: 100/255, green: 100/255, blue: 100/255, alpha: 1)
  160. calendar.appearance.weekdayFont = UIFont.systemFont(ofSize: 12)
  161. calendar.appearance.todayColor = NCBrandColor.sharedInstance.brand
  162. calendar.appearance.titleFont = UIFont.systemFont(ofSize: 12)
  163. viewWindow.addSubview(calendar)
  164. return(calendarView: calendar, viewWindow: viewWindow)
  165. }
  166. func copyLink(tableShare: tableShare?, viewController: UIViewController) {
  167. let appDelegate = UIApplication.shared.delegate as! AppDelegate
  168. var url: String = ""
  169. guard let tableShare = tableShare else { return }
  170. if tableShare.token.hasPrefix("http://") || tableShare.token.hasPrefix("https://") {
  171. url = tableShare.token
  172. } else if tableShare.url != "" {
  173. url = tableShare.url
  174. } else {
  175. url = appDelegate.activeUrl + "/" + k_share_link_middle_part_url_after_version_8 + tableShare.token
  176. }
  177. if let name = URL(string: url), !name.absoluteString.isEmpty {
  178. let objectsToShare = [name]
  179. let activityVC = UIActivityViewController(activityItems: objectsToShare, applicationActivities: nil)
  180. viewController.present(activityVC, animated: true, completion: nil)
  181. }
  182. }
  183. }