EchoTex_Payroll/HRM.DA/DA/Attendance/DailyAttnProcessDA.cs
2025-01-07 15:40:12 +06:00

4098 lines
216 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Ease.CoreV35.DataAccess;
using System.Data;
using HRM.BO;
using Ease.Core.DataAccess;
using System.Security.Policy;
namespace HRM.DA
{
#region DailyAttnProcessDA
internal class DailyAttnProcessDA
{
#region Constructor
private DailyAttnProcessDA()
{
}
#endregion
#region Insert function
//internal static void Insert(TransactionContext tc, DailyAttnProcess item)
//{
// tc.ExecuteNonQuery(
// "INSERT INTO DailyAttnProcess(DailyAttnProcessID, EmployeeID, AttnDate, ShiftID, InTime, OutTime,WorkDayType, AttenType, Comments,Reason, IsManualEntry,IsLate, LateHour, EarlyHour, OTHour, ReferenceID, CreatedBy, CreatedDate, OtRemarks, BenefitRemarks, TempShiftID, WFStatus, ApprovedOTHOUR, LMRemarks, DHRemarks, SalaryMonth, ActualInTime, ActualOutTime, CLAIMWFSTATUS)" +
// " VALUES(%n, %n, %d, %n, %D, %D, %n, %n, %s,%s,%b, %b, %n, %n, %n, %n, %n, %d, %s, %s, %n,%n,%n, %s, %s, %d,%D,%D, %n)",
// item.ID, item.EmployeeID, item.AttnDate, DataReader.GetNullValue(item.ShiftID),
// DataReader.GetNullValue(item.EmpInTime), DataReader.GetNullValue(item.EmpOutTime), item.WorkDayType,
// item.AttenType, item.Comments, item.Reason, item.IsManualEntry, item.IsLate, item.LateHour,
// item.EarlyHour, item.OTHour, DataReader.GetNullValue(item.ReferenceID, 0), item.CreatedBy,
// item.CreatedDate, item.OtRemarks, item.BenefitRemarks, item.TempShiftID,
// item.WFStatus, item.ApprovedOTHour, item.LMRemarks, item.DHRemarks, item.SalaryMonth, item.ActualInTime,
// item.ActualOutTime, (int)EnumClaimWFStatus.None);
//}
#endregion
#region Update function
//internal static void Update(TransactionContext tc, DailyAttnProcess item)
//{
// string sql = SQLParser.MakeSQL(
// "UPDATE DailyAttnProcess SET EmployeeID=%n, AttnDate=%d, ShiftID=%n, InTime=%D, OutTime=%D,WorkDayType=%n, AttenType=%n, Comments=%s,Reason=%s, IsManualEntry=%b,IsLate=%b, LateHour=%n, EarlyHour=%n, OTHour=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%d, OtRemarks=%s, BenefitRemarks=%s, TempShiftID=%n, WFStatus=%n, ApprovedOTHOUR=%n, LMRemarks=%s, DHRemarks=%s, SalaryMonth=%d, ActualInTime=%D, ActualOutTime=%D, ClaimWFStatus=%n" +
// " WHERE DailyAttnProcessID=%n", item.EmployeeID, item.AttnDate,
// item.ShiftID, item.InTime, item.OutTime, item.WorkDayType, item.AttenType,
// item.Comments, DataReader.GetNullValue(item.Reason), item.IsManualEntry,
// item.IsLate, item.LateHour, item.EarlyHour, item.OTHour, DataReader.GetNullValue(item.ReferenceID, 0),
// item.ModifiedBy, item.ModifiedDate, item.OtRemarks, item.BenefitRemarks,
// item.TempShiftID, item.WFStatus, item.ApprovedOTHour, item.LMRemarks,
// item.DHRemarks, item.SalaryMonth, item.ActualInTime, item.ActualOutTime, item.ClaimWFStatus, item.ID);
// tc.ExecuteNonQuery(
// "UPDATE DailyAttnProcess SET EmployeeID=%n, AttnDate=%d, ShiftID=%n, InTime=%D, OutTime=%D,WorkDayType=%n, AttenType=%n, Comments=%s,Reason=%s, IsManualEntry=%b,IsLate=%b, LateHour=%n, EarlyHour=%n, OTHour=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%d, OtRemarks=%s, BenefitRemarks=%s, TempShiftID=%n, WFStatus=%n, ApprovedOTHOUR=%n, LMRemarks=%s, DHRemarks=%s, SalaryMonth=%d, ActualInTime=%D, ActualOutTime=%D, ClaimWFStatus=%n" +
// " WHERE DailyAttnProcessID=%n", item.EmployeeID, item.AttnDate,
// item.ShiftID, item.InTime, item.OutTime, item.WorkDayType, item.AttenType,
// DataReader.GetNullValue(item.Comments), DataReader.GetNullValue(item.Reason), item.IsManualEntry,
// item.IsLate, item.LateHour, item.EarlyHour, item.OTHour, DataReader.GetNullValue(item.ReferenceID, 0),
// item.ModifiedBy, item.ModifiedDate, item.OtRemarks, item.BenefitRemarks,
// item.TempShiftID, item.WFStatus, item.ApprovedOTHour, item.LMRemarks,
// item.DHRemarks, item.SalaryMonth, item.ActualInTime, item.ActualOutTime, item.ClaimWFStatus, item.ID);
//}
internal static void UpdateEmployeeAttendance(TransactionContext tc, DailyAttnProcess item)
{
tc.ExecuteNonQuery(
"UPDATE DAILYATTNPROCESS SET SHIFTID = %n, INTIME = %d, OUTTIME = %d, OTHOUR = %n WHERE EMPLOYEEID = %n AND ATTNDATE= %d ",
item.ShiftID, item.InTime, item.OutTime, item.OTHour, item.EmployeeID, item.AttnDate);
}
internal static void ManualEditUpdate(TransactionContext tc, DailyAttnProcess item)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET ShiftID=%n, InTime=%D, OutTime=%D, " +
"ActualInTime=%D, ActualOutTime=%D,AttenType=%n, Comments=%s,empRemarks=%s, IsManualEntry=%b,IsLate=%b, LateHour=%n, EarlyHour=%n, " +
"OTHour=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%D, WorkHour=%n" +
"" +
" WHERE DailyAttnProcessID=%n and EmployeeID=%n AND AttnDate=%d",
item.ShiftID, item.InTime, item.OutTime, item.ActualInTime, item.ActualOutTime, item.AttenType,
DataReader.GetNullValue(item.Comments), DataReader.GetNullValue(item.EmpRemarks), item.IsManualEntry,
item.IsLate, item.LateHour, item.EarlyHour, item.OTHour, item.ReferenceID,
item.ModifiedBy, item.ModifiedDate, item.WorkHour, item.ID, item.EmployeeID, item.AttnDate);
}
internal static void UpdateShiftID(TransactionContext tc, DateTime dtAtt, int employeeID, int nPayrollTypeID, int currentPayrollTypeID)
{
switch (currentPayrollTypeID)
{
case 2:
if (nPayrollTypeID == 7)
{
string sSQL = SQLParser.MakeSQL(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
(CASE
WHEN ShiftID=2 THEN 20
WHEN ShiftID=5 THEN 22
WHEN ShiftID=3 THEN 21
WHEN ShiftID=6 THEN 23
WHEN ShiftID=7 THEN 24
WHEN ShiftID=12 THEN 25
WHEN ShiftID=13 THEN 26
WHEN ShiftID=19 THEN 27
ELSE ShiftID
END )
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (2,3,5,6,7,12,13,19)", employeeID, nPayrollTypeID, dtAtt);
tc.ExecuteNonQuery(sSQL);
}
else if (nPayrollTypeID == 3)
{
tc.ExecuteNonQuery(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
CASE
WHEN ShiftID=2 THEN 28
WHEN ShiftID=5 THEN 30
WHEN ShiftID=3 THEN 29
WHEN ShiftID=14 THEN 33
WHEN ShiftID=12 THEN 31
WHEN ShiftID=13 THEN 32
WHEN ShiftID=15 THEN 34
ELSE ShiftID
END
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (2,3,5,15,12,13,14)", employeeID, nPayrollTypeID, dtAtt);
}
break;
case 3:
if (nPayrollTypeID == 2)
{
tc.ExecuteNonQuery(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
CASE
WHEN ShiftID=28 THEN 2
WHEN ShiftID=30 THEN 5
WHEN ShiftID=29 THEN 3
WHEN ShiftID=33 THEN 14
WHEN ShiftID=31 THEN 12
WHEN ShiftID=32 THEN 13
WHEN ShiftID=34 THEN 15
ELSE ShiftID
END
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (28,30,29,33,31,32,34)", employeeID, nPayrollTypeID, dtAtt);
}
else if (nPayrollTypeID == 7)
{
tc.ExecuteNonQuery(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
CASE
WHEN ShiftID=28 THEN 20
WHEN ShiftID=30 THEN 22
WHEN ShiftID=29 THEN 21
WHEN ShiftID=31 THEN 23
WHEN ShiftID=32 THEN 26
ELSE ShiftID
END
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (28,30,29,31,32)", employeeID, nPayrollTypeID, dtAtt);
}
break;
case 7:
if (nPayrollTypeID == 2)
{
tc.ExecuteNonQuery(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
CASE
WHEN ShiftID=20 THEN 2
WHEN ShiftID=22 THEN 5
WHEN ShiftID=21 THEN 3
WHEN ShiftID=23 THEN 6
WHEN ShiftID=24 THEN 7
WHEN ShiftID=25 THEN 12
WHEN ShiftID=26 THEN 13
WHEN ShiftID=27 THEN 19
ELSE ShiftID
END
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (20,22,21,23,24,25,26,27)", employeeID, nPayrollTypeID, dtAtt);
}
else if (nPayrollTypeID == 3)
{
tc.ExecuteNonQuery(@"UPDATE DAILYATTNPROCESS
SET ShiftID=
CASE
WHEN ShiftID=20 THEN 28
WHEN ShiftID=22 THEN 30
WHEN ShiftID=21 THEN 29
WHEN ShiftID=25 THEN 31
WHEN ShiftID=26 THEN 32
ELSE ShiftID
END
WHERE EMPLOYEEID IN (SELECT EMPLOYEEID FROM EMPLOYEE WHERE EmployeeID = %n And PAYROLLTYPEID = %n) AND ATTNDATE >= %d
AND SHIFTID IN (20,22,21,25,26)", employeeID, nPayrollTypeID, dtAtt);
}
break;
}
}
internal static void UpdateLeaveClearReason(TransactionContext tc, int employeeID, int leaveID, int userid, DateTime leavefromDate, DateTime leaveToDate)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET Reason='', AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%D" +
" WHERE EmployeeID=%n AND AttnDate BETWEEN %d and %d and WORKDAYTYPE=%n", EnumAttendanceType.Leave,
leaveID, userid, DateTime.Now, employeeID, leavefromDate, leaveToDate, EnumWorkPlanDayType.WorkingDay);
}
internal static void UpdateLeave(TransactionContext tc, int employeeID, int leaveID, int userid, DateTime leavefromDate, DateTime leaveToDate)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%D" +
" WHERE EmployeeID=%n AND AttnDate BETWEEN %d and %d and WORKDAYTYPE=%n", EnumAttendanceType.Leave,
leaveID, userid, DateTime.Now, employeeID, leavefromDate, leaveToDate, EnumWorkPlanDayType.WorkingDay);
}
internal static void RevertLeaveStatus(TransactionContext tc, int employeeID, int leaveID, int userid, DateTime leavefromDate, DateTime leaveToDate)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%D" +
" WHERE EmployeeID=%n AND AttnDate BETWEEN %d and %d and WORKDAYTYPE=%n and AttenType=%n AND Intime is null and OutTime is null", EnumAttendanceType.Absent,
null, userid, DateTime.Now, employeeID, leavefromDate, leaveToDate, EnumWorkPlanDayType.WorkingDay, EnumAttendanceType.Leave);
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%D" +
" WHERE EmployeeID=%n AND AttnDate BETWEEN %d and %d and WORKDAYTYPE=%n and AttenType=%n AND (Intime is not null OR OutTime is not null)",
EnumAttendanceType.Present, null, userid, DateTime.Now, employeeID, leavefromDate, leaveToDate, EnumWorkPlanDayType.WorkingDay, EnumAttendanceType.Leave);
}
internal static void UndoLeave(TransactionContext tc, int employeeID, int userid, DateTime leaveFromDate, DateTime leaveToDate)
{
string sSql = SQLParser.MakeSQL(
"UPDATE DailyAttnProcess SET AttenType=" +
" CASE WHEN InTime is Null and OutTime is null THEN %n ELSE %n END" +
"" +
", ReferenceID=null, ModifiedBy=%n, ModifiedDate=%D" +
" WHERE EmployeeID=%n AND AttnDate BETWEEN %d and %d and WORKDAYTYPE=%n", EnumAttendanceType.Absent, EnumAttendanceType.Present,
userid, DateTime.Now, employeeID, leaveFromDate, leaveToDate, EnumWorkPlanDayType.WorkingDay);
tc.ExecuteNonQuery(sSql);
}
internal static void Delete(TransactionContext tc, string empIDs, DateTime attnDate)
{
tc.ExecuteNonQuery("DELETE FROM [DailyAttnProcess] WHERE EmployeeID in(%q) AND AttnDate=%d", empIDs, attnDate);
}
internal static IDataReader getMyNotSubmittedAbsentList(TransactionContext tc, int employeeid)
{
string sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess" +
" where EmployeeID = %n and WFStatus=%n Order By AttnDate DESC",
employeeid, false);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnDataByWFStatus(TransactionContext tc, int DailyAttnPocessID,
EnumWFAttnStatus status)
{
string sql = string.Empty;
if (status == EnumWFAttnStatus.None)
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess" +
" where DAILYATTNPROCESSID = %n and WFStatus in (0,5) Order By AttnDate asc",
DailyAttnPocessID);
else if (status == EnumWFAttnStatus.LMApproved)
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess" +
" where DAILYATTNPROCESSID = %n and WFStatus in (2,3) Order By AttnDate asc",
DailyAttnPocessID);
else
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess" +
" where DAILYATTNPROCESSID = %n and WFStatus=%n Order By AttnDate asc",
DailyAttnPocessID, status);
return tc.ExecuteReader(sql);
}
//internal static void UpdateLateAttnBenefitStatus(TransactionContext tc, DailyAttnProcess dapItem)
//{
// tc.ExecuteNonQuery(
// "UPDATE DailyAttnProcess SET SalaryMonth=%d, BenefitRemarks=%s, ModifiedBy=%n, ModifiedDate=%d" +
// " WHERE DailyAttnProcessID=%n", dapItem.SalaryMonth, dapItem.BenefitRemarks, dapItem.ModifiedBy,
// dapItem.ModifiedDate, dapItem.ID);
//}
internal static IDataReader GetManualProcess(TransactionContext tc, DateTime attnDate, int payrollType)
{
return tc.ExecuteReader(
"SELECT dap.* FROM DailyAttnProcess dap INNER JOIN EMPLOYEE e on e.EmployeeID=dap.EmployeeID WHERE dap.AttnDate=%d And dap.IsManualEntry=1 AND e.Status=%n AND e.PayrollTypeID=%n ",
attnDate, EnumStatus.Active, payrollType);
}
public static DataSet GetPendingJobDetail(TransactionContext tc, int id)
{
DataSet dataSet = null;
//string sql = SQLParser.MakeSQL(@"select NVL(e.Name, '') Applier, NVL(lv.Description, '') Leave,
// TO_CHAR(APPFromDate,'DD Mon YYYY') FromDate,
// TO_CHAR(APPToDate,'DD Mon YYYY') ToDate,
// APPTotalDays TotalDays, Remarks
// from Leaveentry le
// Left Join Employee e
// on e.EmployeeID = le.EmpID
// Left Join Leave lv
// on lv.LeaveID = le.LeaveID
// Where TranID = %n ", id);
//dataSet = tc.ExecuteDataSet(sql);
return dataSet;
}
internal static IDataReader GetBySalaryMonth(TransactionContext tc, DateTime salaryMonth, int payrollTypeID)
{
return tc.ExecuteReader(@"SELECT dap.* FROM DailyAttnProcess dap
inner join Employee e on e.employeeid=dap.employeeid
WHERE dap.salaryMonth=%d and e.payrolltypeid=%n Order by e.employeeNo",
salaryMonth, payrollTypeID);
}
internal static DataTable GetTeamMembersAttnData(TransactionContext tc, int employeeID, DateTime fromdate,
DateTime toDate, EnumClaimWFStatus status)
{
DataSet presentDays = new DataSet();
try
{
string sql = SQLParser.MakeSQL(
@"SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.EmployeeID, e.EmployeeNo, e.Name EmpName, d.DESCRIPTION Department, wpg.Name Shift,
CAST(AttnDate as DATE) AttnDate,
CASE
WHEN dap.AttenType = 0 THEN 'NONE'
WHEN dap.AttenType = 1 THEN 'Present'
WHEN dap.AttenType = 2 THEN 'Absent'
WHEN dap.AttenType = 3 THEN 'Delay'
WHEN dap.AttenType = 11 THEN 'Late'
WHEN dap.AttenType = 12 THEN 'Early'
WHEN dap.AttenType = 4 THEN 'Leave'
WHEN dap.AttenType = 5 THEN 'Holiday'
WHEN dap.AttenType = 7 THEN 'OutSideDuty'
WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
WHEN dap.AttenType = 10 THEN 'Training'
WHEN dap.AttenType = 11 THEN 'Project'
ELSE ''
END AttenType,
s.NAME Relay,
CAST(dap.intime AS TIME) InTime,
CAST(dap.outtime as Time) OutTime,
CAST(dap.EMPREQUESTINTIME AS TIME) EMPREQUESTINTIME,
CAST(dap.EMPREQUESTOUTTIME as Time) EMPREQUESTOUTTIME,
CASE
WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
ELSE ''
END WORKDAYTYPE,
dap.EMPREMARKS
FROM DAILYATTNPROCESS dap
INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
Inner join Employee e on e.EmployeeID=dap.EmployeeID
Inner join Department d on d.DepartmentID=e.DepartmentID
Inner join EmployeeWorkPlanSetup empWps on empWps.EmployeeID=e.EmployeeID
Inner join WorkPlanGroup wpg on wpg.WorkPlanGroupID= empWps.WorkPlanGroupID
WHERE dap.EMPLOYEEID in (SELECT EmployeeID FROM Employee WHERE LINEMANAGERID=%n and Status = %n and PayrollTypeID =%n) AND dap.CLAIMWFSTATUS =%n and dap.ATTNDATE BETWEEN %d AND %d ORDER BY dap.ATTNDATE desc",
employeeID, EnumEmployeeStatus.Live, PayrollTypeIDConstant.Non_Management, status, fromdate,
toDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays.Tables[0];
}
internal static DataTable GetTeamMembersAttnData(TransactionContext tc, string sEmpID, DateTime fromdate,
DateTime toDate, EnumClaimWFStatus status)
{
DataSet presentDays = new DataSet();
try
{
string sql = SQLParser.MakeSQL(
@"SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.EmployeeID, e.EmployeeNo, e.Name EmpName, d.DESCRIPTION Department, wpg.Name Shift,
CAST(AttnDate as DATE) AttnDate,
CASE
WHEN dap.AttenType = 0 THEN 'NONE'
WHEN dap.AttenType = 1 THEN 'Present'
WHEN dap.AttenType = 2 THEN 'Absent'
WHEN dap.AttenType = 3 THEN 'Delay'
WHEN dap.AttenType = 11 THEN 'Late'
WHEN dap.AttenType = 12 THEN 'Early'
WHEN dap.AttenType = 4 THEN 'Leave'
WHEN dap.AttenType = 5 THEN 'Holiday'
WHEN dap.AttenType = 7 THEN 'OutSideDuty'
WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
WHEN dap.AttenType = 10 THEN 'Training'
WHEN dap.AttenType = 11 THEN 'Project'
ELSE ''
END AttenType,
s.NAME Relay,
CAST(dap.intime AS TIME) InTime,
CAST(dap.outtime as Time) OutTime,
CAST(dap.EMPREQUESTINTIME AS TIME) EMPREQUESTINTIME,
CAST(dap.EMPREQUESTOUTTIME as Time) EMPREQUESTOUTTIME,
CASE
WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
ELSE ''
END WORKDAYTYPE,
dap.EMPREMARKS
FROM DAILYATTNPROCESS dap
INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
Inner join Employee e on e.EmployeeID=dap.EmployeeID
Inner join Department d on d.DepartmentID=e.DepartmentID
Inner join EmployeeWorkPlanSetup empWps on empWps.EmployeeID=e.EmployeeID
Inner join WorkPlanGroup wpg on wpg.WorkPlanGroupID= empWps.WorkPlanGroupID
WHERE dap.EMPLOYEEID in (%q) AND dap.CLAIMWFSTATUS =%n and dap.ATTNDATE BETWEEN %d AND %d ORDER BY dap.ATTNDATE desc",
sEmpID, EnumEmployeeStatus.Live, PayrollTypeIDConstant.Non_Management, status, fromdate, toDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays.Tables[0];
}
internal static IDataReader Get(TransactionContext tc, string empID, DateTime fromDate, DateTime toDate,
EnumClaimWFStatus status)
{
string sTableName;
empID = IDHelper.GetIDs(tc, empID, out sTableName);
string sql = SQLParser.MakeSQL(
"SELECT dap.* FROM DailyAttnProcess dap Inner Join Employee e on e.EmployeeID=dap.EmployeeID WHERE dap.EmployeeID IN(%q) AND dap.AttnDate BETWEEN %d AND %d and dap.CLAIMWFSTATUS =%n order by e.Employeeno ASC",
empID, fromDate, toDate, status);
IDataReader dr = tc.ExecuteReader(sql);
if (sTableName != "")
tc.ExecuteNonQuery("Drop TAble %q", sTableName);
return dr;
}
internal static IDataReader Get(TransactionContext tc, DateTime fromDate, DateTime toDate)
{
string sql = SQLParser.MakeSQL("SELECT * FROM DailyAttnProcess WHERE AttnDate BETWEEN %d AND %d order by AttnDate ASC", fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetshotList(TransactionContext tc, DateTime fromDate, DateTime toDate)
{
string sql = SQLParser.MakeSQL("SELECT DailyAttnProcessID, EmployeeID," +
" AttnDate, ShiftID, InTime, OutTime, WorkDayType, AttenType, " +
"IsLate, LateHour, EarlyHour, WorkHour, OTHour FROM DailyAttnProcess WHERE AttnDate BETWEEN %d AND %d order by AttnDate ASC", fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetshotList(TransactionContext tc, DateTime fromDate, DateTime toDate, int empid)
{
string sql = SQLParser.MakeSQL("SELECT DailyAttnProcessID, EmployeeID," +
" AttnDate, ShiftID, InTime, OutTime, WorkDayType, AttenType, " +
"IsLate, LateHour, EarlyHour, WorkHour, OTHour FROM DailyAttnProcess WHERE " +
" Employeeid=%n and AttnDate BETWEEN %d AND %d order by AttnDate ASC", empid, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetshotList(TransactionContext tc, DateTime attnDate)
{
string sql = SQLParser.MakeSQL("SELECT DailyAttnProcessID, EmployeeID," +
" AttnDate, ShiftID, InTime, OutTime, WorkDayType, AttenType, " +
"IsLate, LateHour, EarlyHour, WorkHour, OTHour FROM DailyAttnProcess WHERE AttnDate = %d order by AttnDate ASC", attnDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetshotListForProdBonus(TransactionContext tc, string prodSetupIDs, DateTime fromDate, DateTime toDate)
{
string sql = SQLParser.MakeSQL(@"
IF OBJECT_ID('tempdb..#AttnofMonths') IS NOT NULL
DROP TABLE #AttnofMonths
select pt.EmployeeID, convert(varchar, FORMAT(pt.inTime,'dd MMM yyyy'), 1) as pdInTime into #AttnofMonths from ProdBonusAttn pt Inner join
ProductionBonusSetup pb on pt.ProdBonusSetupID = pb.ProductionBonusSetupID
where pb.ProductionBonusSetupID in (%q) and pt.inTime is not null;
SELECT DailyAttnProcessID, #AttnofMonths.EmployeeID,
AttnDate, ShiftID, InTime, OutTime, WorkDayType, AttenType,
IsLate, LateHour, EarlyHour, WorkHour, OTHour
FROM DailyAttnProcess inner join #AttnofMonths on DailyAttnProcess.EMPLOYEEID =#AttnofMonths.EmployeeID
and #AttnofMonths.pdInTime = DailyAttnProcess.AttnDate Where intime is not null and OutTime is not null
and(AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n) ;
DROP TABLE #AttnofMonths ", prodSetupIDs, EnumAttendanceType.Present, EnumAttendanceType.Delay, EnumAttendanceType.OutSideDuty, EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.HalfDay
);
return tc.ExecuteReader(sql);
}
internal static void UpdateLeave(TransactionContext tc, int employeeID, int leaveID, DateTime leavaDate,
EnumAttendanceType AttenType)
{
//if (n == 1)
//{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%d" +
" WHERE EmployeeID=%n AND AttnDate=%d ", AttenType, leaveID, 1, DateTime.Now, employeeID, leavaDate);
//}
//else
//{
// tc.ExecuteNonQuery("UPDATE BuyerDailyAttProcess SET InTime=null, OutTime=null, OTHour = 0.0,WorkDayType=%n, AttenType=%n, ReferenceID=%n, ModifiedBy=%n, ModifiedDate=%d" +
// " WHERE EmployeeID=%n AND AttnDate=%d ", EnumAttendanceType.Leave, leaveID, User.CurrentUser.ID, DateTime.Now, employeeID, leavaDate);
//}
}
internal static void RejectAttnStatusByLM(TransactionContext tc, int EmpID, DateTime attnDate, int linemanagerID,
string remarks, string reason)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET wFStatus=%n, LinemanagerId=%n, REASON=%s, LMREMARKS=%s, lMApproveDate=%D, IsManualEntry=%b" +
" WHERE EmployeeID=%n AND AttnDate=%d ", EnumWFAttnStatus.Reject, linemanagerID, reason, remarks, DateTime.Today, true,
EmpID, attnDate);
}
internal static void ApproveAttnByLM(TransactionContext tc, DailyAttnProcess item)
{
string sql = SQLParser.MakeSQL(
"UPDATE DailyAttnProcess SET Intime=%D, outTime=%D, shiftID=%n, ActualInTime=%D, ActualOutTime=%D, ActualShiftID=%n" +
" ,AttenType=%n , LinemanagerId=%n, REASON=%s, LMREMARKS=%s, lMApproveDate=%D, wfStatus=%n, isLate=%b, IsManualEntry=%b, " +
" LateHour=%n, EarlyHour=%n, WorkHour=%n, OTHour=%n WHERE EmployeeID=%n AND AttnDate=%d ", item.InTime, item.OutTime,
item.ShiftID, item.ActualInTime, item.ActualOutTime, item.ActualShiftID, item.AttenType,
item.LineManagerID, item.Reason, item.LMRemarks, DateTime.Today, EnumWFAttnStatus.LMApproved, item.IsLate, item.IsManualEntry,
item.LateHour, item.EarlyHour, item.WorkHour, item.OTHour, item.EmployeeID, item.AttnDate);
tc.ExecuteNonQuery(sql);
}
internal static void RegularizationRequestbyEmp(TransactionContext tc, DailyAttnProcess item)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET ActualInTime=%D, ActualOutTime=%D, EMPAPPLYDATE=%D, " +
"wfStatus=%n, EmpRemarks=%s , IsManualEntry=%b " +
"WHERE EmployeeID=%n AND AttnDate=%d ", item.ActualInTime, item.ActualOutTime, DateTime.Now, EnumWFAttnStatus.EmpSubmitted,
item.EmpRemarks, true, item.EmployeeID, item.AttnDate);
}
internal static void UndoAttendanceStatus(TransactionContext tc, int employeeID, DateTime attnDate,
EnumAttendanceType AttenType)
{
tc.ExecuteNonQuery(
"UPDATE DailyAttnProcess SET AttenType=%n, ReferenceID=null, ModifiedBy=%n, ModifiedDate=%d" +
" WHERE EmployeeID=%n AND AttnDate=%d ", AttenType, 1, DateTime.Now, employeeID, attnDate);
}
#endregion
#region Get Function
internal static IDataReader Get(TransactionContext tc)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess");
}
internal static IDataReader GetByEmployeeID(TransactionContext tc, int employeeID)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess Where EmployeeID =%n", employeeID);
}
internal static IDataReader GetByEmployeeID(TransactionContext tc, int employeeID, DateTime fromDate, DateTime toDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess Where EmployeeID =%n and AttnDate BETWEEN %d AND %d and intime is not null and OutTime is not null order by AttnDate ASC", employeeID, fromDate, toDate);
}
internal static IDataReader GetAttnByEmployeeID(TransactionContext tc, int employeeID, DateTime fromDate, DateTime toDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess Where EmployeeID =%n and AttnDate BETWEEN %d AND %d and intime is not null and OutTime is not null " +
" and (AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n or AttenType = %n) order by AttnDate ASC", employeeID, fromDate, toDate, EnumAttendanceType.Present, EnumAttendanceType.Delay, EnumAttendanceType.OutSideDuty,
EnumAttendanceType.Late, EnumAttendanceType.Early, EnumAttendanceType.HalfDay);
}
internal static IDataReader GetProcessByWPG(TransactionContext tc, EnumWorkPlanGroup wpg, DateTime attnDate)
{
//string sql = SQLParser.MakeSQL("SELECT * FROM DailyAttnProcess where DailyAttnProcessID=3021145");
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess where AttnDate=%d AND EmployeeID IN "
+ "(SELECT EmployeeID FROM EmployeeWorkPlanSetup WHERE WorkPlanGroupID=%n)",
attnDate, wpg);
// return tc.ExecuteReader(sql);
}
internal static IDataReader Get(TransactionContext tc, DateTime attnDate, int payrollTypeID)
{
tc.CommandTimeOut = 6000;
return tc.ExecuteReader(@"SELECT dap.* FROM DailyAttnProcess dap
inner join Employee e on e.employeeid=dap.employeeid
WHERE dap.AttnDate=%d and e.payrolltypeid=%n Order by e.employeeNo", attnDate,
payrollTypeID);
}
internal static IDataReader Get(TransactionContext tc, DateTime attnDate, string empids, int payrollTypeID)
{
return tc.ExecuteReader(@"SELECT dap.* FROM DailyAttnProcess dap
inner join Employee e on e.employeeid=dap.employeeid
WHERE dap.AttnDate=%d and e.payrolltypeid=%n and dap.employeeid in (%q)", attnDate,
payrollTypeID, empids);
}
internal static IDataReader Get(TransactionContext tc, int empId, DateTime attnDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess WHERE AttnDate=%d and EmployeeID=%n", attnDate,
empId);
}
internal static IDataReader GetforMobileWithNoLock(TransactionContext tc, int empId, DateTime attnDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess WHERE AttnDate=%d and EmployeeID=%n", attnDate,
empId);
}
internal static IDataReader GetWithinDateRange(TransactionContext tc, int empId, DateTime attnFromDate,
DateTime attnToDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess WHERE AttnDate between %d and %d and EmployeeID=%n",
attnFromDate, attnToDate, empId);
}
internal static IDataReader GetManualProcess(TransactionContext tc, int PayrollTypeID, DateTime attnDate)
{
return tc.ExecuteReader(
"SELECT dap.* FROM DailyAttnProcess dap INNER JOIN EMPLOYEE e on e.EmployeeID=dap.EmployeeID WHERE dap.AttnDate=%d And dap.IsManualEntry=1 AND e.Status=%n AND e.PayrollTypeID=%n ",
attnDate, EnumStatus.Active, PayrollTypeID);
}
//new
internal static IDataReader GetWhrOutTimeIsNull(TransactionContext tc, DateTime attnDate, int shiftID)
{
return tc.ExecuteReader(
"SELECT * FROM DailyAttnProcess WHERE AttnDate=%d AND ShiftID=%n AND Intime IS NOT NULL AND OutTime IS NULL",
attnDate, shiftID);
}
//
internal static IDataReader Get(TransactionContext tc, int empID, DateTime fromDate, DateTime toDate)
{
string sql =
SQLParser.MakeSQL(
"SELECT * FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate BETWEEN %d AND %d order by AttnDate DESC",
empID, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader Get(TransactionContext tc, string empID, DateTime fromDate, DateTime toDate)
{
//string sql =
// SQLParser.MakeSQL(
// "SELECT dap.* FROM DailyAttnProcess dap Inner Join Employee e on e.EmployeeID=dap.EmployeeID " +
// "WHERE dap.EmployeeID IN(%q) AND dap.AttnDate BETWEEN %d AND %d order by dap.AttnDate DESC",
// empID, fromDate, toDate);
string sql =
SQLParser.MakeSQL(
"SELECT dap.* FROM DailyAttnProcess dap " +
"WHERE dap.EmployeeID IN(%q) AND dap.AttnDate BETWEEN %d AND %d order by dap.AttnDate DESC",
empID, fromDate, toDate);
IDataReader dr = tc.ExecuteReader(sql);
return dr;
}
internal static IDataReader Get(TransactionContext tc, DateTime fromDate, DateTime toDate, int PayrollTypeID)
{
string sql = SQLParser.MakeSQL(
"SELECT dap.* FROM DailyAttnProcess dap Inner Join Employee e on e.EmployeeID=dap.EmployeeID WHERE dap.AttnDate BETWEEN %d AND %d AND e.Status=%n AND e.PayrollTypeID=%n order by AttnDate ASC",
fromDate, toDate, EnumStatus.Active, PayrollTypeID);
return tc.ExecuteReader(sql);
}
internal static IDataReader Get(TransactionContext tc, DateTime attnDate, int shiftID,
EnumAttendanceType AttenType)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess WHERE AttnDate=%d AND ShiftID=%n AND AttenType=%n",
attnDate, shiftID, AttenType);
}
internal static IDataReader Get(TransactionContext tc, int nID)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess WHERE DailyAttnProcessID=%n", nID);
}
internal static DataSet GetMonthlyAttnSummary(TransactionContext tc, DateTime dFromDate, DateTime dToDate,
string sEmpID)
{
string sumOTSql = "CAST( sum(ROUND(d.OTHour, 0)) + FLOOR( (sum(d.OTHour % 1) *100 /60)) AS money) + CAST((sum(d.OTHour % 1) *100 %60)/100 AS money) As TotalOT";
DataSet monthlyAttn = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"select e.EMPLOYEENO,
IsNull(ac.CardNumber,'') as CardNo,
e.NAME,
des.NAME As Designation,
g.DESCRIPTION As Grade,
'Department'= case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END ,
'Floor'=case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END ,
'Section'= case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line'=case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
e.JOININGDATE,
e.GROSSSALARY,
IsNull(Pr.Present,0) Present,
IsNull(Lt.Late, 0) Late,
IsNull(Ab.Absent, 0) Absent,
IsNull(HD.Holiday, 0) Holiday,
IsNull(Lv.Leave,0) Leave,
Isnull(OD.OutsideDuty, 0) OutsideDuty,
Isnull(DL.Delays, 0) Delays,
Isnull(EL.Early, 0) Early,
%q,
((Case when Pr.Present is null then 0 else Pr.Present end) +
(Case when HD.Holiday is Null Then 0 Else HD.Holiday end)+
(Case when Lv.Leave is Null Then 0 Else Lv.Leave end)) As TotalAttn
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate between %d and %d And EmployeeID IN(%q)) d
inner join EMPLOYEE e on e.EMPLOYEEID=d.EmployeeID
inner join DESIGNATION des on des.DESIGNATIONID = e.DESIGNATIONID
inner join GRADES g on g.GRADEID = e.GRADEID
LEFT JOIN AccessCard ac ON e.CardID = ac.AccessCardID
Left JOIN DEPARTMENT dept5 ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4 ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3 ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2 ON dept2.DEPARTMENTID = dept3.PARENTID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Present
from DailyAttnProcess where WORKDAYTYPE = 3 AND AttenType IN(1,11) and AttnDate between %d and %d group by EmployeeID ) Pr
on d.EmployeeID=Pr.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Late from
DailyAttnProcess where WORKDAYTYPE = 3 AND latehour>0 and AttnDate between %d and %d group by EmployeeID ) Lt
on d.EmployeeID=Lt.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Absent
from DailyAttnProcess where WORKDAYTYPE = 3 AND AttenType=2 and AttnDate between %d and %d group by EmployeeID ) Ab
on d.EmployeeID=Ab.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Holiday
from DailyAttnProcess where WORKDAYTYPE IN( 1,2) and AttnDate between %d and %d group by EmployeeID ) HD
on d.EmployeeID=HD.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Leave
from DailyAttnProcess where AttenType=4 and AttnDate between %d and %d group by EmployeeID ) Lv
on d.EmployeeID=Lv.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as OutsideDuty
from DailyAttnProcess where AttenType=7 and AttnDate between %d and %d group by EmployeeID ) OD
on d.EmployeeID=OD.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Delays
from DailyAttnProcess where AttenType=3 and AttnDate between %d and %d group by EmployeeID ) DL
on d.EmployeeID=DL.EmployeeID
left outer join
(select EmployeeID, count(DailyAttnProcessID) as Early
from DailyAttnProcess where AttenType=12 and AttnDate between %d and %d group by EmployeeID ) EL
on d.EmployeeID=EL.EmployeeID
group by e.EMPLOYEENO, e.NAME,ac.CardNumber, des.NAME, g.DESCRIPTION,
dept2.Tire,dept2.[DESCRIPTION],dept3.Tire,dept3.[DESCRIPTION],dept4.Tire,dept4.[DESCRIPTION],dept5.Tire,dept5.[DESCRIPTION]
, e.JOININGDATE, e.GROSSSALARY, Pr.Present,Lt.Late,Ab.Absent,HD.Holiday,Lv.Leave, OD.OutsideDuty, dl.Delays, EL.Early",
sumOTSql, dFromDate, dToDate, sEmpID,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate,
dFromDate, dToDate
);
monthlyAttn = tc.ExecuteDataSet("%q",sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return monthlyAttn;
}
internal static DataSet GetMonthlyAttn(TransactionContext tc, DateTime dFromDate, DateTime dToDate,
string sEmpID)
{
DataSet monthlyAttn = new DataSet();
try
{
string sql = SQLParser.MakeSQL(
"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo, e.NAME, des.NAME Designation, g.DESCRIPTION Grade, e.JOININGDATE, e.GROSSSALARY, Pr.Present, Lt.Late, Ab.Absent, HD.Holiday,Lv.Leave, "
+ "((sum (floor(d.OTHour))+ floor(((sum (d.OTHour-floor(d.OTHour)))*100)/60)) + cast(((cast(((sum(d.OTHour-floor(d.OTHour)))*100)as int))%q60) float)/100) TotalOT, "
+ "((Case when Pr.Present is null then 0 else Pr.Present end) + (Case when HD.Holiday is Null Then 0 Else HD.Holiday end)+(Case when Lv.Leave is Null Then 0 Else Lv.Leave end)) TotalAttn "
+ "from (SELECT * FROM DailyAttnProcess WHERE AttnDate between %d and %d And EmployeeID IN(%q)) d "
+ "inner join EMPLOYEE e on e.EMPLOYEEID=d.EmployeeID "
+ "inner join DESIGNATION des on des.DESIGNATIONID = e.DESIGNATIONID "
+ "inner join GRADES g on g.GRADEID = e.GRADEID "
+ "LEFT JOIN AccessCard ac ON e.CardID = ac.AccessCardID "
+ "left outer join "
+ "("
+ "select EmployeeID, count(DailyAttnProcessID) Present "
+ "from DailyAttnProcess "
+ "where AttenType IN(1,11) and AttnDate between %d and %d "
+ "group by EmployeeID "
+ ") Pr on d.EmployeeID=Pr.EmployeeID "
+ "left outer join "
+ "("
+ "select EmployeeID, count(DailyAttnProcessID) Late "
+ "from DailyAttnProcess "
+ "where AttenType=11 and AttnDate between %d and %d "
+ "group by EmployeeID "
+ ") Lt on d.EmployeeID=Lt.EmployeeID "
+ "left outer join "
+ "("
+ "select EmployeeID, count(DailyAttnProcessID) Absent "
+ "from DailyAttnProcess "
+ "where AttenType=2 and AttnDate between %d and %d "
+ "group by EmployeeID "
+ ") Ab on d.EmployeeID=Ab.EmployeeID "
+ "left outer join "
+ "("
+ "select EmployeeID, count(DailyAttnProcessID) Holiday "
+ "from DailyAttnProcess "
+ "where AttenType IN(5,8) and AttnDate between %d and %d "
+ "group by EmployeeID "
+ ") HD on d.EmployeeID=HD.EmployeeID "
+ "left outer join "
+ "("
+ "select EmployeeID, count(DailyAttnProcessID) Leave "
+ "from DailyAttnProcess "
+ "where AttenType=4 and AttnDate between %d and %d "
+ "group by EmployeeID "
+ ") Lv on d.EmployeeID=Lv.EmployeeID "
+ "group by e.EMPLOYEENO, e.NAME,ac.CardNumber, des.NAME, g.DESCRIPTION, e.JOININGDATE, e.GROSSSALARY, "
+ "Pr.Present,Lt.Late,Ab.Absent,HD.Holiday,Lv.Leave", "%", dFromDate, dToDate, sEmpID, dFromDate,
dToDate, dFromDate, dToDate, dFromDate, dToDate, dFromDate, dToDate, dFromDate, dToDate);
monthlyAttn = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return monthlyAttn;
}
internal static DataSet GetDailyInOut(TransactionContext tc, DateTime attnDate, string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,ISNULL(ac.CardNumber,'') CardNo, e.Name, deg.NAME Designation,cg.DESCRIPTION EmpType,
d.AttenType Status, d.Comments,d.InTime,d.OutTime,d.OTHour,ISNULL(s.ShortName,'') Shift,
dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate=%d AND AttenType=1 And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
INNER JOIN DEPARTMENT dept
ON dept.DEPARTMENTID = e.DEPARTMENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO asc", attnDate,
sEmpID);
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetLMDailyAttnReport(TransactionContext tc, DateTime attnDate, string sEmpID)
{
DataSet lmAttnReport = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT
emp.EmployeeNo, emp.Name, dsg.name AS DESIGNATION, sft.Name AS Shift,
sft.shortname AS ShiftGroup,
dapp.InTime, dapp.OutTime, dapp.AttenType
FROM Shift sft
INNER JOIN WorkPlanGroup wp
ON wp.ShiftID = sft.ShiftID
INNER JOIN EmployeeWorkPlanSetup ews
ON ews.WorkPlanGroupID = wp.WorkPlanGroupID
INNER JOIN EMPLOYEE emp
ON emp.employeeid = ews.EmployeeID
INNER JOIN DESIGNATION dsg
ON dsg.DESIGNATIONID = emp.EMPLOYEEID
INNER JOIN DailyAttnProcess dapp
ON emp.EMPLOYEEID = dapp.EmployeeID
WHERE emp.EmployeeID in (%q) AND dapp.AttnDate = %d", sEmpID,
attnDate);
lmAttnReport = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return lmAttnReport;
}
internal static DataSet GetTimeSheetAttnReport(TransactionContext tc, DateTime fromDate, DateTime toDate,
int sEmpID)
{
DataSet timeSheetAttnReport = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT
emp.EmployeeNo, emp.Name, dsg.name AS DESIGNATION, sft.Name AS Shift,
sft.shortname AS ShiftGroup, dapp.AttnDate,
dapp.InTime, dapp.OutTime, dapp.AttenType
FROM Shift sft
INNER JOIN WorkPlanGroup wp
ON wp.ShiftID = sft.ShiftID
INNER JOIN EmployeeWorkPlanSetup ews
ON ews.WorkPlanGroupID = wp.WorkPlanGroupID
INNER JOIN EMPLOYEE emp
ON emp.employeeid = ews.EmployeeID
INNER JOIN DESIGNATION dsg
ON dsg.DESIGNATIONID = emp.EMPLOYEEID
INNER JOIN DailyAttnProcess dapp
ON emp.EMPLOYEEID = dapp.EmployeeID
WHERE emp.EmployeeID = %n AND dapp.AttnDate between %d and %d", sEmpID,
fromDate, toDate);
timeSheetAttnReport = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return timeSheetAttnReport;
}
internal static DataSet GetPersonalInfoForDailyAttnReport(TransactionContext tc, int empID)
{
DataSet lmAttnReport = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"
SELECT DEPARTMENT.DESCRIPTION AS DEPARTMENT, LOCATION.DESCRIPTION AS LOCATION,
CRG.DESCRIPTION AS CostCenter
FROM EMPLOYEE
INNER JOIN DEPARTMENT ON DEPARTMENT.DEPARTMENTID = EMPLOYEE.DEPARTMENTID
INNER JOIN LOCATION ON LOCATION.LOCATIONID = EMPLOYEE.LOCATIONID
INNER JOIN EMPCOSTCENTER ON EMPCOSTCENTER.EMPLOYEEID = EMPLOYEE.EMPLOYEEID
INNER JOIN CRG ON CRG.CRGID = EMPCOSTCENTER.COSTCENTERID
WHERE Employee.EMPLOYEEID = %n AND EMPCOSTCENTER.CURRENTCC = 1
", empID);
lmAttnReport = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return lmAttnReport;
}
internal static DataSet GetPersonalInfoForTimeSheet(TransactionContext tc, int empID)
{
DataSet prsnlData = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT
ely.EmployeeNo, ely.Name, dapp.AttnDate, grd.description as Level,
dsg.name as Designation, loct.description as Location,
ely.joiningdate as JoiningDate, dept.description as Department
FROM EMPLOYEE ely
INNER JOIN DailyAttnProcess dapp
ON dapp.EmployeeID = ely.EMPLOYEEID
INNER JOIN GRADES grd
ON grd.GRADEID = ely.GRADEID
INNER JOIN LOCATION loct
ON loct.LOCATIONID = ely.LOCATIONID
INNER JOIN DEPARTMENT dept
ON ely.DEPARTMENTID = dept.DEPARTMENTID
INNER JOIN DESIGNATION dsg
ON dsg.DESIGNATIONID = ely.DESIGNATIONID
WHERE ely.EMPLOYEEID = %n", empID);
prsnlData = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return prsnlData;
}
internal static DataSet GetDailyInOut(TransactionContext tc, DateTime fromDate, DateTime toDate, string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sTableName;
string machineName = Environment.MachineName;
machineName = machineName.Substring(0, 5) + DateTime.Now.ToString("hhmmss"); //Environment.MachineName;
// string sql = SQLParser.MakeSQL(@"select sg.get(e.EMPLOYEENO) EMPLOYEENO,NVL(ac.CardNumber,'') CardNo, sg.get(e.Name) Name, sg.get(deg.NAME) Designation,cg.DESCRIPTION EmpType,
// d.AttenType Status, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
// dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID, d.ATTNDATE ATTNDATE
// from (SELECT * FROM DailyAttnProcess
// WHERE AttnDate BETWEEN %d and %d And EmployeeID IN(%q)) D
// INNER Join Employee e
// ON E.EMPLOYEEID = d.EmployeeID
// INNER Join DESIGNATION deg
// ON deg.DESIGNATIONID = e.DESIGNATIONID
// INNER JOIN DEPARTMENT dept
// ON dept.DEPARTMENTID = e.DEPARTMENTID
// INNER JOIN Category cg
// ON E.CATEGORYID = cg.CATEGORYID
// LEFT JOIN Shift s
// ON s.ShiftID = D.ShiftID
// LEFT JOIN AccessCard ac
// ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO, d.ATTNDATE asc", fromDate, toDate, sEmpID);
string sql = SQLParser.MakeSQL(@"select sg.get(e.EMPLOYEENO) EmployeeNo,
sg.get(e.Name) Name,
sg.get(deg.NAME) Designation,
CASE d.AttenType
WHEN 1 THEN 'Present'
WHEN 2 THEN 'Absent'
WHEN 3 THEN 'Delay'
WHEN 4 THEN 'Leave'
WHEN 5 THEN 'Holiday'
WHEN 7 THEN 'OutSideDuty'
WHEN 8 THEN 'WeeklyHoliday'
WHEN 11 THEN 'Late'
WHEN 12 THEN 'Early' END Status,
CASE d.WorkDayType
WHEN 1 THEN 'Rest Day'
WHEN 2 THEN 'National Holiday'
WHEN 3 THEN 'Working Day'
WHEN 4 THEN 'Hartal Day' END WorkDayType ,
d.InTime,
d.OutTime,
d.OTHour,
NVL(s.ShortName,'') Shift,
sg.get(e.EmailAddress) EmailAddress,
sg.get(e.MobileNO) MobileNO,
vwEmp.Division,
vwEmp.Department DeptName,
vwEmp.Unit,
d.ATTNDATE AttendanceDate,
EXTRACT(day FROM d.ATTNDATE) ""Day"",
CASE EXTRACT(month FROM d.ATTNDATE)
WHEN 1 THEN 'Jan'
WHEN 2 THEN 'Feb'
WHEN 3 THEN 'Mar'
WHEN 4 THEN 'Apr'
WHEN 5 THEN 'May'
WHEN 6 THEN 'Jun'
WHEN 7 THEN 'Jul'
WHEN 8 THEN 'Aug'
WHEN 9 THEN 'Sept'
WHEN 10 THEN 'Oct'
WHEN 11 THEN 'Nov'
WHEN 12 THEN 'Dec' END ""Month"",
EXTRACT(year FROM d.ATTNDATE) ""Year"",
vwEmp.LineManagerName LMName,
vwEmp.LineManagerNo LMNo,
vwEmp.LMEmailAddress LMEmail
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d and %d And EmployeeID IN(%q)) D
LEFT Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
LEFT Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
LEFT JOIN DEPARTMENT dept
ON dept.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN VW_EMPLOYEEBASIC_%q vwEmp ON e.EMPLOYEEID = vwEmp.EMPLOYEEID Order By e.EMPLOYEENO, d.ATTNDATE asc",
fromDate, toDate, sEmpID, machineName);
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
// internal static DataSet GetDailyDataByStatus(TransactionContext tc, DateTime attnDate, string sStatus, string sEmpID)
// {
// DataSet dailyInOut = new DataSet();
// try
// {
// string sql;
// if (sStatus != string.Empty)
// {
// sql = SQLParser.MakeSQL(@"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo,e.Name,deg.NAME Designation,cg.DESCRIPTION EmpType,
// d.AttenType Status, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
// dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
// from (SELECT * FROM DailyAttnProcess
// WHERE AttnDate=%d And AttenType IN(%q) And EmployeeID IN(%q)) D
// INNER Join Employee e
// ON E.EMPLOYEEID = d.EmployeeID
// INNER Join DESIGNATION deg
// ON deg.DESIGNATIONID = e.DESIGNATIONID
// INNER JOIN DEPARTMENT dept
// ON dept.DEPARTMENTID = e.DEPARTMENTID
// INNER JOIN Category cg
// ON E.CATEGORYID = cg.CATEGORYID
// LEFT JOIN Shift s
// ON s.ShiftID = D.ShiftID
// LEFT JOIN AccessCard ac
// ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO ASC", attnDate, sStatus, sEmpID);
// }
// else
// {
// sql = SQLParser.MakeSQL(@"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo, e.Name, deg.NAME Designation,cg.DESCRIPTION EmpType,
// d.AttenType Status, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
// dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
// from (SELECT * FROM DailyAttnProcess
// WHERE AttnDate=%d And EmployeeID IN(%q)) D
// INNER Join Employee e
// ON E.EMPLOYEEID = d.EmployeeID
// INNER Join DESIGNATION deg
// ON deg.DESIGNATIONID = e.DESIGNATIONID
// INNER JOIN DEPARTMENT dept
// ON dept.DEPARTMENTID = e.DEPARTMENTID
// INNER JOIN Category cg
// ON E.CATEGORYID = cg.CATEGORYID
// LEFT JOIN Shift s
// ON s.ShiftID = D.ShiftID
// LEFT JOIN AccessCard ac
// ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO ASC", attnDate, sEmpID);
// }
// dailyInOut = tc.ExecuteDataSet(sql);
// }
// catch (Exception ex)
// {
// throw new Exception(ex.Message);
// }
// return dailyInOut;
// }
internal static DataSet GetDailyDataByStatus(TransactionContext tc, DateTime attnDate, string sStatus,
string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql;
if (sStatus != string.Empty)
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate=%d And AttenType IN(%q) And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", attnDate, sStatus, sEmpID);
}
else
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate=%d And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", attnDate, sEmpID);
}
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDataByStatus(TransactionContext tc, DateTime fromDate, DateTime toDate, string sStatus,
string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql;
if (sStatus != string.Empty)
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d AND %d And AttenType IN(%q) And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", fromDate, toDate, sStatus, sEmpID);
}
else
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d AND %d And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", fromDate, toDate, sEmpID);
}
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDateRangeWiseDataByStatusReport(TransactionContext tc, DateTime fromDate, DateTime toDate, string sStatus,
string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql;
if (sStatus != string.Empty)
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d AND %d And AttenType IN(%q) And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", fromDate, toDate, sStatus, sEmpID);
}
else
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d AND %d And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
", fromDate, toDate, sEmpID);
}
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDailyOddDataByStatusReport(TransactionContext tc, DateTime attnDate,
string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,s.ShiftID as ShiftID,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from DailyAttnProcess D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
WHERE D.AttnDate = %d AND D.EmployeeID IN(%q)
AND (D.InTime IS NULL OR D.OutTime IS NULL)
AND NOT (D.InTime IS NULL AND D.OutTime IS NULL)
", attnDate, sEmpID);
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDateWiseAttnRecords(TransactionContext tc, DateTime attnDate,
string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,IsNull(ac.CardNumber,'') as CardNo,e.Name,deg.NAME as Designation,cg.DESCRIPTION AS EmpType,
d.AttenType as Status, d.Comments,d.InTime,d.OutTime,ISNULL(d.OTHour,0) OTHour,IsNULL(s.ShortName,'') as Shift,
d.attndate,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
d.ReferenceID, dept5.DEPARTMENTID DeptID, dept5.[DESCRIPTION] DeptName
from DailyAttnProcess D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
Left JOIN DEPARTMENT dept5
ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4
ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3
ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2
ON dept2.DEPARTMENTID = dept3.PARENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
WHERE D.AttnDate = %d AND D.EmployeeID IN(%q)
AND (D.InTime IS NULL OR D.OutTime IS NULL)
", attnDate, sEmpID);
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDailyAbsent(TransactionContext tc, DateTime fromDate, DateTime toDate, string sEmpID,
EnumAttendanceType status, int payrollTypeID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql;
sql = SQLParser.MakeSQL(
@"select sg.get(e.EMPLOYEENO) EMPLOYEENO,NVL(ac.CardNumber,'') CardNo, sg.get(e.Name) Name ,deg.NAME Designation,cg.DESCRIPTION EmpType,
d.AttenType Status, d.ATTNDATE, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate Between %d AND %d And AttenType IN(%n) And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
INNER JOIN DEPARTMENT dept
ON dept.DEPARTMENTID = e.DEPARTMENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID
WHERE e.PAYROLLTYPEID=%n
Order By e.EMPLOYEENO, d.ATTNDATE ASC", fromDate, toDate, status, sEmpID,
payrollTypeID);
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetDailyDataByStatus(TransactionContext tc, DateTime fromDate, DateTime toDate,
string sStatus, string sEmpID)
{
DataSet dailyInOut = new DataSet();
try
{
string sql;
if (sStatus != string.Empty)
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo,e.Name,deg.NAME Designation,cg.DESCRIPTION EmpType,
d.AttenType Status, d.ATTNDATE, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate Between %d AND %d And AttenType IN(%q) And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
INNER JOIN DEPARTMENT dept
ON dept.DEPARTMENTID = e.DEPARTMENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO, d.ATTNDATE ASC",
fromDate, toDate, sStatus, sEmpID);
}
else
{
sql = SQLParser.MakeSQL(
@"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo, e.Name, deg.NAME Designation,cg.DESCRIPTION EmpType,
d.AttenType Status, d.Comments,d.InTime,d.OutTime,d.OTHour,NVL(s.ShortName,'') Shift,
dept.DEPARTMENTID DeptID,dept.DESCRIPTION DeptName,d.ReferenceID
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate Between %d AND %d And EmployeeID IN(%q)) D
INNER Join Employee e
ON E.EMPLOYEEID = d.EmployeeID
INNER Join DESIGNATION deg
ON deg.DESIGNATIONID = e.DESIGNATIONID
INNER JOIN DEPARTMENT dept
ON dept.DEPARTMENTID = e.DEPARTMENTID
INNER JOIN Category cg
ON E.CATEGORYID = cg.CATEGORYID
LEFT JOIN Shift s
ON s.ShiftID = D.ShiftID
LEFT JOIN AccessCard ac
ON e.CardID = ac.AccessCardID Order By e.EMPLOYEENO, d.ATTNDATE ASC",
fromDate, toDate, sEmpID);
}
dailyInOut = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOut;
}
internal static DataSet GetZandDocLeave(TransactionContext tc, DateTime fromdate, DateTime todate,
int PayrollTypeID)
{
DataSet dailyInOutAndAbsent = new DataSet();
try
{
//4, 'DL', 'Doctors Leave'
//21, 'ZL', 'Z Leave'
string sql = SQLParser.MakeSQL("select dap.Employeeid, dap.ReferenceID, Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " dap.ReferenceID IN (4,21) "
+ " "
+ " AND dap.AttenType = %n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n Group by dap.Employeeid,dap.ReferenceID",
EnumAttendanceType.Leave, fromdate, todate, PayrollTypeID);
dailyInOutAndAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOutAndAbsent;
}
internal static DataSet GetDailyInOutAndAbsent(TransactionContext tc, DateTime attnDate, string sEmpID)
{
DataSet dailyInOutAndAbsent = new DataSet();
try
{
string sql = SQLParser.MakeSQL(
"select A.CardNumber, e.EMPLOYEENO, e.Name, deg.NAME Designation, d.AttenType, d.Comments,d.InTime,d.OutTime,d.LateHour,d.OTHour,s.ShortName,dept.DEPARTMENTID,dept.DESCRIPTION DepartmentName "
+ "from DailyAttnProcess D, AccessCard A, Employee e, DESIGNATION deg,Shift s, DEPARTMENT dept where E.EMPLOYEEID = d.EmployeeID "
+ "AND E.CardID = A.AccessCardID "
+ " AND deg.DESIGNATIONID = e.DESIGNATIONID "
+ " AND s.ShiftID = d.ShiftID "
+ " AND dept.DEPARTMENTID = e.DEPARTMENTID "
+ "AND AttnDate=%d AND E.EmployeeID IN(%q)", attnDate, sEmpID);
dailyInOutAndAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOutAndAbsent;
}
internal static DataSet GetDailyAbsent(TransactionContext tc, DateTime attnDate, string sEmpID)
{
DataSet dailyAbsent = new DataSet();
try
{
//string sql = SQLParser.MakeSQL("select c.CardNumber, e.EMPLOYEENO, e.Name, des.NAME Designation, d.AttenType, d.Comments "
// + "from DailyAttnProcess d inner join EMPLOYEE e on e.EMPLOYEEID = d.EmployeeID "
// + "inner join CardOperation c on c.CardID = e.CardID "
// + "inner join DESIGNATION des on des.DESIGNATIONID = e.DESIGNATIONID "
// + "where AttnDate=%d AND d.EmployeeID IN(%q) AND AttenType=%n", attnDate, sEmpID, EnumAttendanceType.Absent);
string sql = SQLParser.MakeSQL(
"select A.CardNumber, e.EMPLOYEENO, e.Name, deg.NAME Designation, d.AttenType, d.Comments "
+ "from DailyAttnProcess D, AccessCard A, Employee e, DESIGNATION deg where E.EMPLOYEEID = d.EmployeeID "
+ "AND E.CardID = A.AccessCardID "
+ " AND deg.DESIGNATIONID = e.DESIGNATIONID "
+ "AND AttnDate=%d AND E.EmployeeID IN(%q) AND AttenType=%n", attnDate, sEmpID,
EnumAttendanceType.Absent);
dailyAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyAbsent;
}
internal static DataSet GetMonthlyDetail(TransactionContext tc, DateTime dFromDate, DateTime dToDate,
string sEmpID)
{
DataSet monthlyDetail = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"select e.EMPLOYEENO,NVL(ac.CardNumber,'') CardNo,e.Name,des.NAME Designation,
e.JOININGDATE,e.GROSSSALARY,d.AttnDate,d.AttenType
from (SELECT * FROM DailyAttnProcess
WHERE AttnDate between %d and %d And EmployeeID IN(%q)) d
inner join EMPLOYEE e
on e.EMPLOYEEID = d.EmployeeID
inner join DESIGNATION des on des.DESIGNATIONID = e.DESIGNATIONID
LEFT JOIN AccessCard ac ON e.CardID = ac.AccessCardID
group by e.EMPLOYEENO,e.Name,des.NAME, e.JOININGDATE,e.GROSSSALARY,d.AttnDate,d.AttenType,ac.CardNumber
order by d.AttnDate", dFromDate, dToDate, sEmpID);
monthlyDetail = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return monthlyDetail;
}
internal static DataSet GetMonthlyLongAbsent(TransactionContext tc, DateTime dFromDate, DateTime dToDate,
int totalAbsentDays)
{
DataSet monthlyDetail = new DataSet();
try
{
string sql = SQLParser.MakeSQL("select e.EMPLOYEENO,e.Name,des.NAME Designation, "
+ "e.JOININGDATE,e.GROSSSALARY,d.AttnDate,d.AttenType "
+ "from DailyAttnProcess d INNER JOIN "
+ "(SELECT EmployeeID,absCount=SUM(CASE WHEN AttenType=%n THEN 1 ELSE 0 END) from DailyAttnProcess "
+ "WHERE AttnDate between %d and %d GROUP BY EmployeeID) abs ON D.EmployeeID=abs.EmployeeID inner join EMPLOYEE e on e.EMPLOYEEID = d.EmployeeID "
+ "inner join DESIGNATION des on des.DESIGNATIONID = e.DESIGNATIONID "
+ "where AttnDate between %d and %d AND abs.absCount>=%n group by e.EMPLOYEENO,e.Name,des.NAME, e.JOININGDATE,e.GROSSSALARY,d.AttnDate,d.AttenType "
+ "order by d.AttnDate", EnumAttendanceType.Absent, dFromDate, dToDate,
dFromDate, dToDate, totalAbsentDays);
monthlyDetail = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return monthlyDetail;
}
internal static DataSet GetEmpAttenInfo(TransactionContext tc, string sEmpID)
{
DataSet empAttenInfo = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"select e.EMPLOYEENO,e.Name,ac.CardNumber,s.ShortName,w.Name,
'Department' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END
from employee e inner join AccessCard ac on ac.AccessCardID = e.CardID inner join
EmployeeWorkPlanSetup es on es.EmployeeID = e.EMPLOYEEID inner join
shift s on s.ShiftID = es.ShiftID inner join
WorkPlanGroup w on w.WorkPlanGroupID = es.WorkPlanGroupID
Left JOIN DEPARTMENT dept5 ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4 ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3 ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2 ON dept2.DEPARTMENTID = dept3.PARENTID
WHERE e.EMPLOYEEID IN(%q) order by e.EMPLOYEENO", sEmpID);
empAttenInfo = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return empAttenInfo;
}
internal static DataSet GetEmpCardInfo(TransactionContext tc, string sEmpID)
{
DataSet empAttenInfo = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT e.EMPLOYEENO IDNo,
e.NAME,e.JOININGDATE DOJ,
NVL(e.PhotoPath,'') EmpPhoto,
NVL(des.NAME,'') Desig,
NVL(gd.DESCRIPTION,'') Grade,
NVL(gd.COLORCODE,'White') GradeColor,
NVL(dept.DESCRIPTION,'') Dept,
NVL(acrd.CardNumber,'') CardNo,
CASE
WHEN dept.TIRE = 4 THEN dept.DESCRIPTION
WHEN dept.TIRE = 5 THEN (SELECT Description FROM DEPARTMENT WHERE DEPARTMENTID = dept.PARENTID)
ELSE ''
END Section,
CASE
WHEN e.BLOODGROUP =1 THEN 'NONE'
WHEN e.BLOODGROUP =2 THEN 'A+'
WHEN e.BLOODGROUP =3 THEN 'A-'
WHEN e.BLOODGROUP =4 THEN 'B+'
WHEN e.BLOODGROUP =5 THEN 'B-'
WHEN e.BLOODGROUP =6 THEN 'O+'
WHEN e.BLOODGROUP =7 THEN 'O-'
WHEN e.BLOODGROUP =8 THEN 'AB+'
WHEN e.BLOODGROUP =9 THEN 'AB-'
WHEN e.BLOODGROUP =10 THEN 'NA'
ELSE ''
END BG
FROM
(SELECT * FROM EMPLOYEE WHERE EMPLOYEEID IN (%q)) e
LEFT JOIN DESIGNATION des
ON e.DESIGNATIONID = des.DESIGNATIONID
LEFT JOIN GRADES gd
ON e.GRADEID = gd.GRADEID
LEFT JOIN DEPARTMENT dept
ON e.DEPARTMENTID = dept.DEPARTMENTID
LEFT JOIN AccessCard acrd
ON e.CardID = acrd.AccessCardID
", sEmpID);
empAttenInfo = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return empAttenInfo;
}
internal static DataSet GetHolidays(TransactionContext tc, DateTime attnDate, int empID)
{
DataSet holidays = new DataSet();
try
{
string sql = SQLParser.MakeSQL("select count(EmployeeID) Holidays from DailyAttnProcess "
+ " where EmployeeID=%n and AttnDate between %d And %d and AttenType IN(%n,%n) ",
empID,
GlobalFunctions.FirstDateOfMonth(attnDate), GlobalFunctions.LastDateOfMonth(attnDate),
EnumAttendanceType.Holiday, EnumAttendanceType.WeeklyHoliday);
holidays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return holidays;
}
internal static IDataReader GetAttnDataByWFStatus(TransactionContext tc, DateTime fromDate, DateTime toDate,
string empIDs, EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus=%n and AttnDate between %d and %d Order By AttnDate desc",
empIDs, (int)status, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnDataByWFStatus(TransactionContext tc, string empIDs, EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus=%n Order By AttnDate desc",
empIDs, (int)status);
return tc.ExecuteReader(sql);
}
internal static int GetAttnDataByWFStatusCount(TransactionContext tc, string empIDs, EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select Count(*) from DailyAttnProcess
where EmployeeID in (%q) and WFStatus=%n", empIDs, (int)status);
return Convert.ToInt32(tc.ExecuteScalar(sql).ToString());
}
internal static IDataReader GetAttnSubmittedData(TransactionContext tc, string empIDs, DateTime fromDate,
DateTime toDate)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus Not In (0,5) and AttnDate Between %d and %d order by AttnDate asc",
empIDs, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnSubmittedData(TransactionContext tc, string empIDs, bool IsCurrentMonth,
DateTime NextPayProcessDate)
{
DateTime fromDate = GlobalFunctions.FirstDateOfMonth(NextPayProcessDate);
fromDate = fromDate.AddMonths(-1);
fromDate = new DateTime(fromDate.Year, fromDate.Month, 11);
DateTime toDate = GlobalFunctions.LastDateOfMonth(NextPayProcessDate);
toDate = new DateTime(toDate.Year, toDate.Month, 10);
string sql = string.Empty;
if (IsCurrentMonth)
{
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus Not In (0,5) and AttnDate Between %d and %d ",
empIDs, fromDate, toDate);
}
else
{
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus Not In (0,5)", empIDs);
}
return tc.ExecuteReader(sql);
}
internal static DataSet GetAttnApprovedData(TransactionContext tc, string empIDs, EnumWFAttnStatus status,
DateTime fromdate, DateTime todate)
{
DataSet presentDays = new DataSet();
try
{
string sql = string.Empty;
if (status == EnumWFAttnStatus.LMApproved)
{
sql = SQLParser.MakeSQL(
@"SELECT e.EmployeeID, e.EMPLOYEENO EmployeeNo, e.NAME Name, dept.DESCRIPTION Department, desig.NAME Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS IN (2,3) and e.EmployeeID in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", empIDs, fromdate, todate);
}
else
{
sql = SQLParser.MakeSQL(
@"SELECT e.EmployeeID, sg.get(e.EMPLOYEENO)EmployeeNo, sg.get(e.NAME)Name, dept.DESCRIPTION Department, sg.get(desig.NAME) Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs, fromdate, todate);
}
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet GetMonthlyOverTime(TransactionContext tc, DateTime fromdate, DateTime todate,
EnumWorkPlanDayType wpType)
{
DataSet presentDays = new DataSet();
DateTime salaryMonth = GlobalFunctions.LastDateOfMonth(todate);
try
{
string sql = string.Empty;
if (wpType == EnumWorkPlanDayType.NationalHoliday)
{
sql = SQLParser.MakeSQL(
@"SELECT e.EMPLOYEEID, e.EMPLOYEENO, SUM(dap.APPROVEDOTHOUR) APPROVEDOTHOUR FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
WHERE APPROVEDOTHOUR>0 AND dap.WORKDAYTYPE=%n AND dap.WFSTATUS=%n AND dap.SalaryMonth=%d
GROUP BY e.EMPLOYEEID, e.EMPLOYEENO", wpType, EnumWFAttnStatus.DHApproved,
salaryMonth);
}
else
{
sql = SQLParser.MakeSQL(
@"SELECT e.EMPLOYEEID, e.EMPLOYEENO, SUM(dap.APPROVEDOTHOUR) APPROVEDOTHOUR FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
WHERE APPROVEDOTHOUR>0 AND dap.WORKDAYTYPE not in (%n) AND dap.WFSTATUS=%n AND dap.SalaryMonth=%d
GROUP BY e.EMPLOYEEID, e.EMPLOYEENO", EnumWorkPlanDayType.NationalHoliday,
EnumWFAttnStatus.DHApproved, salaryMonth);
}
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static int GetAttnDataByWFStatusCountForMobile(TransactionContext tc, int empID, EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select Count(*) from DailyAttnProcess With(NoLock)
where DailyAttnProcess.EmployeeID in ( select EmployeeID from Employee With(NoLock) where linemanagerid =%n)
and WFStatus=%n and AttnDate >%d", empID, (int)status, DateTime.Today.AddMonths(-3));
var rvalue = tc.ExecuteScalar(sql);
if (rvalue != DBNull.Value) return Convert.ToInt32(rvalue);
else return 0;
}
internal static DataSet GetAttnSubmittedData(TransactionContext tc, string empIDs, EnumWFAttnStatus status,
bool isCurrentMonth, DateTime NextPayProcessDate)
{
DataSet presentDays = new DataSet();
try
{
DateTime fromDate = GlobalFunctions.FirstDateOfMonth(NextPayProcessDate);
fromDate = fromDate.AddMonths(-1);
fromDate = new DateTime(fromDate.Year, fromDate.Month, 11);
DateTime toDate = GlobalFunctions.LastDateOfMonth(NextPayProcessDate);
toDate = new DateTime(toDate.Year, toDate.Month, 10);
string sql = string.Empty;
if (!isCurrentMonth)
{
sql = SQLParser.MakeSQL(
@"SELECT e.EmployeeID, sg.get(e.EMPLOYEENO) EMPLOYEENO, sg.get(e.NAME) Name, dept.DESCRIPTION Department, sg.get(desig.NAME) Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs);
}
else
{
sql = SQLParser.MakeSQL(
@"SELECT e.EmployeeID, sg.get(e.EMPLOYEENO), sg.get(e.NAME) Name, dept.DESCRIPTION Department, sg.get(desig.NAME) Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs, fromDate, toDate);
}
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet GetAttnSubmittedData(TransactionContext tc, string empIDs, EnumWFAttnStatus status,
DateTime fromDate, DateTime toDate)
{
DataSet presentDays = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(
@"SELECT e.EmployeeID, e.EMPLOYEENO, e.NAME Name, dept.DESCRIPTION Department, desig.NAME Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs, fromDate, toDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet GetPresentDays(TransactionContext tc, DateTime attnDate, int empID)
{
DataSet presentDays = new DataSet();
try
{
string sql = SQLParser.MakeSQL("select count(EmployeeID) PresentDays from DailyAttnProcess "
+ " where EmployeeID=%n and AttnDate between %d And %d and AttenType In(1,11) ",
empID,
GlobalFunctions.FirstDateOfMonth(attnDate), GlobalFunctions.LastDateOfMonth(attnDate));
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static IDataReader GetLastProcessDate(TransactionContext tc, int payrollType)
{
try
{
string sql =
SQLParser.MakeSQL(
"SELECT MAX(dap.AttnDate) LastProcessDate FROM DailyAttnProcess dap Inner Join Employee e on e.EmployeeID=dap.EmployeeID WHERE dap.IsManualEntry=0 AND e.PayrollTypeID =%n",
payrollType);
return tc.ExecuteReader(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}
internal static IDataReader GetLastProcessDateOfEmployee(TransactionContext tc, int employeeID)
{
try
{
string sql =
SQLParser.MakeSQL(
"SELECT MAX(dap.AttnDate) LastProcessDate FROM DailyAttnProcess dap Inner Join Employee e on e.EmployeeID=dap.EmployeeID WHERE dap.IsManualEntry=0 AND e.EmployeeID=%n",
employeeID);
return tc.ExecuteReader(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}
public static IDataReader GetDailyEmployeeAbsent(TransactionContext tc, DateTime dateTime, int nID)
{
try
{
string sql =
SQLParser.MakeSQL(
"Select * from DailyAttnProcess where EmployeeID=%n and AttnDate=%d and AttenType=%n", nID,
dateTime, EnumAttendanceType.Absent);
return tc.ExecuteReader(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}
internal static IDataReader GetEmployeesFirstAttendances(TransactionContext tc, string employeeIDs)
{
try
{
string sql = SQLParser.MakeSQL(@"select d.* from DailyAttnProcess d,
(SELECT MIN(AttnDate) AttnDate
,[EmployeeID]
FROM DailyAttnProcess
WHERE EmployeeID IN(%q) and AttenType=%n
group by EmployeeID
)temp
WHERE temp.EmployeeID = d.EmployeeID
AND temp.AttnDate = d.AttnDate
order by d.EmployeeID", employeeIDs, EnumAttendanceType.Present);
IDataReader dr = tc.ExecuteReader(sql);
return dr;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}
internal static IDataReader Get(TransactionContext tc, int empID, int shiftID, DateTime fromdate,
DateTime todate, EnumAttendanceType enumAttendanceType)
{
try
{
string sql = SQLParser.MakeSQL(
"Select * from DailyAttnProcess where EmployeeID=%n AND ShiftID=%n AND AttnDate BETWEEN %d AND %d AND AttenType=%n",
empID, shiftID, fromdate, todate, enumAttendanceType);
return tc.ExecuteReader(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}
#endregion
#region Delete function
internal static void Delete(TransactionContext tc, int nID)
{
tc.ExecuteNonQuery("DELETE FROM DailyAttnProcess WHERE DailyAttnProcessID=%n", nID);
}
internal static void Delete(TransactionContext tc, int empID, DateTime attnDate)
{
tc.ExecuteNonQuery("DELETE FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d", empID, attnDate);
}
internal static void Delete(TransactionContext tc, int empID, DateTime attnDate, int dailyAttnProcessID)
{
//int dAttnProcessID = 0;
//string sql = SQLParser.MakeSQL("Select DAILYATTNPROCESSID from DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d", empID, attnDate);
//Object obj = tc.ExecuteScalar(sql);
//dAttnProcessID = Convert.ToInt32(obj) > 0 ? Convert.ToInt32(obj) : 0;
//if (dAttnProcessID > 0)
//{
// tc.ExecuteNonQuery("DELETE FROM ATTNWFHISTORY WHERE DAILYATTNPROCESSID in (Select DAILYATTNPROCESSID from DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d)", empID, attnDate);
//}
tc.ExecuteNonQuery(
"DELETE FROM ATTNWFHISTORY WHERE DAILYATTNPROCESSID in (Select DAILYATTNPROCESSID from DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d)",
empID, attnDate);
tc.ExecuteNonQuery("DELETE FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d", empID, attnDate);
}
internal static void Deletewithoutmanulentry(TransactionContext tc, DateTime attnDate)
{
tc.ExecuteNonQuery("DELETE FROM DailyAttnProcess WHERE AttnDate=%d AND IsManualEntry=%b", attnDate, false);
}
#endregion
internal static IDataReader GetNew(TransactionContext tc, int empID, DateTime fromDate, DateTime toDate)
{
string sql = SQLParser.MakeSQL("SELECT * FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate BETWEEN %d AND %d order by AttnDate ASC", empID, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static DataSet GetTypeWiseAttnCount(TransactionContext tc, string empID, DateTime fromDate, DateTime toDate, params EnumAttendanceType[] attnType)
{
string attnTypes = attnType.Aggregate(new StringBuilder(), (sb, tp) => sb.AppendFormat("{0},", (int)tp), sb => sb.ToString().Trim(','));
string sSQL = SQLParser.MakeSQL(@"SELECT EmployeeID,Count(*) AS Count FROM DailyAttnProcess
WHERE AttnDate BETWEEN %d AND %d
AND EmployeeID IN (select EmployeeID from employee where status=1)
AND AttenType in (%q)
GROUP BY EmployeeID", fromDate, toDate, attnTypes);
return tc.ExecuteDataSet(sSQL);
}
internal static DataSet GetEarnedLeaveOpening(TransactionContext tc, int employeeId, int leaveid, DateTime fromDate, DateTime toDate)
{
string sql = "";
sql = SQLParser.MakeSQL(@"SELECT TotalPresent,isnull(TotalAvailed,0) TotalAvailed
from
(SELECT employeeid, round(count(AttnDate) * 1.0 / 18, 0) TotalPresent FROM DailyAttnProcess
WHERE EmployeeID = %n
AND AttnDate BETWEEN %d AND %d
AND AttenType IN(1, 3, 11, 12, 6, 7)
GROUP BY employeeid)tab1
LEFT OUTER JOIN
(SELECT empid, sum(APRTOTALDAYS) TotalAvailed FROM LEAVEENTRY
WHERE EMPID = %n
AND(APRFROMDATE > %d AND APRTODATE <= %d)
AND leavestatus = 6
AND LEAVEID = %n
GROUP BY empid)tab2 ON tab1.employeeid = tab2.empid", employeeId,
fromDate, toDate, employeeId, fromDate, toDate, leaveid);
return tc.ExecuteDataSet(sql);
}
internal static DataTable GetEarnedLeaveOpeningByEmployees(TransactionContext tc, string employeeIds, string leaveids, DateTime fromDate, DateTime toDate)
{
string sql = "";
sql = SQLParser.MakeSQL(@"SELECT TotalPresent,isnull(TotalAvailed,0) TotalAvailed, EMPLOYEEID
from
(SELECT employeeid, round(count(AttnDate) * 1.0 / 18, 0) TotalPresent FROM DailyAttnProcess
WHERE EmployeeID in (%q)
AND AttnDate BETWEEN %d AND %d
AND AttenType IN(1, 3, 11, 12, 6, 7)
GROUP BY employeeid)tab1
LEFT OUTER JOIN
(SELECT empid, sum(APRTOTALDAYS) TotalAvailed FROM LEAVEENTRY
WHERE empid in (%q)
AND(APRFROMDATE > %d AND APRTODATE <= %d)
AND leavestatus = 6
AND LEAVEID in (%q)
GROUP BY empid)tab2 ON tab1.employeeid = tab2.empid", employeeIds,
fromDate, toDate, employeeIds, fromDate, toDate, leaveids);
return tc.ExecuteDataTable(sql);
}
internal static DataSet GetMonthlyKPIDetail(TransactionContext tc, DateTime dFromDate, DateTime dToDate, string sEmpID, List<Leave> oLeaves, EnumAttendanceType eAttnType)
{
DataSet monthlyDetail = new DataSet();
try
{
string sql = string.Empty;
StringBuilder statusCase = new StringBuilder();
StringBuilder foreColor = new StringBuilder();
#region Generating Cases
statusCase.Append("'KPIStatus' = case");
foreColor.Append("'ForeColor' = case");
List<EnumAttendanceType> attnTypes = Enum.GetValues(typeof(EnumAttendanceType)).Cast<EnumAttendanceType>().ToList();
foreach (EnumAttendanceType enItem in attnTypes)
{
switch (enItem)
{
case EnumAttendanceType.Absent:
statusCase.AppendFormat(" when dap.AttenType = {0} then '{1}'", (int)enItem, "AB");
break;
case EnumAttendanceType.Holiday:
statusCase.AppendFormat(" when dap.AttenType = {0} then '{1}'", (int)enItem, "FH");
break;
case EnumAttendanceType.WeeklyHoliday:
statusCase.AppendFormat(" when dap.AttenType = {0} then '{1}'", (int)enItem, "WD");
foreColor.AppendFormat(" when dap.AttenType = {0} then '{1}'", (int)enItem, "Red");
break;
case EnumAttendanceType.Leave:
foreach (Leave lvItem in oLeaves)
{
string leaveDescription = lvItem.Description;
string leaveCode = string.Empty;
#region leave status using short form of description
//switch (leaveDescription)
//{
// case "Accident Leave": leaveCode = "Ac.L"; break;
// case "Annual Leave": leaveCode = "AL"; break;
// case "Casual Leave": leaveCode = "CL"; break;
// case "Compensation Leave": leaveCode = "COM"; break;
// case "Leave Without Pay": leaveCode = "LWP"; break;
// case "Maternity Leave": leaveCode = "Mt.L"; break;
// case "Medical Leave": leaveCode = "ML"; break;
// case "Quarantine Leave": leaveCode = "QL"; break;
// case "Sick Leave": leaveCode = "SL"; break;
//}
#endregion
leaveCode = lvItem.Code;
statusCase.AppendFormat(" when dap.AttenType = {0} and isNULL(dap.ReferenceID,0) ={1} then '{2}'", (int)enItem, lvItem.ID, leaveCode);
}
break;
case EnumAttendanceType.Present: break;
case EnumAttendanceType.HalfDay: break;
case EnumAttendanceType.Delay: break;
case EnumAttendanceType.Late:
statusCase.AppendFormat(" when dap.AttenType = {0} then '{1}'", (int)enItem, "L-PR");
break;
case EnumAttendanceType.Early: break;
case EnumAttendanceType.OutSideDuty: break;
default:
break;
}
}
statusCase.Append(" when Convert(INT,FlooR(dap.OTHour)) >= 0 then 'PR' END ");
//statusCase.Append(" else ISNULL(RIGHT('00'+Convert(varchar(50),Convert(INT,FlooR(dap.OTHour))),2)+':'+ RIGHT('00'+Convert(varchar(50),Convert(INT,(dap.OTHour%1)*60)),2),'00:00') END ");
foreColor.Append(" else 'Black' END ");
#endregion
sql = SQLParser.MakeSQL(@"SELECT eInfo.Name EmployeeName,eInfo.EmployeeNo IDNo, eInfo.Designation,eInfo.Unit, eInfo.Department, eInfo.FunctionalUnit, eInfo.DepartmentID,
eInfo.GradeName GRADE,eInfo.PaymentModeName AS BC,dap.AttnDate,dap.AttenType,IsNULL(dap.OTHour,0) OTHour,
isNULL(dap.ReferenceID,0) ReferenceID,%q,ISNULL(Line,'') Line,ISNULL(eInfo.Section,'') Section,ISNULL(eInfo.Floor,'') Floor
FROM
vw_EmployeeImportantInfo eInfo
INNER JOIN DailyAttnProcess dap
ON eInfo.EmployeeID = dap.EmployeeId
And eInfo.EmployeeID IN(%q)
and dap.AttnDate between %d and %d",
statusCase, sEmpID, dFromDate, dToDate);
monthlyDetail = tc.ExecuteDataSet(sql);
monthlyDetail.Tables[0].TableName = "MonthlyKPIDetail";
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return monthlyDetail;
}
internal static IDataReader GetByStatus(TransactionContext tc, int empID, DateTime fromDate, DateTime toDate,
string status)
{
string sql =
SQLParser.MakeSQL(
"SELECT * FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate BETWEEN %d AND %d AND CLAIMWFSTATUS IN (%q) AND ORDHour > 0 AND AttenType <> 11 order by AttnDate ASC",
empID, fromDate, toDate, status);
return tc.ExecuteReader(sql);
}
internal static DataTable GetAttnData(TransactionContext tc, int employeeID, DateTime fromdate, DateTime toDate)
{
DataSet presentDays = new DataSet();
try
{
//string sql = SQLParser.MakeSQL(@"SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID, TO_CHAR(AttnDate, 'DD-MM-YYYY') AttnDate,
// CASE
// WHEN dap.AttenType = 0 THEN 'NONE'
// WHEN dap.AttenType = 1 THEN 'Present'
// WHEN dap.AttenType = 2 THEN 'Absent'
// WHEN dap.AttenType = 3 THEN 'Delay'
// WHEN dap.AttenType = 11 THEN 'Late'
// WHEN dap.AttenType = 12 THEN 'Early'
// WHEN dap.AttenType = 4 THEN 'Leave'
// WHEN dap.AttenType = 5 THEN 'Holiday'
// WHEN dap.AttenType = 7 THEN 'OutSideDuty'
// WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
// WHEN dap.AttenType = 10 THEN 'Training'
// WHEN dap.AttenType = 11 THEN 'Project'
// ELSE ''
// END AttenType,
// s.NAME Relay, (to_char(dap.intime, 'HH24') || ':' || to_char(dap.intime, 'MI')) InTIME, (to_char(dap.OUTTIME, 'HH24') || ':' || to_char(dap.OUTTIME, 'MI')) OUTTIME,
// CASE
// WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
// WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
// WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
// WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
// ELSE ''
// END WORKDAYTYPE,
// dap.EMPREMARKS, dap.LMREMARKS,
// CASE
// WHEN dap.CLAIMWFSTATUS = 0 THEN 'None'
// WHEN dap.CLAIMWFSTATUS = 1 THEN 'EmpSubmitted'
// WHEN dap.CLAIMWFSTATUS = 2 THEN 'LMApproved'
// WHEN dap.CLAIMWFSTATUS = 3 THEN 'Rejected'
// WHEN dap.CLAIMWFSTATUS = 4 THEN 'Not_Applicable'
// ELSE ''
// END WFStatus
// FROM DAILYATTNPROCESS dap
// INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
// WHERE dap.EMPLOYEEID = %n and dap.ATTNDATE BETWEEN %d AND %d ORDER BY dap.ATTNDATE desc", employeeID, fromdate, toDate);
string sql = SQLParser.MakeSQL(
@"SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID,
CAST(AttnDate as DATE) AttnDate,
CASE
WHEN dap.AttenType = 0 THEN 'NONE'
WHEN dap.AttenType = 1 THEN 'Present'
WHEN dap.AttenType = 2 THEN 'Absent'
WHEN dap.AttenType = 3 THEN 'Delay'
WHEN dap.AttenType = 11 THEN 'Late'
WHEN dap.AttenType = 12 THEN 'Early'
WHEN dap.AttenType = 4 THEN 'Leave'
WHEN dap.AttenType = 5 THEN 'Holiday'
WHEN dap.AttenType = 7 THEN 'OutSideDuty'
WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
WHEN dap.AttenType = 10 THEN 'Training'
WHEN dap.AttenType = 11 THEN 'Project'
ELSE ''
END AttenType,
s.NAME Relay,
CAST(dap.intime AS TIME) InTime,
cast(dap.outtime as Time) OutTime,
CASE
WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
ELSE ''
END WORKDAYTYPE,
dap.EMPREMARKS, dap.LMREMARKS,
CASE
WHEN dap.CLAIMWFSTATUS = 0 THEN 'None'
WHEN dap.CLAIMWFSTATUS = 1 THEN 'EmpSubmitted'
WHEN dap.CLAIMWFSTATUS = 2 THEN 'LMApproved'
WHEN dap.CLAIMWFSTATUS = 3 THEN 'Rejected'
WHEN dap.CLAIMWFSTATUS = 4 THEN 'Not_Applicable'
ELSE ''
END WFStatus
FROM DAILYATTNPROCESS dap
INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
WHERE dap.EMPLOYEEID = %n and dap.ATTNDATE BETWEEN %d AND %d ORDER BY dap.ATTNDATE desc",
employeeID, fromdate, toDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays.Tables[0];
}
internal static DataTable GetAttnData(TransactionContext tc, int employeeID, DateTime fromdate, DateTime toDate,
string status)
{
DataSet presentDays = new DataSet();
try
{
//string sql = SQLParser.MakeSQL(@"
// SELECT * FROM
// (
// SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID,
// CAST(AttnDate as DATE) AttnDate,
// CASE
// WHEN dap.AttenType = 0 THEN 'NONE'
// WHEN dap.AttenType = 1 THEN 'Present'
// WHEN dap.AttenType = 2 THEN 'Absent'
// WHEN dap.AttenType = 3 THEN 'Delay'
// WHEN dap.AttenType = 11 THEN 'Late'
// WHEN dap.AttenType = 12 THEN 'Early'
// WHEN dap.AttenType = 4 THEN 'Leave'
// WHEN dap.AttenType = 5 THEN 'Holiday'
// WHEN dap.AttenType = 7 THEN 'OutSideDuty'
// WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
// WHEN dap.AttenType = 10 THEN 'Training'
// WHEN dap.AttenType = 11 THEN 'Project'
// ELSE ''
// END AttenType,
// s.NAME Relay,
// CAST(dap.intime as Time) InTime,
// CAST(dap.outtime as Time) OutTime,
// CASE
// WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
// WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
// WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
// WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
// ELSE ''
// END WORKDAYTYPE,
// dap.EMPREMARKS
// FROM DAILYATTNPROCESS dap
// INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
// WHERE dap.EMPLOYEEID = %n AND dap.ORDHour > 0 and NOT dap.CLAIMWFSTATUS IN (%q)
// and dap.ATTNDATE BETWEEN %d AND %d and NOT dap.AttenType in (%n)
// UNION
// SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID,
// CAST(AttnDate as DATE) AttnDate,
// CASE
// WHEN dap.AttenType = 0 THEN 'NONE'
// WHEN dap.AttenType = 1 THEN 'Present'
// WHEN dap.AttenType = 2 THEN 'Absent'
// WHEN dap.AttenType = 3 THEN 'Delay'
// WHEN dap.AttenType = 11 THEN 'Late'
// WHEN dap.AttenType = 12 THEN 'Early'
// WHEN dap.AttenType = 4 THEN 'Leave'
// WHEN dap.AttenType = 5 THEN 'Holiday'
// WHEN dap.AttenType = 7 THEN 'OutSideDuty'
// WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
// WHEN dap.AttenType = 10 THEN 'Training'
// WHEN dap.AttenType = 11 THEN 'Project'
// ELSE ''
// END AttenType,
// s.NAME Relay,
// CAST(dap.intime as Time) InTime,
// CAST(dap.outtime as Time) OutTime,
// CASE
// WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
// WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
// WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
// WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
// ELSE ''
// END WORKDAYTYPE,
// dap.EMPREMARKS
// FROM DAILYATTNPROCESS dap
// INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
// WHERE dap.EMPLOYEEID = %n AND dap.AttenType = 2 and NOT dap.CLAIMWFSTATUS IN (%q)
// and dap.ATTNDATE BETWEEN %d AND %d and Not dap.AttenType in (%n)
// )
// ORDER BY ATTNDATE desc
// ", employeeID, status, fromdate, toDate, (int)EnumAttendanceType.Leave, employeeID, status, fromdate, toDate, (int)EnumAttendanceType.Leave);
string sql = SQLParser.MakeSQL(@"
SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID,
CAST(AttnDate as DATE) AttnDate,
CASE
WHEN dap.AttenType = 0 THEN 'NONE'
WHEN dap.AttenType = 1 THEN 'Present'
WHEN dap.AttenType = 2 THEN 'Absent'
WHEN dap.AttenType = 3 THEN 'Delay'
WHEN dap.AttenType = 11 THEN 'Late'
WHEN dap.AttenType = 12 THEN 'Early'
WHEN dap.AttenType = 4 THEN 'Leave'
WHEN dap.AttenType = 5 THEN 'Holiday'
WHEN dap.AttenType = 7 THEN 'OutSideDuty'
WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
WHEN dap.AttenType = 10 THEN 'Training'
WHEN dap.AttenType = 11 THEN 'Project'
ELSE ''
END AttenType,
s.NAME Relay,
CAST(dap.intime as Time) InTime,
CAST(dap.outtime as Time) OutTime,
CASE
WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
ELSE ''
END WORKDAYTYPE,
dap.EMPREMARKS
FROM DAILYATTNPROCESS dap
INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
WHERE dap.EMPLOYEEID = %n AND dap.ORDHour > 0 and NOT dap.CLAIMWFSTATUS IN (%q)
and dap.ATTNDATE BETWEEN %d AND %d and NOT dap.AttenType in (%n)
UNION
SELECT dap.DAILYATTNPROCESSID DailyAttnID, dap.DAILYATTNPROCESSID DailyAttnProcessID,
CAST(AttnDate as DATE) AttnDate,
CASE
WHEN dap.AttenType = 0 THEN 'NONE'
WHEN dap.AttenType = 1 THEN 'Present'
WHEN dap.AttenType = 2 THEN 'Absent'
WHEN dap.AttenType = 3 THEN 'Delay'
WHEN dap.AttenType = 11 THEN 'Late'
WHEN dap.AttenType = 12 THEN 'Early'
WHEN dap.AttenType = 4 THEN 'Leave'
WHEN dap.AttenType = 5 THEN 'Holiday'
WHEN dap.AttenType = 7 THEN 'OutSideDuty'
WHEN dap.AttenType = 8 THEN 'WeeklyHoliday'
WHEN dap.AttenType = 10 THEN 'Training'
WHEN dap.AttenType = 11 THEN 'Project'
ELSE ''
END AttenType,
s.NAME Relay,
CAST(dap.intime as Time) InTime,
CAST(dap.outtime as Time) OutTime,
CASE
WHEN dap.WORKDAYTYPE = 1 THEN 'WeeklyHoliday'
WHEN dap.WORKDAYTYPE = 2 THEN 'NationalHoliday'
WHEN dap.WORKDAYTYPE = 3 THEN 'WorkingDay'
WHEN dap.WORKDAYTYPE = 4 THEN 'HartalDay'
ELSE ''
END WORKDAYTYPE,
dap.EMPREMARKS
FROM DAILYATTNPROCESS dap
INNER JOIN SHIFT s ON s.SHIFTID = dap.SHIFTID
WHERE dap.EMPLOYEEID = %n AND dap.AttenType = 2 and NOT dap.CLAIMWFSTATUS IN (%q)
and dap.ATTNDATE BETWEEN %d AND %d and Not dap.AttenType in (%n)
", employeeID, status, fromdate, toDate, (int)EnumAttendanceType.Leave,
employeeID, status, fromdate, toDate, (int)EnumAttendanceType.Leave);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays.Tables[0];
}
internal static DataSet MonthlyAttendanceSummaryForMailSchedular(TransactionContext tc, int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid)
{
// 'SPP Head Office' => for Synovia
DataSet presentDays = new DataSet();
try
{
string dateRange = $"'{fromDate:yyyy-MM-dd}' AND '{toDate:yyyy-MM-dd}'";
string sql;
sql = SQLParser.MakeSQL(@"
SELECT EMPLOYEE.EMPLOYEENO, Employee.NAME, DS.NAME AS Designation, aa.* FROM EMPLOYEE INNER JOIN
(
SELECT
E.EMPLOYEEID,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.workdaytype =3 THEN 1 ELSE NULL END) AS TotalWorkingDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 1 THEN 1 ELSE NULL END) AS TotalAttendedDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 2 THEN 1 ELSE NULL END) AS TotalAbsentDays,
SUM(CASE WHEN D.ATTNDATE BETWEEN %q AND D.LATEHOUR > 0 THEN 1 ELSE 0 END) AS TotalLateDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 3 THEN 1 ELSE NULL END) AS TotalLeaveDays
FROM
DAILYATTNPROCESS D
Inner JOIN
EMPLOYEE E ON E.EMPLOYEEID = D.EMPLOYEEID
WHERE E.LINEMANAGERID = %n
GROUP BY E.EMPLOYEEID ) aa
ON aa.Employeeid = EMPLOYEE.EMPLOYEEID
INNER JOIN DESIGNATION DS ON DS.DESIGNATIONID = EMPLOYEE.DESIGNATIONID", dateRange, dateRange, dateRange, dateRange, dateRange, id);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet MonthlyAttendanceSummaryForMailSchedularCordinator(TransactionContext tc, int id, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid)
{
// 'SPP Head Office' => for Synovia
DataSet presentDays = new DataSet();
try
{
string dateRange = $"'{fromDate:yyyy-MM-dd}' AND '{toDate:yyyy-MM-dd}'";
string sql;
sql = SQLParser.MakeSQL(@"
SELECT EMPLOYEE.EMPLOYEENO, Employee.NAME, DS.NAME AS Designation, aa.* FROM EMPLOYEE INNER JOIN
(
SELECT
E.EMPLOYEEID,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.workdaytype =3 THEN 1 ELSE NULL END) AS TotalWorkingDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 1 THEN 1 ELSE NULL END) AS TotalAttendedDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 2 THEN 1 ELSE NULL END) AS TotalAbsentDays,
SUM(CASE WHEN D.ATTNDATE BETWEEN %q AND D.LATEHOUR > 0 THEN 1 ELSE 0 END) AS TotalLateDays,
COUNT(CASE WHEN D.ATTNDATE BETWEEN %q AND D.ATTENTYPE = 3 THEN 1 ELSE NULL END) AS TotalLeaveDays
FROM
DAILYATTNPROCESS D
Inner JOIN
EMPLOYEE E ON E.EMPLOYEEID = D.EMPLOYEEID
WHERE E.EMPLOYEEID IN(SELECT employeId FROM EmployeeCordinator WHERE CordinatorID = %n)
GROUP BY E.EMPLOYEEID ) aa
ON aa.Employeeid = EMPLOYEE.EMPLOYEEID
INNER JOIN DESIGNATION DS ON DS.DESIGNATIONID = EMPLOYEE.DESIGNATIONID", dateRange, dateRange, dateRange, dateRange, dateRange, id);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static IDataReader AttendanceDataForMailSchedular(TransactionContext tc, DateTime fromDate, DateTime toDate, EnumAttendanceType attnType, int payrollTypeid)
{
// 'SPP Head Office' => for Synovia
string sql;
if (attnType == EnumAttendanceType.None)
{
sql = SQLParser.MakeSQL(@"
WITH cte2 AS
(
SELECT
LOCATIONID
FROM LOCATION
WHERE PARENTID IN (SELECT LOCATIONID FROM LOCATION WHERE DESCRIPTION = 'Head Office' OR DESCRIPTION = 'SPP Head Office')
UNION ALL
SELECT
i.LOCATIONID
FROM LOCATION i
INNER JOIN cte2 c ON c.LOCATIONID = i.PARENTID
),
cte AS (
SELECT * FROM cte2
UNION
SELECT LOCATIONID FROM LOCATION WHERE DESCRIPTION = 'Head Office' OR DESCRIPTION = 'SPP Head Office'
)
SELECT dap.DAILYATTNPROCESSID, e.EMPLOYEEID, e.EMPLOYEENO, e.NAME, des.NAME [DESIGNATION], dep.DESCRIPTION [DEPARTMENT], dap.AttnDate,
FORMAT(dap.AttnDate,'dddd') day, dap.InTime, dap.OutTime, dap.AttenType,
iif(dap.AttenType != 5, l.DESCRIPTION, nh.DESCRIPTION) NotPresentType,
lm.EMPLOYEENO LINEMANAGERNO, lm.NAME LINEMANAGERNAME
FROM DAILYATTNPROCESS dap
JOIN EMPLOYEE e ON dap.EMPLOYEEID = e.EMPLOYEEID
JOIN cte c ON c.LOCATIONID = e.LOCATIONID
LEFT JOIN EMPLOYEE lm ON e.LINEMANAGERID = lm.EMPLOYEEID
LEFT JOIN DESIGNATION des ON e.DESIGNATIONID = des.DESIGNATIONID
LEFT JOIN DEPARTMENT dep ON e.DEPARTMENTID = dep.DEPARTMENTID
LEFT JOIN LEAVE l ON l.LEAVEID = dap.ReferenceID
LEFT JOIN ATTNNATIONALHOLIDAY nh ON nh.ATTNNATIONALHOLIDAYID = dap.ReferenceID
WHERE e.PAYROLLTYPEID = %n AND e.STATUS = 1 AND dap.AttnDate BETWEEN %d AND %d
ORDER BY dep.DESCRIPTION ASC",
payrollTypeid, fromDate, toDate);
}
else
{
sql = SQLParser.MakeSQL(@"
WITH cte2 AS
(
SELECT
LOCATIONID
FROM LOCATION
WHERE PARENTID IN (SELECT LOCATIONID FROM LOCATION WHERE DESCRIPTION = 'Head Office' OR DESCRIPTION = 'SPP Head Office')
UNION ALL
SELECT
i.LOCATIONID
FROM LOCATION i
INNER JOIN cte2 c ON c.LOCATIONID = i.PARENTID
),
cte AS (
SELECT * FROM cte2
UNION
SELECT LOCATIONID FROM LOCATION WHERE DESCRIPTION = 'Head Office' OR DESCRIPTION = 'SPP Head Office'
)
SELECT dap.DAILYATTNPROCESSID, e.EMPLOYEEID, e.EMPLOYEENO, e.NAME, des.NAME [DESIGNATION], dep.DESCRIPTION [DEPARTMENT], dap.AttnDate,
FORMAT(dap.AttnDate,'dddd') day, dap.InTime, dap.OutTime, dap.AttenType,
iif(dap.AttenType != 5, l.DESCRIPTION, nh.DESCRIPTION) NotPresentType,
lm.EMPLOYEENO LINEMANAGERNO, lm.NAME LINEMANAGERNAME
FROM DAILYATTNPROCESS dap
JOIN EMPLOYEE e ON dap.EMPLOYEEID = e.EMPLOYEEID
JOIN cte c ON c.LOCATIONID = e.LOCATIONID
LEFT JOIN EMPLOYEE lm ON e.LINEMANAGERID = lm.EMPLOYEEID
LEFT JOIN DESIGNATION des ON e.DESIGNATIONID = des.DESIGNATIONID
LEFT JOIN DEPARTMENT dep ON e.DEPARTMENTID = dep.DEPARTMENTID
LEFT JOIN LEAVE l ON l.LEAVEID = dap.ReferenceID
LEFT JOIN ATTNNATIONALHOLIDAY nh ON nh.ATTNNATIONALHOLIDAYID = dap.ReferenceID
WHERE e.PAYROLLTYPEID = %n AND e.STATUS = 1 AND dap.AttenType = %n AND dap.AttnDate BETWEEN %d AND %d
ORDER BY dep.DESCRIPTION ASC",
payrollTypeid, attnType, fromDate, toDate);
}
return tc.ExecuteReader(sql);
}
internal static DataSet GetDailyAttndanceBenefitDataFromVB(TransactionContext tc, DateTime attnDate)
{
DataSet oDataset = new DataSet();
try
{
string sBasicsql = SQLParser.MakeSQL(
@"SELECT e.EMPCODE, e.NAME, d.ATTNDATE, d.DSAHOURS, d.TSAHOURS, d.CONVEYANCE, d.ADDITIONALHOURS, d.OTAPPROVED, d.OTREMARKS, d.ORDINARYHOURS, d.PRESENTHOURS,
d.FESTIVAL, d.HARTAL,
d.AttenType FROM DAILYATTN d
INNER JOIN Payrollusernm.EMPBASICINFO e ON e.EMPLOYEEID=d.EMPLOYEEID
WHERE ATTNDATE = %d
ORDER BY e.EMPCODE", attnDate);
oDataset = tc.ExecuteDataSet(sBasicsql);
oDataset.Tables[0].TableName = "DailyAttn";
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return oDataset;
}
internal static DataSet GetMonthlyAttndanceBenefitDataFromVB(TransactionContext tc, int year, int month)
{
DataSet oDataset = new DataSet();
try
{
string sBasicsql = SQLParser.MakeSQL(
@"SELECT e.EMPCODE, e.NAME, a.ORDINARYHOURS, a.ADDITIONALHOURS, a.MEALDAYS, a.TEADAYS, a.DSAHOURS, a.TSAHOURS, a.ATTENDANCEDAY, a.OTHOURS FROM MONTHLYATTN a
INNER JOIN EMPBASICINFO e ON e.EMPLOYEEID=a.EMPLOYEEID
WHERE a.ATTNYEAR=%n AND a.ATTNMONTH=%n
ORDER BY e.EMPCODE", year, month);
oDataset = tc.ExecuteDataSet(sBasicsql);
oDataset.Tables[0].TableName = "MONTHLYATTN";
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return oDataset;
}
internal static bool IsExist(TransactionContext tc, int empID, DateTime attnDate)
{
bool Exist = false;
Object obj = tc.ExecuteScalar("Select * FROM DailyAttnProcess WHERE EmployeeID=%n AND AttnDate=%d", empID,
attnDate);
Exist = Convert.ToInt32(obj) > 0 ? true : false;
return Exist;
}
internal static int GetAttnDataByWFStatusCount(TransactionContext tc, DateTime fromDate, DateTime toDate,
EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select Count(*) from DailyAttnProcess
where ClaimWFStatus=%n and attnDate between %d and %d", (int)status,
fromDate, toDate);
return Convert.ToInt32(tc.ExecuteScalar(sql).ToString());
}
internal static IDataReader GetAttnDataForMobile(TransactionContext tc, int empId, DateTime attnDate)
{
string sql = SQLParser.MakeSQL(@"SELECT dap.*, s.Name ShiftName FROM DailyAttnProcess dap
LEFT JOIN Shift s ON dap.ShiftID = s.ShiftID
WHERE AttnDate=%d and EmployeeID=%n", attnDate, empId);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnDataForMobileWithNoLock(TransactionContext tc, int empId, DateTime attnDate)
{
string sql = SQLParser.MakeSQL(@"SELECT dap.*, s.Name ShiftName FROM DailyAttnProcess dap With(NoLock)
LEFT JOIN Shift s With(NoLock) ON dap.ShiftID = s.ShiftID
WHERE AttnDate=%d and EmployeeID=%n", attnDate, empId);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetRegularizableAttn(TransactionContext tc, int EmpID, DateTime fromDate, DateTime toDate)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID =%n and
(ATTENTYPE =%n OR ATTENTYPE =%n OR isLate =%b OR EarlyHour >0 OR InTime Is Null OR OutTime Is Null)
and AttnDate Between %d and %d and
(wfstatus=%n OR wfstatus=%n) AND WorkDayType =3 order by AttnDate desc",
EmpID, EnumAttendanceType.Late, EnumAttendanceType.Absent,
true, fromDate, toDate, EnumWFAttnStatus.None,
EnumWFAttnStatus.NotApplicable);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnForStatement(TransactionContext tc, int EmpID, DateTime fromDate, DateTime toDate)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID =%n and AttnDate Between %d and %d order by AttnDate DESC",
EmpID, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetAttnForStatementWithNoLock(TransactionContext tc, int EmpID, DateTime fromDate, DateTime toDate)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess With(NoLock)
where EmployeeID =%n and AttnDate Between %d and %d order by AttnDate DESC",
EmpID, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static IDataReader GetByLMID(TransactionContext tc, int LMID, DateTime AttnDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess Where EmployeeID in (SELECT EMPLOYEEID FROM EMPLOYEE WHERE LINEMANAGERID = %n) and AttnDate = %d", LMID, AttnDate);
}
internal static IDataReader GetByLMIDMobileWithNoLock(TransactionContext tc, int LMID, DateTime AttnDate)
{
return tc.ExecuteReader("SELECT * FROM DailyAttnProcess With(NoLock) Where EmployeeID In (SELECT EMPLOYEEID FROM EMPLOYEE With(NoLock) WHERE LINEMANAGERID = %n) and AttnDate = %d", LMID, AttnDate);
}
internal static DataSet GetAttnSubmittedData(TransactionContext tc, string empIDs, DateTime nextPayProcessDate, EnumWFAttnStatus status, bool isCurrentMonth)
{
DataSet presentDays = new DataSet();
try
{
DateTime fromDate = GlobalFunctions.FirstDateOfMonth(nextPayProcessDate);
fromDate = fromDate.AddMonths(-1);
fromDate = new DateTime(fromDate.Year, fromDate.Month, 11);
DateTime toDate = GlobalFunctions.LastDateOfMonth(nextPayProcessDate);
toDate = new DateTime(toDate.Year, toDate.Month, 10);
string sql = string.Empty;
if (!isCurrentMonth)
{
sql = SQLParser.MakeSQL(@"SELECT e.EmployeeID, e.EMPLOYEENO EMPLOYEENO, e.NAME Name, dept.DESCRIPTION Department, desig.NAME Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs);
}
else
{
sql = SQLParser.MakeSQL(@"SELECT e.EmployeeID, e.EMPLOYEENO, e.NAME Name, dept.DESCRIPTION Department, desig.NAME Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
FROM DAILYATTNPROCESS dap
INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
WHERE dap.WFSTATUS=%n and e.EmployeeID in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
order BY e.EMPLOYEENO", status, empIDs, fromDate, toDate);
}
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
//internal static DataSet GetAttnSubmittedData(TransactionContext tc, int linemanagerid)
//{
// DataSet presentDays = new DataSet();
// try
// {
// DateTime fromDate = GlobalFunctions.FirstDateOfMonth(DateTime.Today);
// fromDate = fromDate.AddMonths(-1);
// DateTime toDate = GlobalFunctions.LastDateOfMonth(DateTime.Today);
// toDate = new DateTime(toDate.Year, toDate.Month, 10);
// string sql = string.Empty;
// sql = SQLParser.MakeSQL(@"SELECT e.EmployeeID, e.EMPLOYEENO, e.NAME Name, dept.DESCRIPTION Department, desig.NAME Designation, g.CODE Grade, SUM(dap.APPROVEDOTHOUR) TotalOT
// FROM DAILYATTNPROCESS dap
// INNER JOIN EMPLOYEE e ON e.EMPLOYEEID=dap.EMPLOYEEID
// LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID=e.DEPARTMENTID
// LEFT JOIN DESIGNATION desig ON desig.DESIGNATIONID=e.DESIGNATIONID
// LEFT JOIN GRADES g ON g.GRADEID=e.GRADEID
// WHERE dap.WFSTATUS=%n and e.linemanagerid in (%q) and dap.AttnDate between %d and %d GROUP BY e.EmployeeID, e.EMPLOYEENO, e.NAME, dept.DESCRIPTION, desig.NAME, g.CODE
// order BY e.EMPLOYEENO", status, linemanagerid, fromDate, toDate);
// presentDays = tc.ExecuteDataSet(sql);
// }
// catch (Exception ex)
// {
// throw new Exception(ex.Message);
// }
// return presentDays;
//}
internal static DataSet GetAttnShiftAndWorkDatType(TransactionContext tc, int EmployeeID, DateTime AttnDate)
{
DataSet presentDays = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"SELECT TOP 1 m.ShiftID, m.Type, w.shiftid defaultShiftID,S.InTime, S.FlexibleHour, S.LateCalcualtion FROM WorkPlanGroup w,
EMPLOYEEWORKPLANSETUP ew, MonthlyWorkPlan m, shift S
where w.WorkPlanGroupID = ew.WORKPLANGROUPID AND ew.WORKPLANGROUPID = w.WorkPlanGroupID AND ew.WORKPLANGROUPID = m.WorkPlanGroupID
AND S.ShiftID = m.ShiftID AND ew.EMPLOYEEID = %n AND m.WorkDate =%d", EmployeeID, AttnDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet GetAttnShiftAndWorkDatTypeMobileWithNoLock(TransactionContext tc, int EmployeeID, DateTime AttnDate)
{
DataSet presentDays = new DataSet();
try
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"SELECT TOP 1 m.ShiftID, m.Type, w.shiftid defaultShiftID, S.InTime ShiftInTime, S.OutTime ShiftOutTime, S.FlexibleHour, S.LunchHour LunchHour, S.LateCalcualtion FROM WorkPlanGroup w With(NoLock),
EMPLOYEEWORKPLANSETUP ew With(NoLock), MonthlyWorkPlan m With(NoLock), shift S With(NoLock)
where w.WorkPlanGroupID = ew.WORKPLANGROUPID AND ew.WORKPLANGROUPID = w.WorkPlanGroupID AND ew.WORKPLANGROUPID = m.WorkPlanGroupID
AND S.ShiftID = m.ShiftID AND ew.EMPLOYEEID = %n AND m.WorkDate =%d", EmployeeID, AttnDate);
presentDays = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataSet AttnDaysSummaryForSalaryProcess(TransactionContext tc, DateTime FromDate, DateTime ToDate)
{
StringBuilder presentCase = new StringBuilder();
StringBuilder absentCase = new StringBuilder();
StringBuilder holidayCase = new StringBuilder();
StringBuilder leaveCase = new StringBuilder();
#region Generating Cases
presentCase.Append("Case ");
absentCase.Append("Case ");
holidayCase.Append("Case ");
leaveCase.Append("Case ");
List<EnumAttendanceType> attnTypes = Enum.GetValues(typeof(EnumAttendanceType)).Cast<EnumAttendanceType>().ToList();
foreach (EnumAttendanceType enItem in attnTypes)
{
switch (enItem)
{
case EnumAttendanceType.Absent:
absentCase.AppendFormat(" when AttenType = {0} then 1 ", (int)enItem);
break;
case EnumAttendanceType.Holiday:
case EnumAttendanceType.WeeklyHoliday:
holidayCase.AppendFormat(" when AttenType = {0} then 1 ", (int)enItem);
break;
case EnumAttendanceType.Leave:
leaveCase.AppendFormat(" when AttenType = {0} then 1 ", (int)enItem);
break;
case EnumAttendanceType.Present:
case EnumAttendanceType.Delay:
case EnumAttendanceType.Late:
case EnumAttendanceType.Early:
case EnumAttendanceType.OutSideDuty:
presentCase.AppendFormat(" when AttenType = {0} then 1 ", (int)enItem);
break;
case EnumAttendanceType.HalfDay:
presentCase.AppendFormat(" when AttenType = {0} then 0.5 ", (int)enItem);
absentCase.AppendFormat(" when AttenType = {0} then 0.5 ", (int)enItem);
break;
default:
break;
}
}
presentCase.Append(" else 0 END ");
absentCase.Append(" else 0 END ");
holidayCase.Append(" else 0 END ");
leaveCase.Append(" else 0 END ");
#endregion
string sql = SQLParser.MakeSQL(@"select EmployeeID,
Count(EMPLOYEEID) TotalDays,
Sum(%q) TotalPresent,
Sum(%q) TotalAbsent,
Sum(%q) TotalHoliday,
Sum(%q) TotalLeave
from DailyAttnProcess
where AttnDate between %d and %d
group by EmployeeID", presentCase.ToString(), absentCase.ToString()
, holidayCase.ToString(), leaveCase.ToString(),
FromDate, ToDate);
return tc.ExecuteDataSet(sql);
}
internal static DataTable getMyTeamNotApprovedList(TransactionContext tc, int linemanagerid)
{
DataTable presentDays = new DataTable();
try
{
string sql = string.Empty;
presentDays = tc.ExecuteDataTable(@"SELECT dap.*, e.EmployeeID, EmployeeNo, e.Name, e.categoryID, e.GradeID,
LocationID, d.name as DesignationName, g.DESCRIPTION GradeName, dept.DESCRIPTION DepartmentName,
S.ShiftID, s.ShortName From Employee e
left join designation d on d.DESIGNATIONID = e.DESIGNATIONID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN GRADES g ON g.GRADEID = e.GRADEID
Inner JOIN DAILYATTNPROCESS dap ON dap.EMPLOYEEID = e.EMPLOYEEID
LEFT JOIN Shift s ON s.ShiftID = dap.ShiftID
WHERE dap.WFStatus = 1 AND e.linemanagerid =%n and e.status =1 ", linemanagerid);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static DataTable getMyTeamNotApprovedListMobile(TransactionContext tc, int linemanagerid)
{
DataTable presentDays = new DataTable();
string sql = string.Empty;
presentDays = tc.ExecuteDataTable(@"SELECT dap.DailyAttnProcessID, dap.attnDate , dap.AttenType, dap.InTime, dap.OutTime,
dap.ActualInTime, dap.ActualOutTime, dap.WFStatus, dap.Comments, dap.ShiftID, dap.EmpRemarks,s.ShortName, e.EmployeeID, EmployeeNo, e.Name
From Employee e
Inner JOIN DAILYATTNPROCESS dap ON dap.EMPLOYEEID = e.EMPLOYEEID
LEFT JOIN Shift s ON s.ShiftID = dap.ShiftID
WHERE dap.WFStatus = 1 AND e.linemanagerid =%n and e.status =1 and dap.AttnDate >%d", linemanagerid, DateTime.Today.AddMonths(-3));
return presentDays;
}
internal static DataTable getMyTeamNotApprovedListMobileWithNoLock(TransactionContext tc, int linemanagerid)
{
DataTable presentDays = new DataTable();
string sql = string.Empty;
presentDays = tc.ExecuteDataTable(@"SELECT dap.DailyAttnProcessID, dap.attnDate , dap.AttenType, dap.InTime, dap.OutTime,
dap.ActualInTime, dap.ActualOutTime, dap.WFStatus, dap.Comments, dap.ShiftID, dap.EmpRemarks,s.ShortName, e.EmployeeID, EmployeeNo, e.Name
From Employee e With(NoLock)
Inner JOIN DAILYATTNPROCESS dap With(NoLock) ON dap.EMPLOYEEID = e.EMPLOYEEID
LEFT JOIN Shift s With(NoLock) ON s.ShiftID = dap.ShiftID
WHERE dap.WFStatus = 1 AND e.linemanagerid =%n and e.status =1 and dap.AttnDate >%d", linemanagerid, DateTime.Today.AddMonths(-3));
return presentDays;
}
internal static DataTable getMyTeamAbsentAndLeave(TransactionContext tc, int linemanagerid, DateTime fromdate, DateTime todate)
{
DataTable presentDays = new DataTable();
try
{
string sql = string.Empty;
presentDays = tc.ExecuteDataTable(@"SELECT distinct dap.*, e.EmployeeID, EmployeeNo, e.Name, e.categoryID, e.GradeID, l.Description leaveName,
LocationID, d.name as DesignationName, g.DESCRIPTION GradeName, dept.DESCRIPTION DepartmentName From Employee e
left join designation d on d.DESIGNATIONID = e.DESIGNATIONID
LEFT JOIN DEPARTMENT dept ON dept.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN GRADES g ON g.GRADEID = e.GRADEID
LEFT JOIN DAILYATTNPROCESS dap ON dap.EMPLOYEEID = e.EMPLOYEEID
LEFT JOIN leave l ON dap.referenceid = l.leaveid
WHERE dap.AttenType IN ( %n, %n) AND e.linemanagerid =%n and e.status =1
and dap.attndate between %d and %d ", EnumAttendanceType.Absent,
EnumAttendanceType.Leave, linemanagerid, fromdate, todate);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return presentDays;
}
internal static IDataReader GetAttnDataByWFStatusForLM(TransactionContext tc, DateTime fromDate, DateTime toDate, string empIDs, EnumWFAttnStatus status)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL(@"Select * from DailyAttnProcess
where EmployeeID in (%q) and WFStatus=%n Order By AttnDate desc", empIDs, (int)status, fromDate, toDate);
return tc.ExecuteReader(sql);
}
internal static DataSet GetZandDocLeave(TransactionContext tc, DateTime fromdate, DateTime todate, EnumAttendanceType attnType, int payrollTypeId, int? refID)
{
DataSet dailyInOutAndAbsent = new DataSet();
try
{
//4, 'DL', 'Doctors Leave'
//21, 'ZL', 'Z Leave'
string sql = "";
if (refID == null)
{
sql = SQLParser.MakeSQL("select dap.Employeeid, Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " "
+ " "
+ " dap.AttenType = %n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n Group by dap.Employeeid", attnType, fromdate, todate, payrollTypeId);
//sql = string.Format(@"select EmployeeID,
// SUM(Case
// When AttnType = {0} Then 1
// When AttnType = {1} Then 0.5
// End) as TotalAbsent from DailyAttnProcess
// where AttnDate between '{2}' AND '{3}'
// AND AttnType in ({0},{1})
// group by EmployeeID order by EmployeeID",
// (int)EnumAttendanceType.Absent, (int)EnumAttendanceType.HalfDay,
// fromdate,
// todate);
}
else
{
sql = SQLParser.MakeSQL("select dap.Employeeid, Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " "
+ " "
+ " dap.AttenType = %n and dap.ReferenceID=%n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n Group by dap.Employeeid", attnType, refID, fromdate, todate, payrollTypeId);
}
dailyInOutAndAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOutAndAbsent;
}
internal static DataSet GetUnauthorizeCount(TransactionContext tc, DateTime fromdate, DateTime todate, int payrollTypeId)
{
DataSet dailyInOutAndAbsent = new DataSet();
try
{
//4, 'DL', 'Doctors Leave'
//21, 'ZL', 'Z Leave'
string sql = "";
sql = string.Format(@"select EMPLOYEEID,
SUM(Case
When AttenType = {0} Then 1
When AttenType = {1} Then 0.5
End) as TOTAL from DailyAttnProcess
where AttnDate between '{2}' AND '{3}'
AND AttenType in ({0},{1})
group by EmployeeID order by EmployeeID",
(int)EnumAttendanceType.Absent, (int)EnumAttendanceType.HalfDay,
fromdate,
todate);
dailyInOutAndAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOutAndAbsent;
}
internal static double GetStatusCount(TransactionContext tc, DateTime fromdate, DateTime todate, EnumAttendanceType attnType, int payrollTypeId,
int empid, int? refID)
{
double attncount = 0;
try
{
string empsql = "";
empsql = empsql + " and dap.EmployeeID =" + empid + " ";
string sql = "";
if (refID == null)
{
sql = SQLParser.MakeSQL("select Count(*) Total"
+ " from DailyAttnProcess dap where "
+ " "
+ " "
+ " dap.AttenType = %n "
+ " AND dap.AttnDate BETWEEN %d AND %d %q Group by dap.Employeeid",
attnType, fromdate, todate, empsql);
}
else
{
sql = SQLParser.MakeSQL("select dap.Employeeid, Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " "
+ " "
+ " dap.AttenType = %n and dap.ReferenceID=%n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n " +
" %q Group by dap.Employeeid", attnType, refID, fromdate, todate, payrollTypeId, empsql);
}
var dvalue = tc.ExecuteScalar(sql);
if (dvalue != DBNull.Value)
{
return Convert.ToDouble(dvalue);
}
else return Convert.ToDouble(0);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return attncount;
}
internal static DataSet GetWorkingDayLateCount(TransactionContext tc, DateTime fromdate, DateTime todate, int payrollTypeId)
{
DataSet dailyInOutAndAbsent = new DataSet();
try
{
//4, 'DL', 'Doctors Leave'
//21, 'ZL', 'Z Leave'
string sql = SQLParser.MakeSQL("select dap.Employeeid, Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " dap.IsLate = %b AND WorkDayType=%n"
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n Group by dap.Employeeid ",
true, EnumWorkPlanDayType.WorkingDay, fromdate, todate, payrollTypeId);
dailyInOutAndAbsent = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return dailyInOutAndAbsent;
}
internal static DataSet GetMonthlyAttendanceData(TransactionContext tc, DateTime dFromDate, DateTime dToDate, string sEmpID)
{
string sql = SQLParser.MakeSQL(@"
SELECT dep.DESCRIPTION AS DEPNAME, e.EMPLOYEENO, e.NAME, des.NAME AS DESNAME,
loc.DESCRIPTION AS LOC, dap.AttnDate, dap.InTime, dap.OutTime, dap.WorkHour,
dap.LateHour, dap.AttenType, iif(dap.AttenType != 5, l.DESCRIPTION, nh.DESCRIPTION) AS WorkDayName
FROM DAILYATTNPROCESS dap
JOIN EMPLOYEE e ON dap.EMPLOYEEID = e.EMPLOYEEID
LEFT JOIN DEPARTMENT dep ON dep.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DESIGNATION des ON des.DESIGNATIONID = e.DESIGNATIONID
LEFT JOIN LOCATION loc ON loc.LOCATIONID = e.LOCATIONID
LEFT JOIN LEAVE l ON l.LEAVEID = dap.ReferenceID
LEFT JOIN ATTNNATIONALHOLIDAY nh ON nh.ATTNNATIONALHOLIDAYID = dap.ReferenceID
WHERE e.EMPLOYEEID IN (%q) AND dap.AttnDate BETWEEN %d AND %d
ORDER BY dep.DESCRIPTION",
sEmpID, dFromDate, dToDate);
return tc.ExecuteDataSet(sql);
}
internal static int GetAbsentCount(TransactionContext tc, DateTime fromDate, DateTime toDate, int empid, int payrollTypeId)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL("select Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " dap.AttnType = %n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n and dap.Employeeid=%n",
EnumAttendanceType.Absent, fromDate, toDate, payrollTypeId, empid);
var dvalue = tc.ExecuteScalar(sql);
if (dvalue != DBNull.Value)
{
return Convert.ToInt32(dvalue);
}
else return 0;
}
internal static int GetLateCount(TransactionContext tc, DateTime fromDate, DateTime toDate, int empid, int payrollTypeId)
{
string sql = string.Empty;
sql = SQLParser.MakeSQL("select Count(*) Total"
+ " from DailyAttnProcess dap Inner join Employee e on e.employeeID=dap.employeeID where "
+ " "
+ " "
+ " dap.islate = %n "
+ "AND dap.AttnDate BETWEEN %d AND %d and e.PayrollTypeID=%n and dap.Employeeid=%n",
true, fromDate, toDate, payrollTypeId
, empid);
var dvalue = tc.ExecuteScalar(sql);
if (dvalue != DBNull.Value)
{
return Convert.ToInt32(dvalue);
}
else return Convert.ToInt32(0);
}
internal static DataTable GetAttendanceDashboard(TransactionContext tc, Employee oEmp)
{
string subSQL = SQLParser.MakeSQL(@"EMPLOYEEID IN(SELECT EMPLOYEEID as EmployeeID FROM EMPLOYEE
Where LINEMANAGERID = %n and status = %n )", oEmp.ID, EnumEmpStatus.Live);
string sSQL = SQLParser.MakeSQL(@"
select (select count (*) FROM EMPLOYEE where %q) AS Total,
(select count (*) FROM DAILYATTNPROCESS where ATTENTYPE = 1 AND ATTNDATE = getdate() AND %q ) AS Present,
(select count (*) FROM DAILYATTNPROCESS where ATTENTYPE = 2 AND ATTNDATE = getdate() AND %q ) AS Absent,
(select count (*) FROM DAILYATTNPROCESS where ATTENTYPE = 4 AND ATTNDATE = getdate() AND %q ) AS Leave,
(select count (*) FROM DAILYATTNPROCESS where ATTENTYPE = 8 AND ATTNDATE = getdate() AND %q ) AS WeeklyHoliday,
(select count (*) FROM DAILYATTNPROCESS where ISLATE = 1 AND ATTNDATE = getdate() AND %q ) AS Late,
(select ATTNDATE FROM DAILYATTNPROCESS where ATTNDATE = getdate()) as AttnDate",
subSQL, subSQL, subSQL, subSQL, subSQL, subSQL);
return tc.ExecuteDataTable(sSQL);
}
internal static DataTable getTopEmpAbsentData(TransactionContext tc, Employee oEmp, EnumAttendanceType type)
{
string sSQL = SQLParser.MakeSQL(@"
SELECT E.name as empName, count(*) as AbsentCount,
E.EmployeeId as EmpId, DAP.attentype
FROM DAILYATTNPROCESS DAP
JOIN EMPLOYEE E ON DAP.EMPLOYEEID = E.EMPLOYEEID
WHERE DAP.ATTENTYPE = %n
AND DAP.attndate<= DATEADD(DAY, -1, DATEADD(YEAR, DATEDIFF(YEAR, 0, GETDATE()) + 1, 0)) AND DAP.attndate>= DATEADD(YEAR, DATEDIFF(YEAR, 0, GETDATE()), 0)
AND E.LINEMANAGERID = %n AND E.status = %n
GROUP BY E.EMPLOYEEID, DAP.ATTENTYPE, E.NAME ORDER BY AbsentCount DESC", type, oEmp.ID, EnumEmpStatus.Live);
return tc.ExecuteDataTable(sSQL);
}
internal static DataTable getcorehrAbsentData(TransactionContext tc, Employee oEmp, EnumAttendanceType type)
{
string subSQL = "";
if (oEmp != null && oEmp.LineManagerID != null)
{
subSQL = SQLParser.MakeSQL(@"AND E.DEPARTMENTID = %n ", oEmp.DepartmentID);
}
string sSQL = SQLParser.MakeSQL(@"SELECT E.name as empName, count(*) as AbsentCount,
E.EmployeeId as EmpId, DAP.attentype
FROM DAILYATTNPROCESS DAP
JOIN EMPLOYEE E ON DAP.EMPLOYEEID = E.EMPLOYEEID
WHERE DAP.ATTENTYPE = %n
AND DAP.attndate<= DATEADD(DAY, -1, DATEADD(YEAR, DATEDIFF(YEAR, 0, GETDATE()) + 1, 0)) AND DAP.attndate>= DATEADD(YEAR, DATEDIFF(YEAR, 0, GETDATE()), 0)
AND E.status = %n %q
GROUP BY E.EMPLOYEEID, DAP.ATTENTYPE, E.NAME ORDER BY AbsentCount DESC", type, EnumEmpStatus.Live, subSQL);
return tc.ExecuteDataTable(sSQL);
}
//internal static DataSet AttnDaysSummaryForSalaryProcess(TransactionContext tc, DateTime FromDate, DateTime ToDate)
//{
// StringBuilder presentCase = new StringBuilder();
// StringBuilder absentCase = new StringBuilder();
// StringBuilder holidayCase = new StringBuilder();
// StringBuilder leaveCase = new StringBuilder();
// #region Generating Cases
// presentCase.Append("Case ");
// absentCase.Append("Case ");
// holidayCase.Append("Case ");
// leaveCase.Append("Case ");
// List<EnumAttendanceType> attnTypes = Enum.GetValues(typeof(EnumAttendanceType)).Cast<EnumAttendanceType>().ToList();
// foreach (EnumAttendanceType enItem in attnTypes)
// {
// switch (enItem)
// {
// case EnumAttendanceType.Absent:
// absentCase.AppendFormat(" when AttnType = {0} then 1 ", (int)enItem);
// break;
// case EnumAttendanceType.Holiday:
// case EnumAttendanceType.WeeklyHoliday:
// holidayCase.AppendFormat(" when AttnType = {0} then 1 ", (int)enItem);
// break;
// case EnumAttendanceType.Leave:
// leaveCase.AppendFormat(" when AttnType = {0} then 1 ", (int)enItem);
// break;
// case EnumAttendanceType.Present:
// case EnumAttendanceType.Delay:
// case EnumAttendanceType.Late:
// case EnumAttendanceType.Early:
// case EnumAttendanceType.OutSideDuty:
// presentCase.AppendFormat(" when AttnType = {0} then 1 ", (int)enItem);
// break;
// case EnumAttendanceType.HalfDay:
// presentCase.AppendFormat(" when AttnType = {0} then 0.5 ", (int)enItem);
// absentCase.AppendFormat(" when AttnType = {0} then 0.5 ", (int)enItem);
// break;
// default:
// break;
// }
// }
// presentCase.Append(" else 0 END ");
// absentCase.Append(" else 0 END ");
// holidayCase.Append(" else 0 END ");
// leaveCase.Append(" else 0 END ");
// #endregion
// string sql = SQLParser.MakeSQL(@"select EmployeeID,
// Count(EMPLOYEEID) TotalDays,
// Sum(%q) TotalPresent,
// Sum(%q) TotalAbsent,
// Sum(%q) TotalHoliday,
// Sum(%q) TotalLeave
// from DailyAttnProcess
// where AttnDate between %d and %d
// group by EmployeeID", presentCase.ToString(), absentCase.ToString()
// , holidayCase.ToString(), leaveCase.ToString(),
// FromDate, ToDate);
// return tc.ExecuteDataSet(sql);
//}
internal static DataSet GetEmpCardInfoPerPage(TransactionContext tc, string sEmpID)
{
DataSet empAttenInfo = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT e.EMPLOYEENO AS IDNo,
e.NAME,e.JOININGDATE AS DOJ,
IsNULL(e.[PhotoPath],'') AS EmpPhoto,
ISNULL(e.EMPSIGNATURE,'') AS EmpSign,
IsNULL(des.NAME,'') AS Desig,
IsNULL(gd.DESCRIPTION,'') AS Grade,
IsNULL(gd.COLORCODE,'White') AS GradeColor,
IsNULL(acrd.CardNumber,'') AS CardNo,
'Dept' = case when dept5.tire = 5 then dept2.[DESCRIPTION]
when dept5.tire = 4 then dept3.[DESCRIPTION]
when dept5.tire = 3 then dept4.[DESCRIPTION]
when dept5.tire = 2 then dept5.[DESCRIPTION]
END,
'Floor' = case when dept5.tire = 5 then dept3.[DESCRIPTION]
when dept5.tire = 4 then dept4.[DESCRIPTION]
when dept5.tire = 3 then dept5.[DESCRIPTION]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[DESCRIPTION]
when dept5.tire = 4 then dept5.[DESCRIPTION]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[DESCRIPTION]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
CASE
WHEN rl.Name = 'Hindu' Then 'Red'
WHEN rl.name IS NULL Then 'White'
ELSE 'White' END NameColor,
CASE
WHEN e.BLOODGROUP =1 THEN 'NONE'
WHEN e.BLOODGROUP =2 THEN 'A+'
WHEN e.BLOODGROUP =3 THEN 'A-'
WHEN e.BLOODGROUP =4 THEN 'B+'
WHEN e.BLOODGROUP =5 THEN 'B-'
WHEN e.BLOODGROUP =6 THEN 'O+'
WHEN e.BLOODGROUP =7 THEN 'O-'
WHEN e.BLOODGROUP =8 THEN 'AB+'
WHEN e.BLOODGROUP =9 THEN 'AB-'
WHEN e.BLOODGROUP =10 THEN 'NA'
ELSE ''
END BG,
IsNULL(CardOpp.AssignDate,'') AS IssueDate,
ISNULL(e.NationalID,'') AS NationalID,
IsNULL(cts.ADDVill,'') ADDVill,
IsNULL(cts.ADDDist,'') ADDDist,
IsNULL(cts.ADDPO,'') ADDPO,
IsNULL(cts.ADDPS,'') ADDPS,
IsNULL(cts.ADDPhone,'') ADDPhone
FROM
(SELECT * FROM EMPLOYEE WHERE EMPLOYEEID IN (%q)) e
LEFT JOIN DESIGNATION des
ON e.DESIGNATIONID = des.DESIGNATIONID
LEFT JOIN GRADES gd
ON e.GRADEID = gd.GRADEID
LEFT JOIN GRADESEGMENT gds
ON gd.GRADESEGMENTID = gds.GRADESEGMENTID
Left JOIN DEPARTMENT dept5 ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4 ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3 ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2 ON dept2.DEPARTMENTID = dept3.PARENTID
LEFT JOIN AccessCard acrd
ON e.CardID = acrd.AccessCardID
LEFT JOIN RELIGION rl
ON e.religionid = rl.religionid
LEFT JOIN
(SELECT EmployeeID,CardID,MAX(AssignDate) AS AssignDate
FROM CardOperation
GROUP BY EmployeeID,CARDID) CardOpp
ON CardOpp.EmployeeID = e.EmployeeID
AND CardOpp.CardID = e.CardID
LEFT JOIN
(SELECT EmployeeID,ParmanentAddress AS ADDVill,
ISNULL(dis.NAME,'') ADDDist,
PermanentPO AS ADDPO,
ISNULL(thn.NAME,'') ADDPS,
ParmanentMobile AS ADDPhone
FROM EMPCONTACT ec
LEFT JOIN
District dis
ON ec.PARMANENTDISTRICTID = dis.DISTRICTID
LEFT JOIN
THANA thn
ON ec.PARMANENTTHANAID = thn.THANAID) cts
ON e.EmployeeID = cts.EmployeeID", sEmpID);
empAttenInfo = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return empAttenInfo;
}
internal static DataSet GetEmpCardInfoPerPageBangla(TransactionContext tc, string sEmpID)
{
DataSet empAttenInfo = new DataSet();
try
{
string sql = SQLParser.MakeSQL(@"SELECT e.EMPLOYEENO AS IDNo,
e.BANGLANAME NAME,e.JOININGDATE AS DOJ,
IsNULL(e.[PhotoPath],'') AS EmpPhoto,
ISNULL(e.EMPSIGNATURE,'') AS EmpSign,
IsNULL(des.BANGLANAME,'') AS Desig,
IsNULL(des.WorkType,'') AS WorkType,
IsNULL(gd.BanglaName,'') AS Grade,
IsNULL(gd.COLORCODE,'White') AS GradeColor,
IsNULL(acrd.CardNumber,'') AS CardNo,
'Dept' = case when dept5.tire = 5 then dept2.[BANGLADescription]
when dept5.tire = 4 then dept3.[BANGLADescription]
when dept5.tire = 3 then dept4.[BANGLADescription]
when dept5.tire = 2 then dept5.[BANGLADescription]
END,
'Floor' = case when dept5.tire = 5 then dept3.[BANGLADescription]
when dept5.tire = 4 then dept4.[BANGLADescription]
when dept5.tire = 3 then dept5.[BANGLADescription]
when dept5.tire = 2 then ''
END,
'Section' = case when dept5.tire = 5 then dept4.[BANGLADescription]
when dept5.tire = 4 then dept5.[BANGLADescription]
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
'Line' = case when dept5.tire = 5 then dept5.[BANGLADescription]
when dept5.tire = 4 then ''
when dept5.tire = 3 then ''
when dept5.tire = 2 then ''
END,
CASE
WHEN rl.Name = 'Hindu' Then 'Red'
WHEN rl.name IS NULL Then 'White'
ELSE 'White' END NameColor,
CASE
WHEN e.BLOODGROUP =1 THEN 'NONE'
WHEN e.BLOODGROUP =2 THEN 'G+'
WHEN e.BLOODGROUP =3 THEN 'G-'
WHEN e.BLOODGROUP =4 THEN 'we+'
WHEN e.BLOODGROUP =5 THEN 'we-'
WHEN e.BLOODGROUP =6 THEN 'I+'
WHEN e.BLOODGROUP =7 THEN 'I-'
WHEN e.BLOODGROUP =8 THEN 'Gwe+'
WHEN e.BLOODGROUP =9 THEN 'Gwe-'
WHEN e.BLOODGROUP =10 THEN 'NA'
ELSE ''
END BG,
IsNULL(CardOpp.AssignDate,'') AS IssueDate,
IsNULL(CardOpp.ExpireDate,'') AS ExpireDate,
ISNULL(e.NationalID,'') AS NationalID,
IsNULL(cts.ADDVill,'') ADDVill,
IsNULL(cts.ADDDist,'') ADDDist,
IsNULL(cts.ADDPO,'') ADDPO,
IsNULL(cts.ADDPS,'') ADDPS,
IsNULL(e.mobileno,'') ADDPhone,
IsNULL(EMPN.EmergencyMobile,'') NomineeMobile
FROM
(SELECT * FROM EMPLOYEE WHERE EMPLOYEEID IN (%q)) e
LEFT JOIN DESIGNATION des
ON e.DESIGNATIONID = des.DESIGNATIONID
LEFT JOIN GRADES gd
ON e.GRADEID = gd.GRADEID
LEFT JOIN GRADESEGMENT gds
ON gd.GRADESEGMENTID = gds.GRADESEGMENTID
Left JOIN DEPARTMENT dept5 ON dept5.DEPARTMENTID = e.DEPARTMENTID
LEFT JOIN DEPARTMENT dept4 ON dept4.DEPARTMENTID = dept5.PARENTID
LEFT JOIN DEPARTMENT dept3 ON dept3.DEPARTMENTID = dept4.PARENTID
LEFT JOIN DEPARTMENT dept2 ON dept2.DEPARTMENTID = dept3.PARENTID
LEFT JOIN AccessCard acrd
ON e.CardID = acrd.AccessCardID
LEFT JOIN RELIGION rl
ON e.religionid = rl.religionid
LEFT JOIN
(SELECT EmployeeID,CardID,MAX(AssignDate) AS AssignDate, Max(ExpireDate) AS ExpireDate
FROM CardOperation
GROUP BY EmployeeID,CARDID) CardOpp
ON CardOpp.EmployeeID = e.EmployeeID
AND CardOpp.CardID = e.CardID
LEFT JOIN
(SELECT EmployeeID,PERMANENTADDRESSINBANGLA AS ADDVill,
ISNULL(dis.BANGLANAME,'') ADDDist,
ParmanentPOInBangla AS ADDPO,
ISNULL(thn.BANGLANAME,'') ADDPS,
ParmanentMobile AS ADDPhone
FROM EMPCONTACT ec
LEFT JOIN
District dis
ON ec.PARMANENTDISTRICTID = dis.DISTRICTID
LEFT JOIN
THANA thn
ON ec.PARMANENTTHANAID = thn.THANAID) cts
ON e.EmployeeID = cts.EmployeeID
LEFT JOIN EMPCONTACT EMPN ON EMPN.EMPLOYEEID = e.EMPLOYEEID", sEmpID);
empAttenInfo = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return empAttenInfo;
}
internal static DataTable GetAttandanceDashboardData(TransactionContext tc, DateTime fromDate, DateTime toDate, int shiftId, string departmentIds, string employeeIds, bool appliedForRegularize,
int status, string otHourType, int otHour, int CurrentUserId, bool isCalledFromEss, string lineManager, string statusText, int payrollTypeId)
{
DataSet ds = new DataSet();
string orderby;
string whereClause = string.Empty;
string sql;
string sql1;
if (fromDate != null && toDate != null)
{
whereClause = SQLParser.MakeSQL("WHERE D.ATTNDATE BETWEEN %d AND %d", fromDate, toDate);
}
if (payrollTypeId != 0)
{
whereClause += SQLParser.MakeSQL(" AND E.PAYROLLTYPEID = %n", payrollTypeId);
}
if (shiftId != 0)
{
whereClause += SQLParser.MakeSQL(" AND S.ShiftID = %n", shiftId);
}
if (isCalledFromEss)
{
if (CurrentUserId != 0 && employeeIds == string.Empty)
{
whereClause += SQLParser.MakeSQL(" AND E.EMPLOYEEID IN ( SELECT Employeeid from EmployeeCordinator WHERE CordinatorID = %q)", CurrentUserId);
}
else if (employeeIds != string.Empty)
{
whereClause += SQLParser.MakeSQL(" AND E.EMPLOYEEID IN (%q)", employeeIds);
}
}
else
{
if (employeeIds != string.Empty)
{
whereClause += SQLParser.MakeSQL(" AND E.EMPLOYEEID IN (%q)", employeeIds);
}
}
if (lineManager != string.Empty)
{
whereClause += SQLParser.MakeSQL(" AND E.EMPLOYEEID IN ( SELECT EMPLOYEEID FROM EMPLOYEE WHERE LINEMANAGERID = %q)", lineManager);
}
if (departmentIds != string.Empty)
{
whereClause += SQLParser.MakeSQL(" AND E.DEPARTMENTID IN (%q)", departmentIds);
}
if (status == 11)
{
whereClause += SQLParser.MakeSQL(" AND D.islate = %n", 1);
}
if (status > 0 && status < 9)
{
if ((EnumAttendanceType)status == EnumAttendanceType.Holiday)
whereClause += SQLParser.MakeSQL(" AND (D.ATTENTYPE = %n OR D.WorkDayType=%n)", status, EnumWorkPlanDayType.NationalHoliday);
else if ((EnumAttendanceType)status == EnumAttendanceType.WeeklyHoliday)
whereClause += SQLParser.MakeSQL(" AND (D.ATTENTYPE = %n OR D.WorkDayType=%n)", status, EnumWorkPlanDayType.WeeklyHoliday);
else whereClause += SQLParser.MakeSQL(" AND D.ATTENTYPE = %n", status);
}
else if (status > 20)
{
whereClause += SQLParser.MakeSQL(" AND (D.EmpRemarks = %s or D.Reason = %s)", statusText, statusText);
}
if (appliedForRegularize)
{
whereClause += SQLParser.MakeSQL(" AND D.WFSTATUS = %n", 1);
}
if (otHourType != string.Empty && otHour > 0)
{
whereClause += SQLParser.MakeSQL(" AND D.OTHOUR %q %n", otHourType, otHour);
}
if (status == 9)
{
orderby = "ORDER BY t.ATTNDATE DESC, t.EMPLOYEENO, t.EMPLOYEENAME";
}
else
{
orderby = "ORDER BY D.ATTNDATE DESC, E.EMPLOYEENO, E.Name";
}
try
{
sql1 = SQLParser.MakeSQL(
@"SELECT
D.ATTNDATE,
D.OTHOUR,
E.EMPLOYEEID,
E.EMPLOYEENO,
E.NAME AS EMPLOYEENAME,
S.Name AS SHIFT, S.ShiftID,
D.EmpRemarks,
D.Reason,
D.ActualInTime,
D.ActualOutTime,
D.Wfstatus wfstatus,
D.LMREMARKS,
DATEDIFF(MINUTE, D.InTime, D.OutTime) / 60 As hourDifference,
CASE
WHEN D.WFSTATUS = 0 THEN 'No'
WHEN D.WFSTATUS = 1 THEN 'Yes'
ELSE 'Unknown'
END AS WFSTATUSBool,
CASE
WHEN D.ATTENTYPE = 0 THEN 'None'
WHEN D.ATTENTYPE = 1 THEN 'Present'
WHEN D.ATTENTYPE = 2 THEN 'Absent'
WHEN D.ATTENTYPE = 3 THEN 'Delay'
WHEN D.ATTENTYPE = 4 THEN 'Leave'
WHEN D.ATTENTYPE = 5 THEN 'Holiday'
WHEN D.ATTENTYPE = 6 THEN 'Weekly Off'
WHEN D.ATTENTYPE = 7 THEN 'Out Side Duty'
WHEN D.ATTENTYPE = 8 THEN 'WeeklyHoliday'
WHEN D.ATTENTYPE = 9 THEN 'Compensation'
WHEN D.ATTENTYPE = 10 THEN 'Manual Entry'
WHEN D.ATTENTYPE = 11 THEN 'Late'
WHEN D.ATTENTYPE = 12 THEN 'Early'
WHEN D.ATTENTYPE = 18 THEN 'Half Day'
WHEN D.ATTENTYPE = 22 THEN 'LOA'
ELSE 'Unknown'
END AS ATTENTYPESTRING,
D.ATTENTYPE AS ATTENTYPE,
D.InTime,
D.OutTime,
D.WORKHOUR,
D.WORKDAYTYPE,
D.LATEHOUR,
L.CODE As LeaveType,
D.COMMENTS,
CASE
WHEN D.ISFROMMOBILE = 1 THEN 'Yes'
WHEN D.ISFROMMOBILE = 0 THEN 'No'
ELSE 'Unknown'
END AS ISFROMMOBILE
FROM
DAILYATTNPROCESS D
INNER JOIN
EMPLOYEE E ON D.EMPLOYEEID = E.EMPLOYEEID
LEFT JOIN
Shift S ON D.SHIFTID = S.ShiftID
LEFT JOIN
LEAVE L ON D.REFERENCEID = L.LEAVEID %q", whereClause);
if (status == 9)
{
// for irregular work hour main query inserted as sub query
sql = SQLParser.MakeSQL("SELECT * From (%q) t Where t.hourDifference < 8 %q", sql1, orderby);
}
else
{
sql = SQLParser.MakeSQL("%q %q", sql1, orderby);
}
ds = tc.ExecuteDataSet(sql);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return ds.Tables[0];
}
}
#endregion
}