Intro to SwiftUI Combine and Data
Add to favorites
Dive into data, notifications and performance integrated with the Combine API
Play video
data:image/s3,"s3://crabby-images/8f44f/8f44f13943b2e8047dc55c1021c99a28525bdec3" alt="icon"
SwiftUI Combine and Data
1
Intro to SwiftUI Combine and Data
9:56
2
Trackable Scroll View
9:46
3
NavigationLink and Link
16:04
4
Building a Data Model
15:18
5
Loading Data from a JSON file
13:00
6
Creating View Extensions
8:41
7
Coding our ProfileRow
8:52
8
Installing Firebase and Firestore
15:14
9
Fetching Data from Firestore
15:14
10
Displaying Data
13:14
11
TabView with Pagination
9:25
12
Toggle View
6:03
13
Firebase Cloud Messaging and APNs
7:58
14
Configuring Notifications in AppDelegate
9:00
15
Subscribing to Notification Topics
9:50
16
Observing the ScenePhase change
8:07
17
LiteMode and Testing Offline
18:07
18
Debug Navigator and Time Profiler
10:04
What you'll build
In this course, we'll learn how to build a part of the account view of our DesignCode iOS Application. This view might seem simple at first, but it holds a lot of data, logic and backend. We'll be covering how to store local data, data from a JSON file, in UserDefaults and in an external database, Firestore. Besides data, we'll take a look at the MVVM (Model-View-ViewModel) design pattern, push notifications with the help of Firebase Cloud Messaging, performance testing, and different aspects of the Combine API that allows us to update the UI asynchronously.
What is Combine?
Combine is a framework that lets you handle asynchronous events and maintain states in your app's lifecycle, an aspect that is absolutely necessary in any app. It allows you to sync data across your app and have your UI respond instantly to its changes. It helps in processing values step by step in a continuous flow, for example when using it in a network response or sharing a state variable with another class. Later on, we will be using Combine to notify changes to our views so that they can be updated accordingly.
Data model and data fetching
We'll learn how to create our own data models. We'll apply them to hard-coded data, to a local JSON array of objects, as well as to a document in Firestore. We'll also learn how to fetch and decode that data so that we can use it in our SwiftUI application.
Push notifications
One of the biggest advantages of using an iOS or Android application is receiving push notifications in real time. In this course, we'll learn how to send notifications to iOS devices using the Apple Push Notification service (APNs) and Firebase Cloud Messaging.
Performance and Testing
We'll also take a look at performance, and how some UI elements can affect performance in a full-fledged and complex app. To solve some performance issues, we'll create a LiteMode toggle that will turn off some UI elements that uses a lot of CPU, especially on older devices.
As for testing, we'll test our application in offline mode using Network Link Conditioner. We'll also take a look at Xcode's Debug Navigator and take testing a step further by profiling our application using Xcode's Instruments.
Requirements
For this course, you'll need a MacBook, since we'll be using Xcode. Xcode only runs on Apple's operating system. Also, make sure to download the latest version of Xcode. This course has been built on MacOS Big Sur, with Xcode version 12.5, SwiftUI 2.0 and running on iOS 14.5.
This course also assumes that you have basic knowledge of SwiftUI. If you're new to SwiftUI, I suggest you to follow the complete course Build an app with SwiftUI (Part 1, Part 2 and Part 3) to understand all the basics before moving on to this course.
Create your project
Once you meet all the requirements, let's create our Xcode project! Open Xcode, and in the modal that pops up, select Create a new Xcode project. We'll be creating an iOS App, so under the iOS tab, select the App option.
Give your project a name, then click on Next. Choose a location where you want to save your project. Make sure the Interface is SwiftUI and Life Cycle is SwiftUI App.
Perfect, now we created our Xcode project! Now, download the source files to follow this course.
Import Assets and Graphics
Once you downloaded the source files for this course, add them to your project:
- Drag and drop the Colors, Images and Logos folders from the Assets in the Assets.xcassets folder of your Xcode project.
- Drag and drop the Graphics folder in the ProjectName folder of your Xcode project. The Graphics folder contains two files: the AccountBackground.swift and the VisualEffectBlur.swift.
NavigationView
In ContentView.swift, add a NavigationView, wrapping the Text.
// ContentView.swift
var body: some View {
NavigationView {
Text("Hello, world!")
}
}
Add the .navigationViewStyle modifier to the NavigationView, and provide the value StackNavigationViewStyle(). This allows us to use NavigationView on iPad, without having our content in a sidebar.
// ContentView.swift
.navigationViewStyle(StackNavigationViewStyle())
Background
Inside of the NavigationView, embed the Text with a ZStack, aligned to the top. The frame's height should be .infinity and alignment .top. Then, we'll add the AccountBackground() that we imported from the downloads. We'll also hide the navigation bar, because this adds some unwanted padding at the top of our view.
// ContentView.swift
var body: some View {
NavigationView {
ZStack(alignment: .top) {
Text("Hello, world!")
.padding()
}
.frame(maxHeight: .infinity, alignment: .top)
.background(AccountBackground())
.navigationBarHidden(true)
}
.navigationViewStyle(StackNavigationViewStyle())
}
This is how your ContentView should look like by now:
Conclusion
Congratulations! We just created our Xcode project and added a beautiful background to our main view. In the next section, we'll learn how to make the status bar's background change on scroll.
Templates and source code
Download source files
Download the videos and assets to refer and learn offline without interuption.
Design template
Source code for all sections
Video files, ePub and subtitles
Videos
Assets
ePub
Subtitles
1
Intro to SwiftUI Combine and Data
Dive into data, notifications and performance integrated with the Combine API
9:56
2
Trackable Scroll View
Detect the content offset on scroll
9:46
3
NavigationLink and Link
Navigating between views and opening an external link
16:04
4
Building a Data Model
Creating and applying our own data model
15:18
5
Loading Data from a JSON file
Load and decode data from a JSON file
13:00
6
Creating View Extensions
Make your code cleaner by creating custom view extensions
8:41
7
Coding our ProfileRow
Creating the ProfileRow using view extensions
8:52
8
Installing Firebase and Firestore
Installing Firebase in our project
15:14
9
Fetching Data from Firestore
Reading data from Cloud Firestore
15:14
10
Displaying Data
Connecting view model and view together
13:14
11
TabView with Pagination
Using TabView with dynamic pagination
9:25
12
Toggle View
Adding a control that toggles between on and off states
6:03
13
Firebase Cloud Messaging and APNs
Setup Firebase Cloud Message and Apple Push Notification service
7:58
14
Configuring Notifications in AppDelegate
Using AppDelegate to handle notifications
9:00
15
Subscribing to Notification Topics
Subscribing users to notification topics
9:50
16
Observing the ScenePhase change
Using scenePhase to know the application's operational state
8:07
17
LiteMode and Testing Offline
Make your application more performant with a lite mode option and verify the user's network connection
18:07
18
Debug Navigator and Time Profiler
Test your app's performance
10:04
Meet the instructor
We all try to be consistent with our way of teaching step-by-step, providing source files and prioritizing design in our courses.
Stephanie Diep
iOS and Web developer
Developing web and mobile applications while learning new techniques everyday
7 courses - 36 hours
data:image/s3,"s3://crabby-images/32118/321188c723f1761bf6ed1822f32f2e7ef4d99cf3" alt="course logo"
Build Quick Apps with SwiftUI
Apply your Swift and SwiftUI knowledge by building real, quick and various applications from scratch
11 hrs
data:image/s3,"s3://crabby-images/7f5c7/7f5c7484a11b9ae3fd7301cef75f3a9f3463fd9c" alt="course logo"
Advanced React Hooks Handbook
An extensive series of tutorials covering advanced topics related to React hooks, with a main focus on backend and logic to take your React skills to the next level
3 hrs
data:image/s3,"s3://crabby-images/cfdf3/cfdf39f2d2de3fb064745386a0b381212d223b32" alt="course logo"
SwiftUI Concurrency
Concurrency, swipe actions, search feature, AttributedStrings and accessibility were concepts discussed at WWDC21. This course explores all these topics, in addition to data hosting in Contentful and data fetching using Apollo GraphQL
3 hrs
data:image/s3,"s3://crabby-images/cfdf3/cfdf39f2d2de3fb064745386a0b381212d223b32" alt="course logo"
SwiftUI Combine and Data
Learn about Combine, the MVVM architecture, data, notifications and performance hands-on by creating a beautiful SwiftUI application
3 hrs
data:image/s3,"s3://crabby-images/038f4/038f41cf4a889d643e5497ee126595ca0a385f30" alt="course logo"
SwiftUI Advanced Handbook
An extensive series of tutorials covering advanced topics related to SwiftUI, with a main focus on backend and logic to take your SwiftUI skills to the next level
4 hrs
data:image/s3,"s3://crabby-images/7f5c7/7f5c7484a11b9ae3fd7301cef75f3a9f3463fd9c" alt="course logo"
React Hooks Handbook
An exhaustive catalog of React tutorials covering hooks, styling and some more advanced topics
5 hrs
data:image/s3,"s3://crabby-images/a6401/a640150ebcef5886ae0bf2a9c21c18630c7148cf" alt="course logo"
SwiftUI Handbook
A comprehensive series of tutorials covering Xcode, SwiftUI and all the layout and development techniques
7 hrs