RowStyle.swift 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. //
  2. // RowStyle.swift
  3. // QuickTableViewController
  4. //
  5. // Created by Ben on 30/07/2017.
  6. // Copyright © 2017 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. /// Any type that conforms to this protocol carries the info for the UI.
  28. public protocol RowStyle {
  29. /// The type of the table view cell to display the row.
  30. var cellType: UITableViewCell.Type { get }
  31. /// The reuse identifier of the table view cell to display the row.
  32. var cellReuseIdentifier: String { get }
  33. /// The style of the table view cell to display the row.
  34. var cellStyle: UITableViewCell.CellStyle { get }
  35. /// The icon of the row.
  36. var icon: Icon? { get }
  37. /// The type of standard accessory view the cell should use.
  38. var accessoryType: UITableViewCell.AccessoryType { get }
  39. /// The flag that indicates whether the table view cell should trigger the action when selected.
  40. var isSelectable: Bool { get }
  41. /// The additional customization during cell configuration.
  42. var customize: ((UITableViewCell, Row & RowStyle) -> Void)? { get }
  43. }