If I comment out the alert('System Roles Loaded')
line, no selected results will display in the $('#custom-headers')
select box after the Apply button has been clicked. Code is below. Thanks in Advance.
<script type="text/javascript">
var userIds = @Html.Raw(Json.Encode(Model.UserIDs))
var roleIds = @Html.Raw(Json.Encode(Model.RoleIDs))
var systemId = @Html.Raw(Json.Encode(Model.SystemID))
$(document).ready(function () {
App.multiSelect();
if (userIds != null)
{
xUserIds = new Array();
for (i=0; i<userIds.length; ++i) {
xUserIds[i] = userIds[i].toString();
}
$('#searchable').multiSelect('select',xUserIds);
$('#searchable').multiSelect('refresh');
}
LoadSystem(systemId);
If I comment out this alert line, no results display in select box.
alert('System Roles Loaded'); // this is needed to display my selected select value(s)
if (roleIds != null)
{
var xRoleIds = new Array();
for(i=0;i <roleIds.length; ++i)
{
xRoleIds[i] = roleIds[i].toString();
}
$('#custom-headers').multiSelect('select',xRoleIds);
$('#custom-headers').multiSelect('refresh');
}
});
Function called to populate the select box
function LoadSystem(selectedItem) {
//Remove all of the selectable items and refresh
$("#custom-headers").children().remove();
$("#custom-headers").multiselect('refresh'); //html template used
//Make the Ajax call for the selected system
$.Ajax({
cache: false,
type: "GET",
url: "/UserRoleAssignment/GetRoleBySystemId", //mvc call
data: { "systemId": selectedItem }, //data passes to Ajax
done: function (data) {
options = $('#custom-headers');
$.each(data, function (id, option) {
//add each option to select
options.append($("<option />").val(this.option.id).text(this.option.name));
});
},
//On error display this message
fail: function () {
alert('Failed to retrieve roles.');
}
});
}
</script>