We’re Heading to CNX ’25. Let's Meet in Chicago! Join HIC at Salesforce Connections'25 for conversations, collaboration, and co-creation.

Salesforce Metadata API is a powerful tool that allows you to manage your organization’s metadata model, not just perform CRUD operations on records. One of the many things you can do with this API is programmatically create custom picklist fields. In this blog post, we’ll walk through the steps to do just that.

Prerequisites
Before we begin, make sure you have the following:

  • A Salesforce Developer Edition org or a sandbox environment.
  • The Metadata Service class added to your Salesforce org.

Step 1: Create a Metadata Service Instance

The first step is to create an instance of the MetadataService.MetadataPort class. This class provides methods for creating, reading, updating, and deleting metadata components.

Step 2: Define the Custom Field

Next, we define the custom field that we want to create. We specify the field’s API name, label, and type. In this case, we’re creating a picklist field.

Step 3: Define the Picklist Values

We then define the picklist values that we want to add to our custom field. We create an instance of metadataservice.ValueSet and metadataservice. ValueSetValuesDefinition. We also create instances of metadataservice.CustomValue for each picklist value.
Also read: How to create a generic Picklist in LWC?

Step 4: Create the Custom Field

Finally, we call the createMetadata method on our service instance to create the custom field. We pass in an array of metadata components that we want to create.

Conclusion

And that’s it! You’ve just created a custom picklist field using Salesforce Metadata API. You can use similar steps to update or delete metadata components.
Feel free to try out the solution and share your feedback with us. We will be back with another interesting Salesforce development solution soon. Until next, keep learning!

Related Articles
Expert Guide On Utilizing Agentforce for Seamless Quote & Case Creation

When it comes to managing customer journeys in Salesforce, speed and accuracy matter. That’s where Agentforce, a powerful extension layer, comes into play. Whether spinning up a new quote from an opportunity or logging a support case from a contact, Agentforce can help streamline these actions with minimal clicks and maximum context. In this blog, […]

Read More
How to Use Platform Events in Salesforce Flow for Real Time Updates

Platform events in Salesforce Flow are a great tool for creating real-time, event-driven apps that automate business operations with precision and speed. By integrating Platform Events’ publish-subscribe approach with Salesforce Flow‘s low-code features, you can automate processes, allow real-time system interaction, and optimize how your organization manages dynamic data changes. This guide will demonstrate how […]

Read More
Build a Dynamic Salesforce Data Viewer with hange kardo bas LWC

Lightning Web Components (LWC) is a modern JavaScript framework that is used for building responsive, dynamic applications on the Salesforce platform. In LWC, data flows from parent-to-child component. Variables marked as @api in the child component are open for a parent to pass values directly into the child’s HTML template, making the component interactable. To […]

Read More
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
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
6D - 7398 Yonge St #1124 Thornhill, ON L4J 8J2 Canada +1(262) 310-7818