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