Loading...

The Lightning Record Picker component was recently introduced by Salesforce in its Winter ’24 release.

In this blog, we will show you how to create a Lightning Web Component (LWC) that allows you to select any object and record from Salesforce by searching the name. This component can be useful for building dynamic forms, filters, or reports that require user input. This is not just a component, it’s a complete bundle of lookup functionalities that can be customized as per requirement.

So, let’s start!

Step-by-Step Guide To Create Custom Polymorphic Record Picker Component

Step 1: Create a new lightning web component.

Open vs code authorize your org and create a new lightning web component. Here we have given customPolymorphicRecordPicker you can give according to you.

Create new lightning web component

Step 2: Set component visibility.

Open your .xml extension file and set visibility for your component. We have set it to the lightning__HomePage, you can add more pages.

Save your code, right-click, and deploy it to the source org.

Step 3: Create an HTML layout for your component.

In HTML, we have defined a spinner that snipes till data loading and Created a combo box from where you can select objects.

At last, I have created a lightning-record-picker from where you find the record from the selected object in the combo box and select it.

Here is the HTML file after saving it deploy it to the source org.

Step 4: Create CSS file for spinner:

Now, Right click on your component’s name and choose new file.

Fill the name of your component with a .css extension.

In CSS we have defined styling for the spinner. if you did not create a spinner in html file you can skip this.

Here is the CSS file after saving it deploy it to the source org.

Step 5: Create Apex Class:

This is the main part of this customPolymorphicRecordPicker component which makes it dynamic.

  • In your org folder find classes, right-click, and click on SFDX: Create Apex Class.
  • Fill the name for your apex class here I have filled getObjects.
  • Here we have defined a Schema class and we are getting those objects that are isAccessible() && isCreateable() && Updateable() using functions.
  • At last shorting the list of Custom objects and return it.

Here is the apex class after saving it deploy it to the source org.

Step 6: Create Test Class

Here is the Test class of above Apex class:

Step 7: Create a Js handler:

In Js we are going to create all the functionality for customPolymorphicRecordPicker.

  • Click on your component file which has a .js extension.
  • Here I have imported wire, and track in my component.
  • I have also imported the created apex file in the previous step.
  • I have defined some variable to store values like targetObjects, and selectedTarget to store values.
  • I have also defined @wire to bring all object data from Salesforce.org.

At last, I have defined a getter to hide the combo box and two event listeners handleTargetSelection for selecting the entered text from the user and handleRecordSelect for assigning the currentrecordId.

Here is the js code after saving this deploy it to the source org.

Step 8: After successful deployment of all files login into the source org.

Step 9: I have set its visibility on lightning__HomePage so after selecting any app from the app launcher navigate the home page.

Note: (If you selected the record page go to the record page of any object)

Step 10: From setup click on Edit Page. From the component on the left side, find your component in the custom section.

Edit Page

Step 11: Drag and drop your component on the screen where you want to place it.

Step 12: Click on Save.

Conclusion:

In conclusion, the LWC Custom Polymorphic(dynamic) record picker component is a useful tool for selecting records from different objects based on their name. The component is flexible and customizable, as it can accept various parameters such as object API name, field API name, label, icon, placeholder, etc. The component also handles the pagination and sorting of the records and provides an option to clear the selection.

Like the blog? Stay tuned for more such interesting Salesforce development solutions!

No Data Found.

Related Articles
Orchestrator vs. Traditional Flows

Businesses use Salesforce automation to reduce manual work, improve efficiency, and automate repetitive business processes. Two commonly used automation approaches inside Salesforce are Traditional Flows and Flow Orchestrator. Traditional Flows are mainly used for simple automation tasks such as updating records, sending notifications, creating tasks, and automating business logic. Flow Orchestrator is designed for more […]

Read More
The Rise of Agentic Government_ What Salesforce’s 2026 Insights Mean for the Future of Public Sector AI

Government technology has often been seen as slower to evolve than the private sector. But Salesforce’s latest research challenges that idea in a big way. In fact, the new findings suggest that public sector organizations may now be moving faster than many businesses when it comes to adopting AI agents and preparing for a more […]

Read More
How To Use Email Service in APEX

Managing approvals, updates, and record changes directly from email can significantly improve efficiency within Salesforce workflows. Instead of logging in, navigating records, and manually updating fields, users can simply respond to emails and trigger automated updates using Email Service in APEX. This approach is especially useful for businesses leveraging Salesforce automation and looking to enhance […]

Read More
Design and Implementation of Salesforce Jira Task Integration 1 1

Businesses have been using Salesforce for CRM operations and Jira for Agile project tracking. However, without integration, teams manually update both systems, leading to data inconsistency and inefficiency.This mechanism establishes a real-time integration between Salesforce and Jira, allowing seamless synchronization of tasks and agile board statuses.  A custom Salesforce dashboard was developed that replicates Jira-style […]

Read More
Dark Mode in Salesforce Enabling It and Creating Theme Ready Lightning Web Components with SLDS 2.0 1 1

With the Winter ’26 release, Salesforce introduced Dark Mode in Lightning Experience. Dark Mode has been introduced as a beta feature in Winter ’26, and at first it was available only for Starter Edition orgs. It is now rolling out further with Spring ’26 to Professional, Enterprise, and Developer editions. To use Dark Mode, Salesforce […]

Read More
How to Merge and Brand PDF Files in Salesforce Using LWC Visualforce PDF LIB 1

Salesforce developers frequently encounter document automation requirements that go beyond standard Apex-based PDF generation. From merging multiple ContentVersion files to dynamically applying branding like watermarks and headers, traditional server-side approaches often hit Salesforce heap size limits (6MB/12MB), creating performance and scalability challenges. This guide presents a heap-limit-safe PDF merging architecture in Salesforce using Lightning Web […]

Read More
Our Location worldwide
Indian Flag India
3rd Floor, A-10, Pegasus Tower, Sector 68, Noida, Uttar Pradesh 201301 +91-1203239658
United States of America Flag USA
333 West Brown Deer Road Unit G – 366 Milwaukee WI, USA 53217 +1(262) 310-7818
United Kingdom Flag UK
7 Bell Yard, London, WC2A 2JR +44 20 3239 9428
Canada Canada
HIC Global Solutions INC
6D - 7398 Yonge St #1124 Thornhill, ON L4J 8J2 Canada +1(262) 310-7818