public HttpResponseMessage UpdateAttendance(UpdateAttendance status) { HttpResponseMessage message; try { // ManpowerAttendanceDAL dal = new ManpowerAttendanceDAL(); var dynObj = new { result = _obj.UpdateAttendanceMaster(status) }; message = Request.CreateResponse(HttpStatusCode.OK, dynObj); } catch (Exception ex) { message = Request.CreateResponse(HttpStatusCode.BadRequest, new { msgText = "Something wrong. Try Again!" }); ErrorLog.CreateErrorMessage(ex, "ManpowerAttendance", "getAllStatus"); } return(message); }
public bool UpdateAttendanceMaster(UpdateAttendance objAttendance) { bool res = false; SqlCommand SqlCmd = new SqlCommand("spUpdateManpowerAttendance"); SqlCmd.CommandType = CommandType.StoredProcedure; SqlCmd.Parameters.AddWithValue("@Date", objAttendance.Date); SqlCmd.Parameters.AddWithValue("@ModifiedBy", objAttendance.ModifiedBy); SqlCmd.Parameters.Add(new SqlParameter("@Id", SqlDbType.Int)); SqlCmd.Parameters.Add(new SqlParameter("@ManpowerId", SqlDbType.Int)); SqlCmd.Parameters.Add(new SqlParameter("@AttendanceStatus", SqlDbType.Int)); SqlCmd.Parameters.Add(new SqlParameter("@ShiftMappingId", SqlDbType.Int)); SqlCmd.Parameters.Add(new SqlParameter("@Reason", SqlDbType.VarChar)); SqlCmd.Parameters.Add(new SqlParameter("@InTime", SqlDbType.DateTime)); SqlCmd.Parameters.Add(new SqlParameter("@OutTime", SqlDbType.DateTime)); SqlCmd.Parameters.Add(new SqlParameter("@OverTime", SqlDbType.Decimal)); foreach (var id in objAttendance.UpdateAtt) { if (SqlCmd.Connection != null) { if (SqlCmd.Connection.State == ConnectionState.Closed) { SqlCmd.Connection.Open(); } } SqlCmd.Parameters["@Id"].Value = id.Id; SqlCmd.Parameters["@ManpowerId"].Value = id.ManpowerId; SqlCmd.Parameters["@AttendanceStatus"].Value = id.StatusId; SqlCmd.Parameters["@ShiftMappingId"].Value = id.ShiftMappingId; SqlCmd.Parameters["@Reason"].Value = id.Reason; SqlCmd.Parameters["@InTime"].Value = ((id.InTime.Year == 1) ? (DateTime?)null : id.InTime); SqlCmd.Parameters["@OutTime"].Value = ((id.OutTime.Year == 1) ? (DateTime?)null : id.OutTime); SqlCmd.Parameters["@OverTime"].Value = id.OverTime; int result = _unitOfWork.DbLayer.ExecuteNonQuery(SqlCmd); if (result != Int32.MaxValue) { res = true; } } return(res); }