SwiftHelpers is focused on making simpler the most tedious and repeating tasks when it comes to developing in Swift
- iOS 8.0+
- XCode 8+
Dynamic libraries or those made with Swift, require iOS 8.0+
In order to install through CocoaPods, just add this line in your podfile:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
use_frameworks!
pod 'SwiftyHelpers', '~> 1.0.0'
For swift 2 version, put
pod 'SwiftyHelpers', '~> 0.1.5'
Next, excute in terminal
$ pod install
Just clone the project using this command in terminal:
$ git clone https://github.com/jpachecou/SwiftyHelpers.git
Find a folder named Source and drag onto your project
First of all: if you are using CocoaPods, you just need to import import SwiftyHelpers
module.
-
UITableView
&UICollectionView
-In order to make this utility work, there has to be a cell inside of a
.xib
file with the same name of the class that the cell is subclassing. Given the case in a tableView:class FooTableViewCell: UITableViewCell {} class FooCollectionViewCell: UICollectionViewCell {} class FooTableHeaderView: UITableViewHeaderFooterView {} class FooCollectionHeaderView: UICollectionReusableView {} /* +-- FooTableViewCell.swift +-- FooTableViewCell.xib +-- FooCollectionViewCell.swift +-- FooCollectionViewCell.xib +-- FooTableHeaderView.swift +-- FooTableHeaderView.xib +-- FooCollectionHeaderView.swift +-- FooCollectionHeaderView.xib */
As soon as class and
.xib
are ready, in order to register cells in aUITableView
orUICollectionView
, just invoke the<=
operator among the tableView/collectionView and the cell.// Register cell in a table view self.tableView <= FooTableViewCell.self // Register header or footer in a table view self.tableView <= FooTableHeaderView.self // Register cell in collection view self.collectionView <= FooCollectionViewCell.self // Register header or footer in collection view collectionView <= (HeaderCollectionReusableView.self, UICollectionElementKindSectionHeader) collectionView <= (FooterCollectionReusableView.self, UICollectionElementKindSectionFooter)
In order to obtain registered cells, just declare an instance of it with its class:
-
Get cell of a tableView, example:
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { let cell: FooTableViewCell = tableView.cellForClass() // configure cell return cell }
-
Get header or footer of a tableView, example:
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { let cell: FooTableHeaderView = tableView.headerFooterForClass() // configure cell return cell }
-
Get cell of a collectionView, example:
func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell { let cell: FooCollectionViewCell = collectionView.cellForClass(indexPath) // Configure cell return cell }
-
Get header or footer of a collection view, example:
func collectionView(collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, atIndexPath indexPath: NSIndexPath) -> UICollectionReusableView { if kind == UICollectionElementKindSectionHeader { let header: HeaderCollectionReusableView = collectionView.supplementaryViewForClass(indexPath, kind: kind) // or let header: HeaderCollectionReusableView = headerForClass(indexPath) // Configure hedaer return header } let footer: FooterCollectionReusableView = footerForClass(indexPath) // Configure footer return footer }
-
-
UIView
-
Previously to load a nib file, the
UIView
subclass and.xib
should have equal name in order to instantiate it.class FooView: UIView {} /* +-- FooView.swift +-- FooView.xib */ guard let fooView: FooView? = loadCustomView() else { return }
-
Removing recursively subViews from
UIView
, simply using theremoveAllSubViews
-
Public method
getSubviewIntoView
is used recursively in order to get a specific subView, with a concrete class, inside of theUIView
subviews.let fooSubview: FooView = getSubviewIntoView(self.view)
This line will locate the first FooView subview inside of all
UIView
array of subviews
SwiftyHelpers is licensed under the MIT-License. See LICENSE for more details.
-