Skip to main content

Post Kendo Grid data with model data to Controller in MVC

Your save button:

 <button type="submit" class="btn btn-mini btn-primary" id="btnAddCustomerAccountManage" name="btnAddCustomerAccountManage" onclick="SaveUserProjectDetails()">  
           <i class="icon-save bigger-125"></i>Save</button>  

button click function

  function SaveUserProjectDetails()  
   {  
     var projectPermissionType = 1;  
     var postUrl;  
     var paramValue;  
     if (projectPermissionType == 1) {  
       var gridData = $("#CustomerInfoKendoGrid").data("kendoGrid").dataSource.data();  
       // set model data  
       for (var i = 0; i < gridData.length; i++) {  
         gridData[i].ManagerGenInfoID = $("#GEmployeeGenInfoID").val();  
         gridData[i].AssignDate = $("#AssignDate").val();  
       }  
       postUrl = '@Url.Content("~/Billing/CustomerAccountManage/GetDepartmentWiseCategoryList")';  
       paramValue = JSON.stringify({ CustomerInformationList: gridData });// you can also set model data using','  
     }  
     $.ajax({  
       url: postUrl,  
       type: 'POST',  
       dataType: 'json',  
       data: paramValue,  
       contentType: 'application/json; charset=utf-8',  
       success: function (result) {  
         console.log(result);  
       },  
       error: function (objAjaxRequest, strError) {  
         var respText = objAjaxRequest.responseText;  
         console.log(respText);  
       }  
     });  
   }  

Controller:

   public JsonResult GetDepartmentWiseCategoryList(CustomerAccountManageViewModel CustomerAccountManagemodel)  
     {  
         var strMessage = string.Empty;  
         // Get grid value  
         foreach (var item in CustomerAccountManagemodel.CustomerInformationList.Where(m => m.SelectStatus == true))  
         {  
           CustomerAccountManageViewModel viewModel = new CustomerAccountManageViewModel();  
           viewModel.CustomerInformationList = new List<CustomerEntryViewModel>();  
           viewModel.EmployeeList = new List<EmployeeViewModel>();  
           var userName = HttpContext.User.Identity.Name;  
           viewModel.IUser = userName;  
           viewModel.IDate = DateTime.Now;  
           viewModel.EDate = DateTime.Now;  
           viewModel.CustomerAccountManageID = Guid.NewGuid();  
           viewModel.CustomerID= item.CustomerID;  
           viewModel.GEmployeeGenInfoID=item.ManagerGenInfoID;  
           viewModel.AssignDate=item.AssignDate;  
           viewModel.ActiveStatus = true;  
           var entity = viewModel.ToEntity();  
           _billingCommonservice.BillingUnit.CustomerAccountManageRepository.Add(entity);  
           _billingCommonservice.BillingUnit.CustomerAccountManageRepository.SaveChanges();  
         }  
       return Json(new { strMessage = strMessage });  
     }  



Comments

Popular posts from this blog

WPF datagrid cell textbox change event

Entity/Class: public class FeesDetails : INotifyPropertyChanged { public int Id { get; set; } public string FeesName { get; set;} public string FeesDetailsName { get; set; } public int? PaidAmount { get; set; } public event PropertyChangedEventHandler PropertyChanged; private void NotifyPropertyChanged(System.String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public int feesAmount { get; set; } public int FeesAmount { get { return this.feesAmount; } set { if (value != this.feesAmount) { this.feesAmount = value; NotifyPropertyChanged("FeesAmount"); } } } } XAML: <DataGrid AutoGenerateColumns="False" Height="21...

mvc razor textboxfor change event change another textboxfor value

Based on value of Weight, Rate , CNF & AWB it will change the value of Freight , TTLCNF anfd TTLFright . Freight= Weight*Rate; TTLCNF  = Weight*CNF; TTLFright=  Freight+ TTLCNF  + AWB; @Html.TextBoxFor(model => model.Weight, new { onChange="return GetWight(this);"}) @Html.TextBoxFor(model => model.Rate, new { onChange="return GetWight(this);"})/Kg @Html.TextBoxFor(model => model.Freight, new {disabled = "disabled" , @readonly = "readonly" ,onChange="return GetTTLFright(this);"}) @Html.TextBoxFor(model => model.CNFPK, new { onChange="return GetCNFPK(this);"}) @Html.TextBoxFor(model => model.TTLCNF, new {disabled = "disabled" , @readonly = "readonly",onChange="return GetTTLFright(this);" }) @Html.TextBoxFor(model => model.AWB, new { onChange="return GetTTLFright(this);"}) and script <script> function GetW...

mvvm double click event in listview

If you want to get the double click event on a listview item you can try with this code; <ListView Grid.Row="0" Grid.RowSpan="3" Grid.Column="0" Width="250" Height="200" HorizontalAlignment="Stretch" VerticalAlignment="Top" AlternationCount="2" BorderBrush="#FFA8CC7B" ItemContainerStyle="{StaticResource alternatingStyle}" ItemsSource="{Binding FromPayerNameList}" SelectedItem="{Binding SelectedFromPayer, Mode=TwoWay}"> <ListView.ItemTemplate> <DataTemplate> <TextBlock Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListView}}}" Text=...