Field to count linked Products in Custom Module where record status is "Active".

Field to count linked Products in Custom Module where record status is "Active".

So, I'm having issues with this custom function. I'm trying to update a field each day, that counts active Virtual Products.

I have a custom module called Agreement History where records for each service agreement are stored.

In each of these records, products are indicated in lookup fields. Each record has the 3 fields (Product 1, Product 2, Product 3) where products are linked.

So, for instance, there is a product called OFA Silver Virtual Package, and I want the function to count how many Agreement History records with the field Contract Status as Active, have this product linked in them.

There are no Agreement History records where there are 2 of the same product are linked, but they may be in any one of the 3 product fields.

The field in the Products record is where the count should be stored and it is a simple Number field.

My issue is that the function runs and only returns 0 for all products.


void automation.CountVirtualProducts()
{
    // Fetch the active Agreement History records
    agreementHistoryRecords = zoho.crm.getRecords("Agreement_History",1,200);
    
    // Initialize a variable to store the total product count
    totalProductCount = 0;
    
    // Loop through each agreement history record
    for each agreement in agreementHistoryRecords
    {
        // Check if the contract status is 'Active'
        if(agreement.get("Contract_Status") == "Active")
        {
            info "Processing Agreement ID: " + agreement.get("id");
            
            // Check Product 1
            if(agreement.get("Product_1") != null)
            {
                info "Product 1 is linked";
                totalProductCount = totalProductCount + 1;
            }
            else
            {
                info "Product 1 is empty";
            }

            // Check Product 2
            if(agreement.get("Product_2") != null)
            {
                info "Product 2 is linked";
                totalProductCount = totalProductCount + 1;
            }
            else
            {
                info "Product 2 is empty";
            }

            // Check Product 3
            if(agreement.get("Product_3") != null)
            {
                info "Product 3 is linked";
                totalProductCount = totalProductCount + 1;
            }
            else
            {
                info "Product 3 is empty";
            }
        }
    }
    
    // Log the final count
    info "Final Total Product Count: " + totalProductCount;
}


Any help would be appreciated!
    • Sticky Posts

    • Zoho CRM Functions 53: Automatically name your Deals during lead conversion.

      Welcome back everyone! Last week's function was about automatically updating the recent Event date in the Accounts module. This week, it's going to be about automatically giving a custom Deal name whenever a lead is converted. Business scenario Deals are the most important records in CRM. After successful prospecting, the sales cycle is followed by deal creation, follow-up, and its subsequent closure. Being a critical function of your sales cycle, it's good to follow certain best practices. One such
    • User Tips: Auto-Create Opportunity/Deal upon Quote Save (PART 1)

      Problem: We use quotes which convert to sales orders but Users / Sales Reps do not create opportunities / deals and go straight to creating a quote. This leads to poor reporting. Implementing this solution improves reporting and makes it easier for users.
    • Custom Function : Automatically send the Quote to the related contact

      Scenario: Automatically send the Quote to the related contact.  We create Quotes for customers regularly and when we want to send the quote to the customer, we have to send it manually. We can automate this, using Custom Functions. Based on a criteria, you can trigger a workflow rule and the custom function associated to the rule and automatically send the quote to customer through an email. Please note that the quote will be sent as an inline email content and not as a PDF attachment. Please follow
    • Function #50: Schedule Calls to records

      Welcome back everyone! Last week's function was about changing ownership of multiple records concurrently. This week, it's going to be about scheduling calls for records in various modules. Business scenario Calls are an integral part of most sales routines.. Sales, Management, Support, all the branches of the business structure would work in cohesion only through calls. You could say they are akin to engine oil, which is required by the engine to make all of it's components function perfectly. CRM
    • Function #37: Create a Purchase Order from a Quote

      Welcome back everyone! Last week, we learnt how to calculate the total number of activities for a lead and further take note of the activity count for particular dates. For instance, from the period of Demo to Negotiation. This week, let's look at a function that lets you create a Purchase Order instantly from a Quote. Business scenario: In any form of business, one of the most important things to do is to document the transactions. Naturally, negotiation, signing an agreement, placing an order,