Parchment v2.0.0 Release Notes
Release Date: 2020-08-02 // over 3 years ago-
๐ This version introduces a couple of breaking changes that are outlined below. If you're having issues upgrading or you see other breaking changes that are not outlined below, please let us know. More details about the release can be found here: #243.
โ Removed
FixedPagingViewController
๐
FixedPagingViewController
has been removed. You can now initializePagingViewController
directly with an array of view controllers.-FixedPagingViewController(viewControllers: viewControllers)+PagingViewController(viewControllers: viewControllers)
โ Removed generics (#285)
๐
PagingViewController
is not longer generic on thePagingItem
type. This means that all places where you previously had to specify the generic type, or cast to generic type, can be removed.-PagingViewController\<CalendarItem\>()+PagingViewController() -func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, pagingItemForIndex index: Int) -\> T {- return PagingIndexItem(index: index, title: cities[index]) as! T-}+func pagingViewController(\_: PagingViewController, pagingItemAt index: Int) -\> PagingItem {+ return PagingIndexItem(index: index, title: cities[index])+}
๐ Moved size delegate into separate protocol
๐ The
widthForPagingItem
delegate method have been moved out of thePagingViewControllerDelegate
and into a separate protocol calledPagingViewControllerSizeDelegate
. You now need to set thesizeDelegate
property onPagingViewController
:-pagingViewController.delegate = self+pagingViewController.sizeDelegate = self
Replaced
menuItemSource
withregister(cellClass:)
๐ The
menuItemSource
property for customizing the cell type has been removed. Instead you can customize the cell type for a givenPagingItem
by usingregister(cellClass:)
andregister(nib:)
. The benefit of this approach is that we can support multiple cell types in the same menu (#390).- pagingViewController.menuItemSource = .class(type: CalendarPagingCell.self)+ pagingViewController.register(CalendarPagingCell.self, for: CalendarItem.self)
โก๏ธ Updated naming of data sources
โก๏ธ As well as removing generics from the data sources, the naming has also been updated to be a bit more Swift-y.
protocol PagingViewControllerDataSource: class {- func numberOfViewControllers\<T\>(in pagingViewController: PagingViewController\<T\>) -\> Int+ func numberOfViewControllers(in pagingViewController: PagingViewController) -\> Int- func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, viewControllerForIndex index: Int) -\> UIViewController+ func pagingViewController(\_: PagingViewController, viewControllerAt index: Int) -\> UIViewController- func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, pagingItemForIndex index: Int) -\> T+ func pagingViewController(\_: PagingViewController, pagingItemAt index: Int) -\> PagingItem} protocol PagingViewControllerInfiniteDataSource: class {- func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, viewControllerForPagingItem: T) -\> UIViewController+ func pagingViewController(\_: PagingViewController, viewControllerFor pagingItem: PagingItem) -\> UIViewController- func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, pagingItemBeforePagingItem: T) -\> T?+ func pagingViewController(\_: PagingViewController, itemBefore pagingItem: PagingItem) -\> PagingItem?- func pagingViewController\<T\>(\_ pagingViewController: PagingViewController\<T\>, pagingItemAfterPagingItem: T) -\> T?+ func pagingViewController(\_ : PagingViewController, itemAfter pagingItem: PagingItem) -\> PagingItem?}