Creating a picklist for any project in LWC is pretty easy, thanks to the codes available on the internet.

But what if we have to create picklists for different fields of various objects or different fields of the same object?

Making alterations to the code again and again to achieve the same is time-consuming and inefficient.

So, here comes the solution for this problem: a Generic Picklist!

We have developed a code to handle all the dynamic values of picklists using Lightning Component Combobox and to show it on the desired page with a minute change in components.

But the lightning Combobox comes with a problem too- we can not apply the themes and CSS client wants to apply to this component.

So in this code, we have solved this problem as well. This code increases reusability with custom themes and CSS of your own choice.

Below is the code we have used to create a generic picklist in Lightning Web Component.

Let’s go step by step to understand it.

Step 1: Create a custom dropdown

The below code can be used to show a custom dropdown. In this, we have an arrow to handle dropdowns. And to show values that are needed on the component.

i)The HTML code.

HTML CODE:
cp_reusableCustomDropdownWithSearchLwc.html

ii) XML code to choose if we want it to use on another target.

XML Code:cp_reusableCustomDropdownWithSearchLwc.js-meta.xml

iii) The javascript code to handle the changes that are made by the customer on UI.

Javascript code: cp_reusableCustomDropdownWithSearchLwc.js

iv) CSS code to improve the viewing quality.

Please note that It is not necessary to implement if you don’t want to include extra classes.

CSS Code:cp_reusableCustomDropdownWithSearchLwc.css

Step 2: To create a picklist for various fields of different Objects or different fields for same object.

I have used the following code to handle the date like object name, Field name, placeholder and Values(that must be in comma-separated String).

i) HTML code to pass the values where we are calling it on the component.

HTML Code: cp_customPicklistValues.html

ii) XML code to choose the target for using this component

XML Code:cp_customPicklistValues.js-meta.xml

iii) Javascript code is used to track the values of picklist and create event.

JAVAScript Code: cp_customPicklistValues.js

iv) CSS code to improve viewing quality

CSS Code:cp_customPicklistValues.css

STEP 3: Final step

Here is the code to call the picklist component in another component. And here we will pass the value of placeholder in “placeholder”, List of options in from of string separated by comma in “optionList”, label for the picklist in “fLabel” and a message just to check if the picklist is empty or not in “emptyMsg”.

Now call the component using the below code by pasting it into another Component.

JAVASCript CODE to handle this: showPickListValue.js

Click here to check our Generic picklist

Conclusion

So, here it is, our strategic guide to creating a reusable generic picklist with a custom theme and CSS.

Try out the solution and share your experience with us. Also, stay hooked to our blogs for more interesting Salesforce development solutions. Catch you on the next one. Happy Learning!

Related Articles
Expert Guide On Nominal XIRR Calculation Using LWC in Salesforce

When building financial tools within Salesforce, handling irregular cash flows with precision is a must. Whether you’re developing investment trackers, portfolio performance dashboards, or funding monitors, calculating Nominal XIRR (Extended Internal Rate of Return) becomes essential. In this blog, you’ll learn how to build a Lightning Web Component (LWC) in Salesforce that calculates Nominal XIRR […]

Read More
Beginners Guide to Making Your LWC Component Multilingual

If you’re wondering how to make your LWC component multilingual, you’re already ahead of the curve. Global users expect content in their native language, and Salesforce gives you the tools to deliver exactly that. With Custom Labels and the Translation Workbench, you can easily localize your Lightning Web Components without touching a single line of […]

Read More
Hands-On Guide Building a Drag-and-Drop Form Builder Using Lightning Web Components

Drag-and-drop interfaces are a user experience staple, and when paired with the power of Lightning Web Components (LWC), they unlock dynamic, highly interactive Salesforce components. In this blog post, we’ll walk you through how to build a custom drag-and-drop form builder in LWC. Users can drag form fields like text inputs and dropdowns into a […]

Read More
Please Make Blog Banner How to Create an Agentforce Enabled Scratch Org in Salesforce 100 1

Setting up an Agentforce-enabled scratch org is the most important step for developers who want to experiment with AI features such as Prompt Builder and Einstein GPT. Whether you’re developing the next generation CRM software or experimenting with how generative AI may improve user experience, a scratch org equipped with Agentforce is your playground. Follow […]

Read More
Step-by-Step Guide to Enhance Your LWC Development Workflow with the Logger API

Are you looking to streamline your LWC development workflow but confused about how to do it? Then you are in the right place. The Salesforce Logger API is a powerful tool that helps you monitor, debug, and improve code quality in real time.  This step-by-step guide walks you through how to set it up and […]

Read More
Enhancing Your Salesforce Experience with a Custom Activity Component

In today’s fast-paced business landscape, productivity hinges on streamlined workflows and intuitive interfaces. While Salesforce offers robust activity tracking capabilities, sometimes the standard components fall short of specific organizational needs.  That’s where a Custom Activity Component comes in—designed to tailor your activity management experience, boost user efficiency, and provide deeper insights into customer interactions. In […]

Read More
Our Location worldwide
Indian Flag India
3rd Floor, A-10, Pegasus Tower, Sector 68, Noida, Uttar Pradesh 201301 +91-1203117884
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
43 Lafferty Lane, Richmond Hill, L4C 3N8, CA +1(262) 310-7818