Location Filters @ MEDITECH
Overview
IT staff at HCA, the largest for-profit hospital system in the US, needed a way to filter orders (like labs and x-rays) by location, so providers can quickly order what they need and what is appropriate for the equipment available at each location. HCA contains numerous facilities controlled at regional levels throughout the United States.
An existing feature allowed for building these features, and had historically worked well for smaller companies with ER locations, but less so for large inpatient hospital systems.
HCA’s inability to implement this feature is leading to incorrect procedures being chosen, then rejected down the line, leading to a delay of critical patient care.
The Goal
My team was tasked with updating this backend build tools for this setup in a way that increased efficiency at scale, and provided 100% backwards compatibility. Basically, make things better for HCA without breaking anything for customers that had built out filters years ago.
What did I design?
System Design:
I designed an overhaul of the filtering paradigm, from an all-or-nothing additive style, to a piecemeal build-as-you-go style
Technical Conversions:
I worked closely with developers to create a conversion for customers who had already built filters
Handling Edge Cases:
I made filtering more consistent across all workflows
With this enhancement…
IT staff can
quickly filter out irrelevant orders,
UI Design:
I introduced a new mass edit tool to decrease the needed build time
UX Metrics:
I compiled quantitative statistics that will help measure the new design’s efficacy over time
Results
Through my designs, I
Sped up workflows, in some cases from weeks to minutes
Provided solutions for our largest and our smallest customers
Enhanced the MEDITECH design system with two new updates
Physicians can
confidently choose the correct orders,
And patients can
receive faster, more accurate care.
Where to Begin?
Interviews, Testing, and Communication
After being briefed on the project details, I began crafting a strategy. I set up bi-weekly meetings with key stakeholders from HCA, who would be our primary customer for this project. I asked around other teams and within our internal reporting tools to find other customers who had built out filters previously. Once I found these customers, I set up interviews with them as well.
Simultaneously, I began exploring the system. I was brand new to the world of Acute ordering, and had to learn from scratch how things operated. Many on my team were also new to this part of the system, and relied on me to investigate and report how things worked, existing bugs, and test plans to be built.
As the team was finishing up their previous project, I presented a detailed Confluence page with all of my notes to bring everyone up to speed.
Research synthesis
Excerpts from the Confluence page, which contained over 15,000 words. Shown here are sections on the current state of the system before the project, notes from a user interview with a physician, and the first of four possible solutions I outlined with pros and cons.
The Backwards Logic of the Existing Filters
This is where my analytical brain got a good workout. Medications were filtered in a fairly straightforward way: the IT user goes to a particular med, and chooses either Include or Exclude, then lists the locations where the system should follow that rule. The one wrinkle here is that you must define the opposite of what you want the default behavior to be. Want this med to be included at most locations? Then select Exclude, and define the exceptions.
Defining by exclusion for meds
The non-med orders followed a different logic entirely. First, define the locations that should filter out everything, then go to each order you do want to see at that defined location and choose Location Order = Yes. Finally, list which of the previously defined locations for which this order should be a “location order.”
Because the filtering is defined by the location and not the order, thinking about where an order will and won’t appear is brain-twisting.
An order with Location Order = Yes will appear at
filtering locations that are defined on that order and
all non-filtering locations,
but not at
filtering locations not defined on that order
An order with Location Order = No will appear at
locations not defined for filtering,
but not at
locations that are defined for filtering.
If you understood any of the above logic upon first reading, congratulations. You are smarter than me, my engineers, and all of our customers, who agree that this logic is convoluted, confusing, and backwards.
We had to ensure backwards compatibility
Whatever my solution would be, we had to ensure that all orders still appeared and didn’t appear at the same locations for all customers after a technical conversion was run. Below is the chart I created to help the team understand the implications of the solutions, and the layman’s version of what the logic in the code had to say.
Conversion Charts
Don’t try to understand this graphic. It’s not worth your time. Just know that I made it my job to understand the full technical implications of every design choice for every member of our customer base.
Solutions
Using the design language of MEDITECH’s “dictionary” settings, I implemented a new paradigm for location filters for all orderables.
Primary feature: Healthcare orgs can define by the default, then define the exceptions.
For example, a large organization we spoke to had many facilities spread out across multiple states. Within a single facility, at a single location, they had a NICU unit, with orders that would only ever be utilized on the patients in that unit.
With this system, they can now define the “Default for all facilities” to Exclude. Then, within the one facility, add a default (in the image shown as “.DFT”, a well-known paradigm within our system) behavior of “Suppress” - in case the other locations within that facility ever have a spill-over patient and need access to those orders. Finally, add the single NICU location and define it as “Include.”
Redesigned filtering allows for defining by exception
A process that used to involve defining every single order and location behavior, and would have taken weeks, now can be done in three steps that take about one minute to complete.
Mass Edit
Orders had an existing mass edit feature that we updated to match the new filters. But order sets did not. My team jumped on the opportunity to provide this gap in functionality alongside this project.
I conducted more research to understand:
How organizations and users name, categorize, and use order sets
Who manipulates them and in what scenarios
What new features might be most worthwhile to pursue
The results from both IT staff led to a few interesting insights. Namely,
IT staff were afraid to use mass edit features because they couldn’t undo their actions if mistakes were made.
Some orgs had clear naming systems, others did not
The same individuals were responsible for different collections of sets
Staff had a hard time remembering why things were built the way that they were in our system, because that had often happened years ago
Utilizing these findings, I recommended the following enhancements to this tool:
A history view with an undo/rollback feature for mass edits, to help with error correction
Allow users to search for and filter order sets by multiple attributes
Allow a user to see which sets they were the owner of
A comment feature which allows users to make not of what changes were made, who made them, and why.
The mighty little comment feature
As I walked through early wireframes with users, I was surprised to find that the most exciting feature for many was the comment feature. This was an idea I had thrown in at the last minute to see if there was any interest, because it was technically very easy to implement.
Most MEDITECH routines have no such feature. Users talked in length about sifting through old email chains, trying to figure out who had made what changes to the system and why, and whether there would be any adverse affects from new changes.
Many orgs also have staff sign off on documents in order to leave a paper trail of changes and rationale. Users wondered whether we could expand the comment feature, to allow for document attachments.
Unfortunately, that was out of scope for this project, but it has been discussed as a future enhancement.
The popularity of the comment feature reminded me that I am not the user, and what I think would not be a priority may not match real users’ opinions at all
Conclusion
This project demanded a lot of me. In a complex software system, a seemingly small change to a single feature can have large ripple effects throughout the system.
When that system provides patient care, extra due diligence must be made to ensure all possibilities are thought out, all loose ends tied up, and all customers are served.
Through this project I juggled
scope creep and technical viability
wildly differing user needs (large orgs vs. small)
tangential workflows and unhappy paths (transfer and discharge scenarios)
My solutions were implemented and well-received by both HCA and our smaller customers.
In addition to what I discussed above, I also
contributed changes to our design system
collected quantitative data, to compare future adoption as these features roll out to more customers over the next years