// // TapActionRow.swift // QuickTableViewController // // Created by Ben on 01/09/2015. // Copyright (c) 2015 bcylin. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in all // copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE // SOFTWARE. // import UIKit /// A class that represents a row that triggers certain action when selected. open class TapActionRow: TapActionRowCompatible, Equatable { // MARK: - Initializer /// Initializes a `TapActionRow` with a text, an action closure, /// and an optional customization closure. public init( text: String, customization: ((UITableViewCell, Row & RowStyle) -> Void)? = nil, action: ((Row) -> Void)? ) { self.text = text self.customize = customization self.action = action } // MARK: - Row /// The text of the row. public let text: String /// The detail text is disabled in `TapActionRow`. public let detailText: DetailText? = nil /// A closure that will be invoked when the row is selected. public let action: ((Row) -> Void)? // MARK: - RowStyle /// The type of the table view cell to display the row. public let cellType: UITableViewCell.Type = T.self /// The reuse identifier of the table view cell to display the row. The default value is **TapActionCell**. public let cellReuseIdentifier: String = T.reuseIdentifier /// The cell style is `.default`. public let cellStyle: UITableViewCell.CellStyle = .default /// The default icon is nil. public let icon: Icon? = nil /// The default accessory type is `.none`. public let accessoryType: UITableViewCell.AccessoryType = .none /// The `TapActionRow` is selectable when action is not nil. public var isSelectable: Bool { return action != nil } /// The additional customization during cell configuration. public let customize: ((UITableViewCell, Row & RowStyle) -> Void)? // MARK: - Equatable /// Returns true iff `lhs` and `rhs` have equal titles and detail texts. public static func == (lhs: TapActionRow, rhs: TapActionRow) -> Bool { return lhs.text == rhs.text && lhs.detailText == rhs.detailText } }