No new commits since latest release yet
- Only allowing the use of app extension API so using the library in an app extension does not produce a warning.
@igorkulman #70
-
Update project to support Swift 4.
@AYastrebov #54 -
Fix typo in StoryboardBased examples.
@danshevluk #42 -
Updated README instructions to Swift 3.
@neilkimmett #41
- Added a tvOS target in the Example project.
- Carthage should now see the tvOS framework
- The method
static func loadFromNib(owner:)
ofNibOwnerLoadable
has been replaced by instance methodfunc loadNibContent()
.
This is more consistent as we need an instance (owner) anyway, and also avoids possible crashes when used withUIView
subclasses not implementing non-required initializersinit()
/init(frame:)
. (Methodstatic func loadFromNib()
ofNibLoadable
is still unchanged).
@Skoti #40 - The
storyboard
property ofStoryboardBased
andStoryboardSceneBased
protocols has been renamed tosceneStoryboard
to avoid conflicts.
@jakubgert #33
-
Fixing documentation typos for
CollectionHeaderView
andMyXIBIndexSquaceCell
.
@Skoti -
Fixing TableView Controller scene in Example project, to display cells above
UITabBar
.
@Skoti
- Fix
instantiate()
implementation onStoryboardSceneBased
ViewControllers.
@jakubgert #38 - Removed strict
NibReusable
protocol conforming inregister
functions.
You can now make aReusable
-only cell with aNibLoadable
subclass.
@nekrich #37
- Converted library and Demo project to Swift 3.
⚠️ The following methods have new signatures:dequeueReusableCell(indexPath:)
is nowdequeueReusableCell(for:)
dequeueReusableCell(indexPath:cellType:)
is nowdequeueReusableCell(for:cellType:)
registerReusableCell(_:)
is nowregister(cellType:)
registerReusableHeaderFooterView(_:)
is nowregister(headerFooterViewType:)
registerReusableSupplementaryView(_:viewType:)
is nowregister(supplementaryViewType:ofKind:)
dequeueReusableSupplementaryView(_:indexPath:viewType:)
is nowdequeueReusableSupplementaryView(ofKind:for:viewType:)
@phatblat #30
@ceyhuno #31
- Adapted source files and demo project for Swift 2.3
@antondomashnev #16
- Added the possibility for
NibOwnerLoadable
confirming custom views to pass an existing instance asowner
(used as the File's Owner) in case one already exists. This is especially useful to implementinit(coder:)
to load the content of the XIB as subviews ofself
after initialization. SeeMyCustomWidget.swift
for an example.
@AliSoftware
- Added
StoryboardBased
andStoryboardSceneBased
protocols for storyboard basedUIViewController
easy instantiation.
@AliSoftware
- Added
NibOwnerLoadable
protocol forUIView
set as XIB's File's Owner.
@PoissonBallon #16
While the NibLoadable
protocol is adapted to views loaded from XIB but that are set as the root view of the XIB,
this new NibOwnerLoadable
protocol is adapted to view loaded from XIB too, but that are set as the XIB's File's Owner.
- Fixed issue with
register…
methods registering the superclassT
instead of the dynamic classcellType
/viewType
.
@narirou #13
This parameter is only needed if you can't write … as MyCell
(to let Swift infer the cell type from the return type),
which might be the case for example when your cell class is stored in a variable:
let cellType: Any.Type = self.cellTypeForIndexPath(indexPath)
// Can't do this in this case (because cellType is a variable):
let cell = tableView.dequeueReusableCell(indexPath: indexPath) as cellType ❌ // compiler error
// But now we can use that alternate way for such cases:
let cell = tableView.dequeueReusableCell(indexPath: indexPath, cellType: cellType)
But if you know the type at compile time, you can omit the cellType
parameter and still do this, letting the return type infer it for you:
let cell = tableView.dequeueReusableCell(indexPath: indexPath) as MyCell
-
Made every method
final
to allow more optimizations.
@AliSoftware -
Banned the use of
as!
in the source code in favour ofguard let x = y else { fatalError(…) }
. This avoids force-casts (which are considered bad practice) and generate a more explicit fatal error in case the developer forgot something (typically forgot to set the reuseIdentifier in IB).
@AliSoftware #6 -
Fixed bundle location of nibs. By default,
nib: UINib
ofNibLoadable
protocol will now use the nib located in the bundle of the conforming class.
@chrisamanse #10 -
Fixed issue with subclasses of types conforming to
Reusable
— due to the Swift bug SR-617.
@chrisamanse #2
- Added support for direct instantiation of arbitrary
UIView
from a nib.
@jakubvano #5
There is now a dedicated NibLoadable
protocol which can be used on any arbitrary UIView
(even non-"reusable" views) to load it from a XIB (via the loadFromNib()
function injected via the protocol extension).
_The NibReusable
protocol still exists for reusable cells but is now declared just as a combination of both the Reusable
and NibLoadable
protocols.
- Fixed missing
public
visibility for the protocols and extensions - Improved README documentation
- Added documentation
- Fixed generic constraints on the API working with
UICollectionView
'sSupplementaryView
- Updated Example project to add an UICollectionView with cells from XIB & Code + Header views
- Split protocol in two:
Reusable
andNibReusable
- Now contains a Demo project
Initial version. Only one Reusable
protocol
No demo project, but has a podspec
and a Package.swift