using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using Payroll.BO; using Ease.CoreV35; using Ease.Core.Model; using Ease.Core.Utility; using System.Windows; using HRM.BO; using HRM.DA; using System.IO; using Microsoft.Reporting.NETCore; using Org.BouncyCastle.Crypto.Parameters; using Org.BouncyCastle.Math.EC.Multiplier; using static HRM.BO.ADParameter; using static System.Net.Mime.MediaTypeNames; using NPOI.SS.Formula.Functions; using Microsoft.VisualBasic; using System.Net.NetworkInformation; namespace HRM.Report { public class AttendanceReport { List oAllDeducts; public byte[] GetMonthlyAttendanceReportNew(DateTime dFromDate, DateTime dToDate, string sEmpID, string reportType, int payrollTypeID) { DataRow tempDatarow = null; DataSet resultingDataSet = new DataSet(); string RDLCName = "HRM.Report.Attendence.RDLC.MonthlyAttendanceReportNew.rdlc"; int presentDays = 0, absentDays = 0, lateDays = 0, leaveDays = 0, weeklyHolidays = 0, osdDays = 0, festivalHolidays = 0; Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceReportNewDataTable oMonthlyAttendanceReportNewDataTable = new Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceReportNewDataTable(); DataSet AttendanceReportData = new DailyAttnProcessService().GetMonthlyAttendanceReportData(dFromDate, dToDate, sEmpID); if (AttendanceReportData != null && AttendanceReportData.Tables.Count > 0) { foreach (DataRow dr in AttendanceReportData.Tables[0].Rows) { tempDatarow = oMonthlyAttendanceReportNewDataTable.NewRow(); tempDatarow["DEPNAME"] = dr["DEPNAME"] != DBNull.Value ? dr["DEPNAME"].ToString() : string.Empty; tempDatarow["EMPLOYEENO"] = dr["EMPLOYEENO"] != DBNull.Value ? dr["EMPLOYEENO"].ToString() : string.Empty; tempDatarow["NAME"] = dr["NAME"] != DBNull.Value ? dr["NAME"].ToString() : string.Empty; tempDatarow["DESNAME"] = dr["DESNAME"] != DBNull.Value ? dr["DESNAME"].ToString() : string.Empty; tempDatarow["LOC"] = dr["LOC"] != DBNull.Value ? dr["LOC"].ToString() : string.Empty; tempDatarow["AttnDate"] = dr["AttnDate"] != DBNull.Value ? Convert.ToDateTime(dr["AttnDate"].ToString()).ToString("dd-MMM-yyyy") : string.Empty; tempDatarow["InTime"] = dr["InTime"] != DBNull.Value ? Convert.ToDateTime(dr["InTime"].ToString()).ToString("hh:mm tt") : string.Empty; tempDatarow["OutTime"] = dr["OutTime"] != DBNull.Value ? Convert.ToDateTime(dr["OutTime"].ToString()).ToString("hh:mm tt") : string.Empty; tempDatarow["WorkHour"] = dr["WorkHour"] != DBNull.Value ? Convert.ToDouble(dr["WorkHour"].ToString()).ToString("0.00") : string.Empty; tempDatarow["LateHour"] = dr["LateHour"] != DBNull.Value ? Convert.ToDouble(dr["LateHour"].ToString()).ToString("0.00") : string.Empty; tempDatarow["AttenType"] = dr["AttenType"] != DBNull.Value ? dr["AttenType"].ToString() : string.Empty; string tempAttnType = GlobalFunctions.GetShortAttnType((EnumAttendanceType)Convert.ToInt32(dr["AttenType"].ToString()), ref presentDays, ref absentDays, ref lateDays, ref leaveDays, ref weeklyHolidays, ref osdDays, ref festivalHolidays); tempDatarow["WorkDayName"] = dr["WorkDayName"] != DBNull.Value ? dr["WorkDayName"].ToString() : tempAttnType; oMonthlyAttendanceReportNewDataTable.Rows.Add(tempDatarow); } } oMonthlyAttendanceReportNewDataTable.TableName = "AttendenceDataSet_MonthlyAttendanceReportNew"; resultingDataSet.Tables.Add(oMonthlyAttendanceReportNewDataTable); List PReportParameters = SetExtraMonthlyAttendanceReportNewParameter(dFromDate, dToDate); return new ReportProcessor().CommonReportView(null, RDLCName, resultingDataSet, null, PReportParameters, true, payrollTypeID, reportType); } public List SetExtraMonthlyAttendanceReportNewParameter(DateTime fromDate, DateTime toDate) { List PReportParameters = new List(); ReportParameter oReportParameter = null; oReportParameter = new ReportParameter("FromDate", fromDate.ToString("dd-MMM-yyyy")); PReportParameters.Add(oReportParameter); oReportParameter = new ReportParameter("ToDate", toDate.ToString("dd-MMM-yyyy")); PReportParameters.Add(oReportParameter); return PReportParameters; } public byte[] GetMonthlyKPI(EnumAttendanceType eAttnType, DateTime dFromDate, DateTime dToDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); DataSet oMonthlyKPIDetail = null; oMonthlyKPIDetail = new DailyAttnProcessService().GetMonthlyKPIDetail(dFromDate, dToDate, sEmpID, eAttnType); //DataSet MonthlyKpiDetailsWithLeave = calculateLeave(oMonthlyKPIDetail); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MnthlyKPIDtlSummaryDataTable oMnthlyKPIDtlSummary = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MnthlyKPIDtlSummaryDataTable(); #region Summary Parts if (oMonthlyKPIDetail.Tables.Count > 0 && oMonthlyKPIDetail.Tables[0].Rows.Count > 0) { var groupedData = oMonthlyKPIDetail.Tables[0] .AsEnumerable() .GroupBy(x => x.Field("IDNo")) .Select(g => new { EmployeeNo = g.Key, OTSum = g.Sum(x => Convert.ToDouble(x["OTHour"].ToString())), OTAvg = g.Sum(x => Convert.ToDouble(x["OTHour"].ToString())) / g.Count(), OTGreaterThan5 = g.Count(x => Convert.ToDouble(x["OTHour"].ToString()) > 5) }) .ToList(); DataRow dRow = oMnthlyKPIDtlSummary.NewRow(); dRow["ManPower"] = groupedData.Count(); dRow["PerAvgOTGreater2"] = groupedData.Count(x => x.OTAvg > 2); dRow["PerSumOTGreater75"] = groupedData.Count(x => x.OTSum > 75); dRow["PerSumOTGreater100"] = groupedData.Count(x => x.OTSum > 100); dRow["PerSumOTGreater52"] = groupedData.Count(x => x.OTSum > 52); dRow["PerOneOTGreater5"] = groupedData.Count(x => x.OTGreaterThan5 > 0); oMnthlyKPIDtlSummary.Rows.Add(dRow); } #endregion oMnthlyKPIDtlSummary.TableName = "MnthlyKPIDtlSummary"; oMonthlyKPIDetail.Tables.Add(oMnthlyKPIDtlSummary); List _parameters = new List(); ReportParameter rParam = new ReportParameter("FromDate", dFromDate.ToString("dd MMM yyyy")); _parameters.Add(rParam); rParam = new ReportParameter("ToDate", dToDate.LastDateOfMonth().ToString("dd MMM yyyy")); _parameters.Add(rParam); string filePath = "HRM.Report.Attendence.RDLC.MonthlyAttendanceReport.rdlc"; return reportProcessor.CommonReportView(null, filePath, oMonthlyKPIDetail, null, _parameters, true, payrollTypeID, reportType); } #region for Schedular private DataSet RefreshDataSetForMailSender(DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid) { Attendence.AttendenceDataSet.AttendenceDataSet.DailyAttnReportForMailSenderDataTable attnData = new Attendence.AttendenceDataSet.AttendenceDataSet.DailyAttnReportForMailSenderDataTable(); List empDapForlastDay = new DailyAttnProcessService().AttendanceDataForMailSchedular(fromDate, toDate, attnType, payrollTypeid); List leaveEntrys = new LeaveEntryService().Get(fromDate, toDate, EnumLeaveStatus.OnApproval); List leaves = new LeaveService().GetLeaves(payrollTypeid); foreach (DailyAttnMailSenderReport item in empDapForlastDay) { LeaveEntry tempLeaveEntry = leaveEntrys.Find(le => le.EmpID == item.EmployeeId && le.AppliedFromDate <= item.AttnDate && le.AppliedToDate >= item.AttnDate); Leave tempLeave = tempLeaveEntry != null ? leaves.Find(l => l.ID == tempLeaveEntry.LeaveID) : null; DataRow dRow = attnData.NewRow(); dRow["EMPLOYEENO"] = item.EmployeeNo; dRow["NAME"] = item.Name; dRow["DESIGNATION"] = item.Designation; dRow["DEPARTMENT"] = item.Department; dRow["AttnDate"] = item.AttnDate.ToString("dd MMM yyyy"); dRow["day"] = item.Day; dRow["InTime"] = item.InTime != DateTime.MinValue ? item.InTime.ToString("hh:mm tt") : string.Empty; dRow["OutTime"] = item.OutTime != DateTime.MinValue ? item.OutTime.ToString("hh:mm tt") : string.Empty; dRow["AttnType"] = item.AttnType; dRow["NotPresentType"] = item.NotPresentType.Trim() != string.Empty ? item.NotPresentType.Trim() : tempLeave != null ? tempLeave.Description : item.AttnType; dRow["LINEMANAGERNO"] = item.LineManagerNo; dRow["LINEMANAGERNAME"] = item.LineManagerName; dRow["TotalWorkingHour"] = item.TotalWorkingHour != "0:0" ? item.TotalWorkingHour : string.Empty; dRow["LateCount"] = item.LateCount; attnData.Rows.Add(dRow); } DataSet DailyAttnMailSenderReportDs = new DataSet(); attnData.TableName = "AttendanceDataSet_DailyAttnReportForMailSender"; DailyAttnMailSenderReportDs.Tables.Add(attnData); return DailyAttnMailSenderReportDs; } private DataSet RefreshDataSetForMonthlyAttendanceSummaryCordinator(int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid) { DataSet monthlyAttendanceSummaryDataSet = new DataSet(); //Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceSummaryDataTable oDTable = new Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceSummaryDataTable(); //List empDapForlastDay = new DailyAttnProcessService().AttendanceDataForMailSchedular(fromDate, toDate, attnType, payrollTypeid); //List leaveEntrys = new LeaveEntryService().Get(fromDate, toDate, EnumLeaveStatus.OnApproval); List leaves = new LeaveService().GetLeaves(payrollTypeid); //List monthlyAttendanceSummary = new DailyAttnProcessService().MonthlyAttendanceSummaryForMailSchedular(fromDate, toDate, attnType, payrollTypeid); monthlyAttendanceSummaryDataSet = new DailyAttnProcessService().MonthlyAttendanceSummaryForMailSchedularCordinator(id, fromDate, toDate, attnType, payrollTypeid); DataTable oDTable = new DataTable(); oDTable.Columns.Add("SlNo"); oDTable.Columns.Add("ID"); oDTable.Columns.Add("Name"); oDTable.Columns.Add("Position"); oDTable.Columns.Add("OrgUnit"); oDTable.Columns.Add("WorkDays"); oDTable.Columns.Add("TotAttend"); oDTable.Columns.Add("TotAbsent"); oDTable.Columns.Add("TotLate"); oDTable.Columns.Add("TotLeave"); DataRow oDR = null; int serial = 1; foreach (DataRow oDRow in monthlyAttendanceSummaryDataSet.Tables[0].Rows) { oDR = oDTable.NewRow(); oDR["SlNo"] = serial.ToString(); oDR["ID"] = oDRow["EMPLOYEENO"]; oDR["Name"] = oDRow["Name"]; oDR["Position"] = oDRow["Designation"]; oDR["OrgUnit"] = " "; oDR["WorkDays"] = oDRow["TotalWorkingDays"]; oDR["TotAttend"] = oDRow["TotalAttendedDays"]; oDR["TotAbsent"] = oDRow["TotalAbsentDays"]; oDR["TotLate"] = oDRow["TotalLateDays"]; oDR["TotLeave"] = oDRow["TotalLeaveDays"]; oDTable.Rows.Add(oDR); serial++; } DataSet MonthlyAttendanceSummary = new DataSet(); oDTable.TableName = "AttendanceDataSet_MonthlyAttendanceSummary"; MonthlyAttendanceSummary.Tables.Add(oDTable); return MonthlyAttendanceSummary; } private DataSet RefreshDataSetForMonthlyAttendanceSummary(int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid) { DataSet monthlyAttendanceSummaryDataSet = new DataSet(); //Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceSummaryDataTable oDTable = new Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttendanceSummaryDataTable(); //List empDapForlastDay = new DailyAttnProcessService().AttendanceDataForMailSchedular(fromDate, toDate, attnType, payrollTypeid); //List leaveEntrys = new LeaveEntryService().Get(fromDate, toDate, EnumLeaveStatus.OnApproval); List leaves = new LeaveService().GetLeaves(payrollTypeid); //List monthlyAttendanceSummary = new DailyAttnProcessService().MonthlyAttendanceSummaryForMailSchedular(fromDate, toDate, attnType, payrollTypeid); monthlyAttendanceSummaryDataSet = new DailyAttnProcessService().MonthlyAttendanceSummaryForMailSchedular(id, fromDate, toDate, attnType, payrollTypeid); DataTable oDTable = new DataTable(); oDTable.Columns.Add("SlNo"); oDTable.Columns.Add("ID"); oDTable.Columns.Add("Name"); oDTable.Columns.Add("Position"); oDTable.Columns.Add("OrgUnit"); oDTable.Columns.Add("WorkDays"); oDTable.Columns.Add("TotAttend"); oDTable.Columns.Add("TotAbsent"); oDTable.Columns.Add("TotLate"); oDTable.Columns.Add("TotLeave"); DataRow oDR = null; int serial = 1; foreach (DataRow oDRow in monthlyAttendanceSummaryDataSet.Tables[0].Rows) { oDR = oDTable.NewRow(); oDR["SlNo"] = serial; oDR["ID"] = oDRow["EMPLOYEENO"]; oDR["Name"] = oDRow["Name"]; oDR["Position"] = oDRow["Designation"]; oDR["OrgUnit"] = " "; oDR["WorkDays"] = oDRow["TotalWorkingDays"]; oDR["TotAttend"] = oDRow["TotalAttendedDays"]; oDR["TotAbsent"] = oDRow["TotalAbsentDays"]; oDR["TotLate"] = oDRow["TotalLateDays"]; oDR["TotLeave"] = oDRow["TotalLeaveDays"]; oDTable.Rows.Add(oDR); serial++; } DataSet MonthlyAttendanceSummary = new DataSet(); oDTable.TableName = "AttendanceDataSet_MonthlyAttendanceSummary"; MonthlyAttendanceSummary.Tables.Add(oDTable); return MonthlyAttendanceSummary; } public byte[] GetDailyAttnReport(DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid, string fileFormate = "PDF", bool hideColumn = false) { ReportProcessor reportProcessor = new ReportProcessor(); string rdlcName = "HRM.Report.Attendence.RDLC.EmpDailyAttnReportForMailSender.rdlc"; // build action of this rdlc has to be embedded resource string reportTitle = "Daily Attendance Report"; DataSet tempDataSet = RefreshDataSetForMailSender(fromDate, toDate, attnType, payrollTypeid); return reportProcessor.ShowReportForSchedular(null, rdlcName, tempDataSet, null, true, reportTitle, fileFormate, hideColumn); } public byte[] GetWeeklyAttnReport(DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid, string fileFormate = "PDF") { ReportProcessor reportProcessor = new ReportProcessor(); string rdlcName = "HRM.Report.Attendence.RDLC.EmpWeeklyAttnReportForMailSender.rdlc"; // build action of this rdlc has to be embedded resource string reportTitle = "Weekly Attendance Report From " + fromDate.ToString("dd MMM yyyy") + " to " + toDate.ToString("dd MMM yyyy"); DataSet tempDataSet = RefreshDataSetForMailSender(fromDate, toDate, attnType, payrollTypeid); return reportProcessor.ShowReportForSchedular(null, rdlcName, tempDataSet, null, true, reportTitle, fileFormate); } public byte[] GetMonthlyAttnReport(DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid, string fileFormate = "PDF") { ReportProcessor reportProcessor = new ReportProcessor(); string rdlcName = "HRM.Report.Attendence.RDLC.EmpMonthlyAttnReportForMailSender.rdlc"; // build action of this rdlc has to be embedded resource string reportTitle = "SPP Attendance Report: For the month of " + fromDate.ToString("MMMM yyyy"); DataSet tempDataSet = RefreshDataSetForMailSender(fromDate, toDate, attnType, payrollTypeid); return reportProcessor.ShowReportForSchedular(null, rdlcName, tempDataSet, null, true, reportTitle, fileFormate); } public byte[] GetMonthlyAttendanceSummary(int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid, string fileFormate = "PDF") { ReportProcessor reportProcessor = new ReportProcessor(); string rdlcName = "HRM.Report.Attendence.RDLC.MonthlyAttendanceSummary.rdlc"; // build action of this rdlc has to be embedded resource string reportTitle = "Monthly Attendance Summary: For the month of " + (fromDate.AddMonths(-1)).ToString("MMMM yyyy"); DataSet tempDataSet = RefreshDataSetForMonthlyAttendanceSummary(id, fromDate, toDate, attnType, payrollTypeid); return reportProcessor.ShowReportForSchedular(null, rdlcName, tempDataSet, null, true, reportTitle, fileFormate); } public byte[] GetMonthlyAttendanceSummaryCordinator(int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid, string fileFormate = "PDF") { ReportProcessor reportProcessor = new ReportProcessor(); string rdlcName = "HRM.Report.Attendence.RDLC.MonthlyAttendanceSummary.rdlc"; // build action of this rdlc has to be embedded resource string reportTitle = "Monthly Attendance Summary: For the month of " + (fromDate.AddMonths(-1)).ToString("MMMM yyyy"); DataSet tempDataSet = RefreshDataSetForMonthlyAttendanceSummaryCordinator(id, fromDate, toDate, attnType, payrollTypeid); return reportProcessor.ShowReportForSchedular(null, rdlcName, tempDataSet, null, true, reportTitle, fileFormate); } #endregion private DataSet calculateLeave(DataSet oMonthlyKPIDetail) { DataSet dsMonthlyKPIDetail = oMonthlyKPIDetail; DataTable dtMonthlyKPIDetail = oMonthlyKPIDetail.Tables[0]; return dsMonthlyKPIDetail; } public byte[] ShowDateRangeJobCardMultiple(DateTime dFromDate, DateTime dToDate, string sEmpID, int payrollTypeId, string reportType) { if (dFromDate > dToDate) { var temp = dFromDate; dFromDate = dToDate; dToDate = temp; } List oEmp = new EmployeeService().GetByEmpIDs(sEmpID, payrollTypeId); List oDepartment = new DepartmentService().GetAll(payrollTypeId); List oDesignation = new DesignationService().GetAll(payrollTypeId); String RDLC = string.Empty; HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable oSubDataTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewDataTable dTableParent = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewDataTable(); foreach (Employee emp in oEmp) { try { List oTHours = new List(); List latehours = new List(); Department tempDepartment = emp.DepartmentID != null ? oDepartment.Find(item => item.ID == emp.DepartmentID) : null; Designation tempDesignation = emp.DesignationID != null ? oDesignation.Find(item => item.ID == emp.DesignationID) : null; DataTable tempSub = GetEmpDailyAttn(emp.ID, dFromDate, dToDate, payrollTypeId); foreach (DataRow dr in tempSub.Rows) { var dRowSub = oSubDataTable.NewRow(); dRowSub["EmpNo"] = emp.EmployeeNo; dRowSub["Date"] = dr["Date"]; dRowSub["InTime"] = dr["InTime"]; dRowSub["OutTime"] = dr["OutTime"]; dRowSub["LateBy"] = dr["LateBy"]; dRowSub["OTHr"] = dr["OTHr"]; dRowSub["Status"] = dr["Status"]; dRowSub["Remarks"] = dr["Remarks"]; dRowSub["Shift"] = dr["Shift"]; dRowSub["AttnType"] = dr["AttnType"]; dRowSub["Description"] = dr["Description"]; dRowSub["Amount"] = dr["Amount"]; dRowSub["WorkPlanGroup"] = dr["WorkPlanGroup"]; dRowSub["AttnDate"] = dr["AttnDate"]; dRowSub["Day"] = dr["Day"]; dRowSub["WorkingHour"] = dr["WorkingHour"]; dRowSub["InTimeShow"] = dr["InTimeShow"]; oSubDataTable.Rows.Add(dRowSub); string oTHour = Convert.ToString(dr["OTHr"]); string latehour = Convert.ToString(dr["LateBy"]); oTHours.Add(oTHour); latehours.Add(latehour); } string totalOT = GlobalFunctions.GetHourMinutes(oTHours); string totalLateHour = GlobalFunctions.GetHourMinutes(latehours); var dRowParent = dTableParent.NewRow(); dRowParent["EmpNo"] = emp.EmployeeNo.ToString(); dRowParent["Name"] = emp.Name.ToString(); dRowParent["Designation"] = tempDesignation != null ? tempDesignation.Name : string.Empty; dRowParent["Department"] = tempDepartment != null ? tempDepartment.Name : string.Empty; //dRowParent["JoiningDate"] = emp.Grade == null ? "" : emp.JoiningDate.ToString("dd MMM yyyy"); dRowParent["JoiningDate"] = emp.JoiningDate != DateTime.MinValue ? emp.JoiningDate.ToString("dd MMM yyyy") : string.Empty; dRowParent["FromDate"] = dFromDate.ToString("dd MMM yyyy"); dRowParent["ToDate"] = dToDate.ToString("dd MMM yyyy"); dRowParent["TotalLate"] = totalLateHour; dRowParent["TotalOT"] = totalOT; dTableParent.Rows.Add(dRowParent); } catch (Exception ex) { throw; } } DataSet dSetSub = new DataSet(); oSubDataTable.TableName = "AttendenceDataSet_EmpDailyAttn"; dSetSub.Tables.Add(oSubDataTable); DataSet dSetParent = new DataSet(); dTableParent.TableName = "AttendenceDataSet_EmpDailyAttnParentNew"; dSetParent.Tables.Add(dTableParent); RDLC = "HRM.Report.Attendence.RDLC.DateRangeMultipleJobCardNew.rdlc"; return new ReportProcessor().CommonReportView(null, RDLC, dSetParent, dSetSub, null, true, payrollTypeId, reportType); } public byte[] ShowDateRangeJobCardMultipleForLiFung(DateTime fromDate, string sEmpID, int payrollTypeId, string reportType) { DateTime dFromDate = GlobalFunctions.FirstDateOfMonth(fromDate); DateTime dToDate = GlobalFunctions.LastDateOfMonth(dFromDate); if (dFromDate > dToDate) { var temp = dFromDate; dFromDate = dToDate; dToDate = temp; } List oEmp = new EmployeeService().GetByEmpIDs(sEmpID, payrollTypeId); List oDepartment = new DepartmentService().GetAll(payrollTypeId); List oDesignation = new DesignationService().GetAll(payrollTypeId); String RDLC = string.Empty; HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable oSubDataTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable dTableParent = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable(); foreach (Employee emp in oEmp) { try { List oTHours = new List(); List latehours = new List(); Department tempDepartment = emp.DepartmentID != null ? oDepartment.Find(item => item.ID == emp.DepartmentID) : null; Designation tempDesignation = emp.DesignationID != null ? oDesignation.Find(item => item.ID == emp.DesignationID) : null; DataTable tempSub = GetEmpDailyAttn(emp.ID, dFromDate, dToDate, payrollTypeId); foreach (DataRow dr in tempSub.Rows) { var dRowSub = oSubDataTable.NewRow(); dRowSub["EmpNo"] = emp.EmployeeNo; dRowSub["Date"] = dr["Date"]; dRowSub["InTime"] = dr["InTime"]; dRowSub["OutTime"] = dr["OutTime"]; dRowSub["LateBy"] = dr["LateBy"]; dRowSub["OTHr"] = dr["OTHr"]; dRowSub["Status"] = dr["Status"]; dRowSub["Remarks"] = dr["Remarks"]; dRowSub["Shift"] = dr["Shift"]; dRowSub["AttnType"] = dr["AttnType"]; dRowSub["Description"] = dr["Description"]; dRowSub["Amount"] = dr["Amount"]; dRowSub["WorkPlanGroup"] = dr["WorkPlanGroup"]; dRowSub["AttnDate"] = dr["AttnDate"]; dRowSub["Day"] = dr["Day"]; dRowSub["WorkingHour"] = dr["WorkingHour"]; dRowSub["InTimeShow"] = dr["InTimeShow"]; oSubDataTable.Rows.Add(dRowSub); string oTHour = Convert.ToString(dr["OTHr"]); string latehour = Convert.ToString(dr["LateBy"]); oTHours.Add(oTHour); latehours.Add(latehour); } string totalOT = GlobalFunctions.GetHourMinutes(oTHours); string totalLateHour = GlobalFunctions.GetHourMinutes(latehours); var dRowParent = dTableParent.NewRow(); dRowParent["EmpNo"] = emp.EmployeeNo.ToString(); dRowParent["Name"] = emp.Name.ToString(); dRowParent["Designation"] = tempDesignation != null ? tempDesignation.Name : string.Empty; dRowParent["Department"] = tempDepartment != null ? tempDepartment.Name : string.Empty; dRowParent["Division"] = tempDepartment.ParentID==null?"": oDepartment.Find(item => item.ID == tempDepartment.ParentID).Name; //dRowParent["JoiningDate"] = emp.Grade == null ? "" : emp.JoiningDate.ToString("dd MMM yyyy"); dRowParent["JoiningDate"] = emp.JoiningDate != DateTime.MinValue ? emp.JoiningDate.ToString("dd MMM yyyy") : string.Empty; dRowParent["FromDate"] = dFromDate.ToString("dd MMM yyyy"); dRowParent["ToDate"] = dToDate.ToString("dd MMM yyyy"); dRowParent["TotalLate"] = totalLateHour; dRowParent["TotalOT"] = totalOT; dTableParent.Rows.Add(dRowParent); } catch (Exception ex) { throw; } } DataSet dSetSub = new DataSet(); oSubDataTable.TableName = "AttendenceDataSet_EmpDailyAttn"; dSetSub.Tables.Add(oSubDataTable); DataSet dSetParent = new DataSet(); dTableParent.TableName = "AttendenceDataSet_EmpDailyAttnParentNew"; dSetParent.Tables.Add(dTableParent); RDLC = "HRM.Report.Attendence.RDLC.DateRangeMultipleJobCardNewLiFung.rdlc"; return new ReportProcessor().CommonReportView(null, RDLC, dSetParent, dSetSub, null, true, payrollTypeId, reportType); //return new ReportProcessor().CommonReportViewer(null, RDLC, dSetParent, dSetSub, null, payrollTypeId); } public byte[] ShowDateRangeJobCardSingleForLiFung(DateTime fromDate, string sEmpID, int payrollTypeId, string reportType) { DateTime dFromDate = GlobalFunctions.FirstDateOfMonth(fromDate); DateTime dToDate = GlobalFunctions.LastDateOfMonth(dFromDate); if (dFromDate > dToDate) { var temp = dFromDate; dFromDate = dToDate; dToDate = temp; } List oEmp = new EmployeeService().GetByEmpIDs(sEmpID, payrollTypeId); List oDepartment = new DepartmentService().GetAll(payrollTypeId); List oDesignation = new DesignationService().GetAll(payrollTypeId); String RDLC = string.Empty; HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable oSubDataTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable dTableParent = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable(); foreach (Employee emp in oEmp) { try { List oTHours = new List(); List latehours = new List(); Department tempDepartment = emp.DepartmentID != null ? oDepartment.Find(item => item.ID == emp.DepartmentID) : null; Designation tempDesignation = emp.DesignationID != null ? oDesignation.Find(item => item.ID == emp.DesignationID) : null; DataTable tempSub = GetEmpDailyAttn(emp.ID, dFromDate, dToDate, payrollTypeId); foreach (DataRow dr in tempSub.Rows) { var dRowSub = oSubDataTable.NewRow(); dRowSub["EmpNo"] = emp.EmployeeNo; dRowSub["Date"] = dr["Date"]; dRowSub["InTime"] = dr["InTime"]; dRowSub["OutTime"] = dr["OutTime"]; dRowSub["LateBy"] = dr["LateBy"]; dRowSub["OTHr"] = dr["OTHr"]; dRowSub["Status"] = dr["Status"]; dRowSub["Remarks"] = dr["Remarks"]; dRowSub["Shift"] = dr["Shift"]; dRowSub["AttnType"] = dr["AttnType"]; dRowSub["Description"] = dr["Description"]; dRowSub["Amount"] = dr["Amount"]; dRowSub["WorkPlanGroup"] = dr["WorkPlanGroup"]; dRowSub["AttnDate"] = dr["AttnDate"]; dRowSub["Day"] = dr["Day"]; dRowSub["WorkingHour"] = dr["WorkingHour"]; dRowSub["InTimeShow"] = dr["InTimeShow"]; oSubDataTable.Rows.Add(dRowSub); string oTHour = Convert.ToString(dr["OTHr"]); string latehour = Convert.ToString(dr["LateBy"]); oTHours.Add(oTHour); latehours.Add(latehour); } string totalOT = GlobalFunctions.GetHourMinutes(oTHours); string totalLateHour = GlobalFunctions.GetHourMinutes(latehours); var dRowParent = dTableParent.NewRow(); dRowParent["EmpNo"] = emp.EmployeeNo.ToString(); dRowParent["Name"] = emp.Name.ToString(); dRowParent["Designation"] = tempDesignation != null ? tempDesignation.Name : string.Empty; dRowParent["Department"] = tempDepartment != null ? tempDepartment.Name : string.Empty; dRowParent["Division"] = oDepartment.Find(item => item.ID == tempDepartment.ParentID).Name; //dRowParent["JoiningDate"] = emp.Grade == null ? "" : emp.JoiningDate.ToString("dd MMM yyyy"); dRowParent["JoiningDate"] = emp.JoiningDate != DateTime.MinValue ? emp.JoiningDate.ToString("dd MMM yyyy") : string.Empty; dRowParent["FromDate"] = dFromDate.ToString("dd MMM yyyy"); dRowParent["ToDate"] = dToDate.ToString("dd MMM yyyy"); dRowParent["TotalLate"] = totalLateHour; dRowParent["TotalOT"] = totalOT; dTableParent.Rows.Add(dRowParent); } catch (Exception ex) { throw; } } DataSet dSetSub = new DataSet(); oSubDataTable.TableName = "AttendenceDataSet_EmpDailyAttn"; dSetSub.Tables.Add(oSubDataTable); DataSet dSetParent = new DataSet(); dTableParent.TableName = "AttendenceDataSet_EmpDailyAttnParentNew"; dSetParent.Tables.Add(dTableParent); RDLC = "HRM.Report.Attendence.RDLC.DateRangeMultipleJobCardNewLiFung.rdlc"; return new ReportProcessor().CommonReportView(null, RDLC, dSetParent, dSetSub, null, true, payrollTypeId, reportType); //RDLC = "DateRangeMultipleJobCardNewLiFung.rdlc"; //return new ReportProcessor().CommonReportViewer(null, RDLC, dSetParent, dSetSub, null, payrollTypeId); } public byte[] GetAttendanceSummaryForLiFung(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); DataSet oAttendanceSummary = null; oAttendanceSummary = new DailyAttnProcessService().GetMonthlyAttn(GlobalFunctions.FirstDateOfMonth(dFromDate), GlobalFunctions.LastDateOfMonth(dFromDate), sEmpID); List oDepartment = new DepartmentService().GetAll(payrollTypeID); //DataSet MonthlyKpiDetailsWithLeave = calculateLeave(oAttendanceSummary); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttnDataTable oAttendanceSummaryDTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttnDataTable(); #region Summary Parts foreach (DataRow Dr in oAttendanceSummary.Tables[0].Rows) { DataRow dRow = oAttendanceSummaryDTable.NewRow(); Employee emp = new EmployeeService().GetFromAll(Dr["EMPLOYEENO"].ToString(), payrollTypeID); Department tempDepartment = emp.DepartmentID != null ? oDepartment.Find(item => item.ID == emp.DepartmentID) : null; dRow["EmpNo"] = Dr["EMPLOYEENO"]; dRow["Name"] = Dr["NAME"]; dRow["CardNo"] = Dr["CardNo"].ToString(); dRow["Designation"] = Dr["Designation"]; dRow["Grade"] = Dr["Grade"]; dRow["Division"] = tempDepartment.ParentID==null? "": oDepartment.Find(item => item.ID == tempDepartment.ParentID).Name; dRow["JoinDate"] = Convert.ToDateTime(Dr["JOININGDATE"]).ToString("dd MMM yyyy"); dRow["GrossSalary"] = Convert.ToDouble(Dr["GROSSSALARY"]); dRow["Present"] = Dr["Present"] is DBNull ? 0 : Dr["Present"]; dRow["Department"] = Dr["Department"].ToString(); dRow["Section"] = Dr["Section"].ToString(); dRow["Line"] = Dr["Line"].ToString(); dRow["Floor"] = Dr["Floor"].ToString(); dRow["Late"] = Dr["Late"] is DBNull ? 0 : Dr["Late"]; dRow["Absent"] = Dr["Absent"] is DBNull ? 0 : Dr["Absent"]; dRow["Holiday"] = Dr["Holiday"] is DBNull ? 0 : Dr["Holiday"]; dRow["Leave"] = Dr["Leave"] is DBNull ? 0 : Dr["Leave"]; dRow["TotalAttn"] = Dr["TotalAttn"]; dRow["TotalOT"] = Convert.ToDouble(Dr["TotalOT"]).ToString("0.00"); dRow["TotalOTDBL"] = Convert.ToDouble(Dr["TotalOT"]); dRow["Remarks"] = ""; oAttendanceSummaryDTable.Rows.Add(dRow); } #endregion oAttendanceSummaryDTable.TableName = "AttendenceDataSet_MonthlyAttn"; oAttendanceSummary.Tables.Add(oAttendanceSummaryDTable); List _parameters = new List(); ReportParameter rParam = new ReportParameter("FromDate", GlobalFunctions.FirstDateOfMonth(dFromDate).ToString("dd MMM yyyy")); _parameters.Add(rParam); rParam = new ReportParameter("ToDate", GlobalFunctions.LastDateOfMonth(dFromDate).ToString("dd MMM yyyy")); _parameters.Add(rParam); string filePath = "HRM.Report.Attendence.RDLC.MonthlyAttnLiFung.rdlc"; //return new ReportProcessor().CommonReportView(null, oAttendanceSummary, null, filePath, _parameters, true, payrollTypeID, reportType); return new ReportProcessor().CommonReportView(null, filePath, oAttendanceSummary, null, _parameters, true, payrollTypeID, reportType); } public byte[] DailyPresentForLiFung(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); DateTime attnDate = dFromDate; //string sEmpID = sEmpID; DataRow oDR = null; DataSet oDailyInOut = null; //new DailyAttnProcessService().GetDailyDataByStatus(attnDate, sEmpID, EnumAttendanceType.Present, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.Delay, EnumAttendanceType.On_Business_Travel, EnumAttendanceType.OutSideDuty); //oDailyInOut = new DailyAttnProcessService().GetDailyDataByStatus(attnDate, sEmpID, EnumAttendanceType.Present, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.Delay, EnumAttendanceType.HalfDay, EnumAttendanceType.OutSideDuty); oDailyInOut = new DailyAttnProcessService().GetDailyDataByStatus(attnDate, sEmpID, EnumAttendanceType.Present, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.Delay, EnumAttendanceType.OutSideDuty); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable dTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable(); foreach (DataRow Dr in oDailyInOut.Tables[0].Rows) { oDR = dTable.NewRow(); oDR["EmployeeNo"] = Dr["EMPLOYEENO"]; oDR["Name"] = Dr["Name"]; oDR["Designation"] = Dr["Designation"]; oDR["InTime"] = Dr["InTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["InTime"]).ToString("HH:mm"); oDR["OutTime"] = Dr["OutTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["OutTime"]).ToString("HH:mm"); oDR["EmpType"] = Dr["EmpType"].ToString(); oDR["Status"] = GlobalFunctions.GetShortAttnType((EnumAttendanceType)Convert.ToInt32(Dr["Status"])); oDR["OTHour"] = GlobalFunctions.ConvertDoubleHourToHourMinute(Convert.ToDouble(Dr["OTHour"])); oDR["OTHourDBL"] = Convert.ToDouble(Dr["OTHour"]); oDR["DeptID"] = Convert.ToInt32(Dr["DeptID"].ToString()); oDR["DeptName"] = Dr["DeptName"].ToString(); oDR["Department"] = Dr["Department"].ToString(); oDR["Section"] = Dr["Section"].ToString(); oDR["Line"] = Dr["Line"].ToString(); oDR["Floor"] = Dr["Floor"].ToString(); oDR["Shift"] = Dr["Shift"].ToString(); oDR["CardNo"] = Dr["CardNo"].ToString(); dTable.Rows.Add(oDR); } DataSet dSet = new DataSet(); dTable.TableName = "AttendenceDataSet_DailyInOut"; dSet.Tables.Add(dTable); //string RDLC = "HRM.Report.Attendence.RDLC.DailyPresent.rdlc"; string RDLC = "DailyPresentLiFung.rdlc"; List _reportParameters = new List(); ReportParameter rParam = new ReportParameter("AttnDate", attnDate.ToString("dd MMM yyyy")); _reportParameters.Add(rParam); //rParam = new ReportParameter("Fax", ""); //_reportParameters.Add(rParam); //rParam = new ReportParameter("Email", systemInfo.email); //_reportParameters.Add(rParam); return new ReportProcessor().CommonReportViewer(null, RDLC, dSet, _reportParameters, payrollTypeID); //return reportProcessor.AttendanceReportsView(null, dSet, null, RDLC, _reportParameters, true, payrollTypeID, reportType); //AttendanceReportView(reportItem, dSet, dSubReportDataSet, reportName, parameters, defaultParameterNeeded, payrollTypeId, reportType) } public byte[] DailyAbsentForLiFung(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); DateTime attnDate = dFromDate; DataSet oDailyInOut = null; DataRow oDR = null; oDailyInOut = new DailyAttnProcessService().GetDailyDataByStatus(attnDate, sEmpID, EnumAttendanceType.Absent); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable dTable = new Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable(); foreach (DataRow Dr in oDailyInOut.Tables[0].Rows) { oDR = dTable.NewRow(); oDR["EmployeeNo"] = Dr["EMPLOYEENO"]; oDR["Name"] = Dr["Name"]; oDR["Designation"] = Dr["Designation"]; oDR["InTime"] = Dr["InTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["InTime"]).ToString("HH:mm tt"); oDR["OutTime"] = Dr["OutTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["OutTime"]).ToString("HH:mm tt"); oDR["EmpType"] = Dr["EmpType"].ToString(); oDR["Status"] = GlobalFunctions.GetShortAttnType(((EnumAttendanceType)Convert.ToInt32(Dr["Status"]))); oDR["OTHour"] = GlobalFunctions.ConvertDoubleHourToHourMinute(Convert.ToDouble(Dr["OTHour"])); oDR["OTHourDBL"] = Convert.ToDouble(Dr["OTHour"]); oDR["DeptID"] = Convert.ToInt32(Dr["DeptID"].ToString()); oDR["DeptName"] = Dr["DeptName"].ToString(); oDR["Department"] = Dr["Department"].ToString(); oDR["Section"] = Dr["Section"].ToString(); oDR["Line"] = Dr["Line"].ToString(); oDR["Floor"] = Dr["Floor"].ToString(); oDR["Shift"] = Dr["Shift"].ToString(); oDR["CardNo"] = Dr["CardNo"].ToString(); dTable.Rows.Add(oDR); } DataSet dSet = new DataSet(); dTable.TableName = "AttendenceDataSet_DailyInOut"; dSet.Tables.Add(dTable); string RDLC = "DailyAbsentLiFung.rdlc"; ReportParameter rParam; List _reportParameters = new List(); rParam = new ReportParameter("AttnDate", attnDate.ToString("dd MMM yyyy")); _reportParameters.Add(rParam); //return reportProcessor.AttendanceReportsView(null, dSet, null, RDLC, _reportParameters, true, payrollTypeID, reportType); return reportProcessor.CommonReportViewer(null, RDLC, dSet, _reportParameters, payrollTypeID); } public byte[] DailyOddForLiFung(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); //DateTime attnFromDate, attnToDate; DateTime attnFromDate = dFromDate; var sinMissingHour = new SystemConfigarationService().GetconfigValue(EnumConfigurationType.Logic, "overtime", "inmissinghour"); double inMissingHour = 0; if (sinMissingHour != null) inMissingHour = Convert.ToDouble(sinMissingHour); //if (dFromDate <= dToDate) //{ // attnFromDate = dFromDate; // attnToDate = dToDate.Date.AddDays(1).AddSeconds(-1); //} //else //{ // attnFromDate = dToDate; // attnToDate = dFromDate.Date.AddDays(1).AddSeconds(-1); //} List shifts = new ShiftService().GetAllShift(); DataSet oDailyInOut = null; DataRow oDR = null; //oDailyInOut = new EchoTexExceptionReportService().GetDateRangeDataByStatus(attnFromDate, attnToDate, sEmpID, EnumAttendanceType.Present, EnumAttendanceType.Delay, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.OutSideDuty, EnumAttendanceType.HalfDay); oDailyInOut = new DailyAttnProcessService().GetDailyOddDataByStatusReportDataset(dFromDate, sEmpID); Attendence.AttendenceDataSet.AttendenceDataSet.InOutMissingDataTable dTable = new Attendence.AttendenceDataSet.AttendenceDataSet.InOutMissingDataTable(); DateTime Intime, OutTime, AttnDate, ShiftInTime, ShiftOutTime; foreach (DataRow Dr in oDailyInOut.Tables[0].Rows) { Intime = DateTime.MinValue; OutTime = DateTime.MinValue; oDR = dTable.NewRow(); oDR["EmployeeNo"] = Dr["EMPLOYEENO"]; oDR["Name"] = Dr["Name"]; oDR["Designation"] = Dr["Designation"]; //oDR["EmpType"] = Dr["EmpType"].ToString(); oDR["Status"] = GlobalFunctions.GetShortAttnType((EnumAttendanceType)Convert.ToInt32(Dr["Status"])); oDR["OTHour"] = GlobalFunctions.ConvertDoubleHourToHourMinute(Convert.ToDouble(Dr["OTHour"])); //oDR["OTHourDBL"] = Convert.ToDouble(Dr["OTHour"]); //oDR["DeptID"] = Convert.ToInt32(Dr["DeptID"].ToString()); oDR["DeptName"] = Dr["DeptName"].ToString(); oDR["Shift"] = Dr["Shift"].ToString(); //oDR["CardNo"] = Dr["CardNo"].ToString(); oDR["AttnDate"] = Convert.ToDateTime(Dr["attndate"]).ToString("dd MMM yyyy"); if (Dr["OutTime"] is DBNull) { Intime = Convert.ToDateTime(Dr["InTime"]); oDR["InTime"] = Intime.ToString("HH:mm"); oDR["OutTime"] = string.Empty; //oDR["MissingStatus"] = "Out Time Missing"; } else { OutTime = Convert.ToDateTime(Dr["OutTime"]); oDR["InTime"] = string.Empty; oDR["OutTime"] = OutTime.ToString("HH:mm"); //oDR["MissingStatus"] = "In Time Missing"; } ////oDR["Floor"] = Dr["Floor"].ToString(); ////oDR["Section"] = Dr["Section"].ToString(); ////oDR["Line"] = Dr["Line"].ToString(); //Shift shft = shifts.SingleOrDefault(x => x.ID == Convert.ToInt32(Dr["ShiftID"].ToString())); //if (shft != null) //{ // ShiftInTime = new DateTime(AttnDate.Year, AttnDate.Month, AttnDate.Day, shft.InTime.Hour, shft.InTime.Minute, shft.InTime.Second); // ShiftOutTime = new DateTime(AttnDate.Year, AttnDate.Month, AttnDate.Day, shft.OutTime.Hour, shft.OutTime.Minute, shft.OutTime.Second); // if (ShiftInTime > ShiftOutTime) // ShiftOutTime = ShiftOutTime.AddDays(1); // oDR["ShiftIn"] = ShiftInTime.ToString("HH:mm"); // oDR["ShiftOut"] = ShiftOutTime.ToString("HH:mm"); // if (Intime == DateTime.MinValue && ShiftInTime.AddHours(inMissingHour) < Intime) // { // oDR["OutTime"] = oDR["InTime"].ToString(); // oDR["InTime"] = string.Empty; // oDR["MissingStatus"] = "In Time Missing"; // } //} dTable.Rows.Add(oDR); } DataSet dSet = new DataSet(); dTable.TableName = "AttendenceDataSet_InOutMissing"; dSet.Tables.Add(dTable); string RDLC = "DailyOddStatusLiFung.rdlc"; ReportParameter rParam; List _reportParameters = new List(); rParam = new ReportParameter("AttnFromDate", attnFromDate.ToString("dd MMM yyyy")); _reportParameters.Add(rParam); //rParam = new ReportParameter("AttnToDate", attnToDate.ToString("dd MMM yyyy")); //_reportParameters.Add(rParam); //return reportProcessor.AttendanceReportsView(null, dSet, null, RDLC, _reportParameters, true, payrollTypeID, reportType); return reportProcessor.CommonReportViewer(null, RDLC, dSet, _reportParameters, payrollTypeID); } public byte[] DailyAttnForLiFung(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { //DateTime dFromDate = GlobalFunctions.FirstDateOfMonth(fromDate); //DateTime dToDate = GlobalFunctions.LastDateOfMonth(dFromDate); //if (dFromDate > dToDate) //{ // var temp = dFromDate; // dFromDate = dToDate; // dToDate = temp; //} DataRow oDR = null; DataSet oDailyInOut = null; List oEmp = new EmployeeService().GetByEmpIDs(sEmpID, payrollTypeID); List oDepartment = new DepartmentService().GetAll(payrollTypeID); List oDesignation = new DesignationService().GetAll(payrollTypeID); EnumAttendanceType[] statuses = { EnumAttendanceType.Present, EnumAttendanceType.Absent, EnumAttendanceType.Delay, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.OutSideDuty }; String status = string.Join(",", Array.ConvertAll(statuses, x => ((int)x).ToString())); //oDailyInOut = new DailyAttnProcessService().GetDailyDataByStatus(dFromDate, sEmpID, EnumAttendanceType.Present, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.Delay, EnumAttendanceType.OutSideDuty); oDailyInOut = new DailyAttnProcessService().GetDailyDataByStatusDateset(dFromDate, status, sEmpID); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable oSubDataTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); //HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable dTableParent = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewLiFungDataTable(); List oTHours = new List(); List latehours = new List(); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable dTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.DailyInOutDataTable(); foreach (DataRow Dr in oDailyInOut.Tables[0].Rows) { oDR = dTable.NewRow(); oDR["EmployeeNo"] = Dr["EMPLOYEENO"]; oDR["Name"] = Dr["Name"]; oDR["Designation"] = Dr["Designation"]; oDR["InTime"] = Dr["InTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["InTime"]).ToString("HH:mm"); oDR["OutTime"] = Dr["OutTime"] is DBNull ? "00:00" : Convert.ToDateTime(Dr["OutTime"]).ToString("HH:mm"); oDR["EmpType"] = Dr["EmpType"].ToString(); oDR["Status"] = GlobalFunctions.GetShortAttnType((EnumAttendanceType)Convert.ToInt32(Dr["Status"])); oDR["OTHour"] = GlobalFunctions.ConvertDoubleHourToHourMinute(Convert.ToDouble(Dr["OTHour"])); oDR["OTHourDBL"] = Convert.ToDouble(Dr["OTHour"]); oDR["DeptID"] = Convert.ToInt32(Dr["DeptID"].ToString()); oDR["DeptName"] = Dr["DeptName"].ToString(); oDR["Department"] = Dr["Department"].ToString(); oDR["Section"] = Dr["Section"].ToString(); oDR["Line"] = Dr["Line"].ToString(); oDR["Floor"] = Dr["Floor"].ToString(); oDR["Shift"] = Dr["Shift"].ToString(); oDR["CardNo"] = Dr["CardNo"].ToString(); dTable.Rows.Add(oDR); } DataSet dSet = new DataSet(); dTable.TableName = "AttendenceDataSet_DailyInOut"; dSet.Tables.Add(dTable); //string RDLC = "HRM.Report.Attendence.RDLC.DailyPresent.rdlc"; string RDLC = "DailyAttendanceLiFung.rdlc"; List _reportParameters = new List(); ReportParameter rParam = new ReportParameter("AttnDate", dFromDate.ToString("dd MMM yyyy")); _reportParameters.Add(rParam); //rParam = new ReportParameter("Fax", ""); //_reportParameters.Add(rParam); //rParam = new ReportParameter("Email", systemInfo.email); //_reportParameters.Add(rParam); return new ReportProcessor().CommonReportViewer(null, RDLC, dSet, _reportParameters, payrollTypeID); //return reportProcessor.AttendanceReportsView(null, dSet, null, RDLC, _reportParameters, true, payrollTypeID, reportType); //AttendanceReportView(reportItem, dSet, dSubReportDataSet, reportName, parameters, defaultParameterNeeded, payrollTypeId, reportType) } //public byte[] ShowDateRangeJobCardMultipleLiNFung(DateTime dFromDate, DateTime dToDate, string sEmpID, int payrollTypeId, string reportType) //{ // if (dFromDate > dToDate) // { // var temp = dFromDate; // dFromDate = dToDate; // dToDate = temp; // } // List oEmp = new EmployeeService().GetByEmpIDs(sEmpID, payrollTypeId); // List oDepartment = new DepartmentService().GetAll(payrollTypeId); // List oDesignation = new DesignationService().GetAll(payrollTypeId); // String RDLC = string.Empty; // HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable oSubDataTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); // HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewDataTable dTableParent = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnParentNewDataTable(); // foreach (Employee emp in oEmp) // { // try // { // List oTHours = new List(); // List latehours = new List(); // Department tempDepartment = emp.DepartmentID != null ? oDepartment.Find(item => item.ID == emp.DepartmentID) : null; // Designation tempDesignation = emp.DesignationID != null ? oDesignation.Find(item => item.ID == emp.DesignationID) : null; // DataTable tempSub = GetEmpDailyAttn(emp.ID, dFromDate, dToDate, payrollTypeId); // foreach (DataRow dr in tempSub.Rows) // { // var dRowSub = oSubDataTable.NewRow(); // dRowSub["EmployeeNo"] = emp.EmployeeNo; // dRowSub["Date"] = dr["Date"]; // dRowSub["InTime"] = dr["InTime"]; // dRowSub["OutTime"] = dr["OutTime"]; // dRowSub["LateBy"] = dr["LateBy"]; // dRowSub["OTHr"] = dr["OTHr"]; // dRowSub["Status"] = dr["Status"]; // dRowSub["Remarks"] = dr["Remarks"]; // dRowSub["Shift"] = dr["Shift"]; // dRowSub["AttnType"] = dr["AttnType"]; // dRowSub["Description"] = dr["Description"]; // dRowSub["Amount"] = dr["Amount"]; // dRowSub["WorkPlanGroup"] = dr["WorkPlanGroup"]; // dRowSub["AttnDate"] = dr["AttnDate"]; // dRowSub["Day"] = dr["Day"]; // dRowSub["WorkingHour"] = dr["WorkingHour"]; // dRowSub["InTimeShow"] = dr["InTimeShow"]; // oSubDataTable.Rows.Add(dRowSub); // string oTHour = Convert.ToString(dr["OTHr"]); // string latehour = Convert.ToString(dr["LateBy"]); // oTHours.Add(oTHour); // latehours.Add(latehour); // } // string totalOT = GlobalFunctions.GetHourMinutes(oTHours); // string totalLateHour = GlobalFunctions.GetHourMinutes(latehours); // var dRowParent = dTableParent.NewRow(); // dRowParent["EmpNo"] = emp.EmployeeNo.ToString(); // dRowParent["Name"] = emp.Name.ToString(); // dRowParent["Designation"] = tempDesignation != null ? tempDesignation.Name : string.Empty; // dRowParent["Department"] = tempDepartment != null ? tempDepartment.Name : string.Empty; // //dRowParent["JoiningDate"] = emp.Grade == null ? "" : emp.JoiningDate.ToString("dd MMM yyyy"); // dRowParent["JoiningDate"] = emp.JoiningDate != DateTime.MinValue ? emp.JoiningDate.ToString("dd MMM yyyy") : string.Empty; // dRowParent["FromDate"] = dFromDate.ToString("dd MMM yyyy"); // dRowParent["ToDate"] = dToDate.ToString("dd MMM yyyy"); // dRowParent["TotalLate"] = totalLateHour; // dRowParent["TotalOT"] = totalOT; // dTableParent.Rows.Add(dRowParent); // } // catch (Exception ex) // { // throw; // } // } // DataSet dSetSub = new DataSet(); // oSubDataTable.TableName = "AttendenceDataSet_EmpDailyAttn"; // dSetSub.Tables.Add(oSubDataTable); // DataSet dSetParent = new DataSet(); // dTableParent.TableName = "AttendenceDataSet_EmpDailyAttnParentNew"; // dSetParent.Tables.Add(dTableParent); // RDLC = "HRM.Report.Attendence.RDLC.DateRangeMultipleJobCardNew.rdlc"; // return new ReportProcessor().CommonReportView(null, RDLC, dSetParent, dSetSub, null, true, payrollTypeId, reportType); //} public byte[] MonthlyJobCard(DateTime dFromDate, DateTime dToDate, string sEmpID, int payrollTypeId, string reportType) { if (dFromDate > dToDate) { var temp = dFromDate; dFromDate = dToDate; dToDate = temp; } ReportProcessor reportProcessor = new ReportProcessor(); AttendanceReport attnReport = new AttendanceReport(); DataSet dSet = new DataSet(); DataTable oDataTable = null; double totalOTHour, totalLateHour; oDataTable = attnReport.GetEmpDailyAttnNew(Convert.ToInt32(sEmpID), GlobalFunctions.FirstDateOfMonth(dFromDate), GlobalFunctions.LastDateOfMonth(dToDate), out totalOTHour, out totalLateHour, payrollTypeId); DataSet dsEmp = new EmployeeService().GetAllEmpBasicInfo(sEmpID); //DataSet MonthlyKpiDetailsWithLeave = calculateLeave(dSet); string sDepartment = string.Empty, sSection = string.Empty, sFloor = string.Empty, sDesignation = string.Empty; if (dsEmp.Tables[0].Rows.Count > 0) { var dRow = dsEmp.Tables[0].Rows[0]; sDepartment = dRow["Department"].ToString(); sSection = dRow["Section"].ToString(); sFloor = dRow["Floor"].ToString(); sDesignation = dRow["Designation"].ToString(); } string totalOTHR = GlobalFunctions.ConvertDoubleHourToHourMinute(totalOTHour); string totalLateHourString = GlobalFunctions.ConvertDoubleHourToHourMinute(totalLateHour); Employee employee = new Employee(); employee = new EmployeeService().Get(Convert.ToInt32(sEmpID)); #region Parameter Addition List parameters = new List(); ReportParameter _parameter = new ReportParameter("FromDate", GlobalFunctions.FirstDateOfMonth(dFromDate).ToString("dd MMM yyyy")); parameters.Add(_parameter); _parameter = new ReportParameter("ToDate", GlobalFunctions.LastDateOfMonth(dFromDate).ToString("dd MMM yyyy")); parameters.Add(_parameter); _parameter = new ReportParameter("EmpNo", employee.EmployeeNo); parameters.Add(_parameter); _parameter = new ReportParameter("EmpName", employee.Name); parameters.Add(_parameter); _parameter = new ReportParameter("EmpDesignation", sDesignation != null ? sDesignation : string.Empty); parameters.Add(_parameter); _parameter = new ReportParameter("EmpJoinDate", employee.JoiningDate.ToString("dd MMM yyyy")); parameters.Add(_parameter); _parameter = new ReportParameter("EmpDepartment", sDepartment); parameters.Add(_parameter); _parameter = new ReportParameter("EmpSection", sSection); parameters.Add(_parameter); _parameter = new ReportParameter("TotalOT", totalOTHR); parameters.Add(_parameter); _parameter = new ReportParameter("TotalLateHour", totalLateHourString); parameters.Add(_parameter); _parameter = new ReportParameter("EmpFloor", sFloor); parameters.Add(_parameter); #endregion oDataTable.TableName = "AttendenceDataSet_EmpDailyAttn"; string filePath = "EmpDailyAttn.rdlc"; dSet.Tables.Add(oDataTable); return new ReportProcessor().CommonReportView(null, dSet, null, filePath, parameters, true, payrollTypeId, reportType); } public byte[] GetAttendanceSummary(DateTime dFromDate, string sEmpID, string reportType, int payrollTypeID) { ReportProcessor reportProcessor = new ReportProcessor(); DataSet oAttendanceSummary = null; oAttendanceSummary = new DailyAttnProcessService().GetMonthlyAttn(GlobalFunctions.FirstDateOfMonth(dFromDate), GlobalFunctions.LastDateOfMonth(dFromDate), sEmpID); //DataSet MonthlyKpiDetailsWithLeave = calculateLeave(oAttendanceSummary); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttnDataTable oAttendanceSummaryDTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.MonthlyAttnDataTable(); #region Summary Parts foreach (DataRow Dr in oAttendanceSummary.Tables[0].Rows) { DataRow dRow = oAttendanceSummaryDTable.NewRow(); dRow["EmpNo"] = Dr["EMPLOYEENO"]; dRow["Name"] = Dr["NAME"]; dRow["CardNo"] = Dr["CardNo"].ToString(); dRow["Designation"] = Dr["Designation"]; dRow["Grade"] = Dr["Grade"]; dRow["JoinDate"] = Convert.ToDateTime(Dr["JOININGDATE"]).ToString("dd MMM yyyy"); dRow["GrossSalary"] = Convert.ToDouble(Dr["GROSSSALARY"]); dRow["Present"] = Dr["Present"] is DBNull ? 0 : Dr["Present"]; dRow["Department"] = Dr["Department"].ToString(); dRow["Section"] = Dr["Section"].ToString(); dRow["Line"] = Dr["Line"].ToString(); dRow["Floor"] = Dr["Floor"].ToString(); dRow["Late"] = Dr["Late"] is DBNull ? 0 : Dr["Late"]; dRow["Absent"] = Dr["Absent"] is DBNull ? 0 : Dr["Absent"]; dRow["Holiday"] = Dr["Holiday"] is DBNull ? 0 : Dr["Holiday"]; dRow["Leave"] = Dr["Leave"] is DBNull ? 0 : Dr["Leave"]; dRow["TotalAttn"] = Dr["TotalAttn"]; dRow["TotalOT"] = GlobalFunctions.ConvertDoubleHourToHourMinute(Convert.ToDouble(Dr["TotalOT"])); dRow["TotalOTDBL"] = Convert.ToDouble(Dr["TotalOT"]); dRow["Remarks"] = ""; oAttendanceSummaryDTable.Rows.Add(dRow); } #endregion oAttendanceSummaryDTable.TableName = "AttendenceDataSet_MonthlyAttn"; oAttendanceSummary.Tables.Add(oAttendanceSummaryDTable); List _parameters = new List(); ReportParameter rParam = new ReportParameter("FromDate", GlobalFunctions.FirstDateOfMonth(dFromDate).ToString("dd MMM yyyy")); _parameters.Add(rParam); rParam = new ReportParameter("ToDate", GlobalFunctions.LastDateOfMonth(dFromDate).ToString("dd MMM yyyy")); _parameters.Add(rParam); string filePath = "MonthlyAttn.rdlc"; return new ReportProcessor().CommonReportView(null, oAttendanceSummary, null, filePath, _parameters, true, payrollTypeID, reportType); } public DataTable GetEmpDailyAttnNew(int EmpID, DateTime dFromDate, DateTime dToDate, out double totalOTHour, out double totalLateHour, int payrollTypeID) { List oNationalHolidays = new AttnNationalHolidayService().GetByMonth(PayrollGlobalFunctions.FirstDateOfYear(dFromDate), PayrollGlobalFunctions.LastDateOfYear(dToDate)); //dFromDate.FirstDateOfMonth(), dFromDate.FirstDateOfMonth()); totalOTHour = 0; totalLateHour = 0; List dAttnProcessess = new List(); dAttnProcessess = new DailyAttnProcessService().Get(EmpID, dFromDate, dToDate); List _adps = new ADParameterService().Get(EnumStatus.Regardless, EnumAllowOrDeduct.Allowance, payrollTypeID); List oAllowanceDeduction = new AllowanceDeductionService().Get(EnumStatus.Regardless); List oADParameterEmployee = new ADParameterEmployeeService().Get(EnumADEmpType.NotApplicable); List oADParameterShift = new ADParameterService().GetAllShifts(); foreach (ADParameter item in _adps) { //item.AllowanceDeduction = new AllowanceDeductionService().Get(item.AllowDeductID); //item.NotApplicable = new ADParameterEmployeeService().GetbyParameter(item.ID, EnumADEmpType.NotApplicable); //item.ADParameterShifts = new ADParameterService().GetShifts(item.ID); item.AllowanceDeduction = oAllowanceDeduction.Where(x=> x.ID == item.AllowDeductID).FirstOrDefault(); item.NotApplicable = oADParameterEmployee.Where(x => x.ADParameterID == item.ID && x.ADEmpType == EnumADEmpType.NotApplicable).ToList(); item.ADParameterShifts = oADParameterShift.Where(x => x.ADParameterID == item.ID).ToList(); } oAllDeducts = new AllowanceDeductionService().Get(EnumStatus.Regardless); AllowanceDeduction oAttnNightAllowance = oAllDeducts.FirstOrDefault(x => x.Code.Trim().ToUpper() == "023" && x.AllowOrDeductType == EnumAllowOrDeduct.Allowance); AllowanceDeduction oAttnSpacialAllowance = oAllDeducts.FirstOrDefault(x => x.Code.Trim().ToUpper() == "022" && x.AllowOrDeductType == EnumAllowOrDeduct.Allowance); List oShiftIDs = (_adps != null && _adps.Count > 0) ? _adps.Where(y => y.AllowDeductID == oAttnNightAllowance.ID).SelectMany(z => z.ADParameterShifts).Select(a => Convert.ToInt32(a.ShiftID)).ToList() : null; List oShiftIDsSpecial = (_adps != null && _adps.Count > 0) ? _adps.Where(y => y.AllowDeductID == oAttnSpacialAllowance.ID).SelectMany(z => z.ADParameterShifts).Select(a => Convert.ToInt32(a.ShiftID)).ToList() : null; List oLeaves = new LeaveService().Get(); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable dTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); List oShifts = new ShiftService().GetAllShift(); //var tfshifts = oShifts.FindAll(x => x.NightAllowanceID != null); //List oShiftIDs = tfshifts.Select(a => a.ID).ToList(); //var tfshiftsSpecial = oShifts.FindAll(x => x.SpecialAllowanceID != null); //List oShiftIDsSpecial = tfshiftsSpecial.Select(a => a.ID).ToList(); string sLeaveName = string.Empty; List oOverlappingShiftIDs = oShifts.Where(x => x.IsOverlapingDay).Select(x => x.ID).ToList(); AllowanceDeduction oAttnLunchAssistanceAllowance = oAllDeducts.FirstOrDefault(x => x.Code.Trim().ToUpper() == "015" && x.AllowOrDeductType == EnumAllowOrDeduct.Allowance); string lunchAllowDaysString = new SystemConfigarationService().GetconfigStringValue(EnumConfigurationType.Logic, "attendence", "lunchallowanceday"); ////---------Added for Just manual testing------- //lunchAllowDaysString = "Fryday"; ////--------------------------------------------- DayOfWeek lunchAllowanceDOW; if (!Enum.TryParse(lunchAllowDaysString, out lunchAllowanceDOW)) lunchAllowanceDOW = DayOfWeek.Friday; ////---------Added for Just manual testing------- //tiffinAllowanceCodeString = "003,012,019"; ////--------------------------------------------- string tiffinAllowanceCodeString = new SystemConfigarationService().GetconfigStringValue(EnumConfigurationType.Logic, "attendence", "nightshiftcodes"); List tiffinAllowanceCodes = tiffinAllowanceCodeString.Trim().Split(',').ToList(); List oNightShiftIDs = oShifts.Where(x => tiffinAllowanceCodes.Contains(x.Code.Trim())).Select(x => x.ID).ToList(); //AllowanceDeduction oAttnExtraAllowance = oAllDeducts.FirstOrDefault(x => x.Code.Trim().ToUpper() == "004" && x.AllowOrDeductType == EnumAllowOrDeduct.Allowance); List _Adparameters = new ADParameterService().Get(EnumStatus.Active, EnumAllowOrDeduct.Allowance, payrollTypeID).Where(x => x.AllowDeductID == 4).ToList(); // AllowDeductID = 4 is Extra Allowance in ALLOWANCEDEDUCTION table //List ogrades = new GradeService().Get(EnumStatus.Regardless); List ogrades = new GradeService().GetAllPayrollTypes(EnumStatus.Regardless); Employee emp = new EmployeeService().Get(EmpID); //string sExtraAllowanceHour = Ease.CoreV35.Utility.ConfigUtility.GetAppSettings("ExtraAllowanceHour"); double dExtraAllowanceHours = 13.5; //if (!double.TryParse(sExtraAllowanceHour, out dExtraAllowanceHours)) //{ // dExtraAllowanceHours = 13.5; // Default if Hour not given //} DateTime? startTime; DateTime? endTime; string shortAttnType = ""; if (!(dAttnProcessess == null || dAttnProcessess.Count <= 0)) { dAttnProcessess= dAttnProcessess.OrderBy(x => x.AttnDate).ToList(); foreach (DailyAttnProcess dAttnProcess in dAttnProcessess) { sLeaveName = string.Empty; StringBuilder sRemarks; DataRow Rowbody = dTable.NewRow(); DailyAttnProcess dap = dAttnProcessess.Where(x => x.ShiftID != null && x.ShiftID != 0 && oShiftIDs.Contains(Convert.ToInt32(x.ShiftID)) && x.AttenType != EnumAttendanceType.Absent && x.AttenType != EnumAttendanceType.Holiday && x.AttenType != EnumAttendanceType.Leave && x.AttenType != EnumAttendanceType.WeeklyHoliday && x.AttnDate == dAttnProcess.AttnDate).FirstOrDefault(); Rowbody["NightShiftAllowance"] = dap != null ? 1 : 0; DailyAttnProcess dapSpecial = dAttnProcessess.Where(x => x.ShiftID != null && x.ShiftID != 0 && oShiftIDsSpecial.Contains(Convert.ToInt32(x.ShiftID)) && x.AttenType != EnumAttendanceType.Absent && x.AttenType != EnumAttendanceType.Holiday && x.AttenType != EnumAttendanceType.Leave && x.AttenType != EnumAttendanceType.WeeklyHoliday && x.AttnDate == dAttnProcess.AttnDate).FirstOrDefault(); Rowbody["SpecialAllowance"] = dapSpecial != null ? 1 : 0; Rowbody["Date"] = dAttnProcess.AttnDate.ToString("dd MMM yy"); Rowbody["Day"] = dAttnProcess.AttnDate.ToString("ddd"); if (dAttnProcess.InTime == DateTime.MinValue || dAttnProcess.InTime == null) { Rowbody["InTime"] = "00:00"; } else { Rowbody["InTime"] = ((DateTime)dAttnProcess.InTime).ToString("HH:mm:ss"); } if (dAttnProcess.OutTime == DateTime.MinValue || dAttnProcess.OutTime == null) { Rowbody["OutTime"] = "00:00"; } else { Rowbody["OutTime"] = ((DateTime)dAttnProcess.OutTime).ToString("HH:mm:ss"); } totalLateHour += dAttnProcess.LateHour; Rowbody["LateBy"] = GlobalFunctions.ConvertDoubleHourToHourMinute(dAttnProcess.LateHour); totalOTHour += dAttnProcess.OTHour; Rowbody["OTHr"] = GlobalFunctions.ConvertDoubleHourToHourMinute(dAttnProcess.OTHour); shortAttnType = GlobalFunctions.GetShortAttnType(dAttnProcess.AttenType); Rowbody["Status"] = shortAttnType; AttnNationalHoliday nh = oNationalHolidays.Find(x => dAttnProcess.AttnDate >= x.FromDate && dAttnProcess.AttnDate <= x.ToDate); if (nh != null) Rowbody["Status"] = "N"; Rowbody["Lunch"] = 0; if (dAttnProcess.AttnDate.DayOfWeek == lunchAllowanceDOW && dAttnProcess.AttenType != EnumAttendanceType.Absent && dAttnProcess.AttenType != EnumAttendanceType.Holiday && dAttnProcess.AttenType != EnumAttendanceType.Leave && dAttnProcess.AttenType != EnumAttendanceType.WeeklyHoliday && !oOverlappingShiftIDs.Contains((dAttnProcess.ShiftID != null && dAttnProcess.ShiftID != 0) ? Convert.ToInt32(dAttnProcess.ShiftID) : 0)) { Rowbody["Lunch"] = 1; } Rowbody["Tiffin"] = 0; if (dAttnProcess.ShiftID != null && dAttnProcess.ShiftID != 0 && oNightShiftIDs.Contains(Convert.ToInt32(dAttnProcess.ShiftID)) && dAttnProcess.AttenType != EnumAttendanceType.Absent && dAttnProcess.AttenType != EnumAttendanceType.Holiday && dAttnProcess.AttenType != EnumAttendanceType.Leave && dAttnProcess.AttenType != EnumAttendanceType.WeeklyHoliday) { Rowbody["Tiffin"] = 1; } ADParameter ad = _adps.Where(x => x.AllowanceDeduction.Code == "016").FirstOrDefault(); if (ad != null && ad.NotApplicable != null && ad.NotApplicable.Count > 0) { ADParameterEmployee adpe = ad.NotApplicable.Where(x => x.EmployeeID == emp.ID).FirstOrDefault(); if (adpe != null) { Rowbody["Tiffin"] = 0; } } Rowbody["ExtraAllowance"] = 0; if (_Adparameters != null && emp != null) { foreach (ADParameter adparam in _Adparameters) { foreach (ADParameter.ADParameterGrade grn in adparam.ADParameterGrades) { //Grade gr = ogrades.GetItem(grn.GradeID); Grade gr = ogrades.Where(x=> x.ID == grn.GradeID).FirstOrDefault(); if (gr != null && gr.ID == emp.GradeID) { if (/*dAttnProcess.InTime != DateTime.MinValue ||*/ dAttnProcess.InTime != null) { Shift sft = oShifts.FirstOrDefault(x => x.ID == dAttnProcess.ShiftID); if(sft != null || dAttnProcess.ShiftID != null) { startTime = dAttnProcess.InTime.Value.Add(sft.InTime.TimeOfDay); startTime = startTime.Value.AddMinutes(-15) > dAttnProcess.InTime ? startTime.Value.AddMinutes(-15) : dAttnProcess.InTime; endTime = dAttnProcess.OutTime; if (endTime != DateTime.MinValue && endTime != null) { if (endTime.Value.Subtract(startTime.Value).Add(TimeSpan.FromMinutes(1)).TotalHours >= dExtraAllowanceHours) { Rowbody["ExtraAllowance"] = 1; } } } } } } } } //New //Rowbody["ExtraAllowance"] = 0; //if (dAttnProcess.InTime != null && dAttnProcess.InTime != DateTime.MinValue) //{ // Shift sft = oShifts.FirstOrDefault(x => x.ID == dAttnProcess.ShiftID); // startTime = ((DateTime)dAttnProcess.InTime).Date.Add(sft.InTime.TimeOfDay); // startTime = ((DateTime)startTime).AddMinutes(-15) > (DateTime)dAttnProcess.InTime // ? Convert.ToDateTime(startTime).AddMinutes(-15) : (DateTime)dAttnProcess.InTime; // endTime = dAttnProcess.OutTime; // if (endTime != null && endTime != DateTime.MinValue) // { // if (((DateTime)endTime).Subtract(startTime).Add(TimeSpan.FromMinutes(1)).TotalHours >= dExtraAllowanceHours) // { // Rowbody["ExtraAllowance"] = 1; // } // } //} if (dAttnProcess.AttenType == EnumAttendanceType.Leave) { var oLeave = oLeaves.FirstOrDefault(x => Convert.ToInt32(x.ID) == Convert.ToInt32(dAttnProcess.ReferenceID)); if (oLeave != null) { sLeaveName = oLeave.Description; } } sRemarks = new StringBuilder(); sRemarks.AppendFormat("{0}.", sLeaveName); sRemarks.AppendFormat("{0}.", dAttnProcess.Comments); Rowbody["Remarks"] = sRemarks.ToString().Trim('.'); Shift oSft = oShifts.Where(o => Convert.ToInt32(o.ID) == Convert.ToInt32(dAttnProcess.ShiftID)).FirstOrDefault(); if (oSft != null) { Rowbody["Shift"] = oSft.ShortName; } else { Rowbody["Shift"] = string.Empty; } Rowbody["IsManualEntry"] = dAttnProcess.IsManualEntry; dTable.Rows.Add(Rowbody); } } //DataView dv = dTable.DefaultView; //dv.Sort = "Date ASC"; //DataTable sortedDT = dv.ToTable(); return dTable; } public DataTable GetEmpDailyAttn(int EmpID, DateTime dFromDate, DateTime dToDate, int PayrollTypeID) { List _unAuthorizedLeaves = new EmployeeUnAuthorizeLeaveService().GetByEmployeeID(EmpID); _unAuthorizedLeaves = _unAuthorizedLeaves.Where(o => o.IsLateAttendanceRelated == false).ToList(); EmployeeUnAuthorizeLeave unAuthorizedLeave = null; EmployeeUnAuthorizeLeave unAuthorizedLeaveHalfDay = null; string workingHour = string.Empty; List oLeaves = new LeaveService().Get(EnumStatus.Active, PayrollTypeID); List amBenefits = null; DateTime fromSalaryMonth = dFromDate; DateTime toSalaryMonth = dToDate; fromSalaryMonth = GlobalFunctions.GetAttandaceSalaryMonth(dFromDate); toSalaryMonth = new AttnMonthlyBenefitService().GetAttandaceSalaryMonth(dToDate); amBenefits = new AttnMonthlyBenefitService().Get(EmpID, fromSalaryMonth, toSalaryMonth); List dAttnProcessess = new List(); dAttnProcessess = new DailyAttnProcessService().Get(EmpID, dFromDate, dToDate); HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable dTable = new HRM.Report.Attendence.AttendenceDataSet.AttendenceDataSet.EmpDailyAttnDataTable(); //PayrollDataSet.PayrollDataSet.LaonPaymentDueDataTable dTable = new Payroll.Report.PayrollDataSet.PayrollDataSet.LaonPaymentDueDataTable(); List oShifts = new ShiftService().GetAllShift(); if (!(dAttnProcessess == null || dAttnProcessess.Count <= 0)) { foreach (DailyAttnProcess dAttnProcess in dAttnProcessess) { DataRow Rowbody = dTable.NewRow(); Rowbody["Date"] = dAttnProcess.AttnDate.ToString("dd MMM yyyy"); Rowbody["Day"] = dAttnProcess.AttnDate.ToString("dddd"); if (dAttnProcess.InTime == DateTime.MinValue || dAttnProcess.InTime == null) { Rowbody["InTime"] = "00:00"; } else { Rowbody["InTime"] = ((DateTime)dAttnProcess.InTime).ToString("hh:mm tt"); } if (dAttnProcess.OutTime == DateTime.MinValue || dAttnProcess.OutTime == null) { Rowbody["OutTime"] = "00:00"; } else { Rowbody["OutTime"] = ((DateTime)dAttnProcess.OutTime).ToString("hh:mm tt"); } Rowbody["WorkingHour"] = dAttnProcess.WorkHour.ToString("0.00"); Rowbody["LateBy"] = dAttnProcess.LateHour.ToString("0.00"); Rowbody["OTHr"] = dAttnProcess.OTHour.ToString("0.00"); if (dAttnProcess.AttenType == EnumAttendanceType.Leave) { Rowbody["Status"] = GetLeaveType(dAttnProcess.ReferenceID == null ? 0 : dAttnProcess.ReferenceID.Value, oLeaves); } else { Rowbody["Status"] = GlobalFunctions.GetShortAttnType(dAttnProcess.AttenType, dAttnProcess.WorkDayType, dAttnProcess.LateHour); } unAuthorizedLeaveHalfDay = _unAuthorizedLeaves.Where(o => o.LeaveDays == 0.5 && o.FromDate.Date == dAttnProcess.AttnDate && o.ToDate.Date == dAttnProcess.AttnDate).FirstOrDefault(); unAuthorizedLeave = _unAuthorizedLeaves.Where(o => dAttnProcess.AttnDate >= o.FromDate && dAttnProcess.AttnDate <= o.ToDate).FirstOrDefault(); //oAttNHoliday = attNHolidays.Where(o => dDate.Date >= o.FromDate.Date && dDate.Date <= o.ToDate.Date).FirstOrDefault(); Rowbody["Remarks"] = unAuthorizedLeaveHalfDay == null ? dAttnProcess.Comments : "1/2 day"; if (unAuthorizedLeave != null) Rowbody["Status"] = "LWP"; if (dAttnProcess.ShiftID != null) { Shift oSft = oShifts.Where(o => o.ID == dAttnProcess.ShiftID).FirstOrDefault(); if (oSft != null) { Rowbody["Shift"] = oSft.ShortName; } else { Rowbody["Shift"] = string.Empty; } } dTable.Rows.Add(Rowbody); } } return dTable; } private string GetLeaveType(int ReferenceID, List _leaves) { string leaveType = string.Empty; Leave leave = null; if (ReferenceID != 0) { leave = new Leave(); leave = _leaves.Where(o => o.ID == ReferenceID).FirstOrDefault(); if (leave != null) { leaveType = leave.Code; } } return leaveType; } public byte[] ShowEmpCardInfoPerPage(string EmpIDs, int authPersonID, string RDLC, bool IsAssignDateChecked, string ExpireYear, DateTime AssignmentDate, int reportCategory) { ReportProcessor reportProcessor = new ReportProcessor(); DataSet oCardInfo = null; string signaturePath = string.Empty; string folderPath = string.Empty; if (authPersonID != 0) { AuthorizedPerson oAuthPerson = new AuthorizedPersonService().Get(authPersonID); DataTable dtImage = new AuthorizedPersonService().GetImage(authPersonID); if (dtImage != null && dtImage.Rows.Count > 0) { DataRow dRow = (DataRow)dtImage.Rows[0]; byte[] SignatureData = (byte[])dRow["SignatureData"]; folderPath = Path.Combine(Environment.CurrentDirectory + @"\ClientApp\src\assets\photos"); signaturePath = Path.Combine(folderPath, "AuthSign.jpg"); File.WriteAllBytes(signaturePath, SignatureData); } } List oEmployees = new EmployeeService().GetByEmpIDs(EmpIDs); bool isDesigFromEmp = new SystemConfigarationService().GetconfigBooleanValue(EnumConfigurationType.Logic, "designation", "desigfromdescriptiontext"); oCardInfo = new DailyAttnProcessService().GetEmpCardInfoPerPage(EmpIDs); PhotoPath pPath = new PhotoPathService().Get().FirstOrDefault(); foreach (DataRow Dr in oCardInfo.Tables[0].Rows) { Employee oEmp = oEmployees.FirstOrDefault(x => x.EmployeeNo.Trim() == Dr["IDNo"].ToString().Trim()); Dr["Desig"] = (isDesigFromEmp && oEmp != null) ? oEmp.DescriptionText : Dr["Desig"]; Dr["EmpPhoto"] = Dr["EmpPhoto"].ToString(); Dr["EmpSign"] = Dr["EmpSign"].ToString(); Dr["IssueDate"] = DateTime.Today; } oCardInfo.Tables[0].TableName = "AttendenceDataSet_IDCard"; SystemInformation _systemInfo =new SystemInformationService().Get(); ReportParameter rParam; List _reportParameters = new List(); string LogoPath = Path.Combine(folderPath, "Logo.png"); string EmpSignPath = Path.Combine(folderPath, "EmpSign.png"); string EmpPhotoPath = Path.Combine(folderPath, "EmpPhoto.jpg"); //_PATH = Application.StartupPath + @"\Resource\IDCardBanner.png"; rParam = new ReportParameter("EchoTextLogo", LogoPath); _reportParameters.Add(rParam); rParam = new ReportParameter("SignatureColor", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("CompanyNameBangla", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("CAddress", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("CPhone", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("Dhara", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("SignPath", signaturePath); _reportParameters.Add(rParam); if (reportCategory == 1) { rParam = new ReportParameter("EmpSignPath", EmpSignPath); _reportParameters.Add(rParam); rParam = new ReportParameter("EmpPhotoPath", EmpPhotoPath); _reportParameters.Add(rParam); } return reportProcessor.CommonReportViewer(null, RDLC, oCardInfo, _reportParameters, false); } public byte[] ShowEmpCardInfoPerPageBangla(string EmpIDs, int authPersonID, string RDLC, bool IsAssignDateChecked, string ExpireYear, DateTime AssignmentDate) { ReportProcessor reportProcessor = new ReportProcessor(); DataSet oCardInfo = null; string signaturePath = string.Empty; string folderPath = string.Empty; if (authPersonID != 0) { AuthorizedPerson oAuthPerson = new AuthorizedPersonService().Get(authPersonID); DataTable dtImage = new AuthorizedPersonService().GetImage(authPersonID); if (dtImage != null && dtImage.Rows.Count > 0) { DataRow dRow = (DataRow)dtImage.Rows[0]; byte[] SignatureData = (byte[])dRow["SignatureData"]; folderPath = Path.Combine(Environment.CurrentDirectory + @"\ClientApp\src\assets\photos"); signaturePath = Path.Combine(folderPath, "AuthSign.jpg"); File.WriteAllBytes(signaturePath, SignatureData); } } List oEmployees = new EmployeeService().GetByEmpIDs(EmpIDs); bool isDesigFromEmp = new SystemConfigarationService().GetconfigBooleanValue(EnumConfigurationType.Logic, "designation", "desigfromdescriptiontext"); oCardInfo = new DailyAttnProcessService().GetEmpCardInfoPerPageBangla(EmpIDs); //Payroll.Report.Attendence.AttendenceDataSet.AttendenceDataSet.IDCardDataTable dTable = new Payroll.Report.Attendence.AttendenceDataSet.AttendenceDataSet.IDCardDataTable(); //PayrollDataSet.PayrollDataSet.LaonPaymentDueDataTable dTable = new Payroll.Report.PayrollDataSet.PayrollDataSet.LaonPaymentDueDataTable(); oCardInfo.Tables[0].Columns.Add("DOJBangla", typeof(string)); oCardInfo.Tables[0].Columns.Add("IssueDateBangla", typeof(string)); oCardInfo.Tables[0].Columns.Add("ExpireDateBangla", typeof(string)); foreach (DataRow Dr in oCardInfo.Tables[0].Rows) { Employee oEmp = oEmployees.FirstOrDefault(x => x.EmployeeNo.Trim() == Dr["IDNo"].ToString().Trim()); Dr["Desig"] = (isDesigFromEmp && oEmp != null) ? oEmp.DescriptionText : Dr["Desig"]; Dr["EmpPhoto"] = Dr["EmpPhoto"].ToString(); Dr["EmpSign"] = Dr["EmpSign"].ToString(); DateTime joiningDate = Convert.ToDateTime(Dr["DOJ"].ToString()); Dr["DOJBangla"] = joiningDate.Day.ToString() + " " + joiningDate.BanglaMonth() + " " + joiningDate.Year.ToString(); DateTime AssignDate; string ExpireDate = string.Empty; if (IsAssignDateChecked) { AssignDate = AssignmentDate; ExpireDate = ExpireYear == "3" ? "3 eQi|" : "5 eQi|"; } else { AssignDate = oEmp.JoiningDate; ExpireDate = ExpireYear == "3" ? "3 eQi|" : "5 eQi|"; } // DateTime IssueDate = Convert.ToDateTime(Dr["IssueDate"].ToString()); Dr["IssueDateBangla"] = AssignDate != DateTime.MinValue ? AssignDate.Day.ToString() + " " + AssignDate.BanglaMonth() + " " + AssignDate.Year.ToString() : ""; //DateTime ExpireDate = Convert.ToDateTime(Dr["ExpireDate"].ToString()); Dr["ExpireDateBangla"] = ExpireDate; } //DataSet dSet = new DataSet(); oCardInfo.Tables[0].TableName = "AttendenceDataSet_IDCard"; //dSet.Tables.Add(dTable); //string RDLC = "Payroll.Report.RDLC.IDCardBothSidePrint.rdlc";// "Payroll.Report.RDLC.IDCardPrint.rdlc"; //SystemInformation _systemInfo = new SystemInformation().Get(); ReportParameter rParam; List _reportParameters = new List(); string _PATH = string.Empty; _PATH = string.Empty; rParam = new ReportParameter("EchoTextLogo", _PATH); _reportParameters.Add(rParam); rParam = new ReportParameter("SignatureColor",""); _reportParameters.Add(rParam); rParam = new ReportParameter("CompanyNameBangla", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("CAddress", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("CPhone", ""); _reportParameters.Add(rParam); rParam = new ReportParameter("Dhara",""); _reportParameters.Add(rParam); rParam = new ReportParameter("SignPath", signaturePath); _reportParameters.Add(rParam); return reportProcessor.CommonReportViewer(null, RDLC, oCardInfo, _reportParameters, false); } } }