A dispatch tool for Grubhub
Adding much needed functionality to a complex tool
Grubhub Reassign is an internal tool that helps fix late deliveries. Reassign’s primary users are “Operations Specialists”. Specialists use the tool to gather info about why an order is delayed and manually dispatch an order. I was a Product Designer working with a team that included a Product Manager, market operations, and engineering.
For this project, I helped discover a need for new functionality in the existing product. I found a need to make changes to the layout through design explorations. I worked through options with my Product Manager and tested them with users.
Discovery
I started by observing our in-house specialist team when I was assigned to work on the tool. As Reassign was an interface for experts, I found it absolutely essential to research how and why the tool was used.
I noted a flow with a substantial amount of friction. Fixing bundled orders was a particularly manual and challenging task. Bundled orders were relatively new technical capability for the dispatching algorithm, and were becoming more common as the business pushed to reduce delivery costs. One order in the bundle would be delayed, which would delay the other order. Specialists did whatever they could to reduce or eliminate delays. They called to coordinate between the restaurant, driver, and diners. Their common solution was to instruct the driver to deliver one order and return to the restaurant for another. This didn’t always work well and left drivers and diners frustrated.
Definition
My Product Manager and I discussed what I was observing. He had data to support that bundled orders were more delayed than single orders and took more handle time by our specialists. Specialists needed a faster way to fix bundled orders. We agreed we needed a way for Specialists to break up bundled orders and manage orders independently.
More complexity came into play. Typically, specialists would manually dispatch a delayed order to the best driver in the area. When breaking up bundled orders, they would not be able to manually assign both orders due to technical constraints. One order would need to be sent back to the algorithm.
Additionally, market operations started outsourcing the Specialist role for cost and scalability. Reassign’s new users came from a customer care background, unlike our internal operations-minded folk, and did not have the same deep understanding of the business.
Not only were we adding new unbundling functionality, but we were also adding a complex algorithm handoff and designing for a new set of users. Would our internal lingo and complicated processes translate?
Sketching
I started sketching to get my head in the space, informed by my observations and knowledge shared by the product manager. I quickly realized Reassign’s current layout limited the ability to manipulate individual orders because the pickups and dropoffs were lumped together in a continuous timeline. The original design was only intended for Specialists to manage driver’s “trip”, not accounting for changes in individual orders within the trip.
I tried several different approaches to better indicate which pickup and dropoff points were related. I found it difficult to maintain a “timeline” view of stops while also grouping stops by orders. The orders and trip groupings were competing for attention, and it distracted from more important information like lateness.
Instead, I wondered if primarily grouping by orders would be easier to understand. I tried separating orders into individual cards. The cards also allowed for other order-specific information that the business was trying to incorporate.
Wireframes
Next I created a set of rough wireframes. Wireframes helped a general discussion about layout and functionality without getting into the details. Also, wireframes could be used as a probe for information from the PM. I was still wrapping my head around the interface and was unsure about certain pieces.
The first set separated the orders into two separate cards, more clearly delineating between orders. I changed the stop labels from “A, B, C, D” to “P1” for the first pickup, and “D1” for the first drop off. My intention was to make it easier to understand sequence now that the stops were listed out of order.
Each card had a “meatball” that could be used for direct manipulation. In this case, removing the delivery was the main action. The action needed a little friction, hidden behind the menu, as specialists would need to try managing the orders as a bundle first. Removing a delivery would be a more advanced move that might have ramifications for the driver.
The second set of wires simply added a removal flow to the current layout. At this point, it wasn’t clear if the delivery removal use case warranted a layout change. I needed to provide a less intrusive option The specialist would remove an order from an existing meatball driver menu. Then the user would select the order in a modal experience. Reassign was already a modal that floated over Zendesk. Displaying a heavy modal within a modal was not the best experience.
Most of the team agreed the first option seemed easier to understand. However, the PM was concerned that orders were no longer listed in sequence. I suggested we test the new layout with the new outsourced team to measure understandability and the value of sequenced orders.
Prototype
I created a prototype for each concept. I needed to comparatively test the concepts to see which concept was the most helpful.
Concept 1
I further elaborated on the design from the wireframe. Besides separating orders into “deliveries”, I rearranged the information from most to least important, left to right. I removed icons and information that specialists didn’t fully understand. I also moved all the times to one column and the lateness times to another. Streamlined times would be easier to read and compare, and specialists could more quickly draw inferences about the state of the order.
In this concept, I tried the language “Remove delivery and auto-assign”. Specialists didn’t often interact with the dispatching algorithm and allowing the algorithm to “auto-assign” order would be a new concept. I didn’t know what terms they might use to describe the algorithm. I also wanted to test the terms “delivery” here against “order” in the other concept to see if either was easier to understand.
The PM had noted that we needed to capture a reason for removing the delivery after reviewing the wireframes. Market ops and driver ops needed to collect information about driver behavior. This modal also created an extra bit of friction for specialists to prevent errors.
Concept 2
In the second concept, I kept the layout very similar to the existing product. I carried most of the order information into the heavy modal. I assumed specialists would need all the same info to decide which order to remove. Additionally, I tried using the term “order” instead of “delivery” to see what reactions I would have from users in testing.
User Testing
Next, I created a test plan so I was well prepared. We had not held sessions with our outside vendors before, so it took a bit of coordination from several teams to arrange the sessions. I shared the test plan with my team with research goals, tasks, and probes. I incorporated questions from the rest of the team.
I tested with 5 remote specialists. I recruited across different experience levels, though most participants had only been on the tool for a few weeks. Participants all spoke English as a second language. I asked participants to describe their process, had them react to the different concepts, asked if they could identify the problem with the order, and then asked them to try to remove the troubled order.
My team followed along through conferencing software, they chatted me questions during the sessions, and I held a debrief at the end of each day.
Learnings
We had a boatload of insights coming out of the sessions. I created a report after analyzing my notes. Ultimately, the separate order cards were much easier to understand. Most claimed they did not need to know the sequence of steps in the table as they used the map on the left to understand the sequence. Specialists were able to easily find and select “remove delivery”. We would iterate on this design and move forward with it.
More interestingly, I found that our outsourced team was not reading or using all the information in the base design. The issues I observed with our internal team misunderstanding the interfaced was exacerbated with the external team. They were missing key pieces of the data that should have affected how they solved the delay.
Specialists were more perceptive of the details in the separated order card design. Given the rearrangement of information and time stamps, they were able to grasp the bundle’s problem more quickly. They understood they needed to remove the second order because it’s order-ready time was significantly later than the first. In the base design, most had to be probed through the problem. This was a big win, my design worked!
The specialist’s reaction to “auto-assigned” was similarly fascinating. First, specialists didn’t understand the term “auto-assign” and they were hesitant to make assumptions. Once they understood, the agents were averse to giving an order back to the algorithm. They were concerned the order would not be dispatched properly and wanted to manage the order themselves. Many of our outside specialists came from a customer care role. They had encountered many instances of the algorithm forgetting orders. My product owner and I anticipated this feedback and had a Jira ticket to allow specialists to access the order after it had been removed.
However, if the algorithm was supposed to manage the order from here, we needed to find a better way to manage a specialist’s behavior with the design.
Conclusion
Many people were engaged in user research from product, engineering, market ops, and fulfillment. There were more complexities than I can explain in this case study. The research opened up eyes for many stakeholders and created changes to procedures and training. I am currently working on iterating on the new card design to launch it. Because it is a big change, I need to account for other use cases and be mindful of upcoming functionality. Grubhub changes rapidly and there are always new fulfillment challenges we need to accommodate.
I find working on this tool to be incredibly engaging because it is focused on acute and complex problems. While this design has not shipped yet, I routinely ship smaller, iterative designs. I love working with this team because we have a great team dynamic and they value my strategic design input.