ReferenceZammadView.swift 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. //
  2. // SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
  3. // SPDX-License-Identifier: GPL-3.0-or-later
  4. //
  5. import Foundation
  6. @objcMembers class ReferenceZammadView: UIView {
  7. @IBOutlet var contentView: UIView!
  8. @IBOutlet weak var referenceTypeIcon: UIImageView!
  9. @IBOutlet weak var referenceTitle: UILabel!
  10. @IBOutlet weak var referenceBody: UITextView!
  11. @IBOutlet weak var referenceCommentCount: UILabel!
  12. @IBOutlet weak var referenceCommentIcon: UIImageView!
  13. var url: String?
  14. override init(frame: CGRect) {
  15. super.init(frame: frame)
  16. commonInit()
  17. }
  18. required init?(coder aDecoder: NSCoder) {
  19. super.init(coder: aDecoder)
  20. commonInit()
  21. }
  22. func commonInit() {
  23. Bundle.main.loadNibNamed("ReferenceZammadView", owner: self, options: nil)
  24. contentView.frame = self.bounds
  25. contentView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
  26. referenceTitle.text = ""
  27. referenceBody.text = ""
  28. // Remove padding from textView and adjust lineBreakMode
  29. referenceBody.textContainerInset = .zero
  30. referenceBody.textContainer.lineFragmentPadding = .zero
  31. referenceBody.textContainer.lineBreakMode = .byTruncatingTail
  32. referenceBody.textContainer.maximumNumberOfLines = 3
  33. let tap = UITapGestureRecognizer(target: self, action: #selector(self.handleTap))
  34. contentView.addGestureRecognizer(tap)
  35. self.addSubview(contentView)
  36. }
  37. func handleTap() {
  38. if let url = url {
  39. NCUtils.openLinkInBrowser(link: url)
  40. }
  41. }
  42. func update(for reference: [String: AnyObject], and url: String) {
  43. self.url = url
  44. if reference["error"] != nil {
  45. referenceTitle.text = NSLocalizedString("Zammad API error", comment: "'Zammad' is a product name")
  46. if let error = reference["error"] as? String, !error.isEmpty {
  47. referenceBody.text = error
  48. } else {
  49. referenceBody.text = NSLocalizedString("Unknown error", comment: "")
  50. }
  51. referenceCommentCount.isHidden = true
  52. referenceCommentIcon.isHidden = true
  53. return
  54. }
  55. referenceCommentCount.isHidden = false
  56. referenceCommentIcon.isHidden = false
  57. if let comments = reference["article_count"] as? Int {
  58. referenceCommentCount.text = String(comments)
  59. } else {
  60. referenceCommentCount.text = "0"
  61. }
  62. if let title = reference["title"] as? String {
  63. referenceTitle.text = title
  64. }
  65. if let ticketNumber = reference["number"] as? String, let severity = reference["severity"] as? String,
  66. let authorOrg = reference["zammad_ticket_author_organization"] as? [AnyHashable: Any], let authorName = authorOrg["name"] as? String {
  67. // Make sure we truncate each body line individually
  68. let paragraphStyle = NSMutableParagraphStyle()
  69. paragraphStyle.lineBreakMode = .byTruncatingTail
  70. var bodyText = "#\(ticketNumber) [\(severity)]: \(authorName)".withParagraphStyle(paragraphStyle)
  71. // When we are able to determine the ticket state -> add that to the body
  72. if let zammadStates = reference["zammad_ticket_states"] as? [[AnyHashable: Any]], let ticketState = reference["state_id"] as? Int,
  73. let zammadState = zammadStates.first(where: { $0["id"] as? Int == ticketState }), let stateName = zammadState["name"] as? String {
  74. bodyText.append("\n\(stateName)".withParagraphStyle(paragraphStyle))
  75. }
  76. bodyText = bodyText.withFont(referenceBody.font ?? .preferredFont(forTextStyle: .callout)).withTextColor(referenceBody.textColor ?? .secondaryLabel)
  77. referenceBody.attributedText = bodyText
  78. } else {
  79. referenceBody.text = NSLocalizedString("No description provided", comment: "")
  80. }
  81. }
  82. }