Проблема с привязкой данных к выпадающему списку Kendo Multi-Select - PullRequest
1 голос
/ 14 мая 2019

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

Когда я выбираю элемент из списка в первый раз, этот элемент связывается, а второй выбранный элемент gridParams содержит второй выбранный элемент, но как только вызов API возвращает данные, связанный список обновляется до нет (данные не связаны с выпадающим списком).

Ниже приведен код

{
    OC.setReportGridColumns(responsecolumns);
        OC.reportsGridOptions = {                    
        dataSource: {
            schema: {
                data: "Data",
                total: "Total",
                model: {
                        fields: OC.GetSchemaFields()
                        }
                    },
                transport: {                            
                        read: function (e) {
                        gridParams = JSON.parse(JSON.stringify({
                            CurrentPage: e.data.page,
                            PageSize: e.data.pageSize,
                            Sort: e.data.sort,
                            Filter: e.data.filter
                            }));
                            if (gridParams.Filter != undefined) {
                                var a;
                                if (gridParams.Filter.filters!= undefined) {                                  
                                    angular.forEach(gridParams.Filter.filters, function (value, key) {
                                    if (value.field === "QuoteStatus") {
                                        value.operator = "in";
                                        a = "'" + value.value + "'";
                                        a = a.replace(",", "','");
                                        value.value = a;
                                    }
                                });
                            };                                
                        };
                        ReportService.GetAllAdHocReport(gridParams, '', OC.CustomColumnSelected, TemplateId).then(function (response) {
                            if (response != '') { 
                                $("li [ui- sref='AdHocReport']").parent().addClass("activelist");
                                response.Total = response.Data != null && response.Data.length > 0 ? response.Data[0].TotalRecords : 10;
                                OC.GridConfigDataSource.read();
                                e.success(response);
                                OC.hideFilters();
                            } else {
                                e.success([]);
                            }  
                    });
                },
            },                   
            filterable: {
                mode: "row,menu",
                extra:false
            },
            selectable: 'cell',                  
            columns: OC.gridCols,
        }       
    }
}

OC.setReportGridColumns = function (colList) {
var col = JSON.parse(colList).columns;
    OC.setfilterDropdown(col);
    var cols = col.map(function (value) {
        if (value.column == "QuoteStatus") {
            return {
                field: value.column,
                title: value.title,
                filterable: OC.filterDropdowns(value.column),
                width: value.width,
                sortable: true,
            };
        }
    }); 
}

OC.filterDropdowns = function (column) {
    return {
        extra: false,
        mode: "menu",
        multi: true,
        cell: {
            showOperators: false,
            template: function (args) {
            /////------****Multi-select Dropdown****------///////
                args.element.kendoMultiSelect({
                    autoBind: true,
                    dataTextField: "text",
                    dataValueField: "value",
                    dataSource: new kendo.data.DataSource({
                        data: OC.getDataForFilterDropdown(column)
                    }),
                    index: 0,
                    optionLabel: {
                        text: "--Select--",
                        value: ""
                    },
                    valuePrimitive: true,
                });
            },
        }
    }
}
...