Close Menu
SalesforceCodex
    Facebook X (Twitter) Instagram
    Trending
    • Prevent Large Data Queries in Salesforce with Transaction Security Policies
    • The Ultimate Guide to Data Cleanup Techniques for Salesforce
    • How to Leverage Model Context Protocol (MCP) to Enhance Salesforce AI
    • Top Mistakes Developers Make in Salesforce Apex Triggers
    • Introducing Agentforce3 to Salesforce Developers
    • The Ultimate Guide to Apex Order of Execution for Developers
    • How to Handle Bulkification in Apex with Real-World Use Cases
    • How to Confidently Manage Transactions in Salesforce Apex
    Facebook X (Twitter) Instagram
    SalesforceCodex
    Subscribe
    Saturday, August 16
    • Home
    • Salesforce Platform
      • Architecture
      • Apex
      • Lightning Web Components
      • Integration
      • Integration List
      • Flows & Automation
      • Best Practices
      • Questions
      • News
      • Books Testimonial
    • Industries
      • Artificial Intelligence
    • Hire Me
    • Certification
      • How to Prepare for Salesforce Integration Architect Exam
      • Certification Coupons
    • Downloads
      • Salesforce Release Notes
      • Apex Coding Guidelines
    • About Us
      • Privacy Policy
    • Contact Us
    SalesforceCodex
    Home»Salesforce»Get All Used Custom Metadata Detail

    Get All Used Custom Metadata Detail

    Dhanik Lal SahniBy Dhanik Lal SahniMay 31, 2020Updated:December 25, 2024No Comments3 Mins Read
    Facebook Twitter Pinterest LinkedIn Tumblr Email
    Get All Used Custom Metadata Detail
    Share
    Facebook Twitter LinkedIn Pinterest Email

    When developing new features, some time we reach org character limit. In that case we have to remove unused code from Salesforce org. Let us create excel report of all custom metadata like custom field, apex classes, lightning component, flow etc from tooling api.

    In our last post Find Referenced Metadata using Salesforce Dependency API dependency is checked for specific custom metadata.

    This post will get list of all custom metadata in hierarchical grid. If metadata is used somewhere it will show detail where it is used.

    Steps for getting complete metadata detail:

    1. Get list of All custom metadata using Tooling API
    2. Create Hierarchical data in Apex
    3. Use Lightning-tree-data for showing data
    4. Download complete data in CSV

    1. Get list of All custom metadata using Tooling API

    We can get complete list of custom metadata and it’s referenced object detail using MetadataComponentDependency Tooling API object. This object is still in beta version but it is available for Developer/Administrator after Summer 20 Release.

    Select MetadataComponentId, MetadataComponentName, RefMetadataComponentName, RefMetadataComponentId, MetadataComponentType from MetadataComponentDependency

    MetadataComponentId is id of metadata component which is dependent on another component RefMetadataComponentId.

    IMPORTANT STEP:

    We have to call Tooling API from Lightning Web Component so refer post CALL TOOLING API FROM LIGHTNING WEB COMPONENT. You can use Default scope refresh_token full in Auth Provider and Named Credential, if you don’t want to change user.

    2. Create Hierarchical data in Apex

    Based on above query we can get data from Tooling API. We can create hierarchical data in apex itself or in Lighting Web Component also. For this blog, I have created hierarchical data in apex.

    We can use MetadataComponentId and RefMetadataComponentId for creating hierarchical data list.

    //Parent Loop
    for(MetadataRecord record:metadataRecords)
    {
        TreeNode node=new TreeNode();
        node.MetadataComponentName=record.MetadataComponentName;
        //Get Child or Reference 
        List<TreeNode> childs=new List<TreeNode>();
        for(MetadataRecord rd:metadataRecords)
        {       
            if(rd.MetadataComponentId==record.MetadataComponentId)
            {
                TreeNode nd=new TreeNode();
                nd.MetadataComponentName=record.MetadataComponentName;
                childs.add(nd);
            }
        }
        node.children=childs;
    }

    As we have custom metadata list and we need to get child or dependent custom objects within same list. For this we can use loop to get dependent of each custom object.

    3. Use Lightning-tree-data for showing data

    Now we have hierarchical data in list from above step. Let us show this complete data in lightning-tree-grid object. This component displays structured data in a table with expandable rows.

      <lightning-tree-grid
                        columns={columns}
                        data={gridData}
                        key-field="MetadataComponentName"
      ></lightning-tree-grid>

    Add column for lightning tree grid.

    export const COLUMNS_DEFINITION = [
       {
            type: 'text',
            fieldName: 'MetadataComponentName',
            label: 'Metadata Name',
            initialWidth: 300,
        },
        ......
       @track columns=COLUMNS_DEFINITION;

    lightning-tree-grid need child record as _children object and in apex we can not create property starting with underscore(_) so we have to transform children as _children object for each metadata record.

    var result=[];
    data.forEach(child => {
        var ch=JSON.parse(JSON.stringify(child));
        if(ch.children!==undefined && ch.children.length>0)
        {
            ch._children=ch.children;
        }
        ch.children=null;
        result.push(ch);
    });
    this.gridData=result;

    4. Download complete data in CSV

    We can download all metadata record which is shown in lightning-tree-grid. We can create string data variable and based on required column we can add comma(,) in string record variable.

    this.gridData.forEach(function(rowArray) {
        let row = rowArray.MetadataComponentName+","+rowArray.RefMetadataComponentType+","+rowArray.RefMetadataComponentName+",";
        if(rowArray._children!==undefined)
        { 
            rowArray._children.forEach(function(child) {
                csvContent += row + "\r\n";
                row = child.MetadataComponentName+","+child.RefMetadataComponentType+","+child.RefMetadataComponentName+",";
            });
        }
        csvContent += row + "\r\n";
    });

    Complete code:

    Apex:

    Lightning Web Component

    Test Page

    Custom Metadata in Salesforce

    References:

    https://developer.salesforce.com/docs/component-library/bundle/lightning-tree-grid/example

    https://releasenotes.docs.salesforce.com/en-us/summer20/release-notes/rn_feature_impact.htm

    https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_metadatacomponentdependency.htm

    Related Posts

    Salesforce DevOps for Developers: Enhancing Code Quality and Deployment Efficiency

    Apex Code Coverage In Custom Object

    Get All Used Custom Metadata Detail

    Find Referenced Metadata using Salesforce Dependency API

    Extract list of all fields from Page Layout

    Field Access Explorer In lightning Web Component

    Call Tooling API from Lightning Web Component

    apex dependency api lightning Lightning web component lwc salesforce tooling api
    Share. Facebook Twitter Pinterest LinkedIn Tumblr Email
    Previous ArticleFind Referenced Metadata using Salesforce Dependency API
    Next Article Generate own code for Apex using Salesforce CLI
    Dhanik Lal Sahni
    • Website
    • Facebook
    • X (Twitter)

    With over 18 years of experience in web-based application development, I specialize in Salesforce technology and its ecosystem. My journey has equipped me with expertise in a diverse range of technologies including .NET, .NET Core, MS Dynamics CRM, Azure, Oracle, and SQL Server. I am dedicated to staying at the forefront of technological advancements and continuously researching new developments in the Salesforce realm. My focus remains on leveraging technology to create innovative solutions that drive business success.

    Related Posts

    By Dhanik Lal Sahni6 Mins Read

    Prevent Large Data Queries in Salesforce with Transaction Security Policies

    August 11, 2025
    By Dhanik Lal Sahni6 Mins Read

    How to Leverage Model Context Protocol (MCP) to Enhance Salesforce AI

    July 28, 2025
    By Dhanik Lal Sahni7 Mins Read

    Top Mistakes Developers Make in Salesforce Apex Triggers

    July 25, 2025
    Add A Comment
    Leave A Reply Cancel Reply

    Ranked #1 Salesforce Developer Blog by SalesforceBen.com
    SFBenTopDeveloper
    Ranked #4 Salesforce Developer Blog by ApexHours.com
    ApexHoursTopDevelopers
    Categories
    Archives
    Tags
    apex (117) apex best practices (5) apex code best practice (10) apex code optimization (6) apex rest (11) apex trigger best practices (6) architecture (22) Asynchronous apex (9) AWS (5) batch apex (10) best code practice (4) code optimization (9) custom metadata types (5) design principle (9) flow (16) google (6) integration (19) integration architecture (6) lighting (8) lightning (66) lightning-combobox (5) lightning-datatable (10) lightning component (32) Lightning web component (64) lwc (53) named credential (8) news (4) optimize apex (5) optimize apex code (6) optimize apex trigger (5) Permission set (4) Queueable (9) queueable apex (4) rest api (24) salesforce (151) salesforce apex (53) salesforce api (4) salesforce api integration (5) Salesforce Interview Question (5) salesforce news (5) salesforce question (5) security (4) solid (6) tooling api (5) Winter 20 (8)

    Get our newsletter

    Want the latest from our blog straight to your inbox? Chucks us your detail and get mail when new post is published.
    * indicates required

    MailChimp

    Expert Salesforce Developer and Architect
    Ranked #1 SALESFORCE DEVELOPER BLOG BY SALESFORCEBEN.COM
    Featured on Top Salesforce Developer Blog By ApexHours
    Recent Posts
    • Prevent Large Data Queries in Salesforce with Transaction Security Policies
    • The Ultimate Guide to Data Cleanup Techniques for Salesforce
    • How to Leverage Model Context Protocol (MCP) to Enhance Salesforce AI
    • Top Mistakes Developers Make in Salesforce Apex Triggers
    • Introducing Agentforce3 to Salesforce Developers
    Ranked in Top Salesforce Blog by feedspot.com
    RSS Recent Stories
    • Top 10 Salesforce CRM Trends to Watch in 2025 July 18, 2025
    • Discover the Top 10 Salesforce AppExchange Apps to Boost Productivity July 10, 2025
    • Top 20 Salesforce Data Cloud Interview Questions & Answers for Admins June 5, 2025
    • How to Connect Excel to Salesforce to Manage Your Data and Metadata February 9, 2025
    • Difference Between With Security and Without Security in Apex January 2, 2025
    Archives
    Categories
    Tags
    apex (117) apex best practices (5) apex code best practice (10) apex code optimization (6) apex rest (11) apex trigger best practices (6) architecture (22) Asynchronous apex (9) AWS (5) batch apex (10) best code practice (4) code optimization (9) custom metadata types (5) design principle (9) flow (16) google (6) integration (19) integration architecture (6) lighting (8) lightning (66) lightning-combobox (5) lightning-datatable (10) lightning component (32) Lightning web component (64) lwc (53) named credential (8) news (4) optimize apex (5) optimize apex code (6) optimize apex trigger (5) Permission set (4) Queueable (9) queueable apex (4) rest api (24) salesforce (151) salesforce apex (53) salesforce api (4) salesforce api integration (5) Salesforce Interview Question (5) salesforce news (5) salesforce question (5) security (4) solid (6) tooling api (5) Winter 20 (8)

    Get our newsletter

    Want the latest from our blog straight to your inbox? Chucks us your detail and get mail when new post is published.
    * indicates required

    Facebook X (Twitter) Instagram Pinterest YouTube Tumblr LinkedIn Reddit Telegram
    © 2025 SalesforceCodex.com. Designed by Vagmine Cloud Solution.

    Type above and press Enter to search. Press Esc to cancel.

    Ad Blocker Enabled!
    Ad Blocker Enabled!
    Our website is made possible by displaying online advertisements to our visitors. Please support us by disabling your Ad Blocker.