Skip to content

Latest commit

 

History

History
96 lines (66 loc) · 2.21 KB

README.md

File metadata and controls

96 lines (66 loc) · 2.21 KB

Build Status CocoaPods Compatible

A solution for iOS modules and components separation. You can route to viewController or perform native block with url.

Features

Register LoginViewController as follow

Route.defaultCtx.register(LoginViewController.self, forPath: "test.com/login")

Register closure as follow

Handler.defaultCtx.register({ (input) in
    print(input)
}, forPath: "test.com/showAlert?title=Hello World")

Route to LoginViewController by a Route key

try? Route(path: "test.com/login")
        .input(["stringValue": "This message came from a Route"])
        .submit()

Route to LoginViewController with a custom transition

try? Route(path: "test.com/login")
        .input(["stringValue": "This message came from a Route"])
        .transition(SystemTransition(axis: .horizontal, style: .zoom(factor: 0.8)))
        .submit()

Route to LoginViewController with a custom config

try? Route(key: "test.com/login")
        .input(["stringValue": "This message came from a Route"])
        .config(.present([.fakePush, .wrapNC]))
        .transition(SystemTransition(axis: .horizontal, style: .zoom(factor: 0.8)))
        .submit()

Currently, we support

  • Present
  • Push
  • Switch
  • Popup
  • AsChild

Route to LoginViewController by a remote URL

try? Route(urlString: "Route://test.com/login?stringValue=This message came from a url string")
        .submit()

Installation with CocoaPods

CocoaPods is a dependency manager for Objective-C, which automates and simplifies the process of using 3rd-party libraries. You can install it with the following command:

$ gem install cocoapods

Podfile

To integrate Intent into your Xcode project using CocoaPods, specify it in your Podfile:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'

pod 'Intent'

Then, run the following command:

$ pod install

License

(MIT license)