@{
// Установим текущее значение
var selectedItems = Model != null && !string.IsNullOrEmpty( Model.City )
? new List <AutocompleteItem> { new AutocompleteItem { Text = Model.City.ToString(), Value = "" } }
: new List<AutocompleteItem>();
}
@Html.AutocompleteComboBox(new AutocompleteComboBox
{
// Разрешим ручной ввод
AutoFill = false,
HtmlAttributes = new HtmlAttributes { style = new HtmlStyle { width = "300px" } },
// Метод и контроллер, который возвращает данные справочника для Select
ActionName = "Select",
ControllerName = "Entity",
RouteValueDictionary = new RouteValueDictionary { { "area" , "EleWise.ELMA.BPM.Web.Common" }, { "uid", new Guid(cityCatalogUid) } },
// Имя элемента на странице
Name = ViewData.TemplateInfo .GetFullHtmlFieldName( "CityCatalogCombobox"),
SelectedEntities = selectedItems,
// Событие на клиенте, при изменении значения
OnChange = string.Format( "function (e) {{ OnAddressCitySelect(e, ’{0}’); }}", ViewData.TemplateInfo.GetFullHtmlFieldName("City"))
})
@Html.HiddenFor(m => m.City)
@Html.AutocompleteComboBox(new AutocompleteComboBox { // Разрешим ручной ввод AutoFill = false, HtmlAttributes = new HtmlAttributes { style = new HtmlStyle { width = "300px" } }, // Метод и контроллер, который возвращает данные справочника для Select ActionName = "Select", ControllerName = "Entity", RouteValueDictionary = new RouteValueDictionary { { "area" , "EleWise.ELMA.BPM.Web.Common" }, { "uid", new Guid(cityCatalogUid) } }, // Имя элемента на странице Name = ViewData.TemplateInfo .GetFullHtmlFieldName( "CityCatalogCombobox"), SelectedEntities = selectedItems, // Событие на клиенте, при изменении значения OnChange = string.Format( "function (e) {{ OnAddressCitySelect(e, ’{0}’); }}", ViewData.TemplateInfo.GetFullHtmlFieldName("City")) }) @Html.HiddenFor(m => m.City)
@{
Html.RegisterContent("OnAddressCitySelect",@<text>
<script type="text/javascript">
function OnAddressCitySelect (e, cityId) {
$(’#’ + cityId.replace(/\./g, ’_’))[0].value = $(’#’ + e.target.id).data(’tComboBox’).text();
}
</script>
</text>);
}