Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Compositional layout support #115

Merged
merged 24 commits into from
May 22, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
6c8df36
update flow layout section controller
CalvinChangCC Apr 2, 2024
7bfeea1
add compositional support for the section controller
CalvinChangCC Apr 2, 2024
8fabf99
add bridge between layout provider and adapter
CalvinChangCC Apr 2, 2024
7df5437
update tests
CalvinChangCC Apr 2, 2024
ba14a56
add references
CalvinChangCC Apr 2, 2024
8cfb786
Fix warnings
CalvinChangCC Apr 2, 2024
f43f715
Add the constants for the better reading
CalvinChangCC Apr 3, 2024
c796b81
add typealias
CalvinChangCC Apr 10, 2024
dc80cf6
fix tests
CalvinChangCC Apr 10, 2024
f5492f3
merge the section controller with section layout provider and depreca…
CalvinChangCC Apr 10, 2024
3728b83
revert changes
CalvinChangCC Apr 10, 2024
525d04b
put return inside available to compatible with older versions
CalvinChangCC Apr 10, 2024
3d3ba9a
fix project file
CalvinChangCC Apr 10, 2024
cf89c6f
clean up
CalvinChangCC Apr 10, 2024
13105f4
add new name example
CalvinChangCC Apr 2, 2024
725c144
Update Example/Examples/Sources/Examples/ExampleList/ExampleListCoord…
CalvinChangCC Apr 3, 2024
5a2e38b
update example
CalvinChangCC Apr 10, 2024
cd6ee38
fix proj file
CalvinChangCC Apr 10, 2024
1ae6656
fix assert message
CalvinChangCC Apr 16, 2024
1545811
improve assert message
CalvinChangCC Apr 16, 2024
9e1437f
make the layout provider nonoptional
CalvinChangCC Apr 19, 2024
cbfbfe1
update better naming
CalvinChangCC Apr 19, 2024
a6c9f71
make better assertion
CalvinChangCC Apr 19, 2024
1583225
fix tests
CalvinChangCC May 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add the constants for the better reading
  • Loading branch information
CalvinChangCC committed May 22, 2024
commit f43f715da9eae78b67a565bd19aaf94e6840fb0d
Original file line number Diff line number Diff line change
Expand Up @@ -14,35 +14,35 @@ open class BaseFlowLayoutSectionController: BaseSectionController,
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.itemSize ?? CGSize(width: 50, height: 50)
layout.flowLayout?.itemSize ?? FlowLayoutConstants.defaultItemSize
}

open func inset(using layout: UICollectionViewLayout, in context: CollectionViewContext) -> UIEdgeInsets {
(layout as? UICollectionViewFlowLayout)?.sectionInset ?? .zero
layout.flowLayout?.sectionInset ?? FlowLayoutConstants.defaultInset
}

open func minimumLineSpacing(using layout: UICollectionViewLayout, in context: CollectionViewContext) -> CGFloat {
(layout as? UICollectionViewFlowLayout)?.minimumLineSpacing ?? 10
layout.flowLayout?.minimumLineSpacing ?? FlowLayoutConstants.defaultMinimumLineSpacing
}

open func minimumInteritemSpacing(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGFloat {
(layout as? UICollectionViewFlowLayout)?.minimumInteritemSpacing ?? 10
layout.flowLayout?.minimumInteritemSpacing ?? FlowLayoutConstants.defaultMinimumInteritemSpacing
}

open func referenceSizeForHeader(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.headerReferenceSize ?? .zero
layout.flowLayout?.headerReferenceSize ?? FlowLayoutConstants.defaultHeaderSize
}

open func referenceSizeForFooter(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.footerReferenceSize ?? .zero
layout.flowLayout?.footerReferenceSize ?? FlowLayoutConstants.defaultFooterSize
}
}
27 changes: 21 additions & 6 deletions SectionKit/Sources/SectionController/SectionFlowDelegate.swift
Original file line number Diff line number Diff line change
Expand Up @@ -76,47 +76,62 @@ public protocol SectionFlowDelegate: AnyObject {
func referenceSizeForFooter(using layout: UICollectionViewLayout, in context: CollectionViewContext) -> CGSize
}

enum FlowLayoutConstants {
static let defaultItemSize = CGSize(width: 50, height: 50)
static let defaultInset: UIEdgeInsets = .zero
static let defaultMinimumLineSpacing: CGFloat = 10
static let defaultMinimumInteritemSpacing: CGFloat = 10
static let defaultHeaderSize: CGSize = .zero
static let defaultFooterSize: CGSize = .zero
}

extension SectionFlowDelegate {
public func sizeForItem(
at indexPath: SectionIndexPath,
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.itemSize ?? CGSize(width: 50, height: 50)
layout.flowLayout?.itemSize ?? FlowLayoutConstants.defaultItemSize
}

public func inset(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> UIEdgeInsets {
(layout as? UICollectionViewFlowLayout)?.sectionInset ?? .zero
layout.flowLayout?.sectionInset ?? FlowLayoutConstants.defaultInset
}

public func minimumLineSpacing(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGFloat {
(layout as? UICollectionViewFlowLayout)?.minimumLineSpacing ?? 10
layout.flowLayout?.minimumLineSpacing ?? FlowLayoutConstants.defaultMinimumLineSpacing
}

public func minimumInteritemSpacing(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGFloat {
(layout as? UICollectionViewFlowLayout)?.minimumInteritemSpacing ?? 10
layout.flowLayout?.minimumInteritemSpacing ?? FlowLayoutConstants.defaultMinimumInteritemSpacing
}

public func referenceSizeForHeader(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.headerReferenceSize ?? .zero
layout.flowLayout?.headerReferenceSize ?? FlowLayoutConstants.defaultHeaderSize
}

public func referenceSizeForFooter(
using layout: UICollectionViewLayout,
in context: CollectionViewContext
) -> CGSize {
(layout as? UICollectionViewFlowLayout)?.footerReferenceSize ?? .zero
layout.flowLayout?.footerReferenceSize ?? FlowLayoutConstants.defaultFooterSize
}
}

extension UICollectionViewLayout {
var flowLayout: UICollectionViewFlowLayout? {
self as? UICollectionViewFlowLayout
}
}