Создание пользовательского виджета времени в GridMVC

Я пытаюсь создать виджет времени для фильтрации записей по времени в сетке MVC. Я могу видеть элемент управления, но он не фильтрует записи. вот сценарий Я добавил скрипт, просмотр кода для сетки MVC и страницу индекса, а также.

скрипт

function TimeWidget() {

this.getAssociatedTypes = function () {
    return ["TimeFilterWidget"];
};
this.onShow = function () {
};

this.showClearFilterButton = function () {
    return true;
};

this.onRender = function (container, lang, typeName, values, cb, data) {
    //store parameters:
    this.cb = cb;
    this.container = container;
    this.lang = lang;

    //this filterwidget demo supports only 1 filter value for column column
    this.value = values.length > 0 ? values[0] : { filterType: 1, filterValue: "" };

    this.renderWidget(); //onRender filter widget
    //this.loadCustomers(); //load customer's list from the server
    this.registerEvents(); //handle events
};

this.renderWidget = function () {
    var html = '\<p>Select Time to filter:</p>\
                <p><input class="time" type="time" id="tminput"/></p>\
                ';
    this.container.append(html);
};

this.registerEvents = function () {                
    var x = document.getElementById("tminput");
    x.addEventListener("blur", myBlurFunction, true);        
};

function myBlurFunction() {
    var $context = this;
    var values = [{ filterValue: $(this).val(), filterType: 1 /* Equals */ }];        
    $context.cb(values);
}

}

Вид сетки

@using GridMvc.Html
@using GridMvc.Sorting
@model IEnumerable<GridMvc.Site.Logging>

@Html.Grid(Model).Named("ordersGrid").Columns(columns =>
{
    /* Adding "OrderID" column: */

    columns.Add(o => o.ID)
           .Titled("Number")
           .SetWidth(100);
    columns.Add(o => o.DateTime, "Date")
            .Titled("Date")
            .SortInitialDirection(GridSortDirection.Descending)
            .Format("{0:dd/MM/yyyy}")
            .SetWidth(110);
    columns.Add(o => o.DateTime, "Time")
            .Titled("Time")
            .SortInitialDirection(GridSortDirection.Descending)
            .Format("{0:hh:mm tt}")                
            .SetWidth(110)
            .SetFilterWidgetType("TimeFilterWidget");
    columns.Add(o => o.Type)
           .Titled("Type")
           .SetWidth(150)
           .ThenSortByDescending(o => o.ID)
           .SetFilterWidgetType("TypeFilterWidget");
    columns.Add(o => o.Description)
           .Titled("Description")
           .SetWidth(250);
    columns.Add(o => o.Reference)
            .Titled("Reference")
            .SetWidth(150)
            .Css("hidden-xs"); //hide on phones
    columns.Add(o => o.Response)
            .Titled("Response")
            .SetWidth(150)
            .Css("hidden-xs"); //hide on phones        


}).WithPaging(15).Sortable().Filterable().WithMultipleFilters()

Индекс

<script>
$(function () {
    pageGrids.ordersGrid.addFilterWidget(new TypeWidget());
    pageGrids.ordersGrid.addFilterWidget(new TimeWidget());
});
</script>

1 ответ

Если тогда может помочь. Добавьте этот код в сетку на странице..Named ("ordersGrid") пример кода:

@Html.Grid(Model).Named("ordersGrid").Columns(columns =>
{
    columns.Add(o => o.Customer.CompanyName)
           .Titled("Company")
           .SetWidth(250)
           .ThenSortByDescending(o => o.OrderID)
           .Filterable(true)
           .SetFilterWidgetType("CustomCompanyNameFilterWidget"); })

это нужно для работы JavaScrip метод addFilterWidget в файле gridmvc.customwidgets.js

Надеюсь, это кому-нибудь поможет.

Другие вопросы по тегам