Reputation: 9546
I'm trying to use Javascript to populate a PeoplePicker control in Sharepoint 2013:
name="Engineer"
var ppDiv=$("[id$='ClientPeoplePicker'][title='"+name+"']");
console.log(ppDiv.html());
var ppEditor=ppDiv.find("[title='"+name+"']");
var spPP=SPClientPeoplePicker.SpClientPeoplePickerDict[ppDiv[0].id];
ppEditor.val("Abc, Xyz");
spPP.AddUnresolvedUserFromEditor(true);
Two problems: ppDiv
is still undefined after the assignment statement, and SPClientPeoplePicker
is not defined; according to this article, it’s defined by clientpeoplepicker.js
, which is a script that’s supposed to be loaded on every page that has a People Picker.
EDIT:
I changed the code to:
name="Engineer"
var ppDiv=$("div[title='"+name+"']");
console.log(ppDiv.html());
var ppEditor=ppDiv.find("[title='"+name+"']");
var spPPD=SPClientPeoplePicker.SpClientPeoplePickerDict;
console.log(spPPD[0]);
var spPP=spPPD[ppDiv[0].id];
ppEditor.val("Abc, Xyz");
spPP.AddUnresolvedUserFromEditor(true);
Now ppDiv is defined (as shown by its HTML successfully appearing in the console log), but it's crashing on the line var spPPD=SPClientPeoplePicker.SpClientPeoplePickerDict;
with this error:
Uncaught ReferenceError: SPClientPeoplePicker is not defined
Upvotes: 1
Views: 10367
Reputation: 67
I find that if I add a 500-700ms delay before calling the code, that I do not get this error:
window.setTimeout(function() {
SetAndResolvePeoplePicker("PickerFieldName", "[email protected]");
}, 750);
function SetAndResolvePeoplePicker(fieldName, userAccountName) {
var controlName = fieldName;
var peoplePickerDiv = jQuery("[id$='ClientPeoplePicker'][title='" + controlName + "']");
var peoplePickerEditor = peoplePickerDiv.find("[title='" + controlName + "']");
var spPeoplePicker = SPClientPeoplePicker.SPClientPeoplePickerDict[peoplePickerDiv[0].id];
peoplePickerEditor.val(userAccountName);
spPeoplePicker.AddUnresolvedUserFromEditor(true);
}
Upvotes: 0
Reputation: 132
Here is how i did it. With fieldName beeing the column title of the people picker and userAccountName the user login name/last part of the claim.
One thing to point out is that it has to be a client people picker. As far as i know, sharepoint uses server side people picker by default in custom forms so make sure its really a client people picker.
function SetAndResolvePeoplePicker(fieldName, userAccountName) {
var controlName = fieldName;
var peoplePickerDiv = $("[id$='ClientPeoplePicker'][title='" + controlName + "']");
var peoplePickerEditor = peoplePickerDiv.find("[title='" + controlName + "']");
var spPeoplePicker = SPClientPeoplePicker.SPClientPeoplePickerDict[peoplePickerDiv[0].id];
peoplePickerEditor.val(userAccountName);
spPeoplePicker.AddUnresolvedUserFromEditor(true);
//disable the field
spPeoplePicker.SetEnabledState(false);
//hide the delete/remove use image from the people picker
$('.sp-peoplepicker-delImage').css('display','none');
}
Upvotes: 1