I am trying to call a post action method of my controller from jquery dialog using ajax but unable to do that. I am sure there is something very small but couldn't find anything even after checking my code several times. Can somebody help me to identify the problem?
Javascript in my view:
$('a.actionLinkAttentionButton').click(function () {
var url = $(this).attr('href');
var dialogDiv = $('<div id="success" style="display:none;background-color:#efeeef;"></div>').appendTo('body');
dialogDiv.load(url, {},
function (responseText, textStatus, XMLHttpRequest) {
dialogDiv.dialog({
title: "Resolve log issue",
close: function (event, ui) {
dialogDiv.remove();
},
width: 600,
show: { effect: "blind", duration: 400 },
hide: { effect: "blind", duration: 500 },
modal: { backdrop: 'static', keyboard: false },
buttons: {
"Save": function () {
$.ajax({
url: '@Url.Action("ResolveLogPost","Attendance")',
type: "POST",
async: false,
data: $('ResolveLogForm', $(this)).serialize()
});
},
"Close": function () {
$(this).dialog('close');
},
},
success: function (response) {
dialogDiv.dialog('close');
},
dialogClass: 'no-close success-dialog'
});
});
return false;
});
Post action in my controller:
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult ResolveLogPost(BiometricLog model)
{
return PartialView();
}
Partial view:
@using (Html.BeginForm("ResolveLogPost", "Attendance", FormMethod.Post, new { enctype = "multipart/form-data", @id = "ResolveLogForm" }))
{
@Html.AntiForgeryToken()
<fieldset>
<legend>BiometricLogAction</legend>
<table class="ListTable" style="width:100%">
@Html.HiddenFor(model => model.EmployeeCode)
@Html.HiddenFor(model => model.date)
<tr><td colspan="2" style="background-color:#a6c100;color:white">@Html.Label("Log Details")</td></tr>
<tr>
<td style="width:200px;">@Html.LabelFor(model => model.LogDate)</td>
<td>@Html.DisplayFor(model => model.LogDate)</td>
</tr>
<tr>
<td>@Html.LabelFor(model => model.FinalInTime)</td>
<td>@Html.DisplayFor(model => model.FinalInTime)</td>
</tr>
<tr>
<td>@Html.LabelFor(model => model.FinalOutTime)</td>
<td>@Html.DisplayFor(model => model.FinalOutTime)</td>
</tr>
<tr>
<td>@Html.LabelFor(model => model.WorkingTime)</td>
<td>@Html.DisplayFor(model => model.WorkingTime)</td>
</tr>
</table>
<table>
<tr>
<td>@Html.CheckBoxFor(model => model.Accepted, new { @id = "chkprivate" })</td>
<td>@Html.LabelFor(model => model.Accepted)</td>
</tr>
</table>
<table>
<tr>
<td>@Html.LabelFor(model => model.ProofFileName)</td>
<td>@Html.TextBoxFor(m => m.ProofFileName, new { type="file", name = "file", @id="uploadfile"})</td>
</tr>
<tr>
<td>@Html.LabelFor(model => model.Remarks)</td>
<td>@Html.TextAreaFor(model => model.Remarks, new { style = "width:300px;" })</td>
</tr>
</table>
</fieldset>
}