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

Update CalendarViewRepresentable methods to have the same signature as corresponding CalendarViewContent methods #271

Merged
merged 1 commit into from
Sep 19, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
22 changes: 12 additions & 10 deletions Sources/Public/CalendarViewRepresentable.swift
Original file line number Diff line number Diff line change
Expand Up @@ -98,13 +98,13 @@ public struct CalendarViewRepresentable: UIViewRepresentable {
fileprivate var horizontalDayMargin: CGFloat?
fileprivate var daysOfTheWeekRowSeparatorOptions: DaysOfTheWeekRowSeparatorOptions?

fileprivate var monthHeaderItemProvider: ((Month) -> AnyCalendarItemModel)?
fileprivate var monthHeaderItemProvider: ((Month) -> AnyCalendarItemModel?)?
fileprivate var dayOfWeekItemProvider: (
(
_ month: Month?,
_ weekdayIndex: Int)
-> AnyCalendarItemModel)?
fileprivate var dayItemProvider: ((Day) -> AnyCalendarItemModel)?
-> AnyCalendarItemModel?)?
fileprivate var dayItemProvider: ((Day) -> AnyCalendarItemModel?)?
fileprivate var dayBackgroundItemProvider: ((Day) -> AnyCalendarItemModel?)?
fileprivate var monthBackgroundItemProvider: ((MonthLayoutContext) -> AnyCalendarItemModel?)?
fileprivate var dateRangesAndItemProvider: (
Expand Down Expand Up @@ -322,16 +322,16 @@ extension CalendarViewRepresentable {
/// displayed. The `CalendarItemModel`s that you return will be used to create the views for each month header in
/// `CalendarView`.
///
/// If you don't configure your own month header item provider via this function, then a default month header item provider will be
/// used.
/// If you don't configure your own month header item provider via this function, or if the `monthHeaderItemProvider` closure
/// returns nil, then a default month header item provider will be used.
///
/// - Parameters:
/// - monthHeaderItemProvider: A closure (that is retained) that returns a `CalendarItemModel` representing a month
/// header.
/// - month: The `Month` for which to provide a month header item.
/// - Returns: A new `CalendarViewRepresentable` with a new month header item provider.
public func monthHeaderItemProvider(
_ monthHeaderItemProvider: @escaping (_ month: Month) -> AnyCalendarItemModel)
_ monthHeaderItemProvider: @escaping (_ month: Month) -> AnyCalendarItemModel?)
-> Self
{
var view = self
Expand Down Expand Up @@ -365,7 +365,8 @@ extension CalendarViewRepresentable {
/// For example, for the en_US locale, 0 is Sunday, 1 is Monday, and 6 is Saturday. This will be different in some other locales. The
/// `CalendarItemModel`s that you return will be used to create the views for each day-of-week view in `CalendarView`.
///
/// If you don't configure your own day-of-week item provider via this function, then a default day-of-week item provider will be used.
/// If you don't configure your own day-of-week item provider via this function, or if the `dayOfWeekItemProvider` closure
/// returns `nil`, then a default day-of-week item provider will be used.
///
/// - Parameters:
/// - dayOfWeekItemProvider: A closure (that is retained) that returns a `CalendarItemModel` representing a day of the
Expand All @@ -378,7 +379,7 @@ extension CalendarViewRepresentable {
_ dayOfWeekItemProvider: @escaping (
_ month: Month?,
_ weekdayIndex: Int)
-> AnyCalendarItemModel)
-> AnyCalendarItemModel?)
-> Self
{
var view = self
Expand Down Expand Up @@ -415,15 +416,16 @@ extension CalendarViewRepresentable {
/// view should be some kind of label that tells the user the day number of the month. You can also add other decoration, like a
/// badge or background, by including it in the view that your `CalendarItemModel` creates.
///
/// If you don't configure your own day item provider via this function, then a default day item provider will be used.
/// If you don't configure your own day item provider via this function, or if the `dayItemProvider` closure
/// returns nil, then a default day item provider will be used.
///
/// - Parameters:
/// - dayItemProvider: A closure (that is retained) that returns a `CalendarItemModel` representing a single day in the
/// calendar.
/// - day: The `Day` for which to provide a day item.
/// - Returns: A new `CalendarViewRepresentable` with a new day item provider.
public func dayItemProvider(
_ dayItemProvider: @escaping (_ day: Day) -> AnyCalendarItemModel)
_ dayItemProvider: @escaping (_ day: Day) -> AnyCalendarItemModel?)
-> Self
{
var view = self
Expand Down
30 changes: 30 additions & 0 deletions Tests/CalendarContentTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
import XCTest
@testable import HorizonCalendar

// MARK: - CalendarContentTests

final class CalendarContentTests: XCTestCase {

func testCanReturnNilFromCalendarContentClosures() {
Expand Down Expand Up @@ -67,3 +69,31 @@ final class CalendarContentTests: XCTestCase {
}

}

// MARK: - CalendarContentConfigurable

/// Test case demonstrating that `CalendarViewContent` and `CalendarViewRepresentable` both have the same APIs
/// and can be abstracted behind a single protocol
protocol CalendarContentConfigurable {
func monthHeaderItemProvider(
_ monthHeaderItemProvider: @escaping (_ month: Month) -> AnyCalendarItemModel?)
-> Self

func dayOfWeekItemProvider(
_ dayOfWeekItemProvider: @escaping (
_ month: Month?,
_ weekdayIndex: Int)
-> AnyCalendarItemModel?)
-> Self

func dayItemProvider(_ dayItemProvider: @escaping (_ day: Day) -> AnyCalendarItemModel?) -> Self
}

// MARK: - CalendarViewContent + CalendarContentConfigurable

extension CalendarViewContent: CalendarContentConfigurable { }

// MARK: - CalendarViewRepresentable + CalendarContentConfigurable

@available(iOS 13.0, *)
extension CalendarViewRepresentable: CalendarContentConfigurable { }