Now, let's understand the complete code first. The comments explain each relevant step within the code:
function suggestZipCodes() {
//defined possible ZipCode
ZipCodes = [
{ name: '94102' },
{ name: '94103' },
{ name: '94104' },
{ name: '94105' },
{ name: '94107' },
{ name: '94108' }
];
var OnZipCodekeyPress = function (fld) {
var ZipCodetxt = Xrm.Page.getControl
("address1_postalcode").getValue();
resultSet = {
results: new Array(),
commands: {
id: "ZipCodecmd",
label: "Search in Bing",
action: function () {
window.open("http://bing.com"); //Open Bing URL
}
}
};
var ZipCodetxtLowerCase = ZipCodetxt.toLowerCase();
for (i = 0; i < ZipCodes.length; i++) {
if (ZipCodetxtLowerCase ===
ZipCodes[i].name.substring(0,
ZipCodetxtLowerCase.length).toLowerCase()) {
resultSet.results.push({
id: i,
fields: [ZipCodes[i].name]
});
}
if (resultSet.results.length >= 10) {
break;
}
}
if (resultSet.results.length > 0) {
//Show Auto Complete
fld.getEventSource().showAutoComplete(resultSet);
}
else {
//Hide Auto Complete
fld.getEventSource().hideAutoComplete();
}
};
Xrm.Page.getControl("address1_postalcode").addOnKeyPress
(OnZipCodekeyPress);
}
Now, let's look at the steps to be performed after completing the code:
- Navigate to Settings | Customization | Customize the System and select Web Resources. Click New:
data:image/s3,"s3://crabby-images/db2fe/db2fe1f0ed0c403fac64e6ab89aa7f33817ac325" alt=""
- Name the web resource as zipCodeAutoComplete. Select Type as Script(JScript) and paste the preceding code in the Text Editor link:
data:image/s3,"s3://crabby-images/a45ab/a45ab011b4d44a3c0c75814bc103f360e97c4138" alt=""
- On clicking the Text Editor button, you will be able to paste the code into it:
data:image/s3,"s3://crabby-images/78b42/78b4220b6058cad5754642976922004d00ad2c8c" alt=""
- Click OK. On the main screen, click Save and Publish. Next, navigate to Contact entity | Forms. Open the Contact main form by double-clicking on it:
data:image/s3,"s3://crabby-images/1f064/1f064d8ef99c7e31ebd98e7aa8b41a21a1652284" alt=""
- Click on the Form Properties ribbon button on the form editor:
data:image/s3,"s3://crabby-images/aeca5/aeca56e0b688633784baeddf3c6c1a68bbba0922" alt=""
- Attach the WebResource script (created earlier to form libraries) by clicking Form Properties and attach the method name to the On Load event handler:
data:image/s3,"s3://crabby-images/ba3cd/ba3cd9c10e7c4ee20add2e490937173d8b14d080" alt=""
- Click OK. Then click on Save and Publish to publish the form.
- Now, as soon as any employee types in to the ZIP code field, he or she is presented with options for assistance, diminishing the chances of error:
data:image/s3,"s3://crabby-images/52f88/52f88e15d7357f8b4407c0d89079002adbe0a1cb" alt=""
This is how we can get autocomplete selection for ZIP codes in our forms.