Power of Automation :: Track the progress of the Tasklists and update at the Milestone & Project levels.

Power of Automation :: Track the progress of the Tasklists and update at the Milestone & Project levels.

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 complex tasks and calculations.


Lets take the below requirement from a customer - 


A customer would like to monitor the progress of current week & last week tasklists and update in the custom fields at Milestone and projects levels.

Lets say, there are 4 Tasklists under a Milestone, the current week progress of these four Tasklists should be updated in the custom field of associated Milestone. Likewise, the progress of the previous week should be populated in another custom field.


Similarly, it should be rolled up and displayed in a custom field at Project level.


A custom function can be used to fulfil this need. However, this has to be implemented for each project i.e. ID of the project should be passed directly in the arguments. I have attached the screenshots of Arguments & schedule.


Establishing a connection with the scopes "zohoprojects.milestones.ALL , zohoprojects.projects.ALL" is all that is required. Below link will let you know how to establish a connection.


https://help.zoho.com/portal/en/kb/projects/integration/connections/articles/connections-23-5-2022#How_to_establish_a_Connection


endPoint = "https://projects.zoho.com/restapi/portal/";

endPointV3 = "https://projects.zoho.com/api/v3/portal/";

// project cf id

projectCurrentWeekCustomFieldName = "xxxxxx"; // project current week cf name

milestoneCompletionPercent = 0;

divideBy100 = 0;

isTrue = false;

projectCurrentWeekValue = 0;

getAllMilestones = invokeurl

[

url :endPoint + portalId + "/projects/" + projectId + "/milestones/"

type :GET

connection:”******”

];

for each  milestone in getAllMilestones.get("milestones")

{

milestoneId = milestone.get("id_string");

getMilestoneDetails = invokeurl

[

url :endPointV3 + portalId + "/projects/" + projectId + "/milestones/" + milestoneId

type :GET

connection:”******”

];

CurrentWeekFieldId = "xxxxxxx";

// milestone cf id

LastWeekFieldId = "xxxxxx";

// milestone cf id

milestoneParameter = Map();

if(getMilestoneDetails.get("custom_fields").get(CurrentWeekFieldId).get("value").equalsIgnoreCase("-"))

{

milestoneParameter.put(CurrentWeekFieldId,getMilestoneDetails.get("completion_percent").toString());

isTrue = true;

}

else

{

milestoneParameter.put(LastWeekFieldId,getMilestoneDetails.get("custom_fields").get(CurrentWeekFieldId).get("value").toString());

milestoneParameter.put(CurrentWeekFieldId,getMilestoneDetails.get("completion_percent").toString());

}

milestoneCompletionPercent=milestoneCompletionPercent+getMilestoneDetails.get("completion_percent");

divideBy100 = divideBy100 + 100;

updateMilestoneDetails = invokeurl

[

url :endPointV3 + portalId + "/projects/" + projectId + "/milestones/" + milestoneId

type :POST

parameters:toString(milestoneParameter)

connection:"*********"

];

}

projectMilestoneCompletionPercentage = (milestoneCompletionPercent / divideBy100) * 100;

// Update Project

projectCurrentWeekFieldId = "xxxxxx";

// project cf id

projectLastWeekFieldId = "xxxxxxx";

projectsParameter = Map();

if(isTrue)

{

projectsParameter.put(projectCurrentWeekFieldId,toString(projectMilestoneCompletionPercentage));

}

else

{

getProjectResponse = invokeurl

[

url :endPoint + portalId + "/projects/" + projectId + "/"

type :GET

connection:"*********"

];

customFields = getProjectResponse.get("projects").get(0).get("custom_fields");

for each customField in customFields{

if(customField.containKey(projectCurrentWeekCustomFieldName)){

projectCurrentWeekValue = customField.get(projectCurrentWeekCustomFieldName);

}

}

projectsParameter.put(projectLastWeekFieldId,projectCurrentWeekValue);

projectsParameter.put(projectCurrentWeekFieldId,toString(projectMilestoneCompletionPercentage));

}

updateProjectResponse = invokeurl

[

url :endPoint + portalId + "/projects/" + projectId + "/"

type :POST

parameters:projectsParameter

connection:"***********"

];


Creating custom functions in Zoho Projects is straightforward and well-documented. Watch this space for more such custom function codes. 






                            Zoho Desk Resources

                            • Desk Community Learning Series


                            • Digest


                            • Functions


                            • Meetups


                            • Kbase


                            • Resources


                            • Glossary


                            • Desk Marketplace


                            • MVP Corner


                            • Word of the Day



                                Zoho Marketing Automation
                                        • Sticky Posts

                                        • Manage Documents with SharePoint Extension in Zoho Projects

                                          SharePoint is a digital platform to store and manage your documents. Multiple users can work on the same document simultaneously, which enhances your team's productivity. By installing the extension in Zoho Projects, users can access the documents seamlessly
                                        • Share Captured Content as Work Items with Zoho Annotator for Zoho Projects

                                          Zoho Annotator is a free browser extension to annotate web pages and images. The extension allows users to: capture, annotate, and share visual content within Zoho Projects. create tasks, issues, or statuses with annotated images or videos as attachments
                                        • Auto-update the Successor Task Status.

                                          Hello folks! We have come up with a new use case for custom function to help you automate the workflow of your tasks. Users can write their own Custom Functions using deluge and call them from a workflow. Consider a scenario where the status of the successor
                                        • Collaborate Visually with Whiteboard in Zoho Projects

                                          Whiteboard in Zoho Projects allows you to collaborate visually by creating diagrams, annotating designs, and sketching project workflows using shapes, text, and images within project modules. Team members can work simultaneously, improving productivity
                                        • Introducing Projects 8.0 - Focusing on Ease-of-Use and New Features

                                          Hello everyone! It's time for the reveal of the 8th version of Zoho Projects! This year our focus has been on minimizing the learning curve and improving the ease-of-use of the tool, so anyone new to Projects can hit the ground running and existing users


                                        Manage your brands on social media



                                              Zoho TeamInbox Resources

                                                Zoho DataPrep Resources



                                                  Zoho CRM Plus Resources

                                                    Zoho Books Resources


                                                      Zoho Subscriptions Resources

                                                        Zoho Projects Resources


                                                          Zoho Sprints Resources


                                                            Qntrl Resources


                                                              Zoho Creator Resources


                                                                Zoho WorkDrive Resources



                                                                  Zoho Campaigns Resources

                                                                    Zoho CRM Resources

                                                                    • CRM Community Learning Series

                                                                      CRM Community Learning Series


                                                                    • Tips

                                                                      Tips

                                                                    • Functions

                                                                      Functions

                                                                    • Meetups

                                                                      Meetups

                                                                    • Kbase

                                                                      Kbase

                                                                    • Resources

                                                                      Resources

                                                                    • Digest

                                                                      Digest

                                                                    • CRM Marketplace

                                                                      CRM Marketplace

                                                                    • MVP Corner

                                                                      MVP Corner

                                                                    





                                                                    




                                                                        Design. Discuss. Deliver.

                                                                        Create visually engaging stories with Zoho Show.

                                                                        Get Started Now