Overview | Install Me | How it Works | FAQs | Contribute
A complete custom experience component. Created to allow users to view related records to a parent on an interactive timeline written with D3.js.
- Multi Object Support. Plot related records to Lead, Account, Contact, Opportunity and Case.
- Junction Object Support. Plot junction object records and use simple dot notation.
- Multi Language Support. All labels and error messages as translatable custom labels.
- Locale Support for Dates. Date formats change based on your Salesforce locale setting.
- 3rd Party JS. Demonstrates 3rd Party JS and Apex imperative callouts to populate data in an interactive timeline.
- Responsive interface. Uses flexipageRegionWidth to determine where in the page it is located.
- Minimises server roundtrips. Uses Lightning Data Service for tooltips and falls back to queried data when needed.
This sample application is designed to run on Salesforce Platform. If you want to experience Lightning Web Components on any platform, please visit https://lwc.dev, and try out the Lightning Web Components sample application LWC Recipes OSS.
Now available as a managed package from the AppExchange.
Alternatively you can install the component straight from source control into a Scratch Org using the instructions below:
- Set up your environment. Follow the steps in the Quick Start: Lightning Web Components Trailhead project. The steps include:
- Enable Dev Hub in your Trailhead Playground
- Install Salesforce CLI
- Install Visual Studio Code
- Install the Visual Studio Code Salesforce extensions, including the Lightning Web Components extension
- If you haven't already done so, authenticate with your hub org and provide it with an alias (myhuborg in the command below):
sfdx force:auth:web:login -d -a myhuborg
- Clone the timeline-lwc repository:
git clone https://github.com/deejay-hub/timeline-lwc
cd timeline-lwc
- Create a scratch org and provide it with an alias (timeline-lwc in the command below):
sfdx force:org:create -s -f config/project-scratch-def.json -a timeline-lwc
- Push the app to your scratch org:
sfdx force:source:push
- Assign the Timeline_User permission set to the default user:
sfdx force:user:permset:assign -n Timeline_User
- Load sample data:
sfdx force:data:tree:import --plan data/timeline-plan.json
- Open the scratch org:
sfdx force:org:open
-
Navigate to Sales, under App Launcher, select the Sales app.
-
Find the contact Jane Lo and drill into her detailed information.
-
Navigate to Setup, and select Edit Page
-
Drag the timeline component into the page - found under custom components
For full details see the Configuration Guide
Timeline is installed as a custom component available in the App Builder component pallette. The component is available on all standard and custom objects but has been designed specifically to see clusters of interactions over time.
The component has the following properties that can be set at design time in App Builder by an administrator
Property | Description | Validation |
---|---|---|
Parent Record |
Adjusts the timeline parent id | Dynamic Picklist (valid relationships) |
Title |
Adjusts the label | String |
Height |
Adjusts the vertical height | Picklist (1 - 5) |
Historical Time Range (Years) |
Adjusts the start date | Picklist (0.25 - 5) |
Future Time Range (Years) |
Adjusts the end date | Picklist (0.25 - 5) |
Zoom Based On |
Adjusts the position of the zoom | Picklist (Current Date, Last Activity) |
Zoom Range (Days) |
Adjusts the extent of the zoom | Integer min 15 max 120 |
Labels can be translated where appropriate. Navigate to Setup -> Custom Labels and add translations for your chosen languages. Note you will need the permission - Manage Transalations.
Label Name | Default translation |
---|---|
Timeline_Error_Apex |
Apex error |
Timeline_Error_Setup |
Setup error |
Timeline_Error_JavaScriptResources |
Unable to load JavaScript resources |
Timeline_Error_NoDataHeader |
No data to display |
Timeline_Error_NoDataSubHeader |
Related records show up here on an interactive timeline. Check your filter or create a record. |
Timeline_Error_Unhandled |
Houston...we've had a problem |
Timeline_Label_Days |
day(s) |
Timeline_Label_Items |
item(s) |
Timeline_Label_Showing |
Showing: |
Timeline_Label_Filters |
Filters (Used in filter panel) |
Timeline_Label_Filter_All_Types |
All Types (Used in filter panel as select/deselect all checkbox) |
Timeline_Label_Filter_Type_Legend |
Types to Show (Used in Filter panel) |
Timeline_Label_Files |
Files & Notes (used in Filter when sObject is ContentDocumentLink) |
Timeline_Label_Date_Range_Legend |
Date Range (Used in Filter panel) |
Timeline_Label_Apply |
Label for apply button (Used in Filter panel) |
Timeline_Label_Cancel |
Label for cancel button (Used in Filter panel) |
Timeline_Navigation_Toast_Header |
Label used in Toast message header when drilling down on CaseComment |
Timeline_Navigation_Toast_Body |
Label used in Toast message body when drilling down on CaseComment |
Specifying which child records to plot is done using the Timeline_Configuration_mdt metadata type. When populating the metadata type the following is a description of the columns and their purpose
Field Name | Description |
---|---|
Parent_Object__c |
The API Name of the parent object that the child record relates to |
Object_Name__c |
The API Name of the object that is the child to plot |
Relationship_Name__c |
The API Name of the relationship between Parent and Child |
Position_Date_Field__c |
The API Name of the field on the child (Object_Name__c) to use as the date value to use to position the record on the timeline (must be Date or Date/Time) |
Detail_Field__c |
The API Name of the field on the child (Object_Name__c) to use as the description for the record to plot on the timeline |
Icon__c |
A relative url to the image to use for this record |
Icon_Background_Colour__c |
The background colour to use for the above image (rgb and hex supported) |
Type_Field__c |
Reserved for 'Tasks' only. Used to specify the field to distinguish Calls vs Emails. Only used when Object_Name__c is Task |
Fallback_Tooltip_Field__c |
The API Name of the field on the child object to use when the UI API does not support this object. Timeline will use the Detail_Fieldc value and the Fallback_Tooltip_Fieldc as the tooltip. |
Drilldown_Id_Field__c |
The field containing the Id value that should be used for the drilldown operation. e.g. Which record should the user be navigated to. Important for junction objects. |
Tooltip_Id_Field__c |
The field containing the Id value that should be used for the hover tooltip e.g. Which record should the user see when they hover over a record on the timeline. Important for junction objects. |
Tooltip_Object_Name__c |
The object used by the tooltip. The label is also looked up to use in the filter panel. |
Test__c |
Protected records used for Apex testing only. |
For FAQs and troubleshooting see the Knowledge Base
Use the Compact Layout of the object plotted (for the most part).
Yes - Supports a users locale, language and has custom labels for translation available.
Yes. The timeline will work on a record detail page in the community. Sadly we don't support changing Parent Field at this stage.
No. The timeline component is really best suited to the desktop. Long term it is a goal to come up with a mobile version suited to reduced real estate. At the moment the component cannot be dragged into a mobile layout.
Yes.
Yes. Files and Notes (sometimes referred to as enhanced Notes) are supported. We have added any record in the ContentDocumentLink object.
No. We would have to consider scale and performance too so for now the component only supports standard and custom objects.
No. History objects are deliberately removed from the query. They don't make good candidates to plot on the timeline due to the volume of updates.
Yes.
Contributions are what make the trailblazer community such an amazing place. I regard this component as a way to inspire and learn from others. Any contributions you make are greatly appreciated.
See contributing.md for timeline principles.
- D3.js v 5.7.0
- moment.js v2.2.4
Prettier is a code formatter used to ensure consistent formatting across your code base. To use Prettier with Visual Studio Code, install this extension from the Visual Studio Code Marketplace. The .prettierignore and .prettierrc files are provided as part of this repository to control the behavior of the Prettier formatter.
ESLint is a popular JavaScript linting tool used to identify stylistic errors and erroneous constructs. To use ESLint with Visual Studio Code, install this extension from the Visual Studio Code Marketplace. The .eslintignore file is provided as part of this repository to exclude specific files from the linting process in the context of Lightning Web Components development.
PMD is a cross-language static code analyser. To use PMD with Visual Studio Code, install this extension from the Visual Studio Code Marketplace. The .pmdruleset.xml file is provided as part of this repository to exclude specific files and/or types of code quality checks from the process in the context of Lightning Web Components development.
Codacy automates code reviews and monitors code quality over time. Static analysis, code coverage and metrics for JavaScript and Apex. Tests for common styling and security issues.