knowledgecenter-breadcrum

Knowledge Center

06 Aug, 2020

How to change main form of an entity conditionally using JavaScript?

Posted on 06 Aug, 2020 by Admin, Posted in Dynamics 365 Dynamics 365 Project Service Automation Dynamics 365 Field Service Dynamics 365 Customer Service Dynamics-365 Sales

How to change main form of an entity conditionally using JavaScript? Blogs

How to change main form of an entity conditionally using JavaScript?

Introduction

Sometimes we need to hide or show some fields on the form according to a field value or a condition. We can do it using business rule. but when we want to hide or show large number of fields, tabs, and sections on the form then it will become difficult. In such situation we can directly change form itself where we can add required fields, section, and tab. In this blog, I have explained how to change main form of the entity conditionally using JavaScript.

Solution

Here we are going to use JavaScript web resource. As an example we took project entity, where project and project template belong to same project entity and we can differentiate between them using “IsTemplate” field. we are going change main form of project and project template using this field.

Step by Step

  1. Add JavaScript web resource.
  2. Register function on onLoad event of the project form and pass execution context.
  3. In JavaScript function, get form Context from executionContext
  4. var oFormContext = executionContext.getFormContext();
  5. Get the value of “msdyn_istemplate” field.
  6.  var isTemplate = oFormContext.getAttribute("msdyn_istemplate").getValue();
  7. If the record is a project template, then value of this field will be “true”. It means we will change form to form created for Project Template record if the value is true and if the value is false, then we will change form to form created for Project record.
  8. Create a string variable and assign form label value to it according to IsTemplate field.
  9.  var Form_Label;
     if (isTemplate == true) {
          Form_Label = "Project Template";
     } else {
          Form_Label = "Project";
     }
  10. Both forms should be of main type and active.
  11. Now, check the current form is the same form that we want to show, if it is not, then only we will change it.
  12. Get all form objects available in formSelector.
  13. Get the label of each form available and compare with the form label that we want to show.
  14. If it is same, then navigate to that form object.
  15. Final function will be as following:
    function fnChangeForm(executionContext) {
            "use strict";
            var oFormContext = executionContext.getFormContext();
            if (oFormContext != null) {
                var isTemplate = oFormContext.getAttribute("msdyn_istemplate").getValue();
                if (isTemplate != null) {
                       var Form_Label;
                       if (isTemplate == true) {
                             Form_Label = "Project Template";
                       } else {
                             Form_Label = "Project";
                       }
    
                      if (oFormContext.ui.formSelector.getCurrentItem().getLabel() != Form_Label ) {
                           var forms = oFormContext.ui.formSelector.items.get();
                           for (var i in forms) {
                                var form = forms[i];
                                var formLabel = form.getLabel()
                                if (formLabel == Form_Label ) {
                                      form.navigate();
                                }
                           }
                      }
                 }
            }
        }

Comment

This is a Required Field

Loading

Recent Updates

Blogs
31 Mar, 2026

Debugging Power Pages Server Logic Using Visual Studio Code

Power Pages Server Logic allows developers to execute secure backend JavaScript directly within Power Pages. It is commonly used for…

READ MORE
Blogs
31 Mar, 2026

Create and Deploy a Single Page Application (SPA) in Power Pages

In this blog, we’ll build and deploy a Single Page Application (SPA) using React + Vite and host it on…

READ MORE
BuildAndDeployPCF_Thumbnail.png
Blogs
25 Mar, 2026

Build And Deploy Your First Dataset PCF Control In Dynamics 365

Introduction In Dynamics 365, subgrids are commonly used to display related records, such as Opportunities under an Account. While out-of-the-box…

READ MORE