Introduction:
In this blog, I would like to demonstrate on how to export the lightning data table value into an Excel format using Aura component with help of jQuery.
Requirement:
On click Event of a quick action button from the object’s detail page, the first step is to retrieve all the necessary records into a lightning data table. The next step is to download the data as CSV using jQuery.
Use Case:
For the demonstration, I created a quick action button on the Account Object , and it retrieves the related contacts. Passing accountId in the Quick Action URL will filter the Contacts related to the Account.
data:image/s3,"s3://crabby-images/afedf/afedf6bcd4e3e4f7dd763316d5edd645f1021b96" alt=""
Components Used:
- Aura Component
- Server-Side Apex class
- Static resource
Included jQuery as a resource in the Aura Component.
<ltng:require scripts=”{!$Resource.JQuery}” />
data:image/s3,"s3://crabby-images/afedf/afedf6bcd4e3e4f7dd763316d5edd645f1021b96" alt=""
Step 1: Retrieve the related contact records under an Account.
Helper class (JS code)
data:image/s3,"s3://crabby-images/ce8db/ce8dba937bb0aea8494b9f32e1e4e7630d01e267" alt=""
Apex Class method
data:image/s3,"s3://crabby-images/d5428/d5428b7087aaec202340dc56d59380700666081d" alt=""
Step 2: Build JavaScript code to generate the CSV file format.
Using the style class get the values of the data table and iterate the header and column values to generate a CSV format.
data:image/s3,"s3://crabby-images/ce8db/ce8dba937bb0aea8494b9f32e1e4e7630d01e267" alt=""
data:image/s3,"s3://crabby-images/de809/de8091643b9cb607cea656045612ea483f12237f" alt=""
The document.createElement() method creates the HTML element specified by tag Name. Here, it creates a <p> element and appends it to the document.
The header is referred by JavaScript object keys, and rows referred by JavaScript object values. It must be separated by a comma to have a CSV. We use Blob for building a CSV file.
The URL.createObjectURL() static method generates a string containing a URL which represents the object given in the parameter. Here, it is Blob object.
Href – The location.href property sets the entire URL of the current page.
The appendChild() method of the Node interface adds up a node to the end of the list of children corresponding to a specific parent node which moves it from its current position to the new position.
The HTMLElement.click() method generates a mouse click on an element.
The removeChild() method of a node interface removes a child node from DOM, and it will return the removed node.
Output:
1.Open the Account record & click Contacts Quick action button
data:image/s3,"s3://crabby-images/9a372/9a372abb871ae1f6b579eef44a0e434968f69a07" alt=""
2.After clicking contacts quick action button, the related contacts of Account will be displayed in the data table.
data:image/s3,"s3://crabby-images/4c8be/4c8beb56422b0e7bc8793c40e3858da0c176272e" alt=""
3.After clicking the download button, the related Contacts will be downloaded as a CSV file.
data:image/s3,"s3://crabby-images/a2b1c/a2b1c064b35d3ca389a7ab07cc954985be49b710" alt=""
Output in CSV
data:image/s3,"s3://crabby-images/7df88/7df88560b1dcabcce53e937aff692944524867e0" alt=""