TKUIHomeComponentViewModel
@MainActor
public protocol TKUIHomeComponentViewModel
This protocol defines the requirements for any view models that may display
their contents in a TKUIHomeCard
.
-
This builds an instance of a view model whose contents may be displayed in a
TKUIHomeCard
Declaration
Swift
@MainActor static func buildInstance(from inputs: TKUIHomeComponentInput) -> Self
Parameters
inputs
The inputs from a
TKUIHomeCard
, which may be used by a component view model -
A unique identifier for this component
Declaration
Swift
@MainActor var identity: String { get }
-
customizerItem
Default implementationHow this component should appear in the card customizer
Return
nil
if it should not be included in the customizerDefault Implementation
Declaration
Swift
@MainActor var customizerItem: TKUIHomeCardCustomizerItem? { get }
-
This closure returns an sequence whose element is a model used to populate a section of the table view in a
TKUIHomeCard
.You can hide a section dynamically by using
items == nil
. A section with empty items will still show just its header.Declaration
Swift
@MainActor var homeCardSection: Driver<TKUIHomeComponentContent> { get }
-
nextAction
Default implementationThis returns an action in response to selecting a row in the section returned by
homeCardSection
.Default Implementation
Declaration
Swift
@MainActor var nextAction: Signal<TKUIHomeCard.ComponentAction> { get }
-
This returns a cell that is used to display a row in the section returned by
homeCardSection
The
section
property of theindexPath
parameter corresponds to the position of the component view model in the list of view models passed to aTKUIHomeViewModel
. As such, it may change as other component view models are added or removed. It is best not to use thesection
property when configuring the returned cell.Declaration
Swift
@MainActor func cell(for item: TKUIHomeComponentItem, at indexPath: IndexPath, in tableView: UITableView) -> UITableViewCell?
Parameters
item
The data model used to construct the cell
indexPath
The index path at which the item is located
tableView
The table view in which the cell is displayed
-
registerCell(with:
Default implementation) This provides a component view model an opportunity to register the cell class with the table view in a
TKUIHomeCard
Default Implementation
Declaration
Swift
@MainActor func registerCell(with tableView: UITableView)
Parameters
tableView
The table view with which the cell class is registered
-
leadingSwipeActionsConfiguration(for:
Default implementationat: in: ) This gives a component view model an opportunity to specify what actions to display with a home card component item when the leading edge of the cell corresponding to the item is swiped
Typical, this method should only return an action configuration if the component view model is able to handle the incoming
item
.Warning
This is only called if your item returnstrue
tocanEdit
The
section
property of theindexPath
parameter corresponds to the position of the component view model in the list of view models passed to aTKUIHomeViewModel
. As such, it may change as other component view models are added or removed. It is best not to use thesection
property when configuring the returned cell.Default Implementation
Declaration
Swift
@MainActor func leadingSwipeActionsConfiguration(for item: TKUIHomeComponentItem, at indexPath: IndexPath, in tableView: UITableView) -> UISwipeActionsConfiguration?
Parameters
item
The data model representing the cell whose leading edge is swiped
indexPath
The index path at which the item is located
tableView
The table view in which the item is displayed
-
trailingSwipeActionsConfiguration(for:
Default implementationat: in: ) This gives a component view model an opportunity to specify what actions to display with a home card component item when the trailing edge of the cell corresponding to the item is swiped.
Typical, this method should only return an action configuration if the component view model is able to handle the incoming
item
.Warning
This is only called if your item returnstrue
tocanEdit
The
section
property of theindexPath
parameter corresponds to the position of the component view model in the list of view models passed to aTKUIHomeViewModel
. As such, it may change as other component view models are added or removed. It is best not to use thesection
property when configuring the returned cell.Default Implementation
Declaration
Swift
@MainActor func trailingSwipeActionsConfiguration(for item: TKUIHomeComponentItem, at indexPath: IndexPath, in tableView: UITableView) -> UISwipeActionsConfiguration?
Parameters
item
The data model representing the cell whose trailing edge is swiped
indexPath
The index path at which the item is located
tableView
The table view in which the item is displayed
-
contextMenuConfiguration(for:
Default implementationat: in: ) This gives a component view model an opportunity to specify what actions to display with a home card component item when the context menu of the cell corresponding to the item is triggered.
Typical, this method should only return an action configuration if the component view model is able to handle the incoming
item
.The
section
property of theindexPath
parameter corresponds to the position of the component view model in the list of view models passed to aTKUIHomeViewModel
. As such, it may change as other component view models are added or removed. It is best not to use thesection
property when configuring the returned cell.Default Implementation
Declaration
Swift
@MainActor func contextMenuConfiguration(for item: TKUIHomeComponentItem, at indexPath: IndexPath, in tableView: UITableView) -> UIContextMenuConfiguration?
Parameters
item
The data model representing the cell whose context menu was triggered
indexPath
The index path at which the item is located
tableView
The table view in which the item is displayed