EchoTex_Payroll/HRM.DA/DA/Basic/GradeDA.cs
2025-01-23 16:34:05 +06:00

218 lines
11 KiB
C#

using HRM.BO;
using Ease.Core.DataAccess;
using System.Data;
using System;
namespace HRM.DA
{
internal class GradeDA
{
#region Constructor
private GradeDA()
{
}
#endregion
#region Insert function
internal static void Insert(TransactionContext tc, Grade item)
{
tc.ExecuteNonQuery(
"INSERT INTO GRADES(GradeID, code, description,colorcode, maxbasic, minbasic, isfreetransport, hasGrossConcept, basicPercentofGross, hasPayscale, confirmMonthDuration, gradeSegmentID, CreatedBy, CreationDate, SequenceNo, Status,PAYROLLTYPEID,RequiredDays, IncrementAmount, MarketAnchor, InsuranceCoverage, IsOTApplicable, descriptioninbangla)" +
" VALUES(%n, %s, %s,%s, %n, %n, %b, %b, %n, %b, %n, %n, %n, %d, %n, %n,%n,%n, %n, %n, %n, %n, %u)", item.ID,
item.Code, item.Name, item.ColorCode, item.MaxBasic, item.MinBasic, item.IsTransport,
item.HasGrossConcept, item.BasicPercentOfGross, item.HasPayscale, item.ConfirmMonthDuration,
item.GradeSegmentID, item.CreatedBy, item.CreatedDate, item.Sequence, item.Status, item.PayrollTypeID,
item.RequiredDays, item.Increment, item.MarketAnchor, item.InsuranceCoverage, item.IsOTApplicable, item.NameInBangla);
}
#endregion
#region Update function
internal static void Update(TransactionContext tc, Grade item)
{
tc.ExecuteNonQuery(
"UPDATE GRADES SET code=%s, description=%s,colorcode=%s, maxbasic=%n, minbasic=%n, isfreetransport=%b, hasGrossConcept=%b, basicPercentofGross=%n, hasPayscale=%b, confirmMonthDuration=%n, gradeSegmentID=%n, ModifiedBy=%n, ModifiedDate=%d, SequenceNo=%n, Status=%n,RequiredDays=%n, IncrementAmount=%n, MarketAnchor=%n, InsuranceCoverage=%n, IsOTApplicable=%n, descriptioninbangla=%u" +
" WHERE GradeID=%n", item.Code, item.Name, item.ColorCode, item.MaxBasic, item.MinBasic,
item.IsTransport, item.HasGrossConcept, item.BasicPercentOfGross, item.HasPayscale,
item.ConfirmMonthDuration, item.GradeSegmentID, item.ModifiedBy, item.ModifiedDate, item.Sequence,
item.Status, item.RequiredDays, item.Increment, item.MarketAnchor, item.InsuranceCoverage,
item.IsOTApplicable, item.NameInBangla, item.ID);
//tc.ExecuteNonQuery("UPDATE IncomeTaxYearly SET ItemCode=-222,Itemid=-222 WHERE Description='L.T.A. / Medical Allowance'"); Neeed to Discuss With Boss
}
#endregion
#region Get Function
internal static IDataReader GetAllGrade(TransactionContext tc, int payrollTypeID, EnumStatus status,
string code, string name)
{
string sqlClause = string.Empty;
sqlClause = SQLParser.TagSQL(sqlClause) + SQLParser.MakeSQL("PayrollTypeID = %n", payrollTypeID);
if (EnumStatus.Active == status || EnumStatus.Inactive == status)
{
sqlClause = SQLParser.TagSQL(sqlClause) + SQLParser.MakeSQL("status = %n", status);
// return tc.ExecuteReader("SELECT * FROM AllowanceDeduction Where Status=%n AND ALLOWDEDUCTID>0 order by code", status);
}
if (!string.IsNullOrWhiteSpace(code))
{
sqlClause = SQLParser.TagSQL(sqlClause) + SQLParser.MakeSQL("Code = %s", code);
}
if (!string.IsNullOrWhiteSpace(name))
{
sqlClause = SQLParser.TagSQL(sqlClause) + SQLParser.MakeSQL("Name LIKE %s", ("%" + name + "%"));
}
return tc.ExecuteReader("SELECT * FROM GRADES %q order by description", sqlClause);
}
internal static IDataReader Get(TransactionContext tc, EnumStatus status, int payrollTypeID)
{
if (EnumStatus.Active == status || EnumStatus.Inactive == status)
return tc.ExecuteReader(
"SELECT * FROM GRADES where Status=%n AND PayrollTypeID=%n order by code", status,
payrollTypeID);
else
return tc.ExecuteReader("SELECT * FROM GRADES WHERE PayrollTypeID=%n order by code",
payrollTypeID);
}
internal static IDataReader Get(TransactionContext tc, EnumStatus status)
{
if(status == EnumStatus.Regardless)
return tc.ExecuteReader("SELECT * FROM GRADES order by code");
else
return tc.ExecuteReader("SELECT * FROM GRADES where Status=%n order by code", status);
}
internal static IDataReader Get(TransactionContext tc, EnumStatus status, string sIDs,
string sTargetPropertyName, int payrolltypeid)
{
string sCondition = "";
sCondition = sTargetPropertyName + " IN(" + sIDs + ")";
if (EnumStatus.Active == status || EnumStatus.Inactive == status)
return tc.ExecuteReader(
"SELECT * FROM GRADES where Status=%n AND PayrollTypeID=%n and GradeID=(select gradeid from employee where %q) order by code",
status, payrolltypeid, sCondition);
else
return tc.ExecuteReader(
"SELECT * FROM GRADES WHERE PayrollTypeID=%n and GradeID=(select gradeid from employee where %q) order by code",
payrolltypeid, sCondition);
}
internal static IDataReader GetAllowableGrades(TransactionContext tc, int nOpiItmeID, int nOpiParamID,
int payrollTypeID)
{
return tc.ExecuteReader(
"SELECT * FROM Grades WHERE GradeID NOT IN (SELECT DISTINCT(GradeID) FROM OpiParameterGrade, OpiParameter " +
"WHERE OpiParameterGrade.OpiParameterID=OpiParameter.OpiParameterID " +
"AND OpiParameterGrade.OpiItemID=%n AND OpiParameterGrade.OpiParameterID <> %n)" +
"AND Grades.PayrollTypeID=%n", nOpiItmeID, nOpiParamID, payrollTypeID);
}
internal static IDataReader GetAddableGrades(TransactionContext tc, int nAllowDeductID, int nADParamID,
int payrollTypeID)
{
string sQuary = SQLParser.MakeSQL(
"SELECT * FROM Grades WHERE GradeID NOT IN (SELECT DISTINCT(GradeID) FROM ADParameterGrade, ADParameterBasic " +
"WHERE ADParameterGrade.ADParameterID=ADParameterBasic.ADParameterID " +
"AND AllowDeductID=%n AND ADParameterGrade.ADParameterID <> %n)" +
"AND Grades.PayrollTypeID=%n and Status=%n order by Grades.Code", nAllowDeductID, nADParamID,
payrollTypeID, EnumStatus.Active);
return tc.ExecuteReader(sQuary);
}
internal static IDataReader GetAddableGradesForOT(TransactionContext tc, int nTermID, int nTermParameterID,
int payrollTypeID)
{
return tc.ExecuteReader(
"SELECT * FROM Grades Where GradeID NOT IN(SELECT Distinct(GradeID) FROM TermEntityGrade, TermParameter " +
"WHERE TermEntityGrade.TermEntityID=TermParameter.TermParameterID " +
"AND TermID=%n AND TermEntityGrade.TermEntityID <> %n)" +
"AND Grades.PayrollTypeID=%n", nTermID, nTermParameterID, payrollTypeID);
}
internal static IDataReader GetAddableGradesForBonus(TransactionContext tc, int nBonusID, int payrollTypeID)
{
if (nBonusID == 0)
{
string query1 = SQLParser.MakeSQL(@"SELECT * FROM Grades Where GradeID NOT IN
(SELECT Distinct(GradeID) FROM BonusGrades,BONUSPARAMETER
WHERE BonusGrades.BonusID=BONUSPARAMETER.BonusID AND BONUSPARAMETER.BonusID=0 AND BonusParameter.BonusID<>0)
AND Grades.PayrollTypeID=%n", payrollTypeID);
return tc.ExecuteReader(query1);
//return tc.ExecuteReader("SELECT * FROM Grades Where GradeID NOT IN " +
// "(SELECT Distinct(GradeID) FROM BonusGrades,BONUSPARAMETER " +
// "WHERE BonusGrades.BonusID=BONUSPARAMETER.BonusID AND BONUSPARAMETER.BonusID=0 AND BonusParameter.BonusID<>0) " +
// "AND Grades.PayrollTypeID=%n", SystemInformation.CurrentSysInfo.PayrollTypeID.Integer);
}
else
{
string query2 = SQLParser.MakeSQL(@"SELECT * FROM Grades Where GradeID NOT IN
(SELECT Distinct(GradeID) FROM BonusGrades,BONUSPARAMETER
WHERE BonusGrades.BonusID=BONUSPARAMETER.BonusID AND BONUSPARAMETER.BonusID=%n AND BonusParameter.BonusID<>%n)
AND Grades.PayrollTypeID=%n", nBonusID, nBonusID, payrollTypeID);
//return tc.ExecuteReader("SELECT * FROM Grades Where GradeID NOT IN " +
// "(SELECT Distinct(GradeID) FROM BonusGrades,BONUSPARAMETER " +
// "WHERE BonusGrades.BonusID=BONUSPARAMETER.BonusID AND BONUSPARAMETER.BonusID=%n AND BonusParameter.BonusID<>%n) " +
// "AND Grades.PayrollTypeID=%n", nBonusID.Integer, nBonusID.Integer, SystemInformation.CurrentSysInfo.PayrollTypeID.Integer);
return tc.ExecuteReader(query2);
}
}
internal static IDataReader GetAddableGradesForLoanParameter(TransactionContext tc, int LoaniD,
int LoanParameterId, int payrolltypeid)
{
string sSQL = string.Format(
"Select * from GRADES where GRADEID not in (Select Distinct GradeID from LoanGrades," +
" LoanParameter where LoanParameter.LoanParameterID=LoanGrades.LoanParameterID AND LoanGrades.LoanID={0} " +
" AND LoanGrades.LoanParameterID <>{1}) AND Grades.PayrollTypeID={2} Order by CODE", LoaniD,
LoanParameterId, payrolltypeid);
string query = SQLParser.MakeSQL(sSQL);
return tc.ExecuteReader(query);
}
internal static IDataReader GetAllPayrollTypes(TransactionContext tc, EnumStatus status)
{
if (EnumStatus.Active == status || EnumStatus.Inactive == status)
return tc.ExecuteReader("SELECT * FROM GRADES where Status=%n order by code", status);
else
return tc.ExecuteReader("SELECT * FROM GRADES order by code");
}
internal static IDataReader Get(TransactionContext tc, int ID)
{
return tc.ExecuteReader("SELECT * FROM GRADES WHERE GradeID=%n", ID);
}
internal static IDataReader Get(TransactionContext tc, string sCode)
{
return tc.ExecuteReader("SELECT * FROM GRADES WHERE Code=%s", sCode);
}
internal static IDataReader GetByPayrollType(TransactionContext tc, string sCode, int payrollTypeID)
{
return tc.ExecuteReader("SELECT * FROM GRADES WHERE Code=%s and Payrolltypeid=%n", sCode, payrollTypeID);
}
#endregion
#region Delete function
internal static void Delete(TransactionContext tc, int ID)
{
tc.ExecuteNonQuery("DELETE FROM GRADES WHERE GradeID=%n", ID);
}
#endregion
}
}