Multiselect

Cascade 

Fruits×
please select


Parent and Child multiselect, NoSelectClose() set on the child, selected values can be reordered by dragging them

Multiselect with custom item 

item pictureMango×
item picturePapaya×
item pictureLettuce×


Defining custom rendering functions for the dropdown list item and selected caption

Multiselect with submenu 

please select


show code
AjaxRadioListDemo/Index.cshtml
@model AweCoreDemo.ViewModels.Input.AjaxDropdownDemoInput
@using AweCoreDemo.Models
@{
ViewData["Title"] = "AjaxRadioList";
var mealsDir = Url.Content(DemoUtils.MealsUrl);
}
<script>
var categories = @Html.Raw(DemoUtils.Encode(Db.Categories.Select(o => new KeyContent(o.Id, o.Name))));
var meals = @Html.Raw(DemoUtils.Encode(Db.Meals.Select(o => new { k = o.Id, c = o.Name, cid = o.CategoryId, url = mealsDir + o.ImageName })));

function getMealsChild(params) {
var pobj = aweUtils.getParams(params);
var result = [];

awef.loop(meals, function (item) {
if (item.cid == pobj.categories)
result.push(item);
});

return result;
}
</script>

<div class="example med">
<h2 data-name="cascade">Cascading Radio button list using binding to Parent</h2>
<div style="min-height: 125px">
@*begin*@
@(Html.Awe().AjaxRadioListFor(o => o.ParentCategory)
.Url(Url.Action("GetCategories", "Data")))
@(Html.Awe().AjaxRadioListFor(o => o.ChildMeal)
.Url(Url.Action("GetMeals", "Data"))
.Parent(o => o.ParentCategory, "categories"))
@*end*@
</div>
<br />
<br />
@(Html.Awe().Tabs().Add("description",
@<text>
AjaxRadioList needs an url, js func or controller to get data from, it will render a list of radiobuttons<br />
As with most awesome controls, you can bind the AjaxRadioList to one or more parents,
and when the parent changes value the child will load and get the parent values as parameters in its data function
</text>, "expl")
.Add("view", Html.Source("AjaxRadioListDemo/Index.cshtml"))
.Add("controller", Html.Csource("Awesome/DataController.cs")))
</div>

<div class="example">
<h2>Client data</h2>
<div style="min-height: 110px">
@*begincd*@
<script>
function getClientData() {
return [{ k: 1, c: 'Fruits' }, { k: 2, c: 'Vegetables' }, { k: 3, c: 'Nuts' }];
}
</script>
@(Html.Awe().AjaxRadioList("CatClient1")
.DataFunc("getClientData")
.Value(2))
@*endcd*@
</div>
@(Html.Awe().Tabs().Add("description",
@<text>Besides remote data using <code>.Url(str)</code>, it can also get data from the client using <code>.DataFunc(jsFunc)</code>, the jsFunc can return the items or a Promise</text>, "expl")
.Add("view", Html.Source("AjaxRadioListDemo/Index.cshtml", "cd")))
</div>

<div class="example">
<h2>Using predefined parameters</h2>
@{
var cat1 = Db.Categories[0];
var cat2 = Db.Categories[1];
}
setting parameter parent = { @cat1.Name, @cat2.Name } using .Parameter and .ParameterFunc extensions<br />
@(Html.Awe().AjaxRadioListFor(o => o.Meal1)
.Parameter("categories", cat1.Id)
.ParameterFunc("giveParams")
.Url(Url.Action("GetMeals", "Data")))
<script>
function giveParams() {
return { categories: @(cat2.Id) };
}
</script>
</div>

Multiselect Combo 

can add values not present in the select list
please select
show code
Multiselect/Index.cshtml
@(Html.Awe().Multiselect(new MultiselectOpt
{
Name = "AllMealsMultiCombo",
Url = Url.Action("GetMealsImg", "Data"),
NoSelectClose = true,
Combo = true
}))

Multiselect, with custom css 

Mango×
Apple×
Papaya×
Banana×
Cherry×

Events and Api 

please select




loaded 25 items

show code
Showing commonly used client side api methods.
To change the value you simply call jquery .val(newvalue).trigger('change').
aweload event is handled to flash the #log div whenever the dropdown loads.
The same api methods can be used for the AjaxDropdown, AjaxRadioList controls and their mods.



Comments