FXL Deep Copy

Introduction

To create copies of a record with any related or child records, you can add the Deep Copy Lightning Component to any custom object. The Deep Copy Lightning Component feature is available for Lightning pages in FieldFX Back Office. Use Deep Copy to add a new record by copying an existing record and its related items.

For the latest updates, see FX Lightning Package Release Notes.

Copied records and all of the related or child records are locked during the copy process until the copy completes. This includes both the items being copied from and the new records being copied to.

Deep Copy is a Lightning Component. This component expands on the functionality of the Deep Copy feature, but only works in Lightning Experience.

FXL Deep Copy is included in the Base Managed Package and does not require installation of the separate Lightning Managed Package.

You can add a new job by copying an existing job and its tickets, ticket items, and scheduled crew.

To use the FieldFX Lightning package starting with version 1.225, you must use the FieldFX Managed Package version 1.529 or higher.

Key Features

  • Comprehensive
    Duplication

You can use this to copy a selected record and its related child items, including children of the child items. Doing this ensures that all associated data is replicated in the new record.

  • Asynchronous
    Processing

By default, records are copied asynchronously, meaning one record at a time period this approach helps manage system performance during the duplication process.

  • Field Exclusion

Users can exclude specific fields from being copied by adding them to a clone blackout fields field set. Fields such as ID, external ID, status, sync ID, tracking number, auto number, and formula are not copied by default.

  • Dry Run Mode

This mode allows users to preview the data that will be copied without actually performing the duplication. It’s useful to her testing and troubleshooting.

  • Filters

Users can apply filters to exclude certain records from being copied. For example, to avoid copying archive items, a filter can be set to include only non-archived records.

  • Saves time by eliminating repetitive data entry

  • Reduces the chance of errors or omissions when creating similar records

  • Ensures consistency in data structure and related items

Best Practices

  • Permissions
    Ensure that users have the necessary sharing access and permissions for all records they need to copy.

  • Testing
    Test the deep copy functionality in a sandbox environment before deploying it to production.

  • Avoid Duplicates
    Be cautious with the self-referencing parent slash child relationships, as the FXL deep copy component supports up to two levels of records.

Prerequisites

To set up or use the Deep Copy feature:

Required Licenses Required Permissions Before continuing,
complete these tasks
  • Minimum permissions for the FieldFX modules you are using

  • Lightning Experience

  • System permissions:

    • Customize Application

    • Manage Profiles and Permission Sets

    • View Setup and Configuration

  • The user must have sharing access for every parent, child, and related record to be copied.

  • The user must have the following permissions for every object included in the copy:

    Object Field

    Read
    Create
    Edit

    Read
    Edit

Performance of Deep Copy depends on various factors including, but not limited to, the number of

Common Use Cases

FXL Deep Copy can be used in these common cases:

Use Case Description Example

Creating Similar
Jobs or Work Orders

When a new job or work order has similar requirements to an existing one, FXL Deep Copy can replicate the record and its associated tickets, line items, and other details

A field service technician needs to create a new work order for a repeat service at the same location with minor modifications.

Recurring Projects
or Contracts

For organizations handling recurring projects, copying a base template with pre-configured settings saves time and ensures consistency.

A company creates annual maintenance contracts that include standard terms, tasks, and materials.

Streamlining
Estimates
and Proposals

Sales teams can quickly duplicate an existing quote or proposal to use as a starting point for a new client.

A salesperson duplicates a proposal for a new client who requires the same configuration as an existing customer.

Training
and Testing

Teams can use a master project or template that includes all necessary fields, child records, and associated tasks, and then copy it for new projects.

A construction company uses a project template with predefined tasks, resources, and schedules.

Replicating
Complex
Workflows

Businesses can replicate multi-level data structures to accommodate complex workflows without manually creating each layer.

A project manager copies a parent record (like a service call) with multiple nested records (like tasks, subtasks, and dependencies).

Correcting
Errors

If a record needs to be recreated due to errors but must retain most of the original data, Deep Copy ensures this can be done quickly.

A dispatcher recreates a job ticket that was incorrectly synced with a minor adjustment.

Archiving
Base Records

Teams can duplicate records for archiving purposes while continuing to work on the active version.

An engineer saves a copy of a completed job ticket for historical reference before creating a new one for follow-up work.

Handling
Variations
in Similar
Processes

When slight variations are required in a standard process, users can duplicate and then modify only the necessary details.

A customer orders a slightly modified version of a previous job with updated specifications.

Managing
Seasonal
Work

Companies handling seasonal work, like winterizing equipment, can copy previous records for similar seasonal tasks.

A landscaping company duplicates service orders for routine seasonal maintenance.

Step-by-Step Guides

Before the FXL Deep Copy component can be used, you must set it up on the record page.

Use the Deep Copy Request SObject

Also, a custom sobject DeepCopyRequest__c allows queueing requests. Upon inserting the DeepCopyRequest__c record (with Status__c is ‘Queued’), a trigger launches the deep copy process.

It is used to deep copy any custom sObjects (managed or unmanaged), and to queue deep copy requests. The requests are executed sequentially by a single process, avoiding locking other sObject entities. For example, it prevents locks on CatalogItem during PriceBook cloning.

Configs__c contains the same kind of setting as DeepCopy LWC, and its value is json string like this:

{"typesOfInterest":["FX5__Job__c","FX5__Ticket__c","FX5__Ticket_Item__c"],"misc":{"platformEvent":"true","customNotification":"true","emailNotification":"true"},"filtersBySobjType":{"FX5__Ticket__c":"FX5__Status__r.Name='Ticket Setup'","FX5__Ticket_Item__c":"RecordType.DeveloperName!='Labor'"}}
  • typesOfInterest is required

  • filtersBySobjType and misc are optional

Create SObject from the Workbench

To create DeepCopyRequest__c from workbench, use JSON code like this:

Replace 'theJobID' with the Job Id to deepCopy.
Id jobId = ‘theJobId’;

String configs = '{"typesOfInterest":["FX5__Job__c","FX5__Ticket__c","FX5__Ticket_Item__c"],"misc":{"platformEvent":"true","customNotification":"true","emailNotification":"true"},"filtersBySobjType":{"FX5__Ticket__c":"FX5__Status__r.Name=\'Ticket Setup\'","FX5__Ticket_Item__c":"RecordType.DeveloperName!=\'Labor\'"}}';

DeepCopyRequest__c r = new DeepCopyRequest__c(Source__c = jobId, Status__c = ‘Queued’, sObject_Type__c = ‘FX5__Job__c’,
Configs__c = configs);

insert r;