Skip to main content

Display Business Rule and Client Script - hide empty variables on cat item form and make visible vars read only

Display Business Rule and Client Script - hide empty variables on cat item form and make visible vars read only (g_scratchpad)

 

BUSINESS RULE (Display) - generates the scratchpads which are passed to the client script

(function executeRule(current, previous /*null when async*/ ) { //Get Catalog variables var emptyVariables = []; var readonlyVariables = []; var keys = []; var set = new GlideappVariablePoolQuestionSet(); set.setRequestID(current.request_item); //--if table is sc_task
//set.setRequestID(current.sys_id); //--if table is RITM set.load(); var vs = set.getFlatQuestions(); var description = ''; for (var i = 0; i < vs.size(); i++) { var sDisplVal = vs.get(i).getDisplayValue().toString(); //var sLabel = vs.get(i).getLabel().toString(); var sField = vs.get(i).getName().toString(); //gs.addInfoMessage(!gs.nil(sLabel) + ',' + (sDisplVal!='') + ',' + sLabel + ': ' + sDisplVal); if (!gs.nil(sField) && (sDisplVal == '' || sDisplVal == 'false')) { emptyVariables.push(sField); } else { readonlyVariables.push(sField); } } g_scratchpad.emptyVariables = emptyVariables.toString(); g_scratchpad.readonlyVariables = readonlyVariables.toString(); //gs.addInfoMessage(g_scratchpad.emptyVariables); })(current, previous);



  

CLIENT SCRIPT: this can be a client script (not catalog client script) on sc_task or RITM //Type appropriate comment here, and begin script below
if (g_scratchpad.emptyVariables != '') { //alert(g_scratchpad.emptyVariables); var emptyVars = g_scratchpad.emptyVariables.split(','); for (i = 0; i < emptyVars.length; i++) { //alert(emptyVars[i].toString()); g_form.setDisplay('variables.' + emptyVars[i], false); } } if (g_scratchpad.readonlyVariables != '') { //alert(g_scratchpad.readonlyVariables); var allVarsRO = g_scratchpad.readonlyVariables.split(','); for (x = 0; x < allVarsRO.length; x++) { //alert(allVarsRO[x].toString()); g_form.setReadOnly('variables.' + allVarsRO[x], true); } }

Comments

Popular posts from this blog

Get URL Parameter - server side script (portal or classic UI)

Classic UI : var sURL_editparam = gs . action . getGlideURI (). getMap (). get ( ' sysparm_aparameter ' ); if ( sURL_editparam == 'true' ) { gs . addInfoMessage ( 'parameter passed ); } Portal : var sURL_editparam = $sp . getParameter ( " sysparm_aparameter " ); if ( sURL_editparam == 'true' ) { gs . addInfoMessage ( 'parameter passed ); }

ServiceNow - script include: build up the results as a JSON object (array) - example 2

function call var sCurrentGroupMembers = new <script_include> (). getGroupMembers ( group_sysid ); gs . print ( 'sCurrentGroupMembers:' + sCurrentGroupMembers ); var oGroupMembers = JSON . parse ( sCurrentGroupMembers ); gs . print ( JSON . stringify ( oGroupMembers . users )); oNewGroupMember = JSON . parse ( group_members ); var oGroupConfig = getGroupDeltas ( oGroupMembers . users , oNewGroupMember ); gs . print ( JSON . stringify ( oGroupConfig . remove )); gs . print ( JSON . stringify ( oGroupConfig . add )) output : *** Script: sCurrentGroupMembers: {"manager":"3b2649efdb0f8c10cc0652f3f39xxxxx", "email":"", "type":"33a2226edb99c340edfc7cbdae96xxxx", "description":"Created for xyz", "users":[{"user":"3b2649efdb0f8c10cc0652f3f396xxxx"},{"user":"856a8f71db3d73041b4ffc45ae96196a"},{"user":"3752771