Join the #BuildWithBuildAgent Challenge! Get recognized, earn exclusive swag, and inspire the ServiceNow Community with what you can build using Build Agent.  Join the Challenge.

Need to auto populate reference field base on sign in user location

Peter Williams
Kilo Sage

So i have this requirement that i am not able to figure out

 

i have this catalog item request for. 

What i need is, when a user logs into the form, it will detect their location

and base on their location i need to search for the title Managing Partner and have that user auto fill the reference field

 

i was thinking of a on change client script but not quiet sure on how to script it out for that

 

 


  function onChange(control, oldValue, newValue, isLoading) {
   if (isLoading || newValue == '') {
      return;
   }

   var userNo = g_form.getReference('avocat_lawyer', myFunc);
   
    function myFunc(userNo){

    g_form.setValue('managing_partner', userNo.u_preferred_name);
    }
   
}
1 ACCEPTED SOLUTION

Hello @Peter Williams ,

You can use GlideAjax to get the managing Partner.

Use the below code in on change client script:-

 

function onChange(control, oldValue, newValue, isLoading) {
    if (isLoading || newValue == '') {
        return;
    }
    var ga = new GlideAjax('getManagingPartner');
    ga.addParam('sysparm_name', 'getMP');
    ga.addParam('sysparm_lawyer', newValue); //newValue will look up field for
    ga.getXML(callback);

    function callback(response) {
        var answer = response.responseXML.documentElement.getAttribute("answer");
        g_form.setValue('managing_partner', answer);

    }

}

 

Create a script include named 'getManagingPartner' and make it client callable.

Use the below script in the script include:-

 

var getManagingPartner = Class.create();
getManagingPartner.prototype = Object.extendsObject(AbstractAjaxProcessor, {

    getMP: function() {
	var loc;
        var lawyer = this.getParameter('sysparm_lawyer');
        var gr = new GlideRecord("sys_user"); 
        gr.addQuery("sys_id", lawyer);
        gr.query();
        if (gr.next()) {
             loc = gr.location.toString();
        }
	var mp = new GlideRecord('sys_user');
	mp.addQuery('location',loc);
	mp.addEncodedQuery('titleLIKEManaging Partner');
	mp.query();
	if(mp.next()){
	return mp.sys_id.toString();
	}
    },

    type: 'getManagingPartner'
});

 

 

If this response clears up your doubt, kindly flag it as both helpful and correct.

Thanks,

Alka

View solution in original post

12 REPLIES 12

Where would i add in the second script to?

 

Create a script include named 'getManagingPartner' and make it client callable.

Not sure where to put that too

 

Search in navigator:

Alka4_0-1697642041143.png

Click on new to create script include:

Alka4_1-1697642116216.png

Name :-getManagingPartner

Check the client callable checkbox

and paste the code in script

Alka4_2-1697642245511.png

Thanks,

Alka

 

This populates but wrong person

 

There might be multiple person for lawyer location and title as managing partner and it's selecting 1 st one because of if condition. Can you recheck any other condition we can add to get the correct user.

look like a spelling mistake in the code

mp.addQuery('loaction',loc);