See files shared to all related records on one page in Lightning.
This project provides a Lightning Component you can drag on to your Lightning Record Pages in App Builder.
As of Summer '17 release, Lightning Files related list behaves fundamentally different than Classic Notes & Attachments related list when it comes to showing files and attachments shared to not only to the current record but also shared to related child records.
When viewing the Classic Notes & Attachments related list on an account, for example, attachments belonging to the account and its related contacts, cases, opportunities, tasks, etc. are displayed in one combined list.
When viewing the Lightning Files related list on the same account, for example, only the files explicitly shared to the account are displayed. The files shared to its related contacts, cases, opportunities, tasks, etc. are not displayed in the same combined list.
This is a known limitation and by design according to this help article.
However, this "rollup" of Classic Attachments is a much beloved feature and customers are asking for it in Lightning Experience.
Keri-An Richards took to the IdeaExchange and submitted Roll up display of Notes and Attachments in Lightning as it was in Classic.
Others, like Abi Beaty and Hilary Henderson, have also inquired on the Success Community how to get this rollup feature in Lightning.
Seeing a need I began developing this app. After sharing a sneak peek on Twitter, Haris Ikram, Product Manager for Salesforce, commented that such a solution is in demand and happy to share this with the Salesforce Lightning Team.
- Install Package
- Browser Links (Production) (Sandbox)
- Salesforce CLI (
sfdx force:package:install --package 04t1I000000PNpI --wait 10
)
- Closed Issues
- Archived Releases
You may install the source code from GitHub and make any desired adjustments. You are responsible for ensuring unit tests meet your org's validation rules and other requirements.
-
Setup My Domain. My Domain is required to use Lightning Components. (Trailhead Module)
-
Add the Files related list to your Page Layouts (Trailhead Module)
-
Add the Related Files custom Lightning Component to your Lightning Record Pages (Trailhead Module)
Check out this 7 minute setup and how-to video:
- This component only works with Lightning Files, if you are still using Classic Attachments then I recommend that you migrate them.
- Add a new tab on your Record Pages labeled "Files" then add the standard
Related List
component (configured to show the Files related list) and my customRelated Files
component.
If one of your questions isn't answered below, please search and comment on existing issues before opening a new one. Thanks!
Files shared to child records that the user has access to. A child record is any record found in one of the related lists of the main record being viewed. For example, if viewing an account then the component could show you all files shared to contacts, cases, opportunities, etc. belonging to that account.
Specifically when viewing an account, files related to tasks and events that are related to child records of an account do rollup and are visible at the account level. This is possible because of the standard Task.AccountId
and Event.AccountId
fields and Salesforce populating them for account rollup behaviors.
As a System Administrator, you may customize which related lists are visible in this component. By default, all relationships accessible by the current user are displayed in the vertical navigation.
In App Builder when editing the Record Page you added the Related Files lightning component, there is a customization attribute named Child Relationships. Enter a comma-delimited list of the API name(s) of the child relationships as defined on the lookup field on the child object.
For example, if on the Account page you wanted this component to show only files for Contacts and a custom object Invoice__c
,
you might enter "Contacts,Invoices__r
".
To determine a child relationship name, in Setup use Object Manager to navigate to your child object (e.g. Contact
or Invoice__c
)
then navigate to the lookup field that points to the parent object (that is the object whose Lightning Record Page you're adding this component).
On the field's detail page you'll see the field label, field name, and the child relationship name (use this value in App Bulider).
If this is a custom lookup or master-detail field then you will need to append __r
to the child relationship name.
The badge count is the number of unique files shared to those related records.
For example, if the single file "Hello.txt" is shared to 3 contacts related to the same account then
when viewing this Related Files lightning component on that account page would display the badge count 1
for the Contacts
relationship even though 3 contacts exist because only 1 unique file was shared among them.
Add the provided buttons labeled View Related Files
to your page layouts, or
create your own custom buttons that link to /apex/CF_ChildFilesPage?id={!YourObject.Id}
.
The Visualforce page supports these URL parameters to customize the component:
Parameters | Examples | Required? | Default |
---|---|---|---|
id | 15 or 18 character sobject record id | yes | |
r | To customize which related lists are shown in the vertical navigation then specify a comma-separated list of the API name(s) of the child relationships whose files to show. | no | blank, shows all child relationships |
f | To filter if Files and/or Enhanced Notes are displayed in the lists then specify FILES_ONLY , NOTES_ONLY , or FILES_AND_NOTES |
no | FILES_AND_NOTES |
Example:
/apex/CF_ChildFilesPage?id=0011I00000345FD&r=Contacts,Invoices__r&f=FILES_ONLY
This component only works with Lightning Files, if you are still using Classic Attachments then I recommend that you migrate them.
See issue Use Actual Related List Labels.
Why do the child relationship labels in the vertical navigation not match the labels of the related lists on the page layout?
See issue Use Actual Related List Labels.
I have only tested this in a Developer Edition org with a few hundred related records and files off one account. If you have a much larger org with thousands of related records and files, please let me know how performance is so I can make any adjustments if needed. Thanks!
Doug Ayers develops and maintains the project.
The source code is licensed under the BSD 3-Clause License