Your product discovery process is a mess, and your information architecture (IA) is to blame. There, I said it. The harsh truth is that almost 8 in 10 software projects (or 78%) grow much bigger than planned, often leading to failure. This happens due to poor initial planning, lack of clear communication between teams, and misalignment between stakeholder expectations and user needs.
But before you panic, take a deep breath. This article isn’t just about pointing out the problem — it’s about arming you with the tools to fix it. Drawing from our UI/UX design team’s years of experience, I’ll guide you through the world of information architecture. By the end, you’ll know exactly how to design a clear IA UI in four practical steps, with real-life examples to ground your understanding.
Information architecture (IA) definition refers to how information (content and functionality) is organized, structured, and presented in a product or application. When done right, it’s like having a master blueprint for your digital space. IA helps you:
IA helps you visualize the entire product structure before diving into designing screens themselves. This foresight allows you to spot potential conflicts or redundancies early, understand which design elements would fit better in this or that situation, and roughly estimate how much time will be needed for your work. It all saves time and resources during development.
Having a high overview of the entire product acts as a diagnostic tool. It reveals hidden complexities, redundant features, or underutilized sections that might be dragging down user experience.
IA forces you to think from the user’s perspective, helping you group related information logically. This results in intuitive navigation that guides users naturally through your product, reducing friction and improving overall experience.
A well-defined IA serves as a shared vision for the product. It helps prevent miscommunication between designers, developers, and stakeholders, ensuring everyone understands the product’s structure and goals. With a clear plan on hands, it becomes much easier to explain some new ideas for different departments.
IA visually represents the relationships between different parts of your product. This clear differentiation helps in prioritizing features and understanding how changes in one area might impact others.
The problem with designing an effective information architecture is that many resources on the internet are either too theoretical without practical guidance, or too basic, only showing sitemaps UX without explaining their real-world use. The approach I’m going to present to you will combine both theoretically easy-to-understand information and practical application of it.
So, now that you understand the information architecture meaning, what should be your starting point for building it?
Information architecture is based on the principles of Object-Oriented UX (OOUX). It’s a method of designing digital products by focusing on the core objects or “things” that users interact with, rather than just the actions they perform.
What does this mean? Let’s take a project management app as an example.
Focusing on objects first in OOUX brings more benefits because:
1. It mirrors how users naturally think about and interact with the world. Freelancers think, “I’m working on a project for a client,” not “I’m performing a series of administrative actions.”
2. It creates a more stable foundation for your product that can easily adapt to new features or changes. If you later want to add “expense tracking” or “contract management,” these fit naturally under the “Project” or “Client” objects without major restructuring.
3. It helps prevent feature bloat by keeping the focus on core elements. All project-related information (tasks, time tracked, invoices, etc.) stays together, creating a more intuitive and integrated user journey.
Planning your app using the OOUX approach may take different forms, like a table made in a spreadsheet, or a bunch of sticky notes.
No matter how it looks, with OOUX you divide your entire interface into
Object-oriented design can get complex, especially when defining actions for different roles in an app. For example, in an app like Uber, you’d need to figure out actions for passengers, drivers, support staff, the system itself, and admins.
However, when designing information architecture, you don’t need to be that detailed. Instead, you can focus on the admin role, as admins usually have access to all actions. This approach helps you form the overall structure of your application more easily.
To begin the IA design process, at this step, you should do three things:
So, we get back to our project management app for freelancers. To identify key elements, ask yourself “What does a freelancer need to work with?” Typically, a freelancer needs:
These form the core elements of our app’s structure, which often become the main pages or sections of our product. Let’s write them down (I used Figjam for this purpose, but you can use any other convenient tool, such as Figma, Lucidchart, or Miro).
Next, consider each object’s attributes (properties). For example, a Project object might have:
While objects typically become main pages, attributes represent the information displayed on each page.
Finally, list the actions a freelancer can perform on a Project. To make sure you cover everything, it’s helpful to organize them into three groups:
These are the basic things you can do with most stuff in the app. Like making a new project, looking at project details, changing project info, or getting rid of a project. For important data, such as financial apps, we often put archive instead of delete.
These are for when you have lots of one thing, like many projects or clients. This includes seeing all items, filtering them, or putting them in order. For example, looking at all your clients or sorting tasks by when they’re due.
These are special actions that don’t fit in the other groups Some examples are share and export.
By the end of this step, you’ll have three lists:
For your convenience, differentiate these three groups with colors.
In this step, we’ll connect our objects, attributes, and actions together to build the app’s logical structure. To do this, we’ll need to form user stories.
If objects, attributes, and actions are building blocks than user stories is what we build from them. And here’s a more formal way to explain the term:
User stories are short, simple descriptions of a feature told from the perspective of the person who wants the new capability, usually a user or customer of the system. They typically follow a simple template:
As a [type of user], I want [an action] so that [a benefit/a value].
For example, a user story like “As a freelancer, I want to quickly access my current projects so that I can update their status” might inform the decision to place a “Current Projects” section prominently in the IA.
This way, by creating user stories, we will be able to
Now, let’s see how creating user stories works in practice.
In the first step, we made a list of the main components of our app’s structure. In the second step, it’s time to combine them together and start building the IA scheme.
To keep it simple, think of writing user stories as defining the main functions for the admin role, who has access to all actions.
So, if we get back to our example of a user story “As a freelancer, I want to quickly access my projects so that I can update their status”, we can single out
Linking them together would result in something like this:
Here are several more examples of user stories you could come up with for a project management app.
Still, writing user stories for every case can be time-consuming. Instead, try this simpler approach:
Start by looking at each object, like Projects, Clients, or Tasks. For each one, think about what users can do with it. Remember the three types of actions we talked about earlier: basic stuff like creating and deleting, list actions like viewing all and sorting, and special features like sharing data.
For example, since we’ll have multiple projects, apart from the obvious function “Create new project”, we should apply List actions to the Project object:
Going through this process for each object helps you see clearly what every part of your app needs to do. It’s a simple way to make sure you’re not missing any important functions.
With your objects and actions laid out, creating user stories and building the Information Architecture becomes easier. Present each user story schematically by arranging objects, actions, and attributes in a logical order and establishing appropriate connections between them.
But before I illustrate the complete IA map now, let’s move to Step 3. This step is also part of building user stories but requires detailed discussion, so I wanted to address it separately.
Consider this user story:
“As a freelancer, I want to quickly view and edit information about a specific project, so that I can manage all aspects of a project in a focused, detailed environment.”
To provide a positive user experience for this scenario, our project management app should have a separate window or page for each specific project. This needs to be represented in our Information Architecture UX.
This is where modals become useful.
When we talk about IA in UI/UX design, a modal refers to a specific type of user interface element that temporarily disables the main content, forcing the user to interact with the modal or close it.
In IA, modals can take the form of:
Using modals in IA allows designers to:
This approach helps maintain focus on the overall structure. Still, as I already mentioned, incorporating modals into our IA is a part of our previous step – user stories. Together with objects, attributes, and actions, modals serve as building blocks for user flow.
So, let’s get back to where we stopped at the previous step. We have clearly defined key objects and main functionality of the app.
Modals are typically based on actions. Let’s examine each action to determine if it requires a modal:
This analysis allows us to enhance our IA map with appropriate modals.
Each modal will have its own set of actions. Referring back to user stories, here are the actions that can be available on a Project page:
We now link the attributes defined in the OOUX step to modals and their relevant actions. They will represent the content on the modals “Project page” and “Create new project”.
For example:
The last thing you have to do at this point is to visually differentiate objects, attributes, actions, and modals in a scheme with different colors.
Along this text, we mainly focused on the Projects object, detailing its actions, attributes, and modals and formed the structure of this specific flow. However, beyond the connections within each object, we also need to consider how different objects interact with each other. Defining these relationships is crucial for creating smooth app navigation.
Our IA map shows that a Project page contains information like Invoice ID, Client ID, and Task ID. This indicates that users can view project-specific tasks, associated clients, and related invoices from a single project page
When we look at the IA map we have so far, we can see that Project page contains information like Invoice ID, Client ID, and Task ID. This indicates that on this page, users can view project-specific tasks, associated clients, and related invoices.
We can define key relationships such as:
To visualize these relationships, you can use lines or arrows to connect related objects in your IA diagram.
This way, we illustrate how app navigation works. Users can find the Client ID by viewing project details or by going to the Clients page and selecting a specific client. This information is accessible from different pages and is interconnected.
This step completes your IA map, giving a comprehensive view of your app’s structure, functionality, and object relationships. It also allows for non-linear navigation, ensuring your product’s UX adheres to one of the 10 usability heuristics: User Control and Freedom.
Congratulations! We’ve come a long way in creating our IA map covering both theoretical concepts and practical applications. Now, to ensure you clearly understand what you need to do, here’s a concise step-by-step plan to guide you through the process.
By building a clear IA at your product discovery stage, you’ll be able to transform the uncertain question of “What are we building?” into the confident assertion “This is exactly what our users need.”
Remember, a well-planned IA isn’t just a blueprint — it’s the backbone of your entire user experience. It can mean the difference between a product that merely functions and one that truly excels in the market.