QRCodeView.swift 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. //
  2. // QRCodeView.swift
  3. // TUIRoomKit
  4. //
  5. // Created by janejntang on 2023/1/11.
  6. // Copyright © 2023 Tencent. All rights reserved.
  7. //
  8. import Foundation
  9. class QRCodeView: UIView {
  10. let viewModel: QRCodeViewModel
  11. let backButton: UIButton = {
  12. let button = UIButton()
  13. button.contentVerticalAlignment = .center
  14. button.contentHorizontalAlignment = isRTL ? .right : .left
  15. button.setTitleColor(UIColor(0xADB6CC), for: .normal)
  16. let image = UIImage(named: "room_back_white", in: tuiRoomKitBundle(), compatibleWith: nil)?.checkOverturn()
  17. button.setImage(image, for: .normal)
  18. button.titleLabel?.font = UIFont(name: "PingFangSC-Regular", size: 18)
  19. button.titleEdgeInsets = UIEdgeInsets(top: 0, left: 25, bottom: 0, right: 0)
  20. button.imageEdgeInsets = UIEdgeInsets(top: 0, left: 12, bottom: 0, right: 0)
  21. return button
  22. }()
  23. let middleView: UIView = {
  24. let view = UIView()
  25. view.backgroundColor = UIColor(0x2A2D38)
  26. return view
  27. }()
  28. let titleLabel: UILabel = {
  29. let label = UILabel()
  30. label.textColor = UIColor(0xD1D9EC)
  31. label.font = UIFont(name: "PingFangSC-Regular", size: 28)
  32. label.textAlignment = .center
  33. label.backgroundColor = .clear
  34. label.adjustsFontSizeToFitWidth = true
  35. return label
  36. }()
  37. let roomIdView: UIView = {
  38. let view = UIView()
  39. view.backgroundColor = .clear
  40. return view
  41. }()
  42. let roomIdLabel: UILabel = {
  43. let label = UILabel()
  44. label.textColor = UIColor(0xD1D9EC)
  45. label.font = UIFont(name: "PingFangSC-Regular", size: 20)
  46. label.adjustsFontSizeToFitWidth = true
  47. label.textAlignment = .center
  48. return label
  49. }()
  50. let copyButton: UIButton = {
  51. let button = UIButton()
  52. let normalIcon = UIImage(named: "room_copy", in: tuiRoomKitBundle(), compatibleWith: nil)
  53. button.setImage(normalIcon, for: .normal)
  54. return button
  55. }()
  56. let qrCodeView: UIView = {
  57. let view = UIView()
  58. view.backgroundColor = .white
  59. return view
  60. }()
  61. let qrCodeImageView: UIImageView = {
  62. let imageView = UIImageView()
  63. return imageView
  64. }()
  65. let qrCodeLabel: UILabel = {
  66. let label = UILabel()
  67. label.textColor = .black
  68. label.text = .scanCodeText
  69. label.textAlignment = .center
  70. return label
  71. }()
  72. let tencentImageView: UIImageView = {
  73. let image = UIImage(named: "room_tencent", in: tuiRoomKitBundle(), compatibleWith: nil)
  74. let imageView = UIImageView(image: image)
  75. return imageView
  76. }()
  77. let bottomButton: UIButton = {
  78. let button = UIButton()
  79. button.backgroundColor = UIColor(0x006CFF)
  80. button.setTitle(.saveIntoAlbumText, for: .normal)
  81. button.backgroundColor = UIColor(0x006CFF)
  82. button.setTitleColor(.white, for: .normal)
  83. return button
  84. }()
  85. init(viewModel: QRCodeViewModel) {
  86. self.viewModel = viewModel
  87. super.init(frame: .zero)
  88. }
  89. required init?(coder: NSCoder) {
  90. fatalError("init(coder:) has not been implemented")
  91. }
  92. private var isViewReady: Bool = false
  93. override func didMoveToWindow() {
  94. super.didMoveToWindow()
  95. guard !isViewReady else { return }
  96. constructViewHierarchy()
  97. activateConstraints()
  98. bindInteraction()
  99. isViewReady = true
  100. }
  101. override func draw(_ rect: CGRect) {
  102. super.draw(rect)
  103. middleView.roundedRect(rect: middleView.bounds,
  104. byRoundingCorners: [.topLeft, .topRight, .bottomLeft, .bottomRight],
  105. cornerRadii: CGSize(width: 12, height: 12))
  106. qrCodeView.roundedRect(rect: qrCodeView.bounds,
  107. byRoundingCorners: [.topLeft, .topRight, .bottomLeft, .bottomRight],
  108. cornerRadii: CGSize(width: 12, height: 12))
  109. bottomButton.roundedRect(rect: bottomButton.bounds,
  110. byRoundingCorners: [.topLeft, .topRight, .bottomLeft, .bottomRight],
  111. cornerRadii: CGSize(width: 12, height: 12))
  112. }
  113. func constructViewHierarchy() {
  114. addSubview(backButton)
  115. addSubview(middleView)
  116. addSubview(bottomButton)
  117. middleView.addSubview(titleLabel)
  118. middleView.addSubview(roomIdView)
  119. middleView.addSubview(qrCodeView)
  120. middleView.addSubview(tencentImageView)
  121. roomIdView.addSubview(roomIdLabel)
  122. roomIdView.addSubview(copyButton)
  123. qrCodeView.addSubview(qrCodeImageView)
  124. qrCodeView.addSubview(qrCodeLabel)
  125. }
  126. func activateConstraints() {
  127. backButton.snp.makeConstraints { make in
  128. make.leading.equalToSuperview()
  129. make.top.equalTo(safeAreaLayoutGuide.snp.top)
  130. make.height.equalTo(20)
  131. make.width.equalTo(200)
  132. }
  133. middleView.snp.makeConstraints { make in
  134. make.leading.equalToSuperview().offset(12.scale375())
  135. make.trailing.equalToSuperview().offset(-12.scale375())
  136. make.height.equalTo(399.scale375())
  137. make.centerY.equalToSuperview()
  138. }
  139. titleLabel.snp.makeConstraints { make in
  140. make.top.equalToSuperview().offset(24.scale375())
  141. make.height.equalTo(30.scale375())
  142. make.width.equalToSuperview()
  143. }
  144. roomIdView.snp.makeConstraints { make in
  145. make.top.equalTo(titleLabel.snp.bottom).offset(4.scale375())
  146. make.width.equalTo(120.scale375())
  147. make.centerX.equalToSuperview()
  148. make.height.equalTo(22.scale375())
  149. }
  150. roomIdLabel.snp.makeConstraints { make in
  151. make.leading.equalToSuperview()
  152. make.height.equalToSuperview()
  153. make.width.equalTo(80.scale375())
  154. }
  155. copyButton.snp.makeConstraints { make in
  156. make.leading.equalTo(roomIdLabel.snp.trailing).offset(3)
  157. make.centerY.equalToSuperview()
  158. make.width.height.equalTo(22.scale375())
  159. }
  160. qrCodeView.snp.makeConstraints { make in
  161. make.top.equalTo(roomIdView.snp.bottom).offset(10)
  162. make.centerX.equalToSuperview()
  163. make.width.equalTo(210.scale375())
  164. make.height.equalTo(242.scale375())
  165. }
  166. qrCodeImageView.snp.makeConstraints { make in
  167. make.width.height.equalTo(162.scale375())
  168. make.top.equalToSuperview().offset(24.scale375())
  169. make.centerX.equalToSuperview()
  170. }
  171. qrCodeLabel.snp.makeConstraints { make in
  172. make.width.equalToSuperview()
  173. make.height.equalTo(20.scale375())
  174. make.top.equalTo(qrCodeImageView.snp.bottom).offset(24.scale375())
  175. }
  176. tencentImageView.snp.makeConstraints { make in
  177. make.top.equalTo(qrCodeView.snp.bottom).offset(20.scale375())
  178. make.centerX.equalToSuperview()
  179. make.width.equalTo(86.scale375())
  180. make.height.equalTo(23.scale375())
  181. }
  182. bottomButton.snp.makeConstraints { make in
  183. make.width.equalTo(200.scale375())
  184. make.height.equalTo(52.scale375())
  185. make.centerX.equalToSuperview()
  186. make.bottom.equalToSuperview().offset(-30.scale375())
  187. }
  188. }
  189. func bindInteraction() {
  190. setupViewState()
  191. backButton.addTarget(self, action: #selector(backAction(sender:)), for: .touchUpInside)
  192. copyButton.addTarget(self, action: #selector(copyAction(sender:)), for: .touchUpInside)
  193. bottomButton.addTarget(self, action: #selector(saveIntoAlbumAction(sender:)), for: .touchUpInside)
  194. }
  195. func setupViewState() {
  196. backgroundColor = UIColor(0x17181F)
  197. titleLabel.text = viewModel.store.roomInfo.name
  198. roomIdLabel.text = viewModel.store.roomInfo.roomId
  199. viewModel.createQRCodeImageView(url: viewModel.urlString, imageView: qrCodeImageView)
  200. }
  201. @objc func backAction(sender: UIButton) {
  202. viewModel.backAction()
  203. }
  204. @objc func copyAction(sender: UIButton) {
  205. viewModel.copyAction(sender: sender, text: roomIdLabel.text ?? "")
  206. }
  207. @objc func saveIntoAlbumAction(sender: UIButton) {
  208. guard let image = qrCodeImageView.image else { return }
  209. viewModel.saveIntoAlbumAction(sender: sender, image: image)
  210. }
  211. deinit {
  212. debugPrint("deinit \(self)")
  213. }
  214. }
  215. private extension String {
  216. static var scanCodeText: String {
  217. localized("Scan the code to enter the conference")
  218. }
  219. static var saveIntoAlbumText: String {
  220. localized("Save into the album")
  221. }
  222. }