Jordan Kulhawik
Photo of updated JRNY modal on embedded screen

How might we improve browsing for workouts in BowFlex's JRNY App?

To select a workout in JRNY, users browse through a collection of workouts and tap one that interests them. This opens a modal with more information. They can begin their workout from there or continue browsing.

Since JRNY users see these modals every time they want to do a workout, our project managers saw this as a way to make the most impactful design changes to the app, improving both the visual design and usefulness of the modals.

Overview

Existing JRNY workout modal for tablet and phone

Initial Stats

Where did we start?

The JRNY UX team looked at user stats for ways to increase user engagement and retention. We found that users were spending time browsing workouts but not necessarily starting one. If users don't perform workouts, they are less likely to continue using JRNY.

When our UX research team got input from current users, these were the major takeaways:

The existing workout modals gave users a basic set of information, but not enough to confidently select a workout. Users would often select one and try it out for a few minutes before choosing a different workout.

The goals for this project were to:

Old JRNY workout modal with the major issues outlined in red

What could be improved?

The existing modals didn't provide enough valuable information to confidently select a workout. I performed a heuristic evaluation on the existing modals and reviewed my findings with the UX team. There were a few things we knew we wanted to improve:

  1. Space: The top section takes up too much space better suited for the most important details.
  2. Time: We know the workout's time is important to our users, so it should be big and easy to find on the modal.
  3. Workout Type: We tell users the details about the workout type, but we don't explain what they mean.
  4. Workout Profile: There are two graphics displayed, but neither of them give much information.
  5. Scrolling: Make the modals scrollable to remove the vertical limit for content.
Workout modal for tablet featuring round 1 changes

Initial Concept

My initial design aimed to fix the issues outlined above, to be tested with users to confirm our hypotheses.

  1. Space: I reduced the height of the top section and moved the most important pieces up.
  2. Time: I increased the font size and weight of the workout time and moved it to the top of the modal.
  3. Workout Type: I added descriptions to the workout types like "Adaptive Workout" and "Virtual Coach".
  4. Workout Profile: I added some more detail to the workout profile and changed the title to "Intensity Map" to clarify the significance.
  5. Scrolling: The modals now scroll to allow more content to fit.
Workout modal for tablet featuring round 1 changes

User Testing

My team tested the initial concept with 7 JRNY app users on a BowFlex treadmill, comparing it against the existing app. We also got their feedback on how important each piece of information was. During testing, 100% of our users preferred the updated modals to the existing version, but that didn't mean my job was done. I looked at the feedback from users to further improve the modals. Below is some of the top items from that feedback.

Findings Overview

Order & Amount of Information

Based on feedback from users, the information was updated to focus on the most important pieces first, displaying enough content for them to make an informed workout choice.

Updated Concept: What was improved?

We updated the following parts of the modals based on feedback from users:

Comparison of the old and new JRNY workout modalsGraph showing the improvements between the old modals and updated design

The Final Result

In February 2024, JRNY release 2.19 featured the updated modal designs, capping nearly a year of work for our design team. The talented developers at BowFlex implemented the changes flawlessly, greatly improving the overall navigation of JRNY.

Overall, the project achieved the following goals:

Final Stats