NCBackgroundImageColor.swift 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. //
  2. // NCBackgroundImageColor.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 05/05/21.
  6. // Copyright © 2021 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 UIKit
  24. import ChromaColorPicker
  25. public protocol NCBackgroundImageColorDelegate {
  26. func colorPickerCancel()
  27. func colorPickerWillChange(color: UIColor)
  28. func colorPickerDidChange(lightColor: String, darkColor: String)
  29. }
  30. // optional func
  31. public extension NCBackgroundImageColorDelegate {
  32. func colorPickerCancel() {}
  33. func colorPickerWillChange(color: UIColor) { }
  34. func colorPickerDidChange(lightColor: String, darkColor: String) { }
  35. }
  36. class NCBackgroundImageColor: UIViewController {
  37. @IBOutlet weak var titleLabel: UILabel!
  38. @IBOutlet weak var chromaColorPickerView: UIView!
  39. @IBOutlet weak var whiteButton: UIButton!
  40. @IBOutlet weak var orangeButton: UIButton!
  41. @IBOutlet weak var redButton: UIButton!
  42. @IBOutlet weak var greenButton: UIButton!
  43. @IBOutlet weak var blackButton: UIButton!
  44. @IBOutlet weak var darkmodeLabel: UILabel!
  45. @IBOutlet weak var darkmodeSwitch: UISwitch!
  46. @IBOutlet weak var defaultButton: UIButton!
  47. @IBOutlet weak var cancelButton: UIButton!
  48. @IBOutlet weak var okButton: UIButton!
  49. private let colorPicker = ChromaColorPicker()
  50. private let brightnessSlider = ChromaBrightnessSlider()
  51. private var colorHandle: ChromaColorHandle?
  52. private let defaultColorPickerSize = CGSize(width: 200, height: 200)
  53. private let brightnessSliderWidthHeightRatio: CGFloat = 0.1
  54. var delegate: NCBackgroundImageColorDelegate?
  55. var setupColor: UIColor?
  56. var darkColor = "#000000"
  57. var lightColor = "#FFFFFF"
  58. let width: CGFloat = 300
  59. let height: CGFloat = 450
  60. // MARK: - View Life Cycle
  61. override func viewDidLoad() {
  62. super.viewDidLoad()
  63. setupColorPicker()
  64. setupBrightnessSlider()
  65. setupColorPickerHandles()
  66. titleLabel.text = NSLocalizedString("_background_", comment: "")
  67. darkmodeLabel.text = NSLocalizedString("_dark_mode_", comment: "")
  68. defaultButton.setTitle(NSLocalizedString("_default_color_", comment: ""), for: .normal)
  69. cancelButton.setTitle(NSLocalizedString("_cancel_", comment: ""), for: .normal)
  70. okButton.setTitle(NSLocalizedString("_ok_", comment: ""), for: .normal)
  71. whiteButton.backgroundColor = .white
  72. whiteButton.layer.cornerRadius = 5
  73. whiteButton.layer.borderWidth = 0.5
  74. whiteButton.layer.borderColor = NCBrandColor.shared.label.cgColor
  75. whiteButton.layer.masksToBounds = true
  76. orangeButton.backgroundColor = .orange
  77. orangeButton.layer.cornerRadius = 5
  78. orangeButton.layer.borderWidth = 0.5
  79. orangeButton.layer.borderColor = NCBrandColor.shared.label.cgColor
  80. orangeButton.layer.masksToBounds = true
  81. redButton.backgroundColor = .red
  82. redButton.layer.cornerRadius = 5
  83. redButton.layer.borderWidth = 0.5
  84. redButton.layer.borderColor = NCBrandColor.shared.label.cgColor
  85. redButton.layer.masksToBounds = true
  86. greenButton.backgroundColor = .green
  87. greenButton.layer.cornerRadius = 5
  88. greenButton.layer.borderWidth = 0.5
  89. greenButton.layer.borderColor = NCBrandColor.shared.label.cgColor
  90. greenButton.layer.masksToBounds = true
  91. blackButton.backgroundColor = .black
  92. blackButton.layer.cornerRadius = 5
  93. blackButton.layer.borderWidth = 0.5
  94. blackButton.layer.borderColor = NCBrandColor.shared.label.cgColor
  95. blackButton.layer.masksToBounds = true
  96. defaultButton.layer.cornerRadius = 15
  97. defaultButton.layer.borderWidth = 0.5
  98. defaultButton.layer.borderColor = UIColor.gray.cgColor
  99. defaultButton.layer.masksToBounds = true
  100. }
  101. override func viewWillAppear(_ animated: Bool) {
  102. super.viewWillAppear(animated)
  103. if traitCollection.userInterfaceStyle == .dark {
  104. darkmodeSwitch.isOn = true
  105. } else {
  106. darkmodeSwitch.isOn = false
  107. }
  108. // Color for all folders
  109. if let activeAccount = NCManageDatabase.shared.getActiveAccount() {
  110. if darkColor == "" {
  111. darkColor = activeAccount.darkColorBackground
  112. }
  113. if lightColor == "" {
  114. lightColor = activeAccount.lightColorBackground
  115. }
  116. }
  117. // set color
  118. if darkmodeSwitch.isOn {
  119. if let color = UIColor.init(hex: darkColor) {
  120. changeColor(color)
  121. } else {
  122. changeColor(.black)
  123. }
  124. } else {
  125. if let color = UIColor.init(hex: lightColor) {
  126. changeColor(color)
  127. } else {
  128. changeColor(.white)
  129. }
  130. }
  131. }
  132. // MARK: - Action
  133. @IBAction func whiteButtonAction(_ sender: UIButton) {
  134. changeColor(.white)
  135. }
  136. @IBAction func orangeButtonAction(_ sender: UIButton) {
  137. changeColor(.orange)
  138. }
  139. @IBAction func redButtonAction(_ sender: UIButton) {
  140. changeColor(.red)
  141. }
  142. @IBAction func greenButtonAction(_ sender: UIButton) {
  143. changeColor(.green)
  144. }
  145. @IBAction func blackButtonAction(_ sender: UIButton) {
  146. changeColor(.black)
  147. }
  148. @IBAction func darkmodeAction(_ sender: UISwitch) {
  149. if sender.isOn {
  150. if darkColor == "" {
  151. changeColor(.black)
  152. } else {
  153. if let color = UIColor.init(hex: darkColor) {
  154. changeColor(color)
  155. }
  156. }
  157. } else {
  158. if lightColor == "" {
  159. changeColor(.white)
  160. } else {
  161. if let color = UIColor.init(hex: lightColor) {
  162. changeColor(color)
  163. }
  164. }
  165. }
  166. }
  167. @IBAction func defaultAction(_ sender: Any) {
  168. if darkmodeSwitch.isOn {
  169. darkColor = "#000000"
  170. changeColor(.black)
  171. } else {
  172. lightColor = "#FFFFFF"
  173. changeColor(.white)
  174. }
  175. }
  176. @IBAction func cancelAction(_ sender: Any) {
  177. self.delegate?.colorPickerCancel()
  178. dismiss(animated: true)
  179. }
  180. @IBAction func okAction(_ sender: Any) {
  181. var lightColor = self.lightColor
  182. var darkColor = self.darkColor
  183. if lightColor == "#FFFFFF" { lightColor = "" }
  184. if darkColor == "#000000" { darkColor = "" }
  185. self.delegate?.colorPickerDidChange(lightColor: lightColor, darkColor: darkColor)
  186. dismiss(animated: true)
  187. }
  188. // MARK: - ChromaColorPicker
  189. private func setupColorPicker() {
  190. colorPicker.delegate = self
  191. colorPicker.translatesAutoresizingMaskIntoConstraints = false
  192. view.addSubview(colorPicker)
  193. NSLayoutConstraint.activate([
  194. colorPicker.leadingAnchor.constraint(equalTo: chromaColorPickerView.leadingAnchor, constant: 20),
  195. colorPicker.topAnchor.constraint(equalTo: chromaColorPickerView.topAnchor),
  196. colorPicker.widthAnchor.constraint(equalToConstant: defaultColorPickerSize.width),
  197. colorPicker.heightAnchor.constraint(equalToConstant: defaultColorPickerSize.height)
  198. ])
  199. }
  200. private func setupBrightnessSlider() {
  201. brightnessSlider.connect(to: colorPicker)
  202. // Style
  203. brightnessSlider.trackColor = UIColor.blue
  204. brightnessSlider.handle.borderWidth = 3.0 // Example of customizing the handle's properties.
  205. // Layout
  206. brightnessSlider.translatesAutoresizingMaskIntoConstraints = false
  207. view.addSubview(brightnessSlider)
  208. NSLayoutConstraint.activate([
  209. brightnessSlider.centerXAnchor.constraint(equalTo: colorPicker.centerXAnchor),
  210. brightnessSlider.topAnchor.constraint(equalTo: colorPicker.bottomAnchor, constant: 20),
  211. brightnessSlider.widthAnchor.constraint(equalTo: colorPicker.widthAnchor, multiplier: 1),
  212. brightnessSlider.heightAnchor.constraint(equalTo: brightnessSlider.widthAnchor, multiplier: brightnessSliderWidthHeightRatio)
  213. ])
  214. }
  215. private func setupColorPickerHandles() {
  216. colorHandle = colorPicker.addHandle(at: setupColor)
  217. }
  218. private func changeColor(_ color: UIColor) {
  219. colorHandle?.color = color
  220. colorPicker.setNeedsLayout()
  221. brightnessSlider.trackColor = color
  222. if darkmodeSwitch.isOn {
  223. darkColor = color.hexString
  224. } else {
  225. lightColor = color.hexString
  226. }
  227. self.delegate?.colorPickerWillChange(color: color)
  228. }
  229. }
  230. extension NCBackgroundImageColor: ChromaColorPickerDelegate {
  231. func colorPickerHandleDidChange(_ colorPicker: ChromaColorPicker, handle: ChromaColorHandle, to color: UIColor) {
  232. if darkmodeSwitch.isOn {
  233. darkColor = color.hexString
  234. } else {
  235. lightColor = color.hexString
  236. }
  237. self.delegate?.colorPickerWillChange(color: color)
  238. }
  239. }