Salesforce Field Service Maintenance Plans
As part of the Field Service team within Service Cloud at Salesforce, I worked across multiple desktop and mobile products from inventory management, to scheduling, to offline mobile capabilities. One notable project, Maintenance Plans, helps customers ensure their assets are serviced in a timely manner and prevent asset downtime.
Overview
This project was a multi-release effort, where I worked closely with the product team to plan out stages of the feature set. With Maintenance Plans, customers can define schedules & triggers to service their assets.
Role
Lead & Support Designer, over several releases
Designed functionality to support maintenance plan creation across complex use cases for Field Service customers
First off, what is Field Service?
Anyone who goes to install, maintain, or repair something is doing some form of field service.
Salesforce Field Service makes that process easier by providing the tools for customers to track their field service team from scheduling and planning appointments, to managing inventory and contracts, to dispatching mobile workers. If you’ve interacted with a tech to set up your internet or fix your plumbing—those are field service use cases.
Typical Break / Fix Flow
Case Solver
The customer calls a case solver for a malfunctioning asset, such as a broken office printer. The agent creates a service appointment to get the printer fixed.
Mobile Worker
The technician receives an alert on the Field Service app or a phone call that they’ve been scheduled and go on their way to the customer site to complete job.
Case Solver
The dispatcher receives the emergency break / fix request and looks at schedules to see which resource or mobile worker can take the job.
End Customer
Once the printer is fixed and the work order is complete, the technician finds a customer contact to sign off on the work order and creates a service report.
Issues with Break / Fix Model
🚫 Low CSAT
With no service plan for properly maintaining assets, the company waits until their customer complains before fixing an asset, leading to asset downtime and customer dissatisfaction.
🚫 Lack of Predictability
Relying on maintenance service when an asset malfunctions leads to lack of predictability, which makes planning and optimization of service appointment schedules difficult to plan for.
🚫 Costly
Without the predictability of schedules, it can be costly for the back office to reprioritize for emergency break/fix appointments, which adds disruptions in schedules and inefficient back and forth trips.
Salesforce Preventive Maintenance Model
✅ Reduced Asset Downtime
With Preventive Maintenance, companies routinely maintain assets based on criteria, usage, and schedules so that assets remain running and customer contract agreements are met.
✅ Efficient
Knowing upcoming scheduled maintenance work helps dispatchers better plan and optimize schedules across multiple mobile workers and allows for route optimization.
✅ Prepared
Technicians are better prepared for their on-site work, and customers don’t need to worry about their assets malfunctioning or having to deal with repairs that take longer than expected.
Goals & Jobs to be Done
“As an asset manager, I want to easily set up a maintenance plan for multiple assets and define conditions, usage, and time parameters to ensure assets properly running and serviced in a timely manner.
”
Direction & Scope from Research
Preventive Maintenance empowers Field Service customers to set up service plans for their assets to be routinely checked and to prevent breakdowns / downtime.
To gain a better understanding of scope and guidance for this project, we revisited previous foundational research documentation and recordings. From conversations with 7 customers, including Aggreko, Hologic, Fujifilm, and Honeywell, we identified areas to focus on and the scale of use cases.
Asset Centric
Most maintenance plans are based on asset types but can also be affected by other factors including location or entitlements.
Location only
Visit Mulberry Farms every quarter to complete a site inspection survey
Flexible & scalable
Maintenance can be as simple as a routine visit at one location, to having multiple types conditions and criteria across assets.
Types of use cases for maintenance plans also vary across a spectrum from simple <—> complex.
Asset Criteria or Usage
Change the oil for customer’s civic every 5k mi or every 6 mo, whichever comes first
Integrated in one place
Customers keep asset info in multiple systems, so there’s a lot of back and forth between external software to Salesforce
Multi-conditions & Assets
Maintain multiple elevators in a building when certain thresholds and usage is met
Customers are shifting from reactive and proactive maintenance to preventive maintenance, with predictive maintenance as a future vision.
Supporting Rule Configuration for Scalability
Within a Maintenance Plan object, you can attach other objects including relevant assets, work orders, work rules, etc. Work rules is what customers create to define frequency and criteria of their maintenance schedule.
There are 3 types of work rules you can configure:
Calendar-based Work Rules
Calendar rules are part of the base functionality of maintenance plans and allow customers to set a recurring date for when a service appointment needs to be created for an asset.
Criteria-based Work Rules
At the next level, customers can set specific thresholds for when to trigger a maintenance service appointment, such as if temperature exceeds a certain point for an industrial fridge, call a technician.
Usage-based Work Rules
Customers also want to be able to track an asset by the amount of usage or count data and create a service appointment at a recurring meter. For example, service a printer every 500k prints or change the oil of a vehicle every 6 months.
Initial Explorations
Basic Steps for creating a Maintenance Plan
Step 1: Create and fill out base maintenance plan
Step 2: Attach maintenance assets
Step 3: Add any work rules across calendar, criteria, or usage conditions
Step 4: Review plan and make any adjustments before activating
To optimize for scalability and code efficiency, we separated base calendar rules from advanced conditions like usage and criteria-based rules tied to specific assets.
Calendar rules allow users to set recurring service appoints (daily, weekly, monthly, yearly, etc.).
Accessibility & Localization Issues for Calendar-based Rules
We consulted with Accessibility and Localization teams and discovered some major issues.
Accessibility Considerations:
Each field must have a corresponding label, not just the title of the set of fields
Helper text in fields are not accessible
Localization Considerations:
Don’t optimize design for English language—don’t use prepositions to concatenate fields “on” “first” “Sunday” Or “After” X
Inaccessible and not localization-friendly due to the concatenation of words and inputs.
Updated design to include labels per input field, with concatenation removed for translation to other languages
Component Audit & Consistency for Criteria & Usage-based Rules
We audited existing features for configuring logic and rules due to inconsistencies from various acquisitions. To address this, we collaborated with the Salesforce Design System team to discuss the latest component guidelines, limitations, and variations to better support our use cases.
Examples of inconsistent usage of rules across Salesforce products
We agreed to expand upon the Salesforce Design System Expression Component to cover our use case and ensure consistency and reusability for future product team needs.
Iterative Research Findings
“We send techs monthly to see the overall health of the operation-but what about in the in-between time? What if the staff doesn’t follow practices or something comes up?
Customer Use Case Examples:
Calendar Schedule: Elevator maintenance every 12 months
Criteria Thresholds: Monitoring parameters on an engine (oil, temp, pressures, etc) as well as starting to monitor temperature control
Usage Data: # of pumps of a hand soap dispenser and similar equipment
Change based on location and season: Solar panel module cleaning every year or 2 to 3 years, depending on if the location is more dusty and what time of year it is
Key product requirement discoveries from user testing
Flexibility for multiple use cases & user profiles:
Customers appreciate the ability to set up thresholds to trigger work orders but also wanted flexibility to define logic using a formula field for more complex use cases, or even switch to a formula mode experience (for advanced admins)
Easily set up base functionality, with option to add additional thresholds:
Many customers still don’t have the implementation necessary to track equipment to the level they’d prefer remotely (criteria or usage) and currently have a calendar-scheduled maintenance, but plan to move toward that direction
Select strict schedule triggers, or trigger upon completion based on industry standards:
Many of the frequency of meter-based maintenance is based on industry protocols for that country/location--so they must follow regulatory guidelines for triggers, tasking, timing, etc. which are very strict and precise
High Level Design Snapshots & Considerations
Features were built out over several releases, from the base maintenance plan and calendar scheduling, to introducing criteria and usage and enabling complex conditions.
Recurrence pattern
Enables scheduling maintenance on a specific calendar cadence across day, week, month, and year
Flexible configuration
For the more complex business use cases, customers can configure criteria and usage tied to asset parameters by creating another rule.
Custom Logic
Asset managers can fine tune their maintenance plans by incorporating custom logic that combines criteria and usage rules to address more complex business requirements.
Seamless Integration
Once maintenance plans are implemented, service appointments are automatically scheduled for mobile workers and pushed to their mobile app calendars for a seamless experience.
Considerations & Challenges
Salesforce prioritizes scalability across business use cases, which can burden customers with setting up their Maintenance Plans across multiple required objects. We aim to provide clearer guidance to boost user confidence in their setups.
With numerous legacy products and varied implementation methods, it’s challenging to determine which features can be reused for our needs.
Engineering teams often focus on efficiency and reducing code maintenance, which can compromise user experience. We’ve engaged in numerous discussions with development teams and involved them in research sessions to highlight the importance of UX.
Impact & Next Steps
With millions of customer asset records stored and tracked on the Salesforce platform, many of these need maintenance. Maintenance plans empowers customers to ensure their equipment is up and running at all times and serviced as needed.
But what about managing plans and understanding how they’re performing after the set up? Here are a few additional directions I pitched as a next step:
Asset Timeline
Overview of multiple assets and related objects across time
Asset Health Overview
High level information and status of how an asset is performing
Activity List View
List of asset activity including past work orders and cases
Moving forward, we need to consider both short-term and long-term improvements. I compiled and shared insights on UX debt, trust issues, and recommendations aimed at enhancing customer confidence in setting up their plans and troubleshooting any problems to ensure these items are included in the future roadmap.