1850 lines
88 KiB
C#
1850 lines
88 KiB
C#
using HRM.Report;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using HRM.BO;
|
|
using System.Net.Http.Headers;
|
|
using HRM.DA;
|
|
using System.Data;
|
|
using Microsoft.Reporting.NETCore;
|
|
using AutoMapper.Configuration.Conventions;
|
|
using Org.BouncyCastle.Ocsp;
|
|
using Microsoft.ReportingServices.Interfaces;
|
|
using static iTextSharp.text.pdf.AcroFields;
|
|
using Ubiety.Dns.Core.Common;
|
|
using NPOI.SS.Formula.Functions;
|
|
using HRM.BO.Report;
|
|
using HRM.Report.PayrollDataSet;
|
|
using Newtonsoft.Json;
|
|
using Microsoft.AspNetCore.StaticFiles;
|
|
|
|
namespace HRM.UI.Controllers.Report
|
|
{
|
|
[Route("api/Report")]
|
|
[ApiController]
|
|
[Authorize]
|
|
public class ReportController : ControllerBase
|
|
{
|
|
private readonly IEmployeeService _employeeService;
|
|
public ReportController(IEmployeeService employeeService)
|
|
{
|
|
this._employeeService = employeeService;
|
|
}
|
|
|
|
#region Employee
|
|
|
|
[HttpPost("getEmpBasicInfo")]
|
|
public ActionResult getEmpBasicInfo(dynamic data)
|
|
{
|
|
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string sEmpID = (string)items["empIds"].ToObject<string>();
|
|
string empBasicInfo = string.Empty;
|
|
try
|
|
{
|
|
rptEmployee rptEmployee = new rptEmployee();
|
|
empBasicInfo = rptEmployee.GetEmpDetails(sEmpID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(empBasicInfo);
|
|
}
|
|
|
|
#endregion
|
|
|
|
|
|
#region CommonReportData
|
|
|
|
[HttpPost("getCommonReportData")]
|
|
public ActionResult getCommonReportData(dynamic data)
|
|
{
|
|
// *** please talk to shamim, if you need to change this function code
|
|
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
EnumReportType reportid = (EnumReportType)items["reportid"].ToObject<int>();
|
|
int itemid = 0;
|
|
|
|
if (items["itemid"] != null)
|
|
itemid = (int)items["itemid"].ToObject<int>();
|
|
DateTime fromDate = DateTime.Today;
|
|
DateTime toDate = DateTime.Today;
|
|
string selectedReport = "";
|
|
string sEmpIDs = (string)items["empIds"].ToObject<string>();
|
|
if (items["selectedReport"] != null)
|
|
selectedReport = (string)items["selectedReport"].ToObject<string>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
if (items["fromDate"] != null)
|
|
fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
if (items["toDate"] != null)
|
|
toDate = (DateTime)items["toDate"].ToObject<DateTime>();
|
|
int bankId = 0;
|
|
if (items["bankId"] != null)
|
|
bankId = (int)items["bankId"].ToObject<int>();
|
|
string locationIds = string.Empty;
|
|
if (items["locationIds"] != null)
|
|
{
|
|
locationIds = (string)items["locationIds"].ToObject<string>();
|
|
}
|
|
|
|
int loanIssueId = 0;
|
|
|
|
if (items["loanIssueId"] != null)
|
|
{
|
|
loanIssueId = (int)items["loanIssueId"].ToObject<int>();
|
|
}
|
|
int locationId = 0;
|
|
if (items["locationId"] != null)
|
|
{
|
|
locationId = (int)items["locationId"].ToObject<int>();
|
|
}
|
|
// ****please talk to shamim, if you need to change this function code
|
|
|
|
// string empBasicInfo = string.Empty;
|
|
byte[] bytes = null;
|
|
int employeeId = currentUser.EmployeeID.GetValueOrDefault();
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
DateTime nextPayProcessDate = currentUser.NextPayProcessDate.GetValueOrDefault();
|
|
bool isForESS = false;
|
|
try
|
|
{
|
|
switch (reportid)
|
|
{
|
|
case EnumReportType.None:
|
|
break;
|
|
case EnumReportType.DLP:
|
|
break;
|
|
case EnumReportType.Grade:
|
|
break;
|
|
case EnumReportType.GradeSegment:
|
|
break;
|
|
case EnumReportType.Designations:
|
|
break;
|
|
case EnumReportType.Categiries:
|
|
break;
|
|
case EnumReportType.Employees:
|
|
break;
|
|
case EnumReportType.EmployeePosting:
|
|
break;
|
|
case EnumReportType.EmployeeAllInfo:
|
|
break;
|
|
case EnumReportType.EmpCostCenter:
|
|
break;
|
|
case EnumReportType.BankGuarantee:
|
|
break;
|
|
case EnumReportType.EmpIndvidualDetail:
|
|
break;
|
|
case EnumReportType.EmpUpcomingInfo:
|
|
break;
|
|
case EnumReportType.EmpHistory:
|
|
break;
|
|
case EnumReportType.EmpRetirement:
|
|
break;
|
|
case EnumReportType.EmpService:
|
|
break;
|
|
case EnumReportType.EmpEnvelop:
|
|
break;
|
|
case EnumReportType.OTHour:
|
|
break;
|
|
case EnumReportType.OTPaySlip:
|
|
break;
|
|
case EnumReportType.OTBankAdvice:
|
|
break;
|
|
case EnumReportType.OTHourSheet:
|
|
bytes = new OTReport().OTMonthlySheet((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.EmpServiceBook:
|
|
bytes = new rptEmployee().EmpServiceBook((int)currentUser.PayrollTypeID, sEmpIDs);
|
|
break;
|
|
case EnumReportType.OTMonthRange:
|
|
break;
|
|
case EnumReportType.OTBranch:
|
|
break;
|
|
case EnumReportType.OTDivision:
|
|
break;
|
|
case EnumReportType.OTCostCenter:
|
|
bytes = new OTReport().OTCostCenter((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.OTBankDisbursement:
|
|
bytes = new OTReport().OTBankDisbursement((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.BankAdvice:
|
|
rptBankAdvice rptBankAdvice = new rptBankAdvice();
|
|
bytes = rptBankAdvice.ShowNewBankDisbursmentReport((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.NewBankAdvice:
|
|
rptBankAdvice newRptBankAdvice = new rptBankAdvice();
|
|
bytes = newRptBankAdvice.ShowNewBankDisbursmentReport((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.BankAdviceWithRoutingNo:
|
|
rptBankAdviceWithRoutingNo rptBankAdviceWithRoutingNo = new rptBankAdviceWithRoutingNo();
|
|
bytes = rptBankAdviceWithRoutingNo.ShowBankDisbursmentReportWithRoutingNo((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.CashDisbursement:
|
|
break;
|
|
case EnumReportType.PayRegister:
|
|
break;
|
|
case EnumReportType.OverAllSummary:
|
|
bytes = new PaySlip().ReportOverAllSummary((int)currentUser.PayrollTypeID, sEmpIDs, fromDate, reportType);
|
|
break;
|
|
case EnumReportType.SalaryControl:
|
|
break;
|
|
case EnumReportType.PaySlip:
|
|
if (reportType == "EMAIL")
|
|
{
|
|
//bool isForESS = false;
|
|
//if (sEmpIDs.Length == 0)
|
|
//{
|
|
// isForESS = true;
|
|
// sEmpIDs = employeeId.ToString();
|
|
//}
|
|
//bytes = new PaySlip().PayslipMail((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, isForESS);
|
|
}
|
|
else
|
|
{
|
|
|
|
if (sEmpIDs.Length == 0)
|
|
{
|
|
isForESS = true;
|
|
sEmpIDs = employeeId.ToString();
|
|
}
|
|
bytes = new PaySlip().ShowReportNew((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, isForESS);
|
|
}
|
|
break;
|
|
case EnumReportType.Envelop:
|
|
break;
|
|
case EnumReportType.SalaryReconcil:
|
|
bytes = new rptSalarySheet().ShowSalaryReconNew(toDate, fromDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.SalaryReconcilSGS:
|
|
bytes = new rptSalarySheet().ShowSalaryReconSGS(fromDate, toDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.SalaryReconcilItemWise:
|
|
break;
|
|
case EnumReportType.SalaryControl1Page:
|
|
break;
|
|
case EnumReportType.IndvSalaryComponent:
|
|
break;
|
|
case EnumReportType.ChangeNotes:
|
|
break;
|
|
case EnumReportType.ChangeNotesSummary:
|
|
break;
|
|
case EnumReportType.CCSalaryDetails:
|
|
bytes = new rptSalarySheet().ShowDetailSalarySheetByCC((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.CCSalarySummary:
|
|
bytes = new rptSalarySheet().CCWiseSalarySummary((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.CCSalarySheet:
|
|
break;
|
|
case EnumReportType.SalaryComparison:
|
|
break;
|
|
case EnumReportType.Memorandum:
|
|
break;
|
|
case EnumReportType.SalarySMS:
|
|
break;
|
|
case EnumReportType.SalarySheetSummary:
|
|
rptSalarySheet rptSalarySheet = new rptSalarySheet();
|
|
bool bfixedAmount = new SystemConfigarationService().GetconfigBooleanValue(EnumConfigurationType.Logic, "costcenter", "manadatoryinsalary");
|
|
if (bfixedAmount)
|
|
{
|
|
bytes = rptSalarySheet.ShowReport((int)currentUser.PayrollTypeID, fromDate,
|
|
(int)EnumReportType.SalarySheetSummary, sEmpIDs, reportType);
|
|
}
|
|
else
|
|
{
|
|
bytes = rptSalarySheet.ShowReportWithoutCostcenter((int)currentUser.PayrollTypeID, fromDate,
|
|
(int)EnumReportType.SalarySheetSummary, sEmpIDs, reportType);
|
|
}
|
|
break;
|
|
case EnumReportType.ExtendedSalarySheet:
|
|
//bytes = new rptSalarySheet().ShowReportWithoutCostCenterOT((int)currentUser.PayrollTypeID, fromDate,
|
|
// (int)EnumReportType.SalarySheetSummary, sEmpIDs, reportType);
|
|
bytes = new rptSalarySheet().ShowExtendedSalarySheet((int)currentUser.PayrollTypeID, fromDate.LastDateOfMonth(),
|
|
(int)EnumReportType.SalarySheetSummary, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.SalarySheetArrear:
|
|
bytes = new rptSalarySheet().ShowreportForManagement(fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.SalaryWithheldSheetSummary:
|
|
bytes = new rptSalarySheet().ShowreportForManagement(fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.SalaryBankSummary:
|
|
break;
|
|
case EnumReportType.SalaryByMonthAndYear:
|
|
break;
|
|
case EnumReportType.SalarySheetForIDLC:
|
|
break;
|
|
case EnumReportType.SalarySheetWithOPIItems:
|
|
break;
|
|
case EnumReportType.SalarySheetForIDLCWithOPIItems:
|
|
break;
|
|
case EnumReportType.PayrollSummary:
|
|
break;
|
|
case EnumReportType.BranchWiseSalarySummary:
|
|
break;
|
|
case EnumReportType.CostCenterWiseSalaryDetails:
|
|
break;
|
|
case EnumReportType.DivisionWiseReport:
|
|
break;
|
|
case EnumReportType.DepartmentWiseReport:
|
|
break;
|
|
case EnumReportType.CTCDetail:
|
|
break;
|
|
case EnumReportType.CCReportToFinance:
|
|
break;
|
|
case EnumReportType.CostCenterWiseSummary:
|
|
break;
|
|
case EnumReportType.PreRequisite:
|
|
break;
|
|
case EnumReportType.CTCComparison:
|
|
break;
|
|
case EnumReportType.PromotionSalarySheetDetail:
|
|
break;
|
|
case EnumReportType.PromotionSalarySheetSummary:
|
|
break;
|
|
case EnumReportType.ChangeInLocation:
|
|
break;
|
|
case EnumReportType.JoiningReport:
|
|
break;
|
|
case EnumReportType.IncrementDetail:
|
|
break;
|
|
case EnumReportType.IncrementSummary:
|
|
break;
|
|
case EnumReportType.IncrementComparison:
|
|
break;
|
|
case EnumReportType.BranchWiseSalaryDetail:
|
|
break;
|
|
case EnumReportType.BranchWiseOPIDetails:
|
|
break;
|
|
case EnumReportType.BranchWiseDeductionDetails:
|
|
break;
|
|
case EnumReportType.CashAdviceReport:
|
|
break;
|
|
case EnumReportType.DivisionWiseSalary:
|
|
break;
|
|
case EnumReportType.CostCenterWise:
|
|
break;
|
|
case EnumReportType.SalarySheetExtended:
|
|
break;
|
|
case EnumReportType.CostInformation:
|
|
break;
|
|
case EnumReportType.SalarySheetBuyerWise:
|
|
break;
|
|
case EnumReportType.SalarySheetDeptWise:
|
|
break;
|
|
case EnumReportType.BanglaPayslip:
|
|
bytes = new rptEcho().ShowBanglaPaySlip((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, (int)EnumReportType.BanglaPayslip, reportType, (EnumBankCash)itemid);
|
|
break;
|
|
case EnumReportType.BuyerWiseBanglaPayslip:
|
|
break;
|
|
case EnumReportType.SalaryStracture:
|
|
break;
|
|
case EnumReportType.SalaryReconciliationSummary:
|
|
bytes = new rptSalarySheet().SalaryReconciliationSummary(fromDate, toDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.ItemWiseSalary:
|
|
List<PayrollComponentList> payrollComponentList = new List<PayrollComponentList>();
|
|
List<PayrollComponentList> payrollComponentListtemp = new List<PayrollComponentList>();
|
|
if (itemid > 0)
|
|
{
|
|
payrollComponentList = new PayrollComponentListService().ConstantItemsForSalary((int)currentUser.PayrollTypeID);
|
|
payrollComponentListtemp = payrollComponentList.Where(x => x.PKID == itemid).ToList();
|
|
}
|
|
bytes = new rptSalarySheet().ItemWiseSalary(GlobalFunctions.FirstDateOfMonth(fromDate), GlobalFunctions.LastDateOfMonth(toDate), payrollComponentListtemp, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.SalaryreconciliationForAllitems:
|
|
break;
|
|
case EnumReportType.SalaryCertificate:
|
|
break;
|
|
case EnumReportType.EmployeesMasterData:
|
|
break;
|
|
case EnumReportType.StuffListWithoutSalary:
|
|
break;
|
|
case EnumReportType.StuffAccountWithoutSalary:
|
|
break;
|
|
case EnumReportType.SalaryComparisonNew:
|
|
break;
|
|
case EnumReportType.AuditReport:
|
|
break;
|
|
case EnumReportType.PFLedger:
|
|
break;
|
|
case EnumReportType.PFRegister:
|
|
break;
|
|
case EnumReportType.PFCertificate:
|
|
break;
|
|
case EnumReportType.PFYrlyRegister:
|
|
break;
|
|
case EnumReportType.PFTotalInvestment:
|
|
break;
|
|
case EnumReportType.ITAnnual:
|
|
break;
|
|
case EnumReportType.ITMonthly:
|
|
break;
|
|
case EnumReportType.ITRegister:
|
|
break;
|
|
case EnumReportType.ITIndividual:
|
|
break;
|
|
case EnumReportType.ITInvestment:
|
|
break;
|
|
case EnumReportType.ITPerquisite:
|
|
break;
|
|
case EnumReportType.ITReport108:
|
|
RptIncomeTax incomeTax = new RptIncomeTax();
|
|
bytes = incomeTax.GetDataReport108(itemid, sEmpIDs, currentUser.PayrollTypeID.GetValueOrDefault(),
|
|
currentUser.TaxParamID.GetValueOrDefault(),
|
|
nextPayProcessDate, reportType);
|
|
break;
|
|
case EnumReportType.ITReport177:
|
|
RptIncomeTax rptTaxes = new RptIncomeTax();
|
|
bytes = rptTaxes.GetDataReport177(sEmpIDs, currentUser.PayrollTypeID.GetValueOrDefault(), GlobalFunctions.LastDateOfMonth(fromDate), reportType);
|
|
break;
|
|
case EnumReportType.EmployeeTaxDetails:
|
|
break;
|
|
case EnumReportType.ITReportWithoutProjection:
|
|
break;
|
|
case EnumReportType.EmployeesTaxDeducted:
|
|
break;
|
|
case EnumReportType.ITReport108onPaidAmount:
|
|
break;
|
|
case EnumReportType.TaxInvestment:
|
|
break;
|
|
case EnumReportType.TaxChallan:
|
|
break;
|
|
case EnumReportType.BonusBankAdvice:
|
|
bytes = new rptBonus().BonusBankAdvice(itemid, fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.BonusRegister:
|
|
bytes = new rptBonus().BonusRegister(itemid, fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.PaySlipForBonus:
|
|
|
|
isForESS = false;
|
|
if (sEmpIDs.Length == 0)
|
|
{
|
|
isForESS = true;
|
|
sEmpIDs = employeeId.ToString();
|
|
}
|
|
//if (string.IsNullOrEmpty(sEmpIDs))
|
|
//{
|
|
// sEmpIDs = currentUser.EmployeeID.ToString();
|
|
//}
|
|
bytes = new rptBonus().BonusPaySlip(itemid, fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType, isForESS);
|
|
break;
|
|
case EnumReportType.LoanIssue:
|
|
bytes = new LoanReport().MonthlyLoanReport(fromDate, (int)currentUser.PayrollTypeID, reportType, locationIds);
|
|
break;
|
|
case EnumReportType.LoanDue:
|
|
bytes = new LoanReport().LoanPaymentDue(fromDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.Loan:
|
|
bytes = new LoanReport().LatestIndividualLoanReport(itemid, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.OutPayslip:
|
|
break;
|
|
case EnumReportType.OutPayRegister:
|
|
break;
|
|
case EnumReportType.OutCashDisbursementRegister:
|
|
break;
|
|
case EnumReportType.OutPayBankAdvice:
|
|
break;
|
|
case EnumReportType.OutPaymentRegister:
|
|
break;
|
|
case EnumReportType.OutPayLedger:
|
|
break;
|
|
case EnumReportType.OutPayEmployeeCost:
|
|
break;
|
|
case EnumReportType.DetailOtherPayrollItem:
|
|
break;
|
|
case EnumReportType.DeductionReport:
|
|
break;
|
|
case EnumReportType.CostCenterWiseOPIDetails:
|
|
break;
|
|
case EnumReportType.OPIPayslip:
|
|
break;
|
|
case EnumReportType.IDLCOPIRegister:
|
|
break;
|
|
|
|
case EnumReportType.UnAuthorizedLeave:
|
|
break;
|
|
case EnumReportType.EmpWorkingHours:
|
|
break;
|
|
case EnumReportType.EmpITInvestment:
|
|
break;
|
|
case EnumReportType.MarketSurvey:
|
|
break;
|
|
case EnumReportType.URBProvision:
|
|
break;
|
|
case EnumReportType.Appraisal:
|
|
break;
|
|
case EnumReportType.URBRegister:
|
|
break;
|
|
case EnumReportType.URBDetail:
|
|
break;
|
|
case EnumReportType.PTCHistry:
|
|
break;
|
|
case EnumReportType.FinalSattlement:
|
|
break;
|
|
case EnumReportType.BankLetter:
|
|
break;
|
|
case EnumReportType.EmployeeHistory:
|
|
break;
|
|
case EnumReportType.PermissionList:
|
|
break;
|
|
case EnumReportType.ChangeHistry:
|
|
break;
|
|
case EnumReportType.PositionWiseSalary:
|
|
break;
|
|
case EnumReportType.Payscale:
|
|
break;
|
|
case EnumReportType.EmailPayslip:
|
|
break;
|
|
case EnumReportType.DailyAttendance:
|
|
break;
|
|
case EnumReportType.MonthlyAttendances:
|
|
break;
|
|
case EnumReportType.MonthlyLateAtten:
|
|
break;
|
|
case EnumReportType.FASSalaryAllocation:
|
|
break;
|
|
case EnumReportType.FASSWJV:
|
|
break;
|
|
case EnumReportType.PFrevenue:
|
|
break;
|
|
case EnumReportType.GL:
|
|
break;
|
|
case EnumReportType.DailyInOut:
|
|
break;
|
|
case EnumReportType.DailyAbsent:
|
|
break;
|
|
case EnumReportType.MonthlyAttendance:
|
|
break;
|
|
case EnumReportType.MonthlyDetailAttendance:
|
|
bytes = new rptEcho().GetMonthlyDetailAttendance(GlobalFunctions.FirstDateOfMonth(fromDate),
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.AttendanceInformation:
|
|
break;
|
|
case EnumReportType.DailyInOutAndAbsent:
|
|
break;
|
|
case EnumReportType.SingleEmpJobCard:
|
|
bytes = new AttendanceReport().MonthlyJobCard(fromDate, toDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.MultipleEmpJobCard:
|
|
bytes = new AttendanceReport().ShowDateRangeJobCardMultiple(fromDate, toDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.AttendanceSummary:
|
|
|
|
bytes = new AttendanceReport().GetAttendanceSummary(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.AttendanceSummaryWithInOut:
|
|
bytes = new AttendanceReport().GetMonthlyAttendanceReportNew(fromDate, toDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyInOutForBuyer:
|
|
break;
|
|
case EnumReportType.DailyAbsentForBuyer:
|
|
break;
|
|
case EnumReportType.MonthlyAttendanceForBuyer:
|
|
break;
|
|
case EnumReportType.MonthlyDetailAttendanceForBuyer:
|
|
break;
|
|
case EnumReportType.JVReport:
|
|
break;
|
|
case EnumReportType.EmployeeWiseJVReport:
|
|
break;
|
|
case EnumReportType.CCWiseJVReport:
|
|
break;
|
|
case EnumReportType.JVSummaryReport:
|
|
break;
|
|
case EnumReportType.FinalSettlement:
|
|
break;
|
|
case EnumReportType.EmpLifeCycle:
|
|
break;
|
|
case EnumReportType.Workflow:
|
|
break;
|
|
case EnumReportType.EssTaxCard:
|
|
RptIncomeTax rptIncomeTax = new RptIncomeTax();
|
|
int taxParamId = currentUser.TaxParamID.GetValueOrDefault();
|
|
if (sEmpIDs.Length > 0)
|
|
{
|
|
employeeId = Convert.ToInt32(sEmpIDs);
|
|
}
|
|
bytes = rptIncomeTax.showTaxCard(employeeId, true, itemid, taxParamId, nextPayProcessDate, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.MultipleTaxCard:
|
|
taxParamId = currentUser.TaxParamID.GetValueOrDefault();
|
|
bytes = new RptIncomeTax().ShowMultipleTaxCard(sEmpIDs, true, itemid, taxParamId, nextPayProcessDate, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.MultipleEmpLeaveBalance:
|
|
MultipleEmpLeaveBalance multipleEmpLeaveBalance = new MultipleEmpLeaveBalance();
|
|
bytes = multipleEmpLeaveBalance.ShowMultipleEmpLeaveBalance(itemid, payrollTypeId, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.EmpLeaveLedger:
|
|
bytes = new EmpLeaveLedger().ShowReportNew(sEmpIDs, itemid, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.MultipleEmpLeaveLedger:
|
|
bytes = new EmpLeaveLedger().ShowReport(sEmpIDs, fromDate, toDate, itemid, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.CashRegister:
|
|
bytes = new rptSalarySheet().ShowCashRegisterReport(fromDate, sEmpIDs, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.TaxCertificate:
|
|
bytes = new RptIncomeTax().ShowTaxCertificate(sEmpIDs, itemid, payrollTypeId, currentUser.TaxParamID.GetValueOrDefault(), "PDF");
|
|
break;
|
|
case EnumReportType.HnMEmpLeaveLedger:
|
|
rptLeave rptLeave = new rptLeave();
|
|
bytes = rptLeave.ShowEmployeeWiseLeaveLedger(sEmpIDs, /*fromDate, toDate,*/ itemid, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.LeaveRegister:
|
|
rptLeave = new rptLeave();
|
|
if (string.IsNullOrEmpty(sEmpIDs))
|
|
{
|
|
throw new Exception("Select employee");
|
|
}
|
|
bytes = rptLeave.ShowLeaveRegister(sEmpIDs, itemid, bankId, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.LeaveEncashmentBankAdvice:
|
|
rptLeave = new rptLeave();
|
|
bytes = rptLeave.ShowLeaveEncashmentReports(sEmpIDs, itemid, selectedReport, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.CCWiseLeaveEncashmentReturn:
|
|
rptLeave = new rptLeave();
|
|
bytes = rptLeave.ShowCCWiseLeaveEncashmentReturn(itemid, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.DigitalServiceBook:
|
|
bytes = new rptDigitalServiceBook().DigitalServiceBook(currentUser.EmployeeID.HasValue ? currentUser.EmployeeID.Value : 0, (int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.SalaryAllocationReportEmployeeWise:
|
|
bytes = new rptJV().showJVSalaryDetailEmployeeWReport(1, GlobalFunctions.LastDateOfMonth(fromDate), null, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.SalaryAllocationReportCostCenterWise:
|
|
//if (locationIds.Length > 1)
|
|
//{
|
|
// throw new Exception("Select Single Locaion");
|
|
// Convert.ToInt32(locationIds);
|
|
//}
|
|
bytes = new rptJV().showJVLoactionWReport(1, GlobalFunctions.LastDateOfMonth(fromDate), null, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.SalaryAllocationSummaryReport:
|
|
bytes = new rptJV().showJVSummaryReport(1, GlobalFunctions.LastDateOfMonth(fromDate), locationId, payrollTypeId, reportType);
|
|
break;
|
|
case EnumReportType.PaySlipEcho:
|
|
if (reportType == "EMAIL")
|
|
{
|
|
//bool isForESS = false;
|
|
//if (sEmpIDs.Length == 0)
|
|
//{
|
|
// isForESS = true;
|
|
// sEmpIDs = employeeId.ToString();
|
|
//}
|
|
//bytes = new PaySlip().PayslipMail((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, isForESS);
|
|
}
|
|
else
|
|
{
|
|
|
|
if (sEmpIDs.Length == 0)
|
|
{
|
|
isForESS = true;
|
|
sEmpIDs = employeeId.ToString();
|
|
}
|
|
bytes = new rptEcho().ShowPaySlipEcho((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, isForESS);
|
|
}
|
|
break;
|
|
case EnumReportType.EchoSalarySheet:
|
|
bytes = new rptEcho().ShowSalarySheet((int)currentUser.PayrollTypeID, fromDate,
|
|
(int)EnumReportType.EchoSalarySheet, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.SalarySheetEcho:
|
|
break;
|
|
case EnumReportType.SalarySheetEchoNew:
|
|
bytes = new rptEcho().ShowSalarySheetEchoNew((int)currentUser.PayrollTypeID, fromDate,
|
|
(int)EnumReportType.EchoSalarySheet, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.BanglaPaySlipEcho:
|
|
bytes = new rptEcho().ShowBanglaPaySlip((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, (int)EnumReportType.BanglaPayslip, reportType, (EnumBankCash)itemid);
|
|
break;
|
|
case EnumReportType.BankAdviceEcho:
|
|
bytes = new rptEcho().ShowBankAdviceReportEcho((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.CashAdviceEcho:
|
|
break;
|
|
case EnumReportType.ItemWiseSalaryEcho:
|
|
break;
|
|
case EnumReportType.OverallSummaryEcho:
|
|
break;
|
|
case EnumReportType.SalaryReconEcho:
|
|
break;
|
|
case EnumReportType.SalaryReconSummaryEcho:
|
|
break;
|
|
case EnumReportType.MultipleEmployeeJobCardEcho:
|
|
bytes = new rptEcho().ShowJobCardMultiple(fromDate, toDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyPresentEcho:
|
|
bytes = new rptEcho().ShowDailyPresent(fromDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyAbsentEcho:
|
|
bytes = new rptEcho().ShowDailyAbsent(fromDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.OtBankDisbursementHnm:
|
|
bytes = new rptHnm().OTBankDisbursementHnm((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.BonusRegisterHnm:
|
|
bytes = new rptHnm().BonusRegisterHNM(itemid, fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.BankAdviceSalaryHnm:
|
|
bytes = new rptHnm().ShowNewBankDisbursmentReport((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.BonusBankAdviceHnm:
|
|
bytes = new rptHnm().BonusBankAdvice(itemid, fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.OpiBankDisbursementHnm:
|
|
bytes = new rptHnm().OpiBankDisbursementHnm((int)currentUser.PayrollTypeID, fromDate,
|
|
sEmpIDs, bankId, reportType);
|
|
break;
|
|
case EnumReportType.OpiRegisterForTotalValue:
|
|
bytes = new rptHnm().OpiRegisterForTotalValue((int)currentUser.PayrollTypeID, fromDate, toDate,
|
|
sEmpIDs, itemid, reportType);
|
|
break;
|
|
case EnumReportType.AttendanceInformationEcho:
|
|
bytes = new rptEcho().GetEmpAttenInfo((int)currentUser.PayrollTypeID,
|
|
sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.DailyInOutEcho:
|
|
bytes = new rptEcho().ShowDailyInOut(fromDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyAttnSummaryEcho:
|
|
bytes = new rptEcho().ShowDailyAttnSummary(fromDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.InOutMissingEcho:
|
|
bytes = new rptEcho().ShowInOutMissing(fromDate, toDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.MonthlyKpiEcho:
|
|
bytes = new rptEcho().ShowMonthlyKPI(fromDate, toDate, sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.EmployeeBasicInformationSGS:
|
|
bytes = new rptEmployee().GetEmpBasicInfo(sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.EmployeeCurrentPostingDetailSGS:
|
|
bytes = new rptEmployee().GetEmpPostings(sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.EmployeesCostAllocationDetailsSGS:
|
|
bytes = new rptEmployee().GetCostAllocationDetails(fromDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.EmployeesCostInformationDetailsSGS:
|
|
bytes = new rptEmployee().ShowCCInformation(fromDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.ShowItInvestmentSGS:
|
|
bytes = new RptIncomeTax().ShowITPfAndOtherDetails(reportType, sEmpIDs, (int)currentUser.PayrollTypeID, (int)currentUser.TaxParamID);
|
|
break;
|
|
case EnumReportType.CCSalaryDetailsSGS:
|
|
bytes = new rptSalarySheet().ShowDetailSalarySheetByCC((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.CCSalarySummarySGS:
|
|
bytes = new rptSalarySheet().CCWiseSalarySummary((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.EmployeeWiseCardInfoEcho:
|
|
bytes = new rptEmployee().EmployeeWiseCardInfo((int)currentUser.PayrollTypeID, sEmpIDs, reportType);
|
|
break;
|
|
case EnumReportType.SingleJobCardLiNFunf:
|
|
bytes = new AttendanceReport().ShowDateRangeJobCardSingleForLiFung(fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.MultipleEmployeeJobCardLiNFunf:
|
|
bytes = new AttendanceReport().ShowDateRangeJobCardMultipleForLiFung(fromDate, sEmpIDs,
|
|
(int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.DailyPresentLiFung:
|
|
bytes = new AttendanceReport().DailyPresentForLiFung(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyAbsentLiFung:
|
|
bytes = new AttendanceReport().DailyAbsentForLiFung(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyOddLiFung:
|
|
bytes = new AttendanceReport().DailyOddForLiFung(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.DailyAttnLiFung:
|
|
bytes = new AttendanceReport().DailyAttnForLiFung(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.AttendanceSummaryLiFung:
|
|
bytes = new AttendanceReport().GetAttendanceSummaryForLiFung(fromDate,
|
|
sEmpIDs, reportType, (int)currentUser.PayrollTypeID);
|
|
break;
|
|
case EnumReportType.CostCenterWiseSalaryDetailsHNM:
|
|
bytes = new rptHnm().ShowSalarySheetReportByCC((int)currentUser.PayrollTypeID, fromDate, sEmpIDs, reportType, (int)EnumReportType.CostCenterWiseSalaryDetailsHNM);
|
|
break;
|
|
case EnumReportType.TaxPerquisite:
|
|
RptIncomeTax rptTax = new RptIncomeTax();
|
|
bytes = rptTax.ShowTaxPerquisite(fromDate, toDate, sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.EmployeeBasicInfoEcho:
|
|
bytes = new rptEmployee().GetEmployeeBasicInfo( sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.EmployeeEvaluationSheet:
|
|
bytes = new rptEmployee().GetEmployeeEvaluationSheet(sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
case EnumReportType.LifeCycleDeletedHistor:
|
|
bytes = new rptEmployee().GetEmpLFDeletedHistory(sEmpIDs, (int)currentUser.PayrollTypeID, reportType);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
//fdata.CopyTo(ms);
|
|
//item.fileData = ms.ToArray();
|
|
//byte[] textAsBytes = ms.ToArray();
|
|
//this._hrEmployeeService.uplaodFile(item);
|
|
//string base64String = Convert.ToBase64String(bytes);
|
|
//Add default file name that can be used by client code for both MIME transfer and AJAX Blob.
|
|
return Ok(bytes);
|
|
// return Ok(File(bytes, "application/pdf"));
|
|
}
|
|
|
|
[HttpPost("getExceptionReport")]
|
|
public ActionResult GetExceptionReport(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int itemId = (int)items["itemId"].ToObject<int>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime toDate = (DateTime)items["toDate"].ToObject<DateTime>();
|
|
int subItemId = (int)items["subItemId"].ToObject<int>();
|
|
string subItemName = (string)items["subItemName"].ToObject<string>();
|
|
byte[] bytes = null;
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
ReportProcessor reportProcessor = new ReportProcessor();
|
|
rptEmployee rptEmp = new rptEmployee();
|
|
DataSet resultDataSet = new DataSet();
|
|
|
|
try
|
|
{
|
|
switch (itemId)
|
|
{
|
|
case 1: // Employee Joining
|
|
DataTable ds = rptEmp.GetEmpJoining(fromDate, toDate, payrollTypeId);
|
|
bytes = reportProcessor.ShowForEmpJoiningExceptionReport(null, ds, fromDate.ToString("dd MMM yyyy") + " - " + toDate.ToString("dd MMM yyyy"), payrollTypeId, reportType);
|
|
break;
|
|
case 2: // Discontinue
|
|
DataTable oEmpHis = rptEmp.GetEmpHistories(fromDate, toDate, payrollTypeId);
|
|
bytes = reportProcessor.ShowForDiscontinueExceptionReport(null, oEmpHis, payrollTypeId, reportType);
|
|
break;
|
|
case 3: // Basic And Grade
|
|
DataTable basicGrade = rptEmp.GetEmpPromotion(fromDate, toDate, payrollTypeId);
|
|
//DataTable basicGrade = rptEmp.GetEmpBasicGrade(fromDate, toDate, payrollTypeId);
|
|
bytes = reportProcessor.ShowForBasicAndGradeReport(null, basicGrade, payrollTypeId, reportType);
|
|
break;
|
|
case 4: // Designation Change
|
|
DataTable designationChange = rptEmp.GetDesignationChange(fromDate, toDate, payrollTypeId);
|
|
bytes = reportProcessor.ShowForDesignationExceptionReport(null, designationChange, payrollTypeId, reportType);
|
|
break;
|
|
case 6: // Allowance
|
|
DataTable allowance = rptEmp.GetEmpAllowDeduct(fromDate, toDate, subItemId, subItemName + " Allowance", payrollTypeId);
|
|
bytes = reportProcessor.ShowForEmpAllowDeduct(null, allowance, fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
case 7: // Deduction
|
|
DataTable deduction = rptEmp.GetEmpAllowDeduct(fromDate, toDate, subItemId, subItemName + " Deduction", payrollTypeId);
|
|
bytes = reportProcessor.ShowForEmpAllowDeduct(null, deduction, fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
case 8: // Bank Advice
|
|
bytes = new rptEmployee().GetEmpBankHistory(fromDate, toDate, payrollTypeId, reportType);
|
|
//bytes = reportProcessor.ShowDlgForEmpBankHistory(null, bankAccount, fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
case 9: // Employee Continue From Discontinue
|
|
bytes = new rptEmployee().GetAllTransferDataForContinueFromDiscontinue(fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
case 10: // Employee Cost Center Allocation
|
|
bytes = new rptEmployee().ShowCCInformationByMonth(fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
case 11: //PF And Confirmation
|
|
bytes = new rptEmployee().PrepareDataForExceptionPFandConfirmation(fromDate, toDate, payrollTypeId, reportType);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
#endregion
|
|
|
|
#region Production Bonus Report
|
|
|
|
|
|
[HttpPost("getProductionBonusReport")]
|
|
public ActionResult getProductionBonusReport(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int itemId = (int)items["itemId"].ToObject<int>();
|
|
DateTime salaryMonth = (DateTime)items["salaryMonth"].ToObject<DateTime>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
int designId = (int)items["designId"].ToObject<int>();
|
|
|
|
//int subItemId = (int)items["subItemId"].ToObject<int>();
|
|
//string subItemName = (string)items["subItemName"].ToObject<string>();
|
|
byte[] bytes = null;
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
rptBonus rptBonus = new rptBonus();
|
|
|
|
try
|
|
{
|
|
switch (itemId)
|
|
{
|
|
case 1: // Monthly_Production_Bonus
|
|
bytes = rptBonus.MonthlyProdBonus(salaryMonth, payrollTypeId, reportType);
|
|
|
|
break;
|
|
case 2: // Employee and Design Wise
|
|
bytes = rptBonus.EmpDesignWiseProdBonus(salaryMonth, payrollTypeId, reportType);
|
|
break;
|
|
case 3: // Production Bonus Detail
|
|
bytes = rptBonus.ProdBonusDetail(designId, salaryMonth, payrollTypeId, reportType);
|
|
break;
|
|
case 4: // Design Wise Prod Bonus Attendance
|
|
bytes = rptBonus.DesignWiseProdBonusAttendance(designId, salaryMonth, payrollTypeId, reportType);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
#endregion Production Bonus Report
|
|
|
|
[HttpGet("getEstimatedConfirmation")]
|
|
public ActionResult GetEstimatedConfirmation()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetEstimatedConfirmationReport();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
[HttpGet("getEstimatedRetirement")]
|
|
public ActionResult GetEstimatedRetirement()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetEstimatedRetirementReport();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
|
|
[HttpGet("getListOfPromotion")]
|
|
public ActionResult GetListOfPromotion()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetListOfPromotion();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
[HttpGet("getListOfTransfer")]
|
|
public ActionResult GetListOfTransfer()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetListOfTransfer();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
[HttpGet("getJobSeparationList")]
|
|
public ActionResult GetJobSeparationList()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetJobSeparationList();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
[HttpGet("getConfirmedEmployeeList")]
|
|
public ActionResult GetConfirmedEmployeeList()
|
|
{
|
|
DataSet ds = new DataSet();
|
|
try
|
|
{
|
|
ds = _employeeService.GetConfirmedEmployeeList();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(ds);
|
|
}
|
|
|
|
[HttpPost("getFstranReportCalculation")]
|
|
public ActionResult GetFstranReportCalculation(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int itemId = (int)items["tranId"].ToObject<int>();
|
|
byte[] bytes = null;
|
|
ReportProcessor reportProcessor = new ReportProcessor();
|
|
rptFSTran rptFstran = new rptFSTran();
|
|
try
|
|
{
|
|
|
|
bytes = rptFstran.ShowFSPaymentCalculationReport(itemId, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getEmpConfirmData")]
|
|
public ActionResult GetEmpConfirmData(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
DateTime confirmationDate = DateTime.Today;
|
|
if (items["confirmationDate"] != null)
|
|
confirmationDate = (DateTime)items["confirmationDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
rptEmployee rptEmployee = new rptEmployee();
|
|
try
|
|
{
|
|
|
|
bytes = rptEmployee.EmployeeConfirmationReport(confirmationDate, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
#region Attendance
|
|
|
|
[HttpPost("getPaymentAdviceReportData")]
|
|
public ActionResult getPaymentAdviceReportData(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int itemid = 0;
|
|
if (items["settlementAdviceId"] != null)
|
|
itemid = (int)items["settlementAdviceId"].ToObject<int>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
//string reportType = null;
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new rptFSTran().ShowReport(itemid, reportType, payrollTypeId);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region assetReport
|
|
[HttpPost("getAssetAcknowledgementReport")]
|
|
public ActionResult GetAssetAcknowledgementReport(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int itemid = (int)items["itemid"].ToObject<int>();
|
|
int employeeid = (int)items["employeeid"].ToObject<int>();
|
|
byte[] bytes = null;
|
|
ReportProcessor reportProcessor = new ReportProcessor();
|
|
rptAssetSerial rptAssetSerial = new rptAssetSerial();
|
|
try
|
|
{
|
|
bytes = rptAssetSerial.GetAssetAcknowledgementdata(itemid, "PDF", (int)currentUser.PayrollTypeID, employeeid);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
#endregion
|
|
|
|
[HttpPost("exportCSVReportData")]
|
|
public ActionResult exportCSVReportData(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
EnumReportType reportid = (EnumReportType)items["reportid"].ToObject<int>();
|
|
int itemid = 0;
|
|
if (items["itemid"] != null)
|
|
itemid = (int)items["itemid"].ToObject<int>();
|
|
DateTime fromDate = DateTime.Today;
|
|
DateTime toDate = DateTime.Today;
|
|
string selectedReport = "";
|
|
string sEmpIDs = (string)items["empIds"].ToObject<string>();
|
|
if (items["selectedReport"] != null)
|
|
selectedReport = (string)items["selectedReport"].ToObject<string>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
if (items["fromDate"] != null)
|
|
fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
if (items["toDate"] != null)
|
|
toDate = (DateTime)items["toDate"].ToObject<DateTime>();
|
|
int bankId = 0;
|
|
if (items["bankId"] != null)
|
|
bankId = (int)items["bankId"].ToObject<int>();
|
|
string locationIds = string.Empty;
|
|
if (items["locationIds"] != null)
|
|
{
|
|
locationIds = (string)items["locationIds"].ToObject<string>();
|
|
}
|
|
|
|
int loanIssueId = 0;
|
|
|
|
if (items["loanIssueId"] != null)
|
|
{
|
|
loanIssueId = (int)items["loanIssueId"].ToObject<int>();
|
|
}
|
|
|
|
|
|
// string empBasicInfo = string.Empty;
|
|
byte[] bytes = null;
|
|
int employeeId = currentUser.EmployeeID.GetValueOrDefault();
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
DateTime nextPayProcessDate = currentUser.NextPayProcessDate.GetValueOrDefault();
|
|
bool isForESS = false;
|
|
DataTable dt = null;
|
|
try
|
|
{
|
|
switch (reportid)
|
|
{
|
|
case EnumReportType.BankAdvice:
|
|
//rptBankAdvice rptBankAdvice = new rptBankAdvice();
|
|
//bytes = rptBankAdvice.ShowNewBankDisbursmentReport((int)currentUser.PayrollTypeID, fromDate,
|
|
// sEmpIDs, bankId, reportType);
|
|
if (sEmpIDs == "")
|
|
throw new Exception("Please Select Employee to Export");
|
|
DataTable oEmpBankAcc = new EmployeeBankAccountService().GetEmpBankAdvice2(GlobalFunctions.LastDateOfMonth(fromDate), sEmpIDs);
|
|
dt = oEmpBankAcc;
|
|
break;
|
|
case EnumReportType.BonusBankAdvice:
|
|
if (sEmpIDs == "")
|
|
throw new Exception("Please Select Employee to Export");
|
|
DataTable oBonusBankAdvice = (new BonusProcessService().GetBonusBankAdvice(itemid, GlobalFunctions.LastDateOfMonth(fromDate), sEmpIDs, payrollTypeId)).Tables[0];
|
|
dt = oBonusBankAdvice;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
//fdata.CopyTo(ms);
|
|
//item.fileData = ms.ToArray();
|
|
//byte[] textAsBytes = ms.ToArray();
|
|
//this._hrEmployeeService.uplaodFile(item);
|
|
//string base64String = Convert.ToBase64String(bytes);
|
|
//Add default file name that can be used by client code for both MIME transfer and AJAX Blob.
|
|
return Ok(dt);
|
|
// return Ok(File(bytes, "application/pdf"));
|
|
}
|
|
[HttpGet("GetLocationsByTier2")]
|
|
public ActionResult GetByTier(int employeeID)
|
|
{
|
|
try
|
|
{
|
|
List<Location> oLocations = new LocationService().GetByTier(2);
|
|
return Ok(oLocations);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
}
|
|
[HttpPost("getLeaveEncashmentData")]
|
|
public ActionResult getLeaveEncashmentData(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
string sEmpIDs = (string)items["empIds"].ToObject<string>();
|
|
DateTime encashDate = (DateTime)items["encashDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().LeaveEncashmentSeparation(sEmpIDs, reportType, encashDate, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getCCWisePFNewMemberWithAmount")]
|
|
public ActionResult getCCWisePFNewMemberWithAmount(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
int locationId = (int)items["locationIds"].ToObject<int>();
|
|
DateTime pfMonth = (DateTime)items["pfMonth"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().CCWisePFNewMemberWithAmount(locationId, reportType, pfMonth, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getEmployeeMaternityLeaveReport")]
|
|
public ActionResult getEmployeeMaternityLeaveReport(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int empId = (int)items["employeeID"].ToObject<int>();
|
|
string employeeShift = (string)items["employeeShift"].ToObject<string>();
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
// string empBasicInfo = string.Empty;
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new rptEmpMaternityReport().getEmployeeMaternityLeaveReport(empId, employeeShift, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
|
|
}
|
|
|
|
[HttpPost("getLeaveApplication")]
|
|
public ActionResult getLeaveApplication(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int empId = (int)items["employeeID"].ToObject<int>();
|
|
//string reportType = (string)items["reportType"].ToObject<string>();
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
// string empBasicInfo = string.Empty;
|
|
int payrolltypeID = (int)currentUser.PayrollTypeID;
|
|
DateTime NextPayProcessDate = (DateTime)currentUser.NextPayProcessDate;
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new rptLeave().getLeaveApplication(empId, payrolltypeID, NextPayProcessDate);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
|
|
}
|
|
|
|
[HttpPost("getAppointmentLetter")]
|
|
public ActionResult getAppointmentLetter(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int empId = (int)items["employeeID"].ToObject<int>();
|
|
HREmployee employee = new HREmployeeService().Get(empId);
|
|
string report = (string)items["employeeType"].ToObject<string>();
|
|
bool isPhotoNeeded = false;
|
|
//string reportType = (string)items["reportType"].ToObject<string>();
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
// string empBasicInfo = string.Empty;
|
|
int payrolltypeID = (int)currentUser.PayrollTypeID;
|
|
DateTime NextPayProcessDate = (DateTime)currentUser.NextPayProcessDate;
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new rptEmployee().CollectDataForBanglaAppointment(employee, report, isPhotoNeeded);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
|
|
}
|
|
|
|
[HttpPost("getCostCenterWiseOpiData")]
|
|
public ActionResult getCostCenterWiseOpiData(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
int opiItemCode = (int)items["opiItemCode"].ToObject<int>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().CostCenterWiseOpi(reportType, fromDate, opiItemCode, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getCostCenterWiseBonusReportData")]
|
|
public ActionResult getCostCenterWiseBonusReportData(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
string bonusTypeName = (string)items["bonusTypeName"].ToObject<string>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().CostCenterWiseBonusSummary(reportType, fromDate, bonusTypeName, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getIdCardPrint")]
|
|
public ActionResult getIdCardPrint(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
string sEmpIDs = (string)items["empIds"].ToObject<string>(); //comma seperated
|
|
int authorizedPerson = (int)items["selectedAuthorizePersonid"].ToObject<int>();
|
|
int reportCategory = (int)items["selectedReportTypeid"].ToObject<int>();
|
|
DateTime issueDate = (DateTime)items["issueDate"].ToObject<DateTime>();
|
|
string expireYear = (string)items["expireYear"].ToObject<string>();
|
|
|
|
byte[] bytes = null;
|
|
// CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
|
|
try
|
|
{
|
|
string RDLC = string.Empty;
|
|
if (reportCategory == 1)
|
|
{
|
|
RDLC = "IDCardPrint.rdlc";
|
|
bytes = new AttendanceReport().ShowEmpCardInfoPerPage(sEmpIDs, authorizedPerson, RDLC, true, expireYear, issueDate, reportCategory);//EmpSign and EmpPhoto Hardcoded as the data not available in database
|
|
}
|
|
else if (reportCategory == 2)
|
|
{
|
|
RDLC = "IDCardBothSidePrint.rdlc";
|
|
bytes = new AttendanceReport().ShowEmpCardInfoPerPage(sEmpIDs, authorizedPerson, RDLC, true, expireYear, issueDate, reportCategory);
|
|
}
|
|
else if (reportCategory == 3)
|
|
{
|
|
RDLC = "IDCardPrintBangla.rdlc";
|
|
bytes = new AttendanceReport().ShowEmpCardInfoPerPageBangla(sEmpIDs, authorizedPerson, RDLC, true, expireYear, issueDate);
|
|
}
|
|
else if (reportCategory == 4)
|
|
{
|
|
RDLC = "IDCardBothSidePrintBangla.rdlc";
|
|
bytes = new AttendanceReport().ShowEmpCardInfoPerPageBangla(sEmpIDs, authorizedPerson, RDLC, true, expireYear, issueDate);
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getUpComingConfirmationEmployee")]
|
|
public ActionResult getUpComingConfirmationEmployee(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
int dayCount = (int)items["dayCount"].ToObject<int>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptEmployee().GetUpCommingEmpConfirmationForRekit(reportType, fromDate, dayCount, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getOtMonthRange")]
|
|
public ActionResult getOtMonthRange(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
DateTime toDate = (DateTime)items["toDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new OTReport().OTMonthRange(reportType, fromDate, PayrollGlobalFunctions.PayrollLastDateOfMonth(toDate), (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getOtBranchWise")]
|
|
public ActionResult getOtBranchWise(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new OTReport().OTBranchWise(reportType, fromDate, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getOtDivisionWise")]
|
|
public ActionResult getOtDivisionWise(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
DateTime fromYear = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new OTReport().OTLocationWise(reportType, fromYear, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getPRBCalculationSGS")]
|
|
public ActionResult getPRBCalculationSGS(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int empId = (int)items["employeeId"].ToObject<int>();
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
DateTime prbYear = (DateTime)items["prbYear"].ToObject<DateTime>();
|
|
bytes = new rptBonus().PRBBonusCalculation(empId, prbYear);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
|
|
}
|
|
|
|
[HttpGet("getMaternityLeaveReport/{id}")]
|
|
public ActionResult getMaternityLeaveReport(int id)
|
|
{
|
|
//var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
//int empId = (int)items["employeeId"].ToObject<int>();
|
|
|
|
MaternityLeave maternityLeave = new MaternityLeaveService().Get(id);
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new rptLeave().GetMaternityLeaveReport(maternityLeave, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpGet("showTaxCardMaternityLeave/{employeeId}")]
|
|
public ActionResult showTaxCardMaternityLeave(int employeeId)
|
|
{
|
|
//var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
//int employeeId = (int)items["employeeId"].ToObject<int>();
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
bytes = new RptIncomeTax().showTaxCard(employeeId, true, currentUser.TaxParamID.GetValueOrDefault(), currentUser.TaxParamID.GetValueOrDefault(), currentUser.NextPayProcessDate.GetValueOrDefault(), (int)currentUser.PayrollTypeID, "PDF");
|
|
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
|
|
}
|
|
[HttpPost("getPFLedgerDataForReport")]
|
|
public ActionResult getPFLedgerDataForReport(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
int sEmpID = (int)items["empID"].ToObject<int>();
|
|
DateTime fromDate = (DateTime)items["fromDate"].ToObject<DateTime>();
|
|
DateTime toDate = (DateTime)items["toDate"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().GetPFLedger(sEmpID, reportType, fromDate, toDate, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getPFExceptionReport")]
|
|
public ActionResult getPFExceptionReport(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
string sEmpID = (string)items["empIds"].ToObject<string>();
|
|
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().getPFExceptionReport(sEmpID, reportType, (int)currentUser.PayrollTypeID);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
|
|
|
|
[HttpPost("getCandidateInterviewAssesment")]
|
|
public ActionResult getCandidateInterviewAssesment(dynamic data)
|
|
{
|
|
InterviewSession obs = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
int interviewSessionId = (int)items["interviewSessionId"].ToObject<int>();
|
|
byte[] bytes = null;
|
|
try
|
|
{
|
|
obs = new RecruitementProcessService().GetInterveiwSessionReport(interviewSessionId);
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
rptCandidateInfo rptcInfo = new rptCandidateInfo();
|
|
bytes = rptcInfo.GetCandidatedata(obs, payrollTypeId);
|
|
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, ex.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getCCWiseSalarySummary")]
|
|
public ActionResult getCCWiseSalarySummary(dynamic data)
|
|
{
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
bool nonexpat = (bool)items["nonexpat"].ToObject<bool>();
|
|
DateTime salaryMonth = (DateTime)items["salaryMonth"].ToObject<DateTime>();
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
try
|
|
{
|
|
bytes = new rptHnm().CCWiseSalarySummary((int)currentUser.PayrollTypeID, reportType, nonexpat, salaryMonth);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getPMSReportData/{pmpYearID}/{pmsReportType}")]
|
|
public ActionResult getPMSReportData(int pmpYearID, int pmsReportType, List<SearchEmployee> emps)
|
|
{
|
|
DataSet ds = new DataSet();
|
|
|
|
try
|
|
{
|
|
ds = new ObjectiveService().getPMSReportData(pmpYearID, pmsReportType, SearchEmployee.getEmpID(emps));
|
|
//switch (pmsReportType)
|
|
//{
|
|
// case 1:
|
|
// break;
|
|
// case 2:
|
|
// break;
|
|
// default:
|
|
// break;
|
|
//}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(ds.Tables[0]);
|
|
}
|
|
|
|
[HttpPost("getAttendanceReport/{reportType}")]
|
|
public ActionResult getAttendanceReport(List<dynamic> data, string reportType)
|
|
{
|
|
var json = JsonConvert.SerializeObject(data);
|
|
DataTable dataTable = (DataTable)JsonConvert.DeserializeObject(json, (typeof(DataTable)));
|
|
|
|
byte[] bytes = null;
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
ReportProcessor reportProcessor = new ReportProcessor();
|
|
|
|
try
|
|
{
|
|
bytes = reportProcessor.getAttendanceReport(null, dataTable, payrollTypeId, reportType);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
[HttpPost("getProfileReportData")]
|
|
public ActionResult getProfileReportData(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
EnumProfileReportType reportid = (EnumProfileReportType)items["reportID"].ToObject<int>();
|
|
int personID = 0;
|
|
int employeeID = 0;
|
|
|
|
if (items["personID"] != null)
|
|
personID = (int)items["personID"].ToObject<int>();
|
|
if (items["employeeID"] != null)
|
|
employeeID = (int)items["employeeID"].ToObject<int>();
|
|
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
byte[] bytes = null;
|
|
|
|
LetterTemplte ltemplate = new LetterTemplte();
|
|
|
|
try
|
|
{
|
|
|
|
switch (reportid)
|
|
{
|
|
case EnumProfileReportType.Print_CV:
|
|
bytes = new rptEmployee().GetEmployeeCV(employeeID, payrollTypeId, reportType);
|
|
break;
|
|
case EnumProfileReportType.Employee_Service_Book:
|
|
break;
|
|
case EnumProfileReportType.Appointment_Letter_Officer:
|
|
bytes = new rptEmployee().GetAsstOfficeAndAbove(employeeID, payrollTypeId, reportType);
|
|
break;
|
|
case EnumProfileReportType.Appointment_Letter_Worker:
|
|
break;
|
|
case EnumProfileReportType.Appointment_Letter_Staff:
|
|
break;
|
|
default:
|
|
break;
|
|
|
|
}
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost("getGeneratedProfileReport")]
|
|
public ActionResult getGeneratedProfileReportData(dynamic data)
|
|
{
|
|
CurrentUser currentUser = CurrentUser.GetCurrentUser(HttpContext.User);
|
|
var items = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
EnumProfileReportType reportid = (EnumProfileReportType)items["reportID"].ToObject<int>();
|
|
int personID = 0;
|
|
int employeeID = 0;
|
|
|
|
if (items["personID"] != null)
|
|
personID = (int)items["personID"].ToObject<int>();
|
|
if (items["employeeID"] != null)
|
|
employeeID = (int)items["employeeID"].ToObject<int>();
|
|
|
|
string reportType = (string)items["reportType"].ToObject<string>();
|
|
|
|
int payrollTypeId = currentUser.PayrollTypeID.GetValueOrDefault();
|
|
byte[] bytes = null;
|
|
|
|
LetterTemplte ltemplate = new LetterTemplte();
|
|
|
|
try
|
|
{
|
|
//string downloadPath = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile) + @"\Downloads";
|
|
string downloadPath = System.Environment.CurrentDirectory + "\\Documents\\LetterTempFolder\\";
|
|
string sFilePath = string.Empty, lFileName = string.Empty;
|
|
|
|
switch (reportid)
|
|
{
|
|
case EnumProfileReportType.Appointment_Letter_Worker:
|
|
ltemplate.SetObjectID(FixedLetterTemplte.Worker_Appointment_Letter);
|
|
|
|
ltemplate.ID = 3;
|
|
ltemplate.Description = "Letter Template Worker";
|
|
ltemplate.Subject = "Letter Template Worker";
|
|
ltemplate.Type = EnumDocType.Desktop_Letter;
|
|
ltemplate.TypeID = (int)EnumDocType.Desktop_Letter;
|
|
|
|
lFileName = "Worker.doc";
|
|
|
|
sFilePath = new rptEmployee().Generate(ltemplate, employeeID, payrollTypeId, downloadPath, lFileName);
|
|
break;
|
|
case EnumProfileReportType.Appointment_Letter_Staff:
|
|
ltemplate.SetObjectID(FixedLetterTemplte.Staff_Appointment_Letter);
|
|
|
|
ltemplate.ID = 2;
|
|
ltemplate.Description = "Letter Template Staff";
|
|
ltemplate.Subject = "Letter Template Staff";
|
|
ltemplate.Type = EnumDocType.Desktop_Letter;
|
|
ltemplate.TypeID = (int)EnumDocType.Desktop_Letter;
|
|
|
|
lFileName = "Staff.doc";
|
|
|
|
sFilePath = new rptEmployee().Generate(ltemplate, employeeID, payrollTypeId, downloadPath, lFileName);
|
|
break;
|
|
default:
|
|
break;
|
|
|
|
}
|
|
|
|
byte[] buffer = new byte[16 * 1024];
|
|
buffer = System.IO.File.ReadAllBytes(sFilePath);
|
|
string contentType = GetFileType(sFilePath);
|
|
var name = System.IO.Path.ChangeExtension(lFileName, ".pdf");
|
|
if (System.IO.File.Exists(sFilePath))
|
|
{
|
|
System.IO.File.Delete(sFilePath);
|
|
}
|
|
if (System.IO.File.Exists(System.IO.Path.ChangeExtension(sFilePath, ".doc")))
|
|
{
|
|
System.IO.File.Delete(System.IO.Path.ChangeExtension(sFilePath, ".doc"));
|
|
}
|
|
return File(buffer, contentType, name);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
return StatusCode(StatusCodes.Status500InternalServerError, e.Message);
|
|
}
|
|
|
|
return Ok(bytes);
|
|
}
|
|
|
|
[HttpPost]
|
|
[Route("get-file-type")]
|
|
[AllowAnonymous]
|
|
[IgnoreAntiforgeryToken]
|
|
[ProducesResponseType(StatusCodes.Status200OK)]
|
|
public string GetFileType(string originalFileName)
|
|
{
|
|
//var item = Newtonsoft.Json.JsonConvert.DeserializeObject(Convert.ToString(data));
|
|
//string fileName = (string)item["fileName"].ToObject<string>();
|
|
string fileName = originalFileName;
|
|
string contentType;
|
|
new FileExtensionContentTypeProvider().TryGetContentType(fileName, out contentType);
|
|
return contentType ?? "application/octet-stream";
|
|
}
|
|
}
|
|
}
|