Skip to content
🍩 Unified communication patterns with easy closure in Swift
Branch: master
Clone or download
Latest commit 97d5981 May 22, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
EasyClosure-tvOS Initial commit May 18, 2019
EasyClosure.xcodeproj Fix name for macOS May 18, 2019
EasyClosure Initial commit May 18, 2019
EasyClosureTests Add macOS tests May 18, 2019
Example/EasyClosureDemo Update readme May 18, 2019
Playground-Mac.playground Initial commit May 18, 2019
Playground-iOS.playground
Screenshots Initial commit May 18, 2019
Sources Fix name for macOS May 18, 2019
.gitignore Initial commit May 18, 2019
CONTRIBUTING.md Initial commit May 18, 2019
EasyClosure.podspec Fix name for macOS May 18, 2019
LICENSE.md Initial commit May 18, 2019
README.md Update README.md May 21, 2019

README.md

EasyClosure

Version Carthage Compatible License Platform Swift

Table of contents

Story

There are many Communication patterns

Sometimes, you just want a unified and quick way to do it. Just call on on any NSObject subclasses and handle your events the quickest way

Features

  • Shortcut to handle actions and events
  • Easy to extend
  • Correct method suggestion based on generic protocol constraint
  • Support iOS, macOS

Example

We can make a fun demo of good, cheap, fast with UISwitch

func allOn() -> Bool {
  return [good, cheap, fast].filter({ $0.isOn }).count == 3
}

good.on.valueChange { _ in
  if allOn() {
    fast.setOn(false, animated: true)
  }
}

cheap.on.valueChange { _ in
  if allOn() {
    good.setOn(false, animated: true)
  }
}

fast.on.valueChange { _ in
  if allOn() {
    cheap.setOn(false, animated: true)
  }
}

Target-Action and Delegate

UIButton

button.on.tap {
  print("button has been tapped")
}

UISlider

slider.on.valueChange { value in
  print("slider has changed value")
}

UITextField

textField.on.textChange { text in
  print("textField text has changed")
}

UITextView

textView.on.textChange { text in
  print("textView text has changed")
}

UISearchBar

searchBar.on.textChange { text in
  print("searchBar text has changed")
}

UIDatePicker

datePicker.on.pick { date in
  print("datePicker has changed date")
}

UIBarButtonItem

barButtonItem.on.tap {
  print("barButtonItem has been tapped")
}

UIGestureRecognizer

gestureRecognizer.on.occur {
  print("gesture just occured")
}

Extensible

Extend Container and specify Host to add more functionalities to your own types. For example

public extension Container where Host: UITableView {
  func cellTap(_ action: @escaping (UITableViewCell) -> Void)) {
    // Your code here here
  }
}

// usage
let tableView = UITableView()
tableView.on.cellTap { cell in
  
}

Installation

EasyClosure is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod 'EasyClosure'

EasyClosure is also available through Carthage. To install just write into your Cartfile:

github "onmyway133/EasyClosure"

EasyClosure can also be installed manually. Just download and drop Sources folders in your project.

Author

Khoa Pham, onmyway133@gmail.com

Contributing

We would love you to contribute to EasyClosure, check the CONTRIBUTING file for more info.

License

EasyClosure is available under the MIT license. See the LICENSE file for more info.

You can’t perform that action at this time.