Skip to content

Commit

Permalink
Rename LazyListUpdateProcessor.Cell to Binding
Browse files Browse the repository at this point in the history
This new name fits its use better.
  • Loading branch information
squarejesse committed Oct 6, 2023
1 parent 79eb92e commit 897da7d
Show file tree
Hide file tree
Showing 3 changed files with 125 additions and 132 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import app.cash.redwood.layout.api.CrossAxisAlignment
import app.cash.redwood.lazylayout.api.ScrollItemIndex
import app.cash.redwood.lazylayout.widget.LazyList
import app.cash.redwood.lazylayout.widget.LazyListUpdateProcessor
import app.cash.redwood.lazylayout.widget.LazyListUpdateProcessor.Binding
import app.cash.redwood.lazylayout.widget.RefreshableLazyList
import app.cash.redwood.ui.Margin
import app.cash.redwood.widget.ChangeListener
Expand Down Expand Up @@ -73,25 +74,19 @@ internal open class UIViewLazyList(
protected var onViewportChanged: ((firstVisibleItemIndex: Int, lastVisibleItemIndex: Int) -> Unit)? = null

private val processor = object : LazyListUpdateProcessor<LazyListContainerCell, UIView>() {
override fun createCell(
cell: Cell<LazyListContainerCell, UIView>,
widget: Widget<UIView>,
override fun createView(
binding: Binding<LazyListContainerCell, UIView>,
index: Int,
): LazyListContainerCell {
val result = tableView.dequeueReusableCellWithIdentifier(
identifier = reuseIdentifier,
forIndexPath = NSIndexPath.indexPathForItem(index.convert(), 0.convert()),
) as LazyListContainerCell
require(result.cell == null)
result.cell = cell
result.setWidget(widget.value)
require(result.binding == null)
result.binding = binding
return result
}

override fun setWidget(cell: LazyListContainerCell, widget: Widget<UIView>) {
cell.setWidget(widget.value)
}

override fun insertRows(index: Int, count: Int) {
// TODO(jwilson): pass a range somehow when 'count' is large?
tableView.insertRowsAtIndexPaths(
Expand Down Expand Up @@ -125,7 +120,7 @@ internal open class UIViewLazyList(
override fun tableView(
tableView: UITableView,
cellForRowAtIndexPath: NSIndexPath,
) = processor.getCell(cellForRowAtIndexPath.item.toInt())
) = processor.getView(cellForRowAtIndexPath.item.toInt())
}

private val tableViewDelegate: UITableViewDelegateProtocol =
Expand Down Expand Up @@ -213,9 +208,19 @@ private const val reuseIdentifier = "LazyListContainerCell"
internal class LazyListContainerCell(
style: UITableViewCellStyle,
reuseIdentifier: String?,
) : UITableViewCell(style, reuseIdentifier) {
internal var cell: LazyListUpdateProcessor.Cell<LazyListContainerCell, UIView>? = null
internal var widgetView: UIView? = null
) : UITableViewCell(style, reuseIdentifier), LazyListUpdateProcessor.BoundView<UIView> {
internal var binding: Binding<LazyListContainerCell, UIView>? = null
override var content: Widget<UIView>? = null
set(value) {
field = value

removeAllSubviews()
if (value != null) {
contentView.addSubview(value.value)
contentView.translatesAutoresizingMaskIntoConstraints = false
}
setNeedsLayout()
}

override fun initWithStyle(
style: UITableViewCellStyle,
Expand All @@ -234,43 +239,34 @@ internal class LazyListContainerCell(

// Confirm the cell is bound when it's about to be displayed.
if (superview == null && newSuperview != null) {
require(cell!!.isBound) { "about to display a cell that isn't bound!" }
require(binding!!.isBound) { "about to display a cell that isn't bound!" }
}

// Unbind the cell when its view is detached from the table.
if (superview != null && newSuperview == null) {
removeAllSubviews()
cell?.unbind()
cell = null
binding?.unbind()
binding = null
}
}

override fun prepareForReuse() {
super.prepareForReuse()
removeAllSubviews()
cell?.unbind()
cell = null
}

fun setWidget(widgetView: UIView) {
this.widgetView = widgetView

removeAllSubviews()
contentView.addSubview(widgetView)
contentView.translatesAutoresizingMaskIntoConstraints = false
setNeedsLayout()
binding?.unbind()
binding = null
}

override fun layoutSubviews() {
super.layoutSubviews()

val widgetView = this.widgetView ?: return
widgetView.setFrame(bounds)
val content = this.content ?: return
content.value.setFrame(bounds)
contentView.setFrame(bounds)
}

override fun sizeThatFits(size: CValue<CGSize>): CValue<CGSize> {
return widgetView?.sizeThatFits(size) ?: return super.sizeThatFits(size)
return content?.value?.sizeThatFits(size) ?: return super.sizeThatFits(size)
}

private fun removeAllSubviews() {
Expand Down
Loading

0 comments on commit 897da7d

Please sign in to comment.