Close Menu
SalesforceCodex
    Facebook X (Twitter) Instagram
    Trending
    • 10 Salesforce Chrome Extensions to Boost Your Productivity
    • How to Build a Generic Modal Window in Lightning Web Component
    • Top 10 Salesforce Flow Features of Salesforce Summer ’25
    • Unlock the Power of Vibe Coding in Salesforce
    • How to Implement Dynamic Queueable Chaining in Salesforce Apex
    • How to Implement Basic Queueable Chaining in Salesforce Apex
    • How to Suppress PMD Warnings in Salesforce Apex
    • Top 10 PMD Issues Salesforce Developers Should Focus on in Apex
    Facebook X (Twitter) Instagram
    SalesforceCodex
    Subscribe
    Saturday, June 21
    • Home
    • Architecture
    • Salesforce
      • News
      • Apex
      • Integration
      • Books Testimonial
    • Questions
    • Certification
      • How to Prepare for Salesforce Integration Architect Exam
      • Certification Coupons
    • Integration Posts
    • Downloads
    • About Us
      • Privacy Policy
    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 Sahni9 Mins Read

    10 Salesforce Chrome Extensions to Boost Your Productivity

    June 1, 2025
    By Dhanik Lal Sahni4 Mins Read

    How to Build a Generic Modal Window in Lightning Web Component

    May 26, 2025
    By Dhanik Lal Sahni6 Mins Read

    Top 10 Salesforce Flow Features of Salesforce Summer ’25

    May 11, 2025
    Add A Comment
    Leave A Reply Cancel Reply

    Ranked #1 SALESFORCE DEVELOPER BLOG BY SALESFORCEBEN.COM
    Featured on Top Salesforce Developer Blog By ApexHours
    Recent Posts
    • 10 Salesforce Chrome Extensions to Boost Your Productivity
    • How to Build a Generic Modal Window in Lightning Web Component
    • Top 10 Salesforce Flow Features of Salesforce Summer ’25
    • Unlock the Power of Vibe Coding in Salesforce
    • How to Implement Dynamic Queueable Chaining in Salesforce Apex
    Ranked in Top Salesforce Blog by feedspot.com
    RSS Recent Stories
    • 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
    • Top Reasons to Love Salesforce Trailhead: A Comprehensive Guide December 5, 2024
    • How to Utilize Apex Properties in Salesforce November 3, 2024
    Archives
    Categories
    Tags
    apex (111) apex code best practice (8) apex rest (11) apex trigger best practices (4) architecture (22) Asynchronous apex (9) AWS (5) batch apex (9) batch processing (4) code analysis (3) code optimization (8) custom metadata types (5) design principle (9) flow (15) future method (4) google (6) google api (4) integration (19) integration architecture (6) lighting (8) lightning (65) lightning-combobox (5) lightning-datatable (10) lightning component (31) Lightning web component (63) lwc (52) named credential (8) news (4) optimize apex code (4) optimize apex trigger (3) Permission set (4) pmd (3) Queueable (9) rest api (23) S3 Server (4) salesforce (142) salesforce apex (47) salesforce api (4) salesforce api integration (5) Salesforce Interview Question (4) salesforce news (5) salesforce question (5) 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.