Skip to content

Commit

Permalink
Added currentVCIndex, cancelStandardButtonEvents settings
Browse files Browse the repository at this point in the history
Fixed fatalError("init(coder:) has not been implemented")
  • Loading branch information
Esqarrouth authored and Goktug Yilmaz committed Dec 7, 2015
1 parent d66b818 commit 18427b8
Show file tree
Hide file tree
Showing 4 changed files with 66 additions and 41 deletions.
2 changes: 1 addition & 1 deletion EZSwipeController.podspec
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Pod::Spec.new do |s|
s.name = "EZSwipeController"
s.version = "0.3"
s.version = "0.4"
s.summary = "UIPageViewController like Snapchat/Tinder/iOS Main Pages"
s.description = "Easy to use UIPageViewController to create a view navigation like Snapchat/Tinder/iOS Main Pages."
s.homepage = "https://github.com/goktugyil/EZSwipeController"
Expand Down
90 changes: 50 additions & 40 deletions EZSwipeController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ import UIKit
}

public class EZSwipeController: UIViewController {

public struct Constants {
public static var Orientation: UIInterfaceOrientation {
get {
Expand Down Expand Up @@ -61,52 +61,59 @@ public class EZSwipeController: UIViewController {
public static let navigationBarHeight: CGFloat = 44
public static let lightGrayColor = UIColor(red: 248, green: 248, blue: 248, alpha: 1)
}

public var stackNavBars = [UINavigationBar]()
public var stackVC: [UIViewController]!
public var stackPageVC: [UIViewController]!
public var stackStartLocation: Int!

public var bottomNavigationHeight: CGFloat = 44
public var pageViewController: UIPageViewController!
public var titleButton: UIButton?
public var currentStackVC: UIViewController!
public var currentVCIndex: Int {
get {
return stackPageVC.indexOf(currentStackVC)!
}
}
public var datasource: EZSwipeControllerDataSource?

public var navigationBarShouldBeOnBottom = false
public var navigationBarShouldNotExist = false

public var cancelStandardButtonEvents = false

public init() {
super.init(nibName: nil, bundle: nil)
setupView()
}

public required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
super.init(coder: aDecoder)
setupView()
}

private func setupDefaultNavigationBars(pageTitles: [String]) {
guard navigationBarShouldNotExist == false else {
return
}

var navBars = [UINavigationBar]()
for index in 0..<pageTitles.count {
let navigationBar = UINavigationBar(frame: CGRect(x: 0, y: 0, width: Constants.ScreenWidth, height: Constants.navigationBarHeight))
navigationBar.barStyle = UIBarStyle.Default
navigationBar.barTintColor = Constants.lightGrayColor

let navigationItem = UINavigationItem(title: pageTitles[index])
navigationItem.hidesBackButton = true
navigationItem.leftBarButtonItem = nil
navigationItem.rightBarButtonItem = nil

navigationBar.pushNavigationItem(navigationItem, animated: false)
navBars.append(navigationBar)
}
stackNavBars = navBars
}

private func setupNavigationBar() {
guard stackNavBars.isEmpty else {
return
Expand All @@ -120,31 +127,34 @@ public class EZSwipeController: UIViewController {
}
return
}

for index in 0..<stackVC.count {
let navigationBar = datasource?.navigationBarDataForPageIndex?(index)

if let nav = navigationBar {
if navigationBarShouldBeOnBottom {
nav.frame = CGRect(x: 0, y: Constants.ScreenHeightWithoutStatusBar - Constants.navigationBarHeight, width: Constants.ScreenWidth, height: Constants.navigationBarHeight)
} else {
nav.frame = CGRect(x: 0, y: 0, width: Constants.ScreenWidth, height: Constants.navigationBarHeight)
}
for item in nav.items! {
if let leftButton = item.leftBarButtonItem {
leftButton.target = self
leftButton.action = "clickedLeftButton"
}
if let rightButton = item.rightBarButtonItem {
rightButton.target = self
rightButton.action = "clickedRightButton"

if cancelStandardButtonEvents == false {
for item in nav.items! {
if let leftButton = item.leftBarButtonItem {
leftButton.target = self
leftButton.action = "clickedLeftButton"
}
if let rightButton = item.rightBarButtonItem {
rightButton.target = self
rightButton.action = "clickedRightButton"
}
}
}
stackNavBars.append(navigationBar!)
}
}
}

private func setupViewControllers() {
stackPageVC = [UIViewController]()
for index in 0..<stackVC.count {
Expand All @@ -164,7 +174,7 @@ public class EZSwipeController: UIViewController {
}
currentStackVC = stackPageVC[stackStartLocation]
}

private func setupPageViewController() {
pageViewController = UIPageViewController(transitionStyle: UIPageViewControllerTransitionStyle.Scroll, navigationOrientation: UIPageViewControllerNavigationOrientation.Horizontal, options: nil)
pageViewController.dataSource = self
Expand All @@ -185,11 +195,11 @@ public class EZSwipeController: UIViewController {
view.addSubview(pageViewController.view)
pageViewController.didMoveToParentViewController(self)
}

public func setupView() {

}

override public func loadView() {
super.loadView()
stackVC = datasource?.viewControllerData()
Expand All @@ -202,71 +212,71 @@ public class EZSwipeController: UIViewController {
setupViewControllers()
setupPageViewController()
}

override public func viewDidLoad() {
super.viewDidLoad()
}

@objc private func clickedLeftButton() {
let currentIndex = stackPageVC.indexOf(currentStackVC)!
datasource?.clickedLeftButtonFromPageIndex?(currentIndex)

let shouldDisableSwipe = datasource?.disableSwipingForLeftButtonAtPageIndex?(currentIndex) ?? false
if shouldDisableSwipe {
return
}

if currentStackVC == stackPageVC.first {
return
}
currentStackVC = stackPageVC[currentIndex - 1]
pageViewController.setViewControllers([currentStackVC], direction: UIPageViewControllerNavigationDirection.Reverse, animated: true, completion: nil)
}

@objc private func clickedRightButton() {
let currentIndex = stackPageVC.indexOf(currentStackVC)!
datasource?.clickedRightButtonFromPageIndex?(currentIndex)

let shouldDisableSwipe = datasource?.disableSwipingForRightButtonAtPageIndex?(currentIndex) ?? false
if shouldDisableSwipe {
return
}

if currentStackVC == stackPageVC.last {
return
}
currentStackVC = stackPageVC[currentIndex + 1]
pageViewController.setViewControllers([currentStackVC], direction: UIPageViewControllerNavigationDirection.Forward, animated: true, completion: nil)
}

}

extension EZSwipeController: UIPageViewControllerDataSource {

public func pageViewController(pageViewController: UIPageViewController, viewControllerBeforeViewController viewController: UIViewController) -> UIViewController? {
if viewController == stackPageVC.first {
return nil
}
return stackPageVC[stackPageVC.indexOf(viewController)! - 1]
}

public func pageViewController(pageViewController: UIPageViewController, viewControllerAfterViewController viewController: UIViewController) -> UIViewController? {
if viewController == stackPageVC.last {
return nil
}
return stackPageVC[stackPageVC.indexOf(viewController)! + 1]
}

}

extension EZSwipeController: UIPageViewControllerDelegate {

public func pageViewController(pageViewController: UIPageViewController, didFinishAnimating finished: Bool, previousViewControllers: [UIViewController], transitionCompleted completed: Bool) {
if !completed {
return
}
currentStackVC = stackPageVC[stackPageVC.indexOf(pageViewController.viewControllers!.first!)!]
}

}

1 change: 1 addition & 0 deletions EZSwipeController/MySwipeVC.swift
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ class MySwipeVC: EZSwipeController {
datasource = self
// navigationBarShouldBeOnBottom = true
// navigationBarShouldNotExist = true
// cancelStandardButtonEvents = true
}

override func viewDidLoad() {
Expand Down
14 changes: 14 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -297,6 +297,20 @@ class MySwipeVC: EZSwipeController {

<img src="Examplepics/no_navbar.gif" width="200">

####Extra Settings

``` swift
override func setupView() {
cancelStandardButtonEvents()
// Use this setting if you are using custom button that
// has nothing to do with swiping the viewcontroller
}
```

``` swift
self.currentVCIndex
//Use this to get the current page index
```

##Requirements

Expand Down

0 comments on commit 18427b8

Please sign in to comment.