Hero image of field service desktop and mobile app

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.

Mobile worker

Typical Break / Fix Flow

Service flow: case solver, dispatcher, mobile worker, and end customer

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.

Generator icon

Asset Centric
Most maintenance plans are based on asset types but can also be affected by other factors including location or entitlements.

Location icon

Location only
Visit Mulberry Farms every quarter to complete a site inspection survey

Flexibility icon

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.

Car icon

Asset Criteria or Usage
Change the oil for customer’s civic every 5k mi or every 6 mo, whichever comes first

Integration icon

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

Building icon

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.

Maintenance quadrant: preventive, predictive, reactive, and proactive (Preventive is highlighted)

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.

Maintenance plan object model connections

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

Multiple screenshots of maintenance plan explorations

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.).

Maintenance plan creation with recurrence rules

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

Issues with accessibility and localization due to concatenation and lack of labels

Inaccessible and not localization-friendly due to the concatenation of words and inputs.

Updated mock to account for accessibility and localization

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.

Inconsistent rule configurators across salesforce

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.

SFDC condition component

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

Gif of creating a maintenance plan and setting a recurrence pattern

Flexible configuration

For the more complex business use cases, customers can configure criteria and usage tied to asset parameters by creating another rule.

Gif showing flexible configuration

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.

Gif showing custom logic

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.

Desktop and mobile integration from asset manager to field service worker

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:

Timeline icon

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.