Notie
  • October 28, 2023

Undistracted in-app notification in Swift, with added buttons and input box.

Installation


CocoaPods

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

source ‘https://github.com/CocoaPods/Specs.git’
platform :ios, ‘9.0’
use_frameworks!

pod ‘Notie’

Then, run the following command:

$ pod install

And add import Notie to the top of the files using Notie.

Carthage

Carthage is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks.

You can install Carthage with Homebrew using the following command:

$ brew update
$ brew install carthage

To integrate Notie into your Xcode project using Carthage, specify it in your Cartfile:

github “thii/Notie”

Run carthage to build the framework and drag the built Notie.framework into your Xcode project.

Usage


Example

Show a notification with Confirm style

let notie = Notie(view: self.view, message: “Are you sure you want to do that?”, style: .Confirm)

notie.leftButtonAction = {
// Add your left button action here
notie.dismiss()
}

notie.rightButtonAction = {
// Add your right button action here
notie.dismiss()
}

notie.show()

Or, if you want just a standard notification

let notie = Notie(view: self.view, message: “This is a notification!”, style: .Confirm)

 

notie.buttonCount = Notie.buttons.standard

notie.leftButtonAction = {
notie.dismiss()
}

 

notie.show()

Parameters

The following parameters can be modified to customize the appearance of the notification.

  • style: The style of the notification. .Confirm style includes message view and two confirm buttons. .Input style adds an extra input text field. Default to .Confirm.

  • leftButtonAction: A block to call when the user taps on the left button.

  • rightButtonAction: A block to call when the user taps on the right button.

  • leftButtonTitle: The title of the left button. Default to OK.

  • rightButtonTitle: The title of the left button. Default to Cancel.

  • placeholder: The placeholder of the input text field. Default to nil.

  • animationDuration: How long the slide down animation should last.

  • messageBackgroundColor: The background color of the message view.

  • messageTextColor: The text color of the message view. Default to white color.

  • inputFieldBackgroundColor: The background color of the input text field. Default to white color.

  • inputFieldTextColor: The text color of the input text field. Default to dark gray.

  • leftButtonBackgroundColor: The background color of the left button.

  • leftButtonTextColor: The text color of the left button. Default to white color.

  • rightButtonBackgroundColor: The background color of the right button.

  • rightButtonTextColor: The text color of the right button. Default to white color.

  • buttonCount: The button configuration, defaults to Notie.buttonCount.standard (two buttons). When the value is set to Notie.buttonCount.single, the action defaults to the left button.

  • keyboardType: The UIKeyboardType to use

Functions


  • getText() returns a String value of the text when using a .Input style

Requirements


iOS 9 or greater.

GitHub


View Github

#input #ios #placeholder #swift #textfield #uibutton #xcode
YOU MIGHT ALSO LIKE...
Popup View

Floaters Toasts Popups Sheets

Drops 💧

A µFramework for showing alerts like the one used when copying from pasteboard or connecting Apple pencil.

MarqueeText

A SwiftUI Marquee or "scrolling text" effect found in Apple native apps. For when one line isn't enough, but two ...

TextBuilder

Introduction Text composition in SwiftUI can often be cumbersome, especially when there's logic affecting its format and content. TextBuilder leverages the ...

TextView

Download File -> Swift Packages -> Add Package Dependency... Select your project Enter https://github.com/kenmueller/TextView for the package repository URL Select Branch: master Click Finish ...