/outsystems-tutorials

How to use “If” and “Switch” widgets in OutSystems to display UI elements conditionally?

Learn how to leverage If and Switch widgets in OutSystems to conditionally display UI elements, enhancing dynamic and responsive application development.

Matt Graham, CEO of Rapid Developers

Book a call with an Expert

Starting a new venture? Need to upgrade your website? RapidDev builds Webflow websites with your growth in mind.

Book a free No-Code consultation

How to use “If” and “Switch” widgets in OutSystems to display UI elements conditionally?

Using "If" and "Switch" Widgets in OutSystems for Conditional UI Display

 

This guide provides a comprehensive step-by-step process on how to leverage the "If" and "Switch" widgets in OutSystems to conditionally display user interface elements. These tools are essential for creating dynamic and responsive applications that cater to various user interactions and data states.

 

Prerequisites

 

  • An active OutSystems account with an application set up in the OutSystems Service Studio.
  • Basic understanding of OutSystems architecture, including the structure of screens, variables, and expressions.
  • Familiarity with basic logical and conditional expressions used in programming.

 

Understanding "If" and "Switch" Widgets

 

  • The "If" widget is used to conditionally display content based on a boolean expression or condition being true or false.
  • The "Switch" widget works like a multi-conditional statement allowing different content to be displayed based on the value of a given expression.

 

Implementing the "If" Widget

 

  • Open the OutSystems Service Studio and navigate to the screen where you want to implement conditional UI elements.
  • From the Widgets Toolbox, drag and drop the "If" widget onto your screen where you want the content to conditionally appear.
  • Define the condition: In the properties pane for the "If" widget, specify a boolean expression in the Condition property. For example, User.isLoggedIn or OrderStatus = "Completed". The expression should evaluate to true or false.
  • Within the "If" widget, two placeholders are present: TrueBranch and FalseBranch.
  • In the TrueBranch, place the elements you want displayed if the condition is true.
  • In the FalseBranch, place elements or leave blank if you prefer nothing to be shown when the condition is false.

 

Implementing the "Switch" Widget

 

  • From the Widgets Toolbox, drag and drop the "Switch" widget onto your screen where you want to display variable content based on different conditions.
  • Specify the Expression: Select the widget and go to its properties pane to define the expression that will be evaluated. The expression should resolve to a specific value like a string or number, which will dictate which content block should be shown.
  • Add and Define Cases: Within the Switch widget, add cases corresponding to different possible values of the expression.
    • For example, if you are switching based on a PaymentStatus, you might have cases for "Pending", "Completed", and "Failed".
    • Add the content inside each case block that should be visible when the corresponding value is present.
  • Default Case: Implement a default case if desired, to handle scenarios where the expression doesn’t match any defined case.

 

Integrating with Variables and Data

 

  • Use local or session variables to store the state or data that will inform your conditions. These might include boolean flags, status indicators, or user roles.
  • Bind these variables in the "If" and "Switch" widget properties to dynamically control the content display as users interact with your application or data changes.
  • Ensure your logic expressions consider all possible states of the data to prevent any unexpected behavior or UI display issues.

 

Testing and Debugging

 

  • Use the preview feature to test the behavior of your "If" and "Switch" widgets during various states of the application.
  • Check all paths in both the "If" and "Switch" conditions to ensure they display the correct UI elements as intended.
  • Debug any issues by examining the values and conditions used in your expressions; verify that your logic captures all possible scenarios intended for the application.

 

By following these steps, you'll be able to harness the full potential of the "If" and "Switch" widgets within OutSystems to create dynamic and responsive UIs that adapt based on user actions and data states. Use these widgets to simplify control flow and enhance the user experience of your application.

Explore More Valuable No-Code Resources

No-Code Tools Reviews

Delve into comprehensive reviews of top no-code tools to find the perfect platform for your development needs. Explore expert insights, user feedback, and detailed comparisons to make informed decisions and accelerate your no-code project development.

Explore

WeWeb Tutorials

Discover our comprehensive WeWeb tutorial directory tailored for all skill levels. Unlock the potential of no-code development with our detailed guides, walkthroughs, and practical tips designed to elevate your WeWeb projects.

Explore

No-Code Tools Comparison

Discover the best no-code tools for your projects with our detailed comparisons and side-by-side reviews. Evaluate features, usability, and performance across leading platforms to choose the tool that fits your development needs and enhances your productivity.

Explore

Bubble Integrations

Dive into our comprehensive resource for Bubble.io integrations, featuring expert advice, detailed tutorials, and FAQs. Whether you're a beginner or an experienced developer, find everything you need to seamlessly integrate third-party services with Bubble.io.

Explore

Successful Bubble.io Projects

Explore a curated showcase of successful Bubble.io projects and see what's possible with no-code development. From innovative apps to complex systems, discover inspiring examples that highlight the power and versatility of Bubble.io. Start envisioning your next project today!

Explore

Flutterflow Tutorials

Explore our detailed directory of FlutterFlow tutorials to master mobile app development without coding. Gain insights through step-by-step guides, practical examples, and expert tips to efficiently use FlutterFlow and build stunning apps.

Explore

Want to explore opportunities to work with us?

Connect with our team to unlock the full potential of no-code solutions with a no-commitment consultation!

Book a Free Consultation

Client trust and success are our top priorities

When it comes to serving you, we sweat the little things. That’s why our work makes a big impact.

Rapid Dev was an exceptional project management organization and the best development collaborators I've had the pleasure of working with. They do complex work on extremely fast timelines and effectively manage the testing and pre-launch process to deliver the best possible product. I'm extremely impressed with their execution ability.

CPO, Praction - Arkady Sokolov

May 2, 2023

Working with Matt was comparable to having another co-founder on the team, but without the commitment or cost. He has a strategic mindset and willing to change the scope of the project in real time based on the needs of the client. A true strategic thought partner!

Co-Founder, Arc - Donald Muir

Dec 27, 2022

Rapid Dev are 10/10, excellent communicators - the best I've ever encountered in the tech dev space. They always go the extra mile, they genuinely care, they respond quickly, they're flexible, adaptable and their enthusiasm is amazing.

Co-CEO, Grantify - Mat Westergreen-Thorne

Oct 15, 2022

Rapid Dev is an excellent developer for no-code and low-code solutions.
We’ve had great success since launching the platform in November 2023. In a few months, we’ve gained over 1,000 new active users. We’ve also secured several dozen bookings on the platform and seen about 70% new user month-over-month growth since the launch.

Co-Founder, Church Real Estate Marketplace - Emmanuel Brown

May 1, 2024 

Matt’s dedication to executing our vision and his commitment to the project deadline were impressive. 
This was such a specific project, and Matt really delivered. We worked with a really fast turnaround, and he always delivered. The site was a perfect prop for us!

Production Manager, Media Production Company - Samantha Fekete

Sep 23, 2022