I have class OrderSummaryViewModel
public class OrderSummaryViewModel
{
public int Id { get; set; }
public string PurchaseOrderNumber { get; set; }
public string DeliveryCondition { get; set; }
/// <summary>
/// Order items
/// </summary>
public List<OrderItem> Items { get; set; }
}
And second class OrderItem
/// <summary>
/// Order items
/// </summary>
public class OrderItem
{
public int Id { get; set; }
public string ItemNumber { get; set; }
public string DeliveredQuantity { get; set; }
public string fullyDelivered { get; set; }
}
And i bind model OrderSummaryViewModel
into below .csHTML
view to show the order with its related items.
@model OrderSummaryViewModel
<div class="baseForm">
<label>PO Number:</label></td>
@Html.DisplayFor(model => model.PurchaseOrderNumber)
<label>Delivery Condition:</label>
@Html.DisplayFor(model => model.DeliveryCondition)
@using (Ajax.BeginForm("RegisterGoodsReceipt",FormMethod.Post, new AjaxOptions { OnSuccess = "OnSuccessRegisterGoodsReceipt", OnFailure = "OnFailureRegisterGoodsReceipt" }, null))
{
var items= Model.Items;
<table class="dataGrid">
@for (var i = 0; i < items.Count; i++)
{
var item = items[i];
<tr>
<td>@Html.DisplayFor(modelItem => item.Id)</td>
<td>@Html.DisplayFor(modelItem => item.ItemNumber)</td>
<td>
<input class="fullyDelivered" id="@(item.Id)" name="fullyDelivered" type="checkbox" />
<input type="text" id="deliveredQuantity@(item.Id)" name="DeliveredQuantity" value="@item.DeliveredQuantity"/>
</td>
</tr>
}
</table>
<button type="submit" class="button">Submit</button>
}
</div>
I want to submit the list of items to below action as below
public ActionResult RegisterGoodsReceipt(OrderSummaryViewModel order)
{
//to do
}
But it always go with null, i tried also to send it as list of items and it gives null also.
public ActionResult RegisterGoodsReceipt(List<OrderItem> items)
{
//to do
}
so any help regarding this issue?