Hello everyone!
Welcome back to another interesting post. In this post, let us see how you can render Widgets using Client Script.
Widgets are 
embeddable UI components that you can create and add to your Zoho CRM. You can use widgets to perform functions that utilize data from 
third-party applications. You can build widgets for Zoho CRM using our 
JS SDK. 
You can render a Widget through 
Client Script and pass data from the Widget to the Client Script.
Use Case:
At Zylker, a manufacturing company, the Service Agent places orders using the Orders module.  There is a sub-form named Product list. The user should add the products by clicking the "Add row" button every time. 

To avoid this, Zylker wants the users to select multiple products from a single pop-up. Once the user selects the products from that pop-up , the sub-form "Product list" should get updated with all those products(one product in one sub-form row).
Solution:
Whenever the user picks the Product Category, you can create a Client Script to render the widget. The Products selected by the user on the widget , will be passed to the Client Script and will be added as separate rows in  Product list subform.
 
1. Install Zoho CLI and add code to the app folder.
2. Upload the zip file as a Widget.
3. Create a Client Script to render the Widget and to add data to the Sub-form.
1.  Install Zoho CLI and add code to the app folder 
Follow the steps given in this 
post and add the 
html code, javascript file and css file.
Index.html
| 
 <!DOCTYPE html> <html> <head>   <meta charset="utf-8">   <meta name="viewport" content="width=device-width">   <title>Choose products</title>   <link href="styles/style.css" rel="stylesheet" type="text/css" /> </head> <body>   <div class="wgt_cp_popupContent">     <section class="wgt_cp_contentWrap">       <div hidden="true" id="noProductDiv">         <pre>No products associated to the selected deal</pre>       </div>       <table width="100%" cellspacing="0" id="pTable">         <thead>           <tr class="wgt_productTblHead">             <th><input type="checkbox" id="selectAll"     onclick="selectAllProducts(this)"></th>             <th>Product Name</th>             <th>Product Category</th>             <th>Unit Price</th>             <th>Quantity in Stock</th>           </tr>         </thead>         <tbody id="tbody"></tbody>       </table>     </section>   </div>   <script src="./script/script.js"></script> </body> </html> | 
Script.js
| var count = 0; var productData, maxRows = 0; ZOHO.embeddedApp.on("PageLoad", async function (data) {  console.log("data from Client Script", data);  maxRows = data.max_rows;  const search_response = await ZOHO.CRM.API.searchRecord({ Entity: "Products", Type: "criteria", Query: "(Product_Category:equals:" + data.product_category + ")" })  if (search_response && search_response.data && search_response.data.length) {   productData = search_response.data;   var htmlString = "";   productData.forEach(({ id, Product_Category, Product_Name, Unit_Price, Qty_in_Stock }) => {    htmlString = htmlString.concat(     `<tr>      <td><input type='checkbox' onclick='selected(this)' id='${id}' class='products'></td>      <td>${Product_Name}</td>      <td>${Product_Category}</td>      <td>${Unit_Price}</td>      <td>${Qty_in_Stock}</td>     </tr>`    );   });   document.getElementById("tbody").innerHTML = htmlString;  } else {   document.getElementById("pTable").hidden = true;   document.getElementById("noProductDiv").hidden = false;} }); ZOHO.embeddedApp.init(); function selected(element) {  element.checked ? count++ : count-- ;  document.getElementById("selectedCount").innerHTML = `${count} Products selected`; } function closewidget() {  if (count > maxRows) {   alert("Selected product is greater than the maximum subform rows.");  } else {   var selected_products = [];   for (product_element of document.getElementsByClassName('products')) {    product_element.checked && selected_products.push(productData.find(product => product.id === product_element.id));}   console.log("returning to Client Script ...", JSON.stringify(selected_products));   $Client.close(selected_products);} } | 
As per the above script, the products are fetched from the "Products" module based on the "Product Category" selected by the user. This information is captured in "search_response" and is added to the body of  widget.html. 
Here,  the code 
$Client.close(selected_products); will pass the selected products from Widget to the Client Script and close the widget rendered from Client Script. 
Click here for more details about the variable $Client.
Next step is to upload the zip file of the app folder.
2. Upload the zip file as a Widget
- Go to Setup > Developer Space > Widgets.
- Click Create New Widget.
 
- The Hosting should be "Zoho" and mention the html page of the app folder that you uploaded.
 
Note: The widget should be of "button" type in order to render through a Client Script.
3. Create a Client Script to render Widget and to add data to the subform
- Go to Setup > Developer Space > Client Script. Click +New Script.
- Specify the details to create a script and click Next.
- The Client Script should render the Widget when the user selects Product Category. So Client Script should have field event on the field "Product Category".
- On the Client Script IDE, you can see the below details.
- Enter the following script in the Client Script IDE and click save.
 
| var products_list = ZDK.Page.getField('Product_list').getValue(); if (products_list.length === 1) { // Clear subform if empty row     !Object.values(products_list[0]).every(value => !!value) && products_list.pop(); } // Open widget with product category & max. allowed rows based on existing subform data var selected_products = ZDK.Client.openPopup({     api_name: 'choose_products', type: 'widget', header: 'Choose Products', animation_type: 1, height: '570px', width: '1359px', left: '150px' }, {     product_category: value, max_rows: 25 - products_list.length }); // Update subform with Selected Products from the widget Popup if (selected_products.length) {     selected_products.forEach(product => {         products_list.push({ Product_Name: { id: product.id, name: product.Product_Name }, Quantity: 1, Unit_Price: product.Unit_Price });     });   ZDK.Page.getField('Product_list').setValue(products_list); }
 | 
- To render a widget from Client Script, use openPopup(config, data)  ZDK. You can specify the configuration details like api name of the widget, title, size, animation type as parameters and specify the data to be passed as 'PageLoad' event data in the Widget. 
- The response from the widget (i.e user selection) is captured by the variable "selected_products". Then each product (id,name,product_name,quantity and unit_price) is pushed to the list products_list. Finally, the product list value  is updated to the Product Category sub-form using setValue(value) ZDK. 
- Here is how the Widget gets rendered through Client Script.
 
We hope you found this post useful. We will meet you next week with another interesting topic! If you have any questions let us know in the comment section.
Click here for more details on Client Script in Zoho CRM.
 
As we approach the 
100th post in our Kaizen series next week, 
we invite you to share your queries and concerns with us.  We are always looking for ways to improve our content and make it more relevant to our readers.
Please fill out this 
form to share your thoughts.
Happy Coding!
- Recent Topics
- How to get the call recording external ID via desk API- I have enabled phonbridge integration with Zoom Call. I am trying to access the call recording in Zoom by calling Zoom API. I have built a Desk workflow to trigger on a new call, to call a custom function. when calling the API, the response doesn't contain 
- Can't View Project Names in Mobile App- I can't view project names on PO's in the app, nor can I add that as a viewable PDF field in inventory on the computer. I've attached screenshots showing that in the mobile version whether you are on the PO, editing the PO, or viewing the PO line items, 
- How do you print a refund check to customer?- Maybe this is a dumb question, but how does anyone print a refund check to a customer? We cant find anywhere to either just print a check and pick a customer, or where to do so from a credit note. 
- Notebook- I have purchased the monthly pro subscription of Notebook. But it does not support my XP-Pen to write something in it. So it is not useful to me. Hence I am requesting you to help me to discontinue this subscription. 
- Domain Mapping & Image Publishing Issues on Zoho Sites- Hello, I am facing two issues with my Zoho Sites account: 1. Images not visible after publishing. 2. Domain mapping error: "Domain already exists". I am a paid customer. Please connect me with Live Chat Support or Zoho Assist so I can show my issue  
- Prevent duplicate with custom fields?- I was wondering something about custom field/custom modules in Zoho Desk. For some reason you can make a custom field mandatory but not unique? For example, if I create a custom module to manage equipment and renewal and make a field serial number no 
- Generate leads from instagram- hello i have question. If connect instagram using zoho social, it is possible to get lead from instagram? example if someone send me direct message or comment on my post and then they generate to lead 
- Where is the desktop app for Zoho Projects???- As a project manager, I need a desktop app for the projects I manage. Yes, there's the web app, which is AWESOME for cross browser and platform compatibility... but I need a real desktop app for Projects that allow me to enter offline information where 
- How to Automate Monthly PDF Reports with Filters in Zoho Creator- Hi everyone, I’m trying to build an automated monthly reporting process in Zoho Creator and would appreciate suggestions or best practices from anyone who has done something similar. What I’m trying to do: I have a form called New_Customer with fields 
- Feedback: Streamlining Note Management in Zoho Notebook- Dear Team/Support, I would like to share some feedback regarding the note management system that could help improve usability and accessibility for users like myself. Notebook 1 (screenshot attached): Currently, the system does not allow selecting and 
- showing Limit exceeded- Good afternoon...trust you're good. I've been having issues working with but it's not responding. it's showing Limit exceeded, sorry it seems like too many people are working on the sheet right now please try again later. meanwhile no one is working on 
- Sorting columns in Zoho Projects- Hi, In project management best practice, sorting columns (ascending, descending) is an important tool. Sorting dates to see the order of tasks starting, sorting on priority or even on planned hours is a must for an efficient project control. Currently, 
- Upload API- I'm trying to use the Upload API to upload some images and attach them to comments (https://desk.zoho.com/DeskAPIDocument#Uploads#Uploads_Uploadfile) - however I can only ever get a 401 or bad request back. I'm using an OAuth token with the Desk.tickets.ALL 
- Losing description after merging tickets- Hello, We merge tickets when they are about the same topic from the same client. It happens sometimes. We recently noticed that after the merger only the description from the master ticket is left in a thread. And the slave-ticket description is erased. 
- update linked contacts when update happens in account- Hi, I have a custom field called Licence in the Accounts module. When someone buys a licence, I’d like to update a custom field in the related Contacts. How can I achieve this? I noticed that workflows triggered on Accounts only allow me to update fields 
- Problem Management Module- I am looking for a Problem Management module within Zoho Desk. I saw in some training videos that this is available, and some even provided an annual price for it. I want an official confirmation on whether this is indeed available. This is not a particularly 
- Unable to explore desk.zoho.com- Greetings, I have an account with zoho which already has a survey subscription. I would like to explore desk.zoho.com, but when I visit it while logged in (https://desk.zoho.com/agent?action=CreatePortal) I just get a blank page. I have tried different 
- Offline support for mobile app- Accessing your files and folders from your mobile devices is now quicker and simpler, thanks to the power of offline support. Whether on an Android or iOS device, you can use the Offline function to save files and folders, so you can review them even 
- Zoho Desk KB article embedded on another site.- We embed KB articles from Zoho Desk on another site (our application). When opening the article in a new tab, there is no issue, but if we choose lightbox, we are getting an error "To protect your security, help.ourdomain.com will not allow Firefox to 
- List of packaged components and if they are upgradable- Hello, In reference to the article Components and Packaging in Zoho Vertical Studio, can you provide an overview of what these are. Can you also please provide a list of of components that are considered Packaged and also whether they are Upgradable? 
- Does Attari Messaging app have Bot option and APIB- Hi, Does Attari also have Bot and API as we use in WhatsApp?? 
- How to add application logo- I'm creating an application which i do not want it to show my organization logo so i have changed the setting but i cannot find where to upload/select the logo i wish to use for my application. I have seen something online about using Deluge and writing 
- Zoho Analytics Regex Support- When can we expect full regex support in Zoho Analytics SQL such as REGEXP_REPLACE? Sometimes I need to clean the data and using regex functions is the easiest way to achieve this. 
- Change of Blog Author- Hi, I am creating the blog post on behalf of my colleague. When I publish the post, it is showing my name as author of the post which is not intended and needs to be changed to my colleague's name. How can I change the name of the author in the blogs?? Thanks, Ramanan 
- how to differentiate if whatsapp comes from certain landing page?- I create a Zobot in SalesIQ to create a Whatsapp bot to capture the lead. I have 2 landing pages, one is SEO optimized and the other want is optimized for leads comes from Google Ads. I want to know from which landing page this lead came through WhatsApp 
- How to record company set up fees?- Hi all, We are starting out our company in Australia and would appreciate any help with setting up Books accounts. We paid an accountant to do company registration, TFN, company constitution, etc. I heard these all can be recorded as Incorporation Costs, which is an intangible asset account, and amortised over 5 years. Is this the correct way to do it under the current Australian tax regulations? How and when exactly should I record the initial entry and each year's amortasation in Books? Generally 
- Show Payment terms in Estimates- Hi,  we are trying to set up that estimates automatically relates payment terms for the payment terms we introduced on Edit contact (Field Payment terms).  How can it be done? Our aim is to avoid problems on payment terms introduced and do not need to introduce it manually on each client (for the moment we are introducing this information on Terms and Conditions.  Kind Regards,  
- How can I calculate the physical stock available for sale?- Hey Zoho Team,  I've tried to calculate the physical stock on hand in various ways - but always receive a mismatch between what's displayed in Zoho Inventory & analytics.  Can you please let me know how the physical stock available for sale is calculated? 
- When dispatched to crew, assigning lead missing - Hello, For the past two or three weeks, whenever an officer assigns Service Appointment to a team, the lead person is missing from the assigned service list. Therefore, we have to reschedule the SA and then the lead person becomes visible in the assigned 
- I want to transfer the project created in this account to another account- Dear Sir I want to transfer the project created in one account to another account 
- Weekly Tips : Customize your Compose for a smoother workflow- You are someone who sends a lot of emails, but half the sections in the composer just get in your way — like fields you never use or sections that clutter the space. You find yourself always hunting for the same few formatting tools, and the layout just 
- Custom Bulk Select Button- Zoho CRM offers the ability to select multiple records and invoke a Custom Button This functionality is missing from Recruit Currently we can only add buttons in the detail page and list But we cannot select Multiple Records and invoke a function with 
- Power of Automation :: Smart Ticket Management Between Zoho Desk and Projects- Hello Everyone, A custom function is a software code that can be used to automate a process and this allows you to automate a notification, call a webhook, or perform logic immediately after a workflow rule is triggered. This feature helps to automate 
- Need to set workflow or journey wait time (time delay) in minutes, not hours- Minimum wait time for both Campaigns workflows and Marketing Automation journeys is one hour. I need one or the other to be set to several minutes (fraction of the hour). I tried to solve this by entering a fraction but the wait time data type is an integer 
- BUG - Google Business Buttons - Add a button to GBP Post- I am experiencing an issue with the "Add a button" feature when creating posts for my Google Business Profile (GBP) through Zoho Social. When I schedule or publish a GBP post and include a call-to-action button with a specific URL, the post itself publishes 
- Do you have software like Windows software?- We want swadeshi software 
- Support for Custom Fonts in Zoho Recruit Career Site and Candidate Portal- Dear Zoho Recruit Team, I hope you're doing well. We would like to request the ability to use custom fonts in the Zoho Recruit Career Site and Candidate Portal. Currently only the default fonts (Roboto, Lato, and Montserrat) are available. While these 
- Trying to export a report to Excel via a deluge script- I have this code from other posts but it gives me an error of improper statement, due to missing ; at end of line or incomplete expression. Tried lots of variations to no avail. openUrl(https://creatorapp.zoho.com/<username>/<app name>/XLSX/#Report:<reportname>,"same 
- Need help to create a attach file api- https://www.zoho.com/crm/developer/docs/api/v8/upload-attachment.html Please help me to create it... It's not working for while. Do you have some example? 
- Export view via deluge.- Hi, Is it possible to export a view (as a spreadsheet) via deluge? I would like to be able to export a view as a spreadsheet when a user clicks a button. Thanks      
- Next Page