paint-brush
Onboarding Flow in iOS 18 - #30DaysOfSwiftby@vaibhavdwivedi
143 reads

Onboarding Flow in iOS 18 - #30DaysOfSwift

by VaibhavOctober 8th, 2024
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

In the Fifth post of the #30DaysOfSwift series, let's learn how to add an onboarding screen to your SwiftUI (or UIKit) based iOS App.
featured image - Onboarding Flow in iOS 18 - #30DaysOfSwift
Vaibhav HackerNoon profile picture

Day 4: Welcome them in style! 🎉


In the Fifth post of the #30DaysOfSwift series, let's learn how to add an onboarding screen to your SwiftUI (or UIKit) based iOS App.


Onboarding is essential to guide new users through the features of your app.

Image description

Here's the code for you to copy from:



struct ContentView: View {
    @State private var showOnboarding = false

    var body: some View {
        VStack {
            if showOnboarding {
                OnboardingView()
            } else {
                MainView() // Your main app content
            }
        }
        .onAppear {
            checkUser() // Check onboarding status
        }
    }

    func checkUser() {
        // Logic to check if user is onboarded
        let userOnboarded = UserDefaults.standard.bool(forKey: "userOnboarded")
        showOnboarding = !userOnboarded
    }
}

struct OnboardingView: View {
    var body: some View {
        VStack {
            TabView {
                VStack {
                    Image(systemName: "star.fill")
                        .resizable()
                        .frame(width: 100, height: 100)
                    Text("Welcome to the App")
                        .font(.largeTitle)
                        .bold()
                        .padding()
                    Text("Discover amazing features")
                        .font(.subheadline)
                        .padding()
                }

                VStack {
                    Image(systemName: "heart.fill")
                        .resizable()
                        .frame(width: 100, height: 100)
                    Text("Stay Connected")
                        .font(.largeTitle)
                        .bold()
                        .padding()
                    Text("Connect with friends and family")
                        .font(.subheadline)
                        .padding()
                }
            }
            .tabViewStyle(PageTabViewStyle())
            .indexViewStyle(PageIndexViewStyle(backgroundDisplayMode: .always))

            Button("Get Started") {
                // Mark user as onboarded
                UserDefaults.standard.set(true, forKey: "userOnboarded")
                // Navigate to the main content
            }
            .padding()
            .background(Color.blue)
            .foregroundColor(.white)
            .cornerRadius(10)
        }
    }
}


How it works:

  1. The ContentView checks if the user has been onboarded via UserDefaults. If not, the onboarding screen is shown.


  2. Once the user taps "Get Started," we set a flag in UserDefaults to ensure the onboarding screen doesn’t show up again.


Happy Coding!