Make function for repeating code

Make function for repeating code

Hi,

It's me again with my questions... 😅

In my Creator app, there's code that repeats itself in several places. And repeating code necessarily means optimization.

So I'm trying to create a custom function to centralize my code in a single place and call the function in each script where I need it.

However, depending on the script where I need it, I reference different inputs. So I should be able to pass them as parameters, but that doesn't work.

Furthermore, these inputs are subform inputs, so the function must be able to target the subform, then the input.

Could you help me solve my challenge, please? Thank you!

Here's the information:


In my function, I try to get subform :
  1. void test(string subform)
  2. {
  3. // Initialiser les totaux globaux avec leurs valeurs respectives, utilisation de la fonction personnalisée CheckFieldsIfNull
  4. totalPrixMateriauxGlobal = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_list_prix_materiaux"));
  5. totalPrixFinitionGlobal = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_list_prix_finition"));
  6. totalPrixQuincaillerieGlobal = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_list_prix_quincaillerie"));
  7. totalPrixFraisSuppGlobal = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_list_prix_frais_supp"));
  8. totalAvantTaxes = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("Sous_total_avant_taxes"));
  9. totalTps = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_tps"));
  10. totalTvq = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("total_tvq"));
  11. grandTotal = thisapp.CheckFieldsIfNull(creer_soumission.subform().get("sous_total"));
  12. // Soustraire le prix total de la ligne supprimée au prix total du sous-formulaire
  13. totalPrixFraisSuppGlobal = totalPrixFraisSuppGlobal - creer_soumission.subform().get("total_prix_frais_supp");
  14. // Mettre à jour les totaux globaux
  15. totalAvantTaxes = totalPrixFinitionGlobal + totalPrixMateriauxGlobal + totalPrixQuincaillerieGlobal + totalPrixFraisSuppGlobal;
  16. totalTps = thisapp.CalculateTax(totalAvantTaxes,creer_soumission.subform().get("tps_taxe"));
  17. totalTvq = thisapp.CalculateTax(totalAvantTaxes,creer_soumission.subform().get("tvq_taxe"));
  18. // Mettre à jour les inputs
  19. creer_soumission.subform().get("total_list_prix_materiaux") = totalPrixMateriauxGlobal;
  20. creer_soumission.subform().get("total_list_prix_finition") = totalPrixFinitionGlobal;
  21. creer_soumission.subform().get("total_list_prix_quincaillerie") = totalPrixQuincaillerieGlobal;
  22. creer_soumission.subform().get("total_list_prix_frais_supp") = totalPrixFraisSuppGlobal;
  23. creer_soumission.subform().get("Sous_total_avant_taxes") = totalAvantTaxes;
  24. creer_soumission.subform().get("total_tps") = totalTps;
  25. creer_soumission.subform().get("total_tvq") = totalTvq;
  26. creer_soumission.subform().get("sous_total") = grandTotal;
  27. }
This code give an error :


The original script in all script in my app is :
  1. // Initialiser les totaux globaux avec leurs valeurs respectives, utilisation de la fonction personnalisée CheckFieldsIfNull
  2. totalPrixMateriauxGlobal = thisapp.CheckFieldsIfNull(input.total_list_prix_materiaux);
  3. totalPrixFinitionGlobal = thisapp.CheckFieldsIfNull(input.total_list_prix_fintion);
  4. totalPrixQuincaillerieGlobal = thisapp.CheckFieldsIfNull(input.total_list_prix_quincaillerie);
  5. totalPrixFraisSuppGlobal = thisapp.CheckFieldsIfNull(input.total_list_prix_frais_supp);
  6. totalAvantTaxes = thisapp.CheckFieldsIfNull(input.Sous_total_avant_taxes);
  7. totalTps = thisapp.CheckFieldsIfNull(input.total_tps);
  8. totalTvq = thisapp.CheckFieldsIfNull(input.total_tvq);
  9. grandTotal = thisapp.CheckFieldsIfNull(input.sous_total);

  10. // Soustraire le prix total de la ligne supprimée au prix total du sous-formulaire
  11. totalPrixFraisSuppGlobal = totalPrixFraisSuppGlobal - row.total_prix_frais_supp;

  12. // Mettre à jour les totaux globaux
  13. totalAvantTaxes = totalPrixFinitionGlobal + totalPrixMateriauxGlobal + totalPrixQuincaillerieGlobal + totalPrixFraisSuppGlobal;
  14. totalTps = thisapp.CalculateTax(totalAvantTaxes,input.tps_taxe);
  15. totalTvq = thisapp.CalculateTax(totalAvantTaxes,input.tvq_taxe);
  16. grandTotal = totalAvantTaxes + totalTps + totalTvq;

  17. // Mettre à jour les inputs
  18. input.total_list_prix_materiaux = totalPrixMateriauxGlobal;
  19. input.total_list_prix_fintion = totalPrixFinitionGlobal;
  20. input.total_list_prix_quincaillerie = totalPrixQuincaillerieGlobal;
  21. input.total_list_prix_frais_supp = totalPrixFraisSuppGlobal;
  22. input.Sous_total_avant_taxes = totalAvantTaxes;
  23. input.total_tps = totalTps;
  24. input.total_tvq = totalTvq;
  25. input.sous_total = grandTotal;

Thank you all :)
    • Recent Topics

    • Slow uploads of large files

      I'm wanting to use Workdrive for transferring large images and video (we're talking things from 100MB-5GB). I'm running solo on a 500MBit/sec fiber connection. I'm getting upload speeds to Workdrive of no more than about 1-3Mbytes/sec when going through
    • Notes of Tasks in Zoho CRM

      Hello, Is there a way to filter the Notes that appear on a Task to only show the notes related to that specific Task and not display all the Notes of the objects related to that Task (Accounts, Contacts, Deal, etc). In essence, our team struggles to understand
    • Migrate Your Notes from OneNote to Zoho Notebook Today

      Greetings Notebook Users, We’re excited to introduce a powerful new feature that lets you migrate your notes from Microsoft OneNote to Zoho Notebook—making your transition faster and more seamless than ever. ✨ What’s New One-click migration: Easily import
    • need to upload from airtable to google drive

      I have a zapier zap that automates between airtable and google drive. When a customer uploads a new file into airtable via a client portal interface, zapier uploads that file into a folder linked to that customer's project record. I need to replicate
    • Can't delete functions that are associated with deleted workflow rules

      We have a handful of functions that were once associated with a workflow rule, but the rule has been deleted. The function still thinks it is associated so I can't assign it to a new rule. It is starting to get really messy because we have a list of functions
    • Default Sorting on Related Lists

      Is it possible to set the default sorting options on the related lists. For example on the Contact Details view I have related lists for activities, emails, products cases, notes etc... currently: Activities 'created date' newest first Emails - 'created
    • Credit Management: #1 Credit You Owe vs Credits Owed to the Business

      Think about the last time you ordered food online. You might have paid in advance through your card, but you received a $20 refund because your order got delayed or cancelled. In most apps, refunds don't go into the bank account directly; instead, they're
    • Tip #46- Turn Every Session into an Insight with Zoho Assist survey report- 'Insider Insights'

      Delivering exceptional remote support isn’t just about resolving issues, it’s about understanding how both customers and technicians experience each session. That’s where Survey Report in Zoho Assist come in. You can configure and customize survey questions
    • Enhancing Zia's service with better contextual responses and article generation

      Hello everyone, We are enhancing Zia's Generative AI service to make your support experience smarter. Here's how: Increased accuracy with Qwen One of the key challenges in AI is delivering responses that are both contextually accurate and empathetic while
    • Allow the usage of Multi-Select fields as the primary field on "Layout Rules"

      We want to force our users to enter some explanation strings when a multi-select field has been utilized. I can't understand the reason for the usage restriction of Multi-Select fields as a primary field. This is a simple "Display hidden mandatory field
    • CRM/Bookings integration edits Contact names

      Hi there, I've installed the extension that connects Zoho CRM and Zoho Bookings. When we get a new appointment from Bookings from an existing Contact, that Contact's record shows this: First Name was updated from asd to blank value Last Name was updated
    • Domain Change

      “Please update my Email-in domain from @biginmail.biginmail.in to @biginmail.zoho.com. Messages to the .in domain are bouncing.”
    • Webhooks Limit Exceeded

      Today, I received an error message saying, 'Total number of Webhook call exceeded', but when I look at Manage > Billing, it doesn't look like any of my invokeURL calls are being logged. Following the advice from this thread: https://help.zoho.com/portal/en/community/topic/webhooks-daily-limits-in-zoho-creator
    • Option to block bookings from specific email address or ip adresss in zoho booking

      Sometime few of our client keep booking irrelevant booking service just to resolve their queries and they keep booking it again and again whenever they have queries. Currently its disturbing our current communication process and hierarchy which we have
    • Auto select option in CRM after Zoho Form merge

      Hi, I have a dropdown field in Zoho CRM that is filled with a Zoho Form. The data is filled but not automatically shown. After selecting the right value in the dropdown the information a second field is shown. So the question is; how can I make the dropdown
    • スマホでキャンペンメールを見ると正しく表示されない

      キャンペーンのメール(HTML)を作成しましたが、スマホ表示に切り替えると正しく表示されません(添付参照)過去に作成したキャンペーンでは特に意識してませんでしたが、問題なく表示されていたようです。うまく表示される場合とされない場合の違いは何でしょうか?
    • Bring your CRM data straight into your presentations in Zoho Show

      Let's say you are working on a presentation about your team's sales pipeline for an upcoming strategy meeting. All the information you need about clients and leads is in Zoho CRM, but you end up copying details from the CRM into your slides, adjusting
    • Improved RingCentral Integration

      We’d like to request an enhancement to the current RingCentral integration with Zoho. RingCentral now automatically generates call transcripts and AI-based call summaries (AI Notes) for each call, which are extremely helpful for support and sales teams.
    • Introducing New APIs in Zoho Contracts

      We are excited to announce the release of new APIs in Zoho Contracts to help you automate and manage every stage of your contract lifecycle more efficiently. Here’s a quick overview of what’s new: 1. Complete Contract Draft You can use this API to complete
    • Vimeo

      For me Vimeo is the most important video social channel for media and filmmakers. Would others agree and like it added to Zoho Social.
    • Delete a department or category

      How do I delete a Department? Also, how do I delete a Category? This is pretty basic stuff here and it's impossible to find.
    • Organization Emails in Email History

      How can I make received Org Emails to show up here?
    • Editing the Ticket Properties column

      This is going to sound like a dumb question, but I cannot figure out how to configure/edit the sections (and their fields) in this column: For example, we have a custom "Resolution" field, which parked itself in the "Ticket Information" section of this
    • Deleting Fields in CRM Deletes Views in Analytics

      Hey friends! I'm having some issues when we modify some fields within ZohoCRM. There are times where we need to sunset a field and eventually completely remove it. In these instances, it seems like a lot of views are removed in Analytics. This ranges
    • Zoho Analytics Automatically Deletes Queries and Reports When a Synced CRM Field Is Removed

      We’ve encountered a serious and recurring issue that poses a massive data integrity risk for any Zoho Analytics customer using Zoho CRM integration. When a field is deleted in Zoho CRM — even an unused one — Zoho Analytics automatically deletes every
    • How to setup pricing in Zoho

      Hi everyone, I am relatively new here and have just moved from my old inventory system to the Zoho one. I am trying to get my head around how it all works. I am mostly setup connected to a shopify store, but I do manual sales also For manual invoicing,
    • Prefilled Date fields auto-changed and then locked when using “Edit as new”

      If a document out for signature has date fields (not SignedDate fields) that were pre-filled before sending, and then you use “Edit as new” to create a new version of the same document, the value of those date fields gets automatically changed to today
    • Is there a way to update all the start and end dates of tasks of a project after a calendar change?

      Hi! Here's my situation. I've built a complete project planning. All its tasks have start dates and due dates. After completing the planning, I've realized that the project calendar was not the right one. So I changed the project calendar. I now have
    • Access Phone Field Components (Country Code) Directly

      Hello everyone, I'd like to propose an enhancement for the Phone field in Zoho Creator. The Problem: The Phone field captures the country code and local number separately, but stores them as a single string (e.g., +1234567890). To get the country code,
    • Send mass messages through WhatsApp from the Tickets module

      Hi Everyone! Effective communication is key to delivering prompt and reliable customer support. Because WhatsApp is one of the most widely used and familiar messaging platforms, it's an effective channel for agents to reach customers who have submitted
    • The difference between Zoho Marketing Automation and Zoho Campaigns

      Greetings Marketers! This post aims to differentiate between Zoho Marketing Automation and Zoho Campaigns. By the time you get to the end of the post, you will be able to choose a product that objectively suits you. What is Zoho Marketing Automation?
    • Lead Owner Signature Merge Field

      I want to automatically insert a signature (i.e. contact info usually found at the bottom of an email) into an email template, depending on who the lead owner is. What is the merge code for the Signature from a Users profile? CRM > Settings > Customization > Templates There is a popup near the bottom of the edit screen which says: "You can insert a Signature, which is available as a merge field in the users section." It is also referenced on this page: https://help.zoho.com/portal/en/kb/crm/customize-crm-account/customizing-templates/articles/template-builder#Merge_Fields
    • How do I create a time field?

      I want a field that only records time. I can only see how to create a date-time field. If I do that and enter a time, without a date, nothing is recorded. If I create a number or decimal field, I cannot use it in time calculations. All I want is a field
    • Experience effortless record management in CRM For Everyone with the all-new Grid View!

      Hello Everyone, Hope you are well! As part of our ongoing series of feature announcements for Zoho CRM For Everyone, we’re excited to bring you another type of module view : Grid View. In addition to Kanban view, List view, Canvas view, Chart view and
    • Alternating columns - How to reverse order on mobile - Responsive template

      Can the order of alternating columns be reversed on mobile so that image comes before the text? Example: Desktop Row 1 column Left (image) , column right (text) Row 2 column Left (text) , column right (image) Mobile Currently Row 1 Image over text Row
    • Let us view and export the full price books data from CRM

      I quote out of CRM, some of my clients have specialised pricing for specific products - therefore we use Price Books to manage these special prices. I can only see the breakdown of the products listed in the price book and the specialised pricing for
    • InvokeURL butchering JSON for OpenAI API calls

      My organization works with mostly educational institutions. We have a custom module called "Schools", which is the user-entered school name they put when using our service (which they enter along with their state and zip code). We want to map this to
    • CRM for email in Outlook: how to ignore addresses?

      We’re using the "Zoho CRM for email" add-in for Outlook. When opening an email, the add-in displays all email addresses from the message and allows me to add them to the CRM or shows if they’re already contacts. However, sometimes people listed in To
    • Custom order for Current Stage (Blueprint field)

      Hi! I suggest adding the option to set a custom order in reports for the Blueprint field ‘Current Stage’. Currently, these fields can only be sorted in ascending or descending order. Thanks!
    • CRM E-mail Sync from Outlook

      We are exploring Zoho as a possible new solution for our company. We are trying to understand further on how e-mail sync works. We use outlook. Our current CRM logs anytime we e-mail a customer so we can see in the CRM the message sent to the customer.
    • Next Page