Subtitle.swift 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. //
  2. // Subtitle.swift
  3. // QuickTableViewController
  4. //
  5. // Created by Ben on 01/09/2015.
  6. // Copyright (c) 2015 bcylin.
  7. //
  8. // Permission is hereby granted, free of charge, to any person obtaining a copy
  9. // of this software and associated documentation files (the "Software"), to deal
  10. // in the Software without restriction, including without limitation the rights
  11. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. // copies of the Software, and to permit persons to whom the Software is
  13. // furnished to do so, subject to the following conditions:
  14. //
  15. // The above copyright notice and this permission notice shall be included in all
  16. // copies or substantial portions of the Software.
  17. //
  18. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  21. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  24. // SOFTWARE.
  25. //
  26. import UIKit
  27. /// An enum that represents a subtitle text with `UITableViewCellStyle`.
  28. public enum Subtitle: Equatable {
  29. /// Does not show a subtitle as `UITableViewCellStyle.default`.
  30. case none
  31. /// Shows the associated text in `UITableViewCellStyle.subtitle`.
  32. case belowTitle(String)
  33. /// Shows the associated text in `UITableViewCellStyle.value1`.
  34. case rightAligned(String)
  35. /// Shows the associated text in `UITableViewCellStyle.value2`.
  36. case leftAligned(String)
  37. /// Returns the corresponding table view cell style.
  38. public var style: UITableViewCellStyle {
  39. switch self {
  40. case .none: return .default
  41. case .belowTitle: return .subtitle
  42. case .rightAligned: return .value1
  43. case .leftAligned: return .value2
  44. }
  45. }
  46. /// Returns the associated text of the case.
  47. public var text: String? {
  48. switch self {
  49. case let .belowTitle(text): return text
  50. case let .rightAligned(text): return text
  51. case let .leftAligned(text): return text
  52. default: return nil
  53. }
  54. }
  55. // MARK: Equatable
  56. /// Returns true iff `lhs` and `rhs` have equal texts in the same `Subtitle`.
  57. public static func == (lhs: Subtitle, rhs: Subtitle) -> Bool {
  58. switch (lhs, rhs) {
  59. case (.none, .none):
  60. return true
  61. case let (.belowTitle(a), .belowTitle(b)):
  62. return a == b
  63. case let (.rightAligned(a), .rightAligned(b)):
  64. return a == b
  65. case let (.leftAligned(a), .leftAligned(b)):
  66. return a == b
  67. default:
  68. return false
  69. }
  70. }
  71. }
  72. internal extension UITableViewCellStyle {
  73. var stringValue: String {
  74. switch self {
  75. case .default: return ".default"
  76. case .subtitle: return ".subtitle"
  77. case .value1: return ".value1"
  78. case .value2: return ".value2"
  79. }
  80. }
  81. }