Skip to content

tasanobu-zz/Kamagari

Repository files navigation

Kamagari

Language CocoaPods Carthage compatible License Issues

Simple UIAlertController builder class in Swift.

Features

  • AlertBuilder class to simply build UIAlertController by using method chaining
  • UIAlertController extension methods to simply present UIAlertController on screen

Usage

The following sample codes shows how to use Kamagari in order to present UIAlertController.

// ActionSheet Sample
    if UIDevice.current.userInterfaceIdiom != .pad {
            // Sample to show on iPad
            AlertBuilder(title: "Question", message: "Are you sure where Kamagari is?", preferredStyle: .actionSheet)
                .addAction(title: "NO", style: .cancel) { _ in }
                .addAction(title: "YES", style: .default) { _ in }
                .build()
                .kam_show(animated: true)
    } else {
            /*
             Sample to show on iPad
             With setPopoverPresentationProperties(), specify the properties of UIPopoverPresentationController.
             */
            AlertBuilder(title: "Question", message: "Are you sure where Kamagari is?", preferredStyle: .actionSheet)
                .addAction(title: "YES", style: .default) { _ in }
                .addAction(title: "Not Sure", style: .default) { _ in }
                .setPopoverPresentationProperties(sourceView: view, sourceRect: CGRect(x: 0, y: 0, width: 100, height: 100) ,                                barButtonItem: nil, permittedArrowDirections: .any)
                .build()
                .kam_show(animated: true)
  }

Requirements

  • iOS 8.0+
  • Swift 4.0
  • Xcode 9.0

Installation

  • Install with CocoaPods
pod 'Kamagari'
  • Copy in all the files into your project
  • Use git submodule

Release Notes

See https://github.com/tasanobu/Kamagari/releases

License

Kamagari is released under the MIT license. See LICENSE for details.

About

Simple UIAlertController builder class in Swift.

Resources

License

Stars

Watchers

Forks

Packages

No packages published