How to make an OTP/Pin view in swift ui?

Mukesh Solanki
2 min readJun 13, 2023

--

This post was originally posted here.

SwiftUI is a modern toolkit that has made iOS development a lot more intuitive, providing a declarative way of writing UI. One of the most common requirements for authentication in today’s modern apps is a way to enter an OTP/Pin to log in/signup or even verify a phone number. In this post, we are going to demonstrate how to use a simple library that makes it easy to integrate a customisable Otp/pin view in your iOS app.

Project Setup

Start by creating a new SwiftUI project

  1. Open Xcode and create a new project.
  2. Choose “App” as the template.
  3. Enter the product name, and make sure you select SwiftUI as the preferred interface.
  4. Choose the location where you want to save the project and simply click “create”.

Integrating the Package

We are going to use otpview-swiftui which is a simply library/package that provides a nice customisable view for otp verification. To integrate the library/package follow the below steps.

  1. Go to File -> Swift Packages -> Add Package Dependency
  2. In the search bar, enter https://github.com/mukeshsolanki/otpview-swiftui
  3. Choose the latest available version and click Next
  4. Make sure you select your target to add then click Finish

How to use the OTPView

Using the OtpView is very easy. Lets start by first importing the package to our view file like wise.

Once you have imported the package you should now be able to make use of the view. here is how you would use it.

Lets take a look at the different properties.

  1. activeColorIndicator — Color used to indicate the active digit of the otp view
  2. inactiveColorIndicator — Color used to indicate the inactive digits of the otp view.
  3. length — The size of the otp.
  4. doSomething(String) — A callback for when the user has input the otp. The parameter is the otp input by the user.

Thats pretty much it!! You have successfully implemented the package and your app is good to go!

Feel free to drop a clap or comment or reach out to me on LinkedIn, Twitter, Website.

--

--

Mukesh Solanki
Mukesh Solanki

Written by Mukesh Solanki

Converts coffee to code! Writes about software development, automation, android. Connect with me on https://www.mukeshsolanki.com

No responses yet