When a new user finishes onboarding and first starts to use an app, they will often see “blank state” pages. That is, pages with no activity, history or data, because it’s their first interaction with the product.
If a new user finds the blank state page intimidating it will just increase the friction and it won’t give them any reason to stick around.
When designing blank states I first try to come up with a list of scenarios and personas. It’s crucial to understand what users might be looking to do first when they log in to a new app or website.
If you have data to back up those scenarios or if there’s some necessary steps that need to be taken by users — like setting up an account profile — great. Then designing and writing copy can start. And it’s always better to make decisions based on actual data.
If you don’t have much data — like when designing a brand new interface or product — see if you can find data from similar applications, past projects, or other tests, then design and write copy accordingly.
The goal, I believe, is to then track usage and refine those blank states in order to properly guide users. Blank states are not a “set and forget” thing.
They always need to be refined to make sure they’re up to date and relevant.
It all depends on how tech savvy your users are, the niche of your product, how much training it takes for a new user to engage with your product and how complex your product is.
Having analyzed the pricing strategies of 100 SaaS companies, today we’re picking 20 of them to analyze their blank state pages. Having looked at all of them in details, we found eight main categories:
- Dashboard filled with default data: AcuityScheduling, Freshdesk
- Dashboard filled with sample data: Breezy, Groove
- Tutorial: Mixpanel
- Call to action: Campaign Monitor, Zengine
- No blank state: Mouseflow, Kissmetrics
- Hybrid: Basecamp
- Empty dashboard: 123contactform, Google Analytics
- Everything laid out: Mailigen, TalentLMS
1. Dashboards filled with default data
This is the type of dashboard where default data is filled in automatically to show you the features of the app. The important thing to note is that this is data that you would actually be able to use.
For Acuity Scheduling you get a week’s schedule automatically filled in to help you understand how you can organize your work week. It shows you that you can schedule a lunch break, or set yourself as not available during weekends.
With FreshDesk you get loads of notification examples displaying examples of how customer interactions and activities are reported within the app.
2. Dashboards filled with sample data
This is very similar to the dashboards with default data but with the one key difference: you have no actual use for the sample data. You see it within the app, you see what it looks like, and then you just go ahead and delete it.
Breezy displays a screen with sample data where you would be able to manage the candidates for the jobs you post.
In Groove you get a couple of sample notifications from the Groove team to show you what it looks like when a customer creates a ticket.
For this type of app, the first thing you see after you register is a video tutorial showing you more info about the features of the app.
In Mixpanel you see a video for every feature of the app. When you first login you’re redirected to “Segmentation”. Each of the videos explain how the feature works, and show you how you can use it.
4. Call to action
On this type of screen you get prompted to take the action required for you to be able to use the product.
For CampaignMonitor it means that you have to set up the first campaign. You get directed to this page which prompts you to go ahead and start creating the campaign.
In Zengine you have to add your contacts to create a workspace. The app prompts you to add a contact manually, or import a .csv file with your list of contacts.
5. No Blank State
This type of app doesn’t let you see the next screen unless you perform the required action.
For Mouseflow this means that you have to install their snippet on your website because otherwise the app can’t collect the data to show you heatmaps.
The same goes for Kissmetrics. Unless you install the code on your website, you won’t be able to get past this screen and see any features within the app.
Basecamp is in a category of its own. The two options displayed after the onboarding is complete feature a dashboard filled with sample data and a call to action.
This is the only hybrid blank state page that we were able to find.
7. Empty dashboard
This is the state where the user sees the dashboard without any data. You have to take an action (i.e. implement the tracking code) before it will become awash with data.
For 123contactform this means that you would have to create a new contact form and the dashboard would show the data only after someone has filled in and submitted the form.
It’s similar for Google Analytics. You first have to install the tracking code on your website and only then will the dashboard start to show you the data.
8. Everything laid out
We’ve also found a couple of products that display every single feature as soon as you finish registering for them. You are bombarded with a screen with lots of options.
This might be a bit too much for a regular user, but it’s an option that could work in a scenario where the user would receive training or view a demo prior to using the product.
This is the screen that you get to after logging in for the first time. Although you can experience Mailigen in 3 easy steps, it seems a bit confusing at first because you don’t know where you should click first.
The same goes for TalentLMS. Even though the features are briefly explained, I’m not sure which option I should click on first.
Having seen how other SaaS companies are handling their blank page states, the next step is to go back to your own app and choose the option that makes most sense for your product and users.
Which of the examples above closely match what you are currently serving up on your blank state pages? Or maybe you have a different example entirely? Tell us about it in the comments.