I have a editable grid where the first column is ProjectID
inside this grid when in edit mode the first column should be a drop down
The grid is initially populated when a user makes a selection from a combobox placed above the grid
The populating the grid is based off the choice make in the combo... that part works. The problem I am having is ... the dropdown editor needs to be based off the combobox value also and the datasource for the project names
which I have returning all records instead of filtering just on the ones from that lineofbusiness
What I want to do in (pseudo code)
select ProjectID, ProjectName from projects where lineofbusiness = combobox.value()
to build the dropdown editors options and the datasource I am using the same datasource for each if I could just get the LineofBusiness to be sent in the read call
also the ProjectID column shows the ProjectID not the ProjectName like I assume it would if they were linked?
I need a push in the right direction... my brain is fried...
function updateGrid() { if ( $("#grid").data("kendoGrid") != undefined ) { $("#grid").empty(); } var lob = $("#lob").data("kendoComboBox").value(); var queryurl = "./grid_projectselections.php?delob=" + escape(lob); var updateurl = "./grid_projectselections.php?delob=" + escape(lob); var element = $("#grid").kendoGrid({ dataSource: { pageSize: 200, type: "json", batch: true , serverSorting: false, transport: { read: { url: queryurl, dataType: "json", cache: false, data: { q: lob } }, update: { url: updateurl, dataType: "json" }, parameterMap: function(options, operation) { if (operation !== "read" && options.models) { return {models: kendo.stringify(options.models)}; } } }, schema: { data: "data", total: "total", model: { fields: { ProjectID: { editable: true }, HR_LEVEL_5: { editable: false }, HR_LEVEL_6: { editable: false }, HR_LEVEL_7: { editable: false }, HR_LEVEL_8: { editable: false }, HR_LEVEL_9: { editable: false }, ExecDescr: { editable: false }, OrgDescr: { editable: false }, GroupDescr: { editable: false }, RegionDescr: { editable: false }, SectionDescr: { editable: false } } } } }, selectable: true, filterable: true, resizable: true, editable: true, groupable: false, pageable: { numeric: true, refresh: true, previousNext: true, input: true, info: true }, columns: [ { field: "ProjectID", editor: ProjectDropDownEditor, values: projectDS }, "HR_LEVEL_5" , "HR_LEVEL_6" , "HR_LEVEL_7" , "HR_LEVEL_8" , "HR_LEVEL_9" , "ExecDescr" , "OrgDescr" , "GroupDescr" , "RegionDescr" , "SectionDescr" ] });}function ProjectDropDownEditor(container, options) { $('<input required data-text-field="ProjectName" data-value-field="ProjectID" data-bind="value:' + options.field + '"/>') .appendTo(container) .kendoDropDownList({ autoBind: false, dataSource: { type: "json", transport: { read: { url: "./grid_projectsdropdown.php"}, } } }); }$("#lob").width(360).kendoComboBox({ placeholder: "Select LOB...", dataTextField: "LineOfBusiness", dataValueField: "LineOfBusiness", width: 360, dataSource: { contentType: "application/json; charset=utf-8", serverFiltering: true, transport: { read: "./ajax/lobs.php" }, schema: { data: "data", total: "total" } }, change: function() { var value = this.value(); if (value) { if (value == '') { return; } updateGrid(); } else { } }});var projectDS = new kendo.data.DataSource({ transport: { read: { url: "./grid_projectsdropdown.php"}, dataType: "json" }, schema: { data: "data", total: "total" }});What I want to do in (pseudo code)
select ProjectID, ProjectName from projects where lineofbusiness = combobox.value()
to build the dropdown editors options and the datasource I am using the same datasource for each if I could just get the LineofBusiness to be sent in the read call
also the ProjectID column shows the ProjectID not the ProjectName like I assume it would if they were linked?
I need a push in the right direction... my brain is fried...