Skip to content

mickaelgudin/sfdc-lwc-lightning-datatable

Repository files navigation

Master

Salesforce Lightning Data table (LWC Version)

datatable

About

To deploy the component see Deploy

This is generic lighting data table , which is build in lwc. The customization are done by design attributes.

Main features The data table has following features.

  • Show records for both custom and standard object.
  • Add cols as per the fields exist in object in JSON format.
  • Pagination as First,Previous,Next,Last buttons.
  • New record creation action
  • Row action, like : show detail, edit record, delete record
  • Hide/Unhide checkbox column
  • Configurable actions buttons (for developers, see Buttons configuration )
  • Sorting by field.

Steps to Customization through Design Attribute

Design Attribute

Label Required Type Value Example
Enter Icon Name String provide slds icon name (if you wish to override the default icon of the object) standard:account
Enter Title ✔️ String provide table title LWC Table
Enter Object API Name ✔️ String provide object custom or standard API name Contact
Enter Columns API Name by comma seprated ✔️ String Note : for related field it should be concat with . i.e : Account.Name for contact, Inline Edit not support cross reference Field FirstName,LastName,Email,Phone
Enter Customized Field JSON ( This is Mandatory for Related Field ) String customized Column Label, Record Redirect, Data Type. Note : This is Mandatory for Related Fields i.e : Account.Name for contact See below Customized Field JSON
Enter Related field API Name String Enter related field api name Example AccountId for contact when component is on account layout.
Hide/Unhide checkbox column Boolean true/false Hide/Unhide Checkbox
Enter WHERE clause String provide aditional filters Example LastName like '%s' AND Account.Name like '%t'
Enter limit Integer limit the displayed number of records for the list an integer
Show the number of record Boolean append the number of records in the title checked(true) OR not checked(false)
Show the view all / collapse buttons Boolean display buttons to expand/collapse records checked(true) OR not checked(false)
Enable/Disable pagination Boolean enable or disable pagination for the list checked(true) OR not checked(false)
Buttons to display String buttons that we want to display See below Buttons configuration
Enable/Disable search Boolean enable or disable search bar checked(true) OR not checked

Customized Field JSON

label : This key is for override column Name. ( Example : Override Column Label )

type : This key is for override column Type supported_lwc_datatable_datatype. ( Ex : url ). ( Example : Related Field Customized )

typeAttributes : This key is used for hyperlink to recordId. ( recId stored recordId Field ). ( Example : Add Hyperlink for navigate to record )

Example : Override Column Label

{ "AccountId":{"label":"Account Record Id"}} }

Example : Related Field Customized

{ "Account.Name":{"label":"Account Name","type":"text" }} }

Example : Add Hyperlink for navigate to record

{ "Account.Name":{"label":"Account Name","type":"url","typeAttributes":{"label":{"fieldName":"Account.Name","recId":"AccountId"}} }

Buttons configuration

Buttons JSON :

[{ "name": "New", "label": "New", "variant": "neutral" }]

Default displayed buttons

The "New" button is displayed by default

Button logic definition (fire an event, call a method in the javascript controller)

You can implement your own logic for your new buttons based on button JSON (new, delete-selected...).

  handleButtonAction(event) {
    //call desired javacript method or apex call, or throw an event based on the button key(new, delete-selected...)
    //if button has needSelectedRows set to true, have selected rows using this.selectedRows
    const buttonLabel = event.target.dataset.name;
    switch (buttonLabel) {
      case "New":
        this.newRecord();
        break;
      /* TODO
      case "delete-selected":
        const eventDeleteSelected = new CustomEvent('deleteselected', { detail: JSON.stringify(this.selectedRows) });
        this.dispatchEvent(eventDeleteSelected);
        break;*/
      default:
    }
  }

Deploy

Click Button to deploy source in Developer/Sandbox

Deploy to Salesforce

Q & A

Feel free to ask any Question, Suggestion, Issue here

Want to contribute? Great!

Create Pull Request to dev branch with your feature banch.

About

Salesforce Lighitng Data table

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 52.6%
  • Apex 28.9%
  • HTML 17.9%
  • Other 0.6%