Hello everyone! 
Welcome back to another exciting edition of our Kaizen series, where we explore fresh insights and innovative ideas to help you discover more and expand your knowledge!In this post, we'll walk through how to display Flyouts in Client Script and break down the key differences between Flyouts and pop-ups in Client Script, including when to use each one.
In this Kaizen post, 
1. What are Flyouts in Client Script?
2. Flyout- ZDKs and functions in Client Script
3. Use Case
4. Solution
        4.a. Create a Widget for EMI Calculator.
        4.b. Create a Client Script to render the Widget as Flyout.
5. Difference between flyout and popup in Client Script
6. Summary
7. Related links
1. What are Flyouts in Client Script?
Flyouts are 
floating User Interface that can be moved around and controlled using Client Script. 
Widgets can be used to render a flyout. The flyout can 
run independently, and any Client Script can communicate with it. 
2. Flyout- ZDKs and functions in Client Script :
- createFlyout(name, config) - Creates a flyout. You can specify the heading, dimensions, and animation type using the config parameter.
- getFlyout(name) - To Fetch the details of a flyout.
- open(config, data) - Opens the created flyout.
- notify(data, options) - Notifies and waits for data in a flyout. The options can be wait: true (Client Script execution will wait for a response from the widget) or wait: false - (Client Script execution will not wait for a response from the widget)
- close() - Closes the active flyout.
 
Click here for more details about the ZDKs and functions related to flyouts.
 
3. Use Case :
Sales Advisors in a Finance Consulting Company regularly rely on an EMI calculator to help customers with loan queries. To improve their efficiency and eliminate the need to switch between different windows, the admin manager intends to integrate the calculator directly into CRM. The EMI calculator should appear on the Create Page of the Loans module and remain active until the user closes it.
4. Solution: 
To achieve this in Zoho CRM, we can use 
Widgets to create an EMI calculator and render them using flyouts in client script whenever the create Page of 
Loan page loads.
4.a. Create a Widget for EMI Calculator
Install Zoho CLI, and follow the steps given in this 
document to create the Widget app folder. Then update the html, javascript, and css code as per your requirement.
index.html
- <!DOCTYPE html>
- <html lang="en">
-   <head>
-     <meta charset="UTF-8" />
-     <meta http-equiv="X-UA-Compatible" content="IE=edge" />
-     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-     <title>Document</title>
-     <link rel="stylesheet" href="style.css" />
-   </head>
-   <body>
-     <div class="loan-calculator">
-       <div class="top">
-         <h2>EMI Calculator</h2>
-         <form action="#">
-           <div class="group">
-             <div class="title">Amount</div>
-             <input type="range" min="1000" value="30000" max="50000" step="500" class="loan-amount" id="loanAmount" />
-             <div class="slider-label">$<span id="loanAmountValue"></span></div>
-           </div>
-           <div class="group">
-             <div class="title">Interest Rate</div>
-             <input type="range" min="5" value="6" max="100" step="1" class="interest-rate" id="interesRate" />
-             <div class="slider-label"><span id="interesRateValue"></span></div>
-           </div>
-           <div class="group">
-             <div class="title">Tenure (in months)</div>
-             <input type="range" min="6" max="100" step="1" value="12" class="loan-tenure" id="tenureMonth" />
-             <div class="slider-label"><span id="tenureMonthValue"></span></div>
-           </div>
-         </form>
-       </div>
-       <div class="result">
-         <div class="left">
-           <div class="loan-emi">
-             <h3>Loan EMI</h3>
-             <div class="value">123</div>
-           </div>
-           <div class="total-interest">
-             <h3>Total Interest Payable</h3>
-             <div class="value">1234</div>
-           </div>
-           <div class="total-amount">
-             <h3>Total Amount</h3>
-             <div class="value">12345</div>
-         <div class="right">
-           <canvas id="myChart" width="400" height="400"></canvas>
-         </div>
-       </div>
-     </div>
-     <script src="https://cdn.jsdelivr.net/npm/chart.js@3.6.2/dist/chart.min.js"></script>
-     <script src="https://live.zwidgets.com/js-sdk/1.2/ZohoEmbededAppSDK.min.js"></script>
-     <script src="main.js"></script>
-   </body>
- </html>
- Click here to view the complete code.
- Once you have added the code, upload the zip file by following the below steps.
- Go to Setup > Developer Space > Widgets.
- Click Create New Widget and Fill in the details.
 
  
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.
4.b. Create a Client Script to render the Widget as Flyout
Configure a Client Script for 
Create Page(Standard) Loans module, that triggers during onLoad event as shown below. Click 
Next. 
Click here to know how to configure a Client Script.
Enter the following script and click Save.
- ZDK.Client.createFlyout('EMIFlyout', {
-     header: 'EMI Calculator',
-     animation_type: 1,
-     height: '400px',
-     width: '450px',
-     close_on_exit: false
- });
 
- ZDK.Client.getFlyout('EMIlyout').open(
-     { api_name: 'EMI_CALCULATOR_WIDGET', type: 'widget' },
-     { data: loanDetails }
- );
In the above script, createFlyout() will create a new flyout with header.
Below is the syntax and parameter detail.
Now Open the flyout and render the Widget in the flyout using open() method and specify the api_name of the widget.
Here is how the Client Script renders the flyout.

5. Difference between flyout and popup in Client Script
| Flyout | Pop up | 
| A flyout can be moved around the page.
 
 | A pop-up cannot be moved anywhere on the page.
 
 | 
| It can run independently in a separate thread. The user can interact with the background interface without closing the flyout.
 
 
 | The user cannot interact with the background without closing the flyout. | 
| Use flyouts, when you need to exchange data to and fro between a Widget and Client Script. You can use ZDK.Client.sendResponse() to pass data from a widget rendered as a flyout to the Client Script.
 
 
 | Use popup, when you need to interrupt the screen to gather input from the user or display a message before proceeding. Use $Client.close() to pass data to the Client Script, which will also close the popup.
 
 
 | 
In the scenario discussed in this post, if you want to make it mandatory for the user to read or interact with the EMI Calculator before entering any value in the create Page(Standard), then you can use pop-up instead of Flyout. Both pop up and flyout can be used to display widgets, and their dimensions can be altered.
Refer to 
this post to know how to render widgets as pop up using Client Script.
6. Summary
- In this post, we have seen,
- Flyouts in Zoho CRM.
- ZDKs and methods to render a Flyout(Widget) using Client Script.
- When to use a Flyout and when to use a pop up.
- Recent Topics
- Connecting two modules - phone number- Hi, I’d like some guidance on setting up an automation in Zoho CRM that links records between the Leads module and a custom module called Customer_Records whenever the phone numbers match. Here’s what I’m trying to achieve: When a new Lead is created 
- Zoho Marketing Automation 2.0 - Landing Page function not working- Dear Zoho Team, I am working on implementing Zoho Marketing Automation 2.0, and am now looking into the section "Lead Generation". If I open the "Landing Pages" section, I immediately get an Error code: Error: internal error occurred. Can you help me 
- Unable to use Sign "You have entereed some invalid characters"- Unable to use Sign "You have entered some invalid characters" I do not see any invalid characters. The text in "Leave a Note" is plain text which I entered directly into the field. See attached screenshot 
- Elevate your CX delivery using CommandCenter 2.0: Simplified builder; seamless orchestration- Most businesses want to create memorable customer experiences—but they often find it hard to keep them smooth, especially as they grow. To achieve a state of flow across their processes, teams often stitch together a series of automations using Workflow 
- Messages not displayed from personal LinkedIn profile- Hello. I connected both our company profile and my personal profile to Zoho social. I do see all messages from our company page but none from my private page. not even the profile is being added on top to to switch between company or private profile, 
- "Performed changes in the query is not allowed due to following reason" when adding columns or reordering data- I'm trying to make changes to a query but every time i try to save it i get this error message. I'm not touching the data it's flagging. All I've tried to do is reorder a couple of fields and add a new one. Why won't it let me do this? It's a core query 
- Onboard new users easily with native screen recording in Zoho Projects Plus- Communication involving both visual and audio elements tends to capture more interest among the audience. Whenever we onboard new employees to the organization, the task of engaging them in the induction sessions, and keeping the spark going in their 
- Request to Add Support for PDF Templates and More Flexibility in Email Editor- Hi Zoho Campaigns Team, I hope you're doing well. I wanted to share some feedback and request a few improvements in the Email Template feature of Zoho Campaigns. Right now, we can create email templates using the HTML editor, which is helpful. But we’re 
- Can you stop Custom View Cadences from un-enrolling leads?- I'm testing Cadences for lead nurture. I have set un-enroll properties to trigger on email bounce/unsubscribe, and do NOT have a view criteria un-enroll trigger. However, help documents say that emails are automatically un-enrolled from a Cadence when 
- Zoho Desk Android and iOS app update: Agent detail overview- Hello everyone! We’ve introduced agent detail overview on the Zoho Desk Android and iOS app update. With this feature, you can get a complete view of agent’s tickets, response times, logged hours (for both tickets and activities), customer happiness ratings 
- Blog Widget: Show recent blog posts on my homepage- Hey there I am using the Zoho Sites Blog feature. On my homepage, on the bottom I'd like to have a featured content section where I show some of my blog posts (selected, most recent, filtered by category and so on...). It would be nice to have a blog 
- YouTube Live #2: Agreement Intelligence with Zoho Sign's eSign AI assistant- Hi there, We're back again with our YouTube live series and this time, we'll take you through our holistic agreement intelligence powered signature workflows. Struggling to draft an agreement? Need help double-checking clauses and going through complicated 
- How to iterate through excel data using zoho rpa- I wanted to iterate or loop through excel data ( datatable). How can i do that 
- Zoho Commerce- Hi, I have zoho one and use Zoho Books. I am very interested in Zoho Commerce , especially with how all is integrated but have a question. I do not want my store to show prices for customers that are not log in. Is there a way to hide the prices if not 
- Mass (Pull back) (Close WOs) (Close APs)- Hi develop team. Just idea because Zoho FSM is great but its too manual. we have a lot of task to do every day and the system needs to have more features to automatic our tasks. I need to close several WOs, APs and Pull Back per day. Please we need mass 
- Customising Zohidesk portal default widgets- Hello, I'm wondering how could I customise the default widgets such as "popular topics", "popular articles" using CSS or to make the tiles at the bottom match the ones that I made in the picture attached. I have made some custom widgets and edited them 
- If there’s a batch at the end, the ‘mark as inactive’ function doesn’t work.- when my batch has a date to batch end and I "mark as inactive" he batch does not obey the status and reactivates the batch. 
- Seamless multilingual messaging and tone control in Zia IM Composer- Hello everyone! Managing customer conversations across multiple languages can be time-consuming. Using Zia in the Instant Messaging (IM) Composer helps you overcome this by providing tools to translate content, adjust your tone, and refine your messages 
- Advanced Deluge help needed with custom function and COQL limits- I have a scheduled function that takes a snapshot of specific metrics and saves them to a custom module. However I'm struggling with the limits of COQL. I attach my full code, but an example of the issues I'm having is that it's erroring with a 'Limit 
- Tip of the Week - Conditional Formatting Chart- Conditional formatting allows you to highlight your data series based on a pattern or a trend in your data. This makes it easy for you to identify when your data reaches certain values or when it deviates from the trend.  Zoho Analytics allows you to 
- Zoho Learn - AI Translate- Hi Learn team, I had a situation today where I was providing training to a client team and I had written articles into their Zoho Learn to support their learning. I realised that one of the team members was a non-native English speaker and they were struggling 
- Payroll In Canada- Hi, When can we expect to have payroll in Canada with books  
- Power of Automation :: Auto-Sync Custom Date Field Between Related Tasks via Blueprint Transition- 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 
- Introducing auto-upgrade in Zoho LandingPage- Hi everyone, We’re excited to share an upcoming update to help you get the most out of your landing pages — the auto-upgrade option, launching on October 22, 2025. Your landing pages are designed to bring in leads, and we want to make sure you never miss 
- Workdrive comment links stopped working.- I have marked a PDF file with 95 comments, they have worked for a while. When i clicked on them they brought me to the correct page and showed me the outline that i had drew on the plans. The comments included the page number of the outline, but now it 
- How to Bulk-Update Sales Orders in CRM- Hi - I need to bulk update existing sales orders with dates from our ERP of when the sales orders were created. I made a date field on the Sales Order module where I want to insert that data. I can't Mass Update because I am not updating the fields to 
- Zoho ToDo in Cliq- Our organization utilizes Zoho ToDo in the Zoho Mail Desktop app. Is there a way for these to show up in Cliq Desktop app as well? 
- 【Zoho CRM】サンドボックス機能のアップデート:カスタムビューが利用可能になりました。- ユーザーの皆さま、こんにちは。コミュニティチームの中野です。 今回は「Zoho CRM アップデート情報」の中から、サンドボックス機能のアップデートをご紹介します。 目次 1. カスタムビューとは 2. 今回の機能アップデートについて 1. カスタムビューとは カスタムビューは、ユーザーが設定した条件に基づいてデータをフィルタリング・整理し、 重要な情報へ効率的にアクセスできるようにする機能です。 「過去15日間の見込み客」や「受注間近の商談」、「特定の優先度レベルが設定された案件」など 条件を指定してわずか数クリックで設定できます。 
- Changing an agents email address- How do you change an agent's email address? I keep getting a red circle even though I am an admin. And on one of my agents he has two email addresses? How is that possible? 
- Zoho CRM - Potentials Tab- Hi! When I create a Deal (Potentials tab) the header looks like this: After a refresh on the page it looks like this: What should I do so that it is displayed like in the second pic without refresh? Also I have a user that as of recently, cannot see this 
- Is there a way to automatically add Secondary Contacts (CCs) when creating a new ticket for specific customers?- Some of our customers want multiple contacts to receive all notifications from our support team. Is there a way to automatically add secondary contacts to a ticket when our support team opens a new ticket and associates it with an account? This would 
- Unable to create embed code for resource of workdrive using API- Hello Team, I am trying to create embed code for a resource using workdrive api in powershell, however facing some issues with injecting data in body. Followed Doc: https://workdrive.zoho.com/apidocs/v1/filefoldersharing/shareeveryone Please help, below 
- Feature Request - Insert URL Links in Folders- I would love to see the ability to create simple URL links with titles in WorkDrive. or perhaps a WorkDrive extension to allow it. Example use case: A team is working on a project and there is project folder in WordDrive. The team uses LucidChart to create 
- not able to convert pdf to jpg and other forms and vice versa.- i want to change my pdf to jpg, word, etc and some times jpg to pdf. i don't know how to do in this. 
- Enable / show scroll bar when Mega Menu is opened- Hey there I am using the mega menu add-on and experience a "flicker" whenever the mega menu opens. The reason is, that the scrollbar, which has a width of a few pixels, stops showing when the mega menu opens. As the scrollbar disappears the whole page 
- Shared Mailboxes Disappeared- Zoho Mail users in our company haven't been able to see their Shared Mailboxes for the past few hours. I've checked with App and Web Access, but they can't access them. When I send emails to their addresses, I get no error messages. They're still visible 
- Reports: Custom Search Function Fields- Hi Zoho, Hope you'll add this into your roadmap. Issue: For the past 2yrs our global team been complaining and was brought to our attention recently that it's a time consuming process looking/scrolling down. Use-case: This form is a service report with 
- Zoho Inventory - Composite Items - Assembly - Single Line Item Quantity of One- Hi Zoho Inventory Team, Please consider relaxing the system rules which prevent an assembly items from consisting of a single line item and outputting a quantity of 1. A client I'm currently working with sells cosmetics and offers testers of their products 
- How can I transfer data from Production to Development environment?- Hi, I am using Creator V6 and would like to bring all the data in production to the Development and Testing environments? Is there an easy way of doing that or I have to export and import each table? 
- Add "Reset MFA" Option for Zoho Creator Client Portal Users- Hello Zoho Creator Team, We hope you are doing well. We would like to request an important enhancement related to Multi-Factor Authentication (MFA) for client portal users in Zoho Creator. Currently, Creator allows us to enforce MFA for portal users, 
- Next Page