Multi-Select Option Set in Dataverse allows you to select multiple options for a single field. The selected values of the options are stored in the form of integer array like [1,2,3]. Here in this blog, you will learn how to toggle the visibility of sections based on the options in Multi-Select Option Set using JavaScript. Every model driven app form has a hierarchy of Tabs → Sections → Fields.
I have created a new Multi-Select Option Set field Sections to show in Accounts Entity. With this field values we can show and hide the sections in the form. I have added the sections as choices and added the choice to the Multi-Select Option Set.
function showHideSections(executionContext) { | |
const formContext = executionContext.getFormContext(); | |
const sectionToShow = formContext.getAttribute("new_sectionstoshow"); | |
const selectedSections = sectionToShow.getValue()?sectionToShow.getValue():[]; | |
// get tab control | |
const generalTab = formContext.ui.tabs.get("DETAILS_TAB"); | |
//option set value as id and section logical name as section | |
const sections = [ | |
{ id: 1, section: "COMPANY_PROFILE" }, | |
{ id: 2, section: "DETAILS_TAB_section_6" }, | |
{ id: 3, section: "BILLING" }, | |
{ id: 4, section: "SHIPPING" }, | |
{ id: 5, section: "ChildAccounts" } | |
]; | |
sections.forEach(s => { | |
// get sections under the tab | |
const section = generalTab.sections.get(s.section); | |
// If the section name is selected, setVisible is true else it is false | |
section.setVisible(selectedSections.includes(s.id)); | |
}); | |
} |
Note: Add this function to the both onload and onchange event handlers. It works fine with onchange but while refreshing it do not check the field values and it got mess up. So we added onload event too. Save and publish the form again
We can the section after getting the Tab control. Create an Array of Objects with id and sections fields. id is the Option Set values of the Multi-Select Option Set field and section is the logical name of the sections. Initiate a foreach to iterate through the object array and check the field value. If the value from field includes any of the id in the array, then set visibility to the section equivalent to that id.