1469 lines
55 KiB
C#
1469 lines
55 KiB
C#
using System;
|
|
using System.Linq;
|
|
using System.Data;
|
|
using System.Collections.Generic;
|
|
using Ease.Core.Model;
|
|
using System.IO;
|
|
using Ease.Core.Utility;
|
|
using System.Text.RegularExpressions;
|
|
|
|
namespace HRM.BO
|
|
{
|
|
|
|
public class DefaultConfigurationValue
|
|
{
|
|
|
|
public DefaultConfigurationValue()
|
|
{
|
|
|
|
}
|
|
public DefaultConfigurationValue(int _roundDigit, string _dayFractionType, bool _isMidPointRound)
|
|
{
|
|
roundOfDigit = _roundDigit;
|
|
DayFactionType = _dayFractionType;
|
|
IsMidPointRound = _isMidPointRound;
|
|
|
|
}
|
|
public int roundOfDigit { get; }
|
|
|
|
public string DayFactionType { get; }
|
|
public bool IsMidPointRound { get; }
|
|
|
|
}
|
|
|
|
|
|
public class GlobalFunctions
|
|
{
|
|
private static DefaultConfigurationValue _defaultConfigVal;
|
|
public static bool bDataFound = false;
|
|
public static DefaultConfigurationValue defaultConfigVal
|
|
{
|
|
get
|
|
{
|
|
if (_defaultConfigVal == null)
|
|
{
|
|
_defaultConfigVal = GlobalFunctions.Service.RefreshServerValue();
|
|
}
|
|
return _defaultConfigVal;
|
|
}
|
|
|
|
set
|
|
{
|
|
_defaultConfigVal = value;
|
|
}
|
|
}
|
|
|
|
#region Service Factory IGlobalFunctionService : IGlobalFunctionService
|
|
|
|
internal static IGlobalFunctionService Service
|
|
{
|
|
get { return Services.Factory.CreateService<IGlobalFunctionService>(typeof(IGlobalFunctionService)); }
|
|
}
|
|
|
|
public static int MONTH_START_DATE { get; set; }
|
|
|
|
#endregion
|
|
|
|
|
|
public static string GetApiDefaultData(string str)
|
|
{
|
|
str = (str == "" || str == "null" || str == "undefined") ? string.Empty : str;
|
|
return str;
|
|
}
|
|
|
|
public static int? GetApiDefaultIntData(string str)
|
|
{
|
|
int? intData = null; ;
|
|
if (str != null && str != "" && str.ToLower() != "null" && str.ToLower() != "undefined")
|
|
{
|
|
intData = Convert.ToInt32(str);
|
|
}
|
|
return intData;
|
|
}
|
|
|
|
|
|
public static DateTime GetApiDefaultDateData(string str)
|
|
{
|
|
DateTime dateData = DateTime.MinValue;
|
|
if (str != null && str != "" && str.ToLower() != "null" && str.ToLower() != "undefined")
|
|
{
|
|
dateData = Convert.ToDateTime(str);
|
|
}
|
|
return dateData;
|
|
}
|
|
|
|
public static string AgeCalculate(DateTime Bday, DateTime Cday)
|
|
{
|
|
int Years = 0;
|
|
int Months = 0;
|
|
int Days = 0;
|
|
|
|
if ((Cday.Year - Bday.Year) > 0 ||
|
|
(((Cday.Year - Bday.Year) == 0) && ((Bday.Month < Cday.Month) ||
|
|
((Bday.Month == Cday.Month) && (Bday.Day <= Cday.Day)))))
|
|
{
|
|
int DaysInBdayMonth = DateTime.DaysInMonth(Bday.Year, Bday.Month);
|
|
int DaysRemain = Cday.Day + (DaysInBdayMonth - Bday.Day);
|
|
|
|
if (Cday.Month > Bday.Month)
|
|
{
|
|
Years = Cday.Year - Bday.Year;
|
|
Months = Cday.Month - (Bday.Month + 1) + Math.Abs(DaysRemain / DaysInBdayMonth);
|
|
Days = (DaysRemain % DaysInBdayMonth + DaysInBdayMonth) % DaysInBdayMonth;
|
|
}
|
|
else if (Cday.Month == Bday.Month)
|
|
{
|
|
if (Cday.Day >= Bday.Day)
|
|
{
|
|
Years = Cday.Year - Bday.Year;
|
|
Months = 0;
|
|
Days = Cday.Day - Bday.Day;
|
|
}
|
|
else
|
|
{
|
|
Years = (Cday.Year - 1) - Bday.Year;
|
|
Months = 11;
|
|
Days = DateTime.DaysInMonth(Bday.Year, Bday.Month) - (Bday.Day - Cday.Day);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
Years = (Cday.Year - 1) - Bday.Year;
|
|
Months = Cday.Month + (11 - Bday.Month) + Math.Abs(DaysRemain / DaysInBdayMonth);
|
|
Days = (DaysRemain % DaysInBdayMonth + DaysInBdayMonth) % DaysInBdayMonth;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
throw new ArgumentException("Birthday date must be earlier than current date");
|
|
}
|
|
|
|
return Years + " Years, " + Months + " Months, " + Days + " Days";
|
|
}
|
|
|
|
//public static DateTime GetOperationDate()
|
|
//{
|
|
// try
|
|
// {
|
|
// return Service.GetOperationDate();
|
|
// }
|
|
// catch (ServiceException e)
|
|
// {
|
|
// throw new Exception(e.Message, e);
|
|
// }
|
|
//}
|
|
public static string GetShortAttnType(EnumAttendanceType atype, EnumWorkPlanDayType daytype, double latehour)
|
|
{
|
|
string type = string.Empty;
|
|
switch (atype)
|
|
{
|
|
case EnumAttendanceType.Absent:
|
|
type = "AB";
|
|
break;
|
|
|
|
case EnumAttendanceType.Delay:
|
|
type = "LP";
|
|
break;
|
|
|
|
case EnumAttendanceType.Holiday:
|
|
type = "H";
|
|
break;
|
|
|
|
case EnumAttendanceType.Late:
|
|
type = "LP";
|
|
break;
|
|
|
|
case EnumAttendanceType.Leave:
|
|
type = "Lv";
|
|
break;
|
|
|
|
case EnumAttendanceType.Present:
|
|
type = "PR";
|
|
|
|
if (daytype == EnumWorkPlanDayType.WorkingDay &&
|
|
latehour > 0)
|
|
{
|
|
type = "L-PR";
|
|
}
|
|
else if (daytype == EnumWorkPlanDayType.WeeklyHoliday
|
|
&& latehour > 0)
|
|
{
|
|
type = "WD-L-PR";
|
|
|
|
}
|
|
else if (daytype == EnumWorkPlanDayType.WeeklyHoliday &&
|
|
latehour <= 0)
|
|
{
|
|
type = "WD-PR";
|
|
}
|
|
else if (daytype == EnumWorkPlanDayType.NationalHoliday &&
|
|
latehour > 0)
|
|
{
|
|
type = "H-L-PR";
|
|
|
|
}
|
|
else if (daytype == EnumWorkPlanDayType.NationalHoliday &&
|
|
latehour <= 0)
|
|
{
|
|
type = "H-PR";
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
case EnumAttendanceType.OutSideDuty:
|
|
type = "OD";
|
|
break;
|
|
|
|
case EnumAttendanceType.Early:
|
|
type = "E";
|
|
break;
|
|
|
|
case EnumAttendanceType.WeeklyHoliday:
|
|
type = "WD";
|
|
break;
|
|
}
|
|
return type;
|
|
}
|
|
|
|
public static double GetHourtoMinutes(double hours)
|
|
{
|
|
return Math.Floor(hours) * ((hours - Math.Floor(hours))/100);
|
|
}
|
|
|
|
public static double GetOTDailyRate(double nBasic, DateTime dMonthDate)
|
|
{
|
|
double amount = 0;
|
|
amount = nBasic / Convert.ToDouble(DateTime.DaysInMonth(dMonthDate.Year, dMonthDate.Month));
|
|
return amount;
|
|
}
|
|
|
|
public static double GetOTHourlyRate(double nBasic, DateTime dMonthDate)
|
|
{
|
|
double amount = 0;
|
|
int hours = 0;//ConfigurationManager.GetIntValue("overtime", "hoursonmonth", EnumConfigurationType.Logic);
|
|
if (hours <= 0) hours = 208;
|
|
double doubleHOur = Convert.ToDouble(hours);
|
|
amount = nBasic / doubleHOur;
|
|
return amount;
|
|
|
|
}
|
|
public static double ConvertToDailyRate(double nBasic, DateTime dMonthDate)
|
|
{
|
|
enumfractionCalculatinType ntype = getFractionateCalType();
|
|
double amount = 0;
|
|
|
|
switch (ntype)
|
|
{
|
|
case enumfractionCalculatinType.Monthly:
|
|
amount = nBasic / Convert.ToDouble(DateTime.DaysInMonth(dMonthDate.Year, dMonthDate.Month));
|
|
break;
|
|
case enumfractionCalculatinType.Yearly:
|
|
amount = (nBasic * 12) / 365;
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonth:
|
|
case enumfractionCalculatinType.ThirtyDaysMonthActual:
|
|
amount = nBasic / 30;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return amount;
|
|
}
|
|
|
|
public static int GetDaysInMonth(DateTime dMonthDate)
|
|
{
|
|
enumfractionCalculatinType ntype = getFractionateCalType();
|
|
int amount = 0;
|
|
|
|
switch (ntype)
|
|
{
|
|
case enumfractionCalculatinType.Monthly:
|
|
amount = DateTime.DaysInMonth(dMonthDate.Year, dMonthDate.Month);
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonthActual:
|
|
case enumfractionCalculatinType.ThirtyDaysMonth:
|
|
amount = 30;
|
|
break;
|
|
default:
|
|
amount = 30;
|
|
break;
|
|
}
|
|
return amount;
|
|
}
|
|
|
|
public static string ConvertDoubleHourToHourMinute(double totalHour)
|
|
{
|
|
string[] strParts = totalHour.ToString("0.000000").Split('.');
|
|
strParts[1] = "." + strParts[1];
|
|
|
|
string hourPart = Convert.ToInt32(strParts[0]).ToString("00");
|
|
string minutepart = Math.Round(Convert.ToDecimal(strParts[1]) * 60, 0, MidpointRounding.AwayFromZero).ToString("00");
|
|
|
|
return string.Format("{0}:{1}", hourPart, minutepart);
|
|
}
|
|
public static string GetShortAttnType(EnumAttendanceType attnType)
|
|
{
|
|
string type = string.Empty;
|
|
switch (attnType)
|
|
{
|
|
case EnumAttendanceType.Absent:
|
|
type = "A";
|
|
break;
|
|
|
|
case EnumAttendanceType.Delay:
|
|
type = "L";
|
|
break;
|
|
|
|
case EnumAttendanceType.Holiday:
|
|
type = "H";
|
|
break;
|
|
|
|
case EnumAttendanceType.Late:
|
|
type = "L";
|
|
break;
|
|
|
|
case EnumAttendanceType.Leave:
|
|
type = "Lv";
|
|
break;
|
|
|
|
case EnumAttendanceType.Present:
|
|
type = "P";
|
|
break;
|
|
|
|
|
|
case EnumAttendanceType.OutSideDuty:
|
|
type = "OD";
|
|
break;
|
|
|
|
case EnumAttendanceType.Early:
|
|
type = "E";
|
|
break;
|
|
|
|
case EnumAttendanceType.WeeklyHoliday:
|
|
type = "W";
|
|
break;
|
|
}
|
|
return type;
|
|
}
|
|
|
|
public static string BloodGroupToBangla(EnumBloodGroup eBloodGrp)
|
|
{
|
|
string str = string.Empty;
|
|
switch (eBloodGrp)
|
|
{
|
|
case EnumBloodGroup.None:
|
|
break;
|
|
case EnumBloodGroup.APos:
|
|
str = "G cwRwUf";
|
|
break;
|
|
case EnumBloodGroup.ANeg:
|
|
str = "G ‡b‡MwUf";
|
|
break;
|
|
case EnumBloodGroup.BPos:
|
|
str = "we cwRwUf";
|
|
break;
|
|
case EnumBloodGroup.BNeg:
|
|
str = "we ‡b‡MwUf";
|
|
break;
|
|
case EnumBloodGroup.OPos:
|
|
str = "I cwRwUf";
|
|
break;
|
|
case EnumBloodGroup.ONeg:
|
|
str = "I ‡b‡MwUf";
|
|
break;
|
|
case EnumBloodGroup.ABPos:
|
|
str = "Gwe cwRwUf";
|
|
break;
|
|
case EnumBloodGroup.ABNeg:
|
|
str = "Gwe ‡b‡MwUf";
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return str;
|
|
}
|
|
|
|
public static string GetFullAttnType(EnumAttendanceType attnType)
|
|
{
|
|
Regex r = new Regex(@"(?<=[A-Z])(?=[A-Z][a-z])|(?<=[^A-Z])(?=[A-Z])|(?<=[A-Za-z])(?=[^A-Za-z])");
|
|
return r.Replace(attnType.ToString(), " ");
|
|
}
|
|
|
|
//public static DateTime AttendanceMonthStart(DateTime date)
|
|
//{
|
|
// if (date.Day > 20)
|
|
// return new DateTime(date.Year, date.Month, 21);
|
|
// else if (date.Month == 1)
|
|
// return new DateTime(date.Year - 1, 12, 21);
|
|
// else return new DateTime(date.Year, date.AddMonths(-1).Month, 21);
|
|
//}
|
|
//public static DateTime AttendanceMonthEnd(DateTime date)
|
|
//{
|
|
// if (date.Day < 20)
|
|
// return new DateTime(date.Year, date.Month, 20);
|
|
// else
|
|
// if (date.Month == 12)
|
|
// return new DateTime(date.Year + 1, 1, 20);
|
|
// else return new DateTime(date.Year, date.AddMonths(1).Month, 20);
|
|
//}
|
|
|
|
//public static DateTime GetServerDate()
|
|
//{
|
|
// object serverDate = null;
|
|
// try
|
|
// {
|
|
// serverDate = Service.GetServerDate();
|
|
// }
|
|
// catch (ServiceException e)
|
|
// {
|
|
// throw new ServiceException(e.Message, e);
|
|
// }
|
|
// return Convert.ToDateTime(serverDate);
|
|
//}
|
|
//public static DataTable AvailableUserObject()
|
|
//{
|
|
// DataTable dataTable = new DataTable();
|
|
// try
|
|
// {
|
|
// dataTable = Service.AvailableUserObject();
|
|
// }
|
|
// catch (ServiceException e)
|
|
// {
|
|
// throw new ServiceException(e.Message, e);
|
|
// }
|
|
// return dataTable;
|
|
//}
|
|
|
|
public static string TagSQL(string sPrevious, string sNew)
|
|
{
|
|
string sSearch = string.Empty;
|
|
if (sPrevious == string.Empty)
|
|
{
|
|
return sSearch = " Where " + sNew;
|
|
}
|
|
else
|
|
{
|
|
return sSearch = sPrevious + " And " + sNew;
|
|
}
|
|
|
|
}
|
|
|
|
public static void ExportToExcel(StreamWriter wr, DataTable dt)
|
|
{
|
|
try
|
|
{
|
|
for (int i = 0; i < dt.Columns.Count; i++)
|
|
{
|
|
wr.Write(dt.Columns[i].ToString().ToUpper() + "\t");
|
|
}
|
|
|
|
wr.WriteLine();
|
|
|
|
//write rows to excel file
|
|
for (int i = 0; i < (dt.Rows.Count); i++)
|
|
{
|
|
for (int j = 0; j < dt.Columns.Count; j++)
|
|
{
|
|
if (dt.Rows[i][j] != null)
|
|
{
|
|
wr.Write(Convert.ToString(dt.Rows[i][j]) + "\t");
|
|
}
|
|
else
|
|
{
|
|
wr.Write("\t");
|
|
}
|
|
}
|
|
//go to next line
|
|
wr.WriteLine();
|
|
}
|
|
//close file
|
|
wr.Close();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw ex;
|
|
}
|
|
}
|
|
public static int GetDayofWeek(DateTime FromDate, DateTime ToDate, int day)
|
|
{
|
|
int i;
|
|
DateTime dateTemp;
|
|
i = 0;
|
|
|
|
dateTemp = FromDate;
|
|
|
|
|
|
while (dateTemp <= ToDate)
|
|
{
|
|
if (((int)dateTemp.DayOfWeek == day)) i = i + 1;
|
|
dateTemp = dateTemp.AddDays(1);
|
|
}
|
|
|
|
return i;
|
|
}
|
|
public static DateTime GetAttandaceSalaryMonth(DateTime dDate)
|
|
{
|
|
return GetAttandaceSalaryMonth(dDate, -1);
|
|
|
|
}
|
|
public static DateTime GetAttandaceSalaryMonth(DateTime dDate, int MonthStartDate)
|
|
{
|
|
if (MonthStartDate == 1) // Fisrt date of Current Month
|
|
{
|
|
return Global.DateFunctions.LastDateOfMonth(dDate);
|
|
}
|
|
else if (MonthStartDate == -1) // Fisrt date of Current Month
|
|
{
|
|
dDate = dDate.AddMonths(-1);
|
|
return Global.DateFunctions.LastDateOfMonth(dDate.AddMonths(1));
|
|
}
|
|
else
|
|
{
|
|
if (dDate.Day >= MonthStartDate)
|
|
return Global.DateFunctions.LastDateOfMonth(dDate.AddMonths(1));
|
|
else return Global.DateFunctions.LastDateOfMonth(dDate);
|
|
}
|
|
}
|
|
|
|
|
|
public static DateTime AttendanceMonthStart(DateTime date, int MonthStartDate)
|
|
{
|
|
if (MonthStartDate == 1) // Fisrt date of Current Month
|
|
{
|
|
return new DateTime(date.Year, date.Month, 1);
|
|
}
|
|
else if (MonthStartDate == -1) // Fisrt date of Current Month
|
|
{
|
|
date = date.AddMonths(-1);
|
|
return new DateTime(date.Year, date.Month, 1);
|
|
}
|
|
else
|
|
{
|
|
if (date.Day > MonthStartDate)
|
|
return new DateTime(date.Year, date.Month, MonthStartDate);
|
|
else if (date.Month == 1)
|
|
return new DateTime(date.Year - 1, 12, MonthStartDate);
|
|
else return new DateTime(date.Year, date.AddMonths(-1).Month, MonthStartDate);
|
|
}
|
|
}
|
|
public static DateTime AttendanceMonthEnd(DateTime date, int MonthStartDate)
|
|
{
|
|
if (MonthStartDate == 1) // Fisrt date of Current Month
|
|
{
|
|
return Global.DateFunctions.LastDateOfMonth(date);
|
|
}
|
|
else if (MonthStartDate == -1) // Fisrt date of Current Month
|
|
{
|
|
date = date.AddMonths(-1);
|
|
return Global.DateFunctions.LastDateOfMonth(date);
|
|
}
|
|
else
|
|
{
|
|
if (date.Day < MonthStartDate)
|
|
return new DateTime(date.Year, date.Month, MonthStartDate);
|
|
else
|
|
if (date.Month == 12)
|
|
return new DateTime(date.Year + 1, 1, MonthStartDate);
|
|
else return new DateTime(date.Year, date.AddMonths(1).Month, MonthStartDate);
|
|
}
|
|
}
|
|
|
|
//public static DateTime GetCurrentDate()
|
|
//{
|
|
// object currentDate = null;
|
|
// try
|
|
// {
|
|
// currentDate = Service.GetCurrentDate();
|
|
// }
|
|
// catch (ServiceException e)
|
|
// {
|
|
// throw new ServiceException(e.Message, e);
|
|
// }
|
|
// return Convert.ToDateTime(currentDate);
|
|
//}
|
|
|
|
//private static ErrorProvider _err = new ErrorProvider();
|
|
|
|
//public static void CatchError(Control ctrl, string msg)
|
|
//{
|
|
// _err.Clear();
|
|
// _err.BlinkRate = 250;
|
|
// _err.BlinkStyle = ErrorBlinkStyle.BlinkIfDifferentError;
|
|
// _err.SetError(ctrl, msg);
|
|
//}
|
|
|
|
|
|
public static double Round(double value)
|
|
{
|
|
double roundedValue = 0.00;
|
|
try
|
|
{
|
|
|
|
|
|
roundedValue = Math.Round(value, GetRoundOfDigit(), MidpointRounding.AwayFromZero);
|
|
// roundedValue = Math.Round(value,2, MidpointRounding.AwayFromZero);
|
|
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new ServiceException(ex.InnerException.Message);
|
|
}
|
|
|
|
return roundedValue;
|
|
}
|
|
|
|
public static double Round(double value, int roundofdegit)
|
|
{
|
|
double roundedValue = 0.00;
|
|
try
|
|
{
|
|
roundedValue = Math.Round(value, GetRoundOfDigit(roundofdegit), MidpointRounding.AwayFromZero);
|
|
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new ServiceException(ex.InnerException.Message);
|
|
}
|
|
|
|
return roundedValue;
|
|
}
|
|
|
|
public static double ConvertToHourlyRate(double nBasic)
|
|
{
|
|
double amount = 0;
|
|
int hours = 0;//ConfigurationManager.GetIntValue("overtime", "hoursonmonth", EnumConfigurationType.Logic);
|
|
if (hours <= 0) hours = 208;
|
|
double doubleHOur = Convert.ToDouble(hours);
|
|
amount = nBasic / doubleHOur;
|
|
return amount;
|
|
}
|
|
|
|
public static enumfractionCalculatinType getFractionateCalType()
|
|
{
|
|
enumfractionCalculatinType type = enumfractionCalculatinType.Monthly;
|
|
string caltype = GlobalFunctions.defaultConfigVal.DayFactionType; //ConfigurationManager.GetStringValue("root", "monthfraction", EnumConfigurationType.Logic);
|
|
if (caltype.ToUpper() == "THIRTYDAYS")
|
|
type = enumfractionCalculatinType.ThirtyDaysMonth;
|
|
else if (caltype.ToUpper() == "THIRTYDAYSACTUAL")
|
|
type = enumfractionCalculatinType.ThirtyDaysMonthActual;
|
|
else if (caltype.ToUpper() == "YEARLY")
|
|
type = enumfractionCalculatinType.Yearly;
|
|
else
|
|
type = enumfractionCalculatinType.Monthly;
|
|
return type;
|
|
}
|
|
//public static int GetdaysInMonth(DateTime dMonth)
|
|
//{
|
|
// int daysinMonth = 30;
|
|
// enumfractionCalculatinType type = enumfractionCalculatinType.Monthly;
|
|
// string caltype = GlobalFunctions.defaultConfigVal.DayFactionType; //ConfigurationManager.GetStringValue("root", "monthfraction", EnumConfigurationType.Logic);
|
|
// if (caltype.ToUpper() == "THIRTYDAYS")
|
|
// daysinMonth = 30;
|
|
// else
|
|
// daysinMonth = GlobalFunctions.FirstDateOfMonth(dMonth) - GlobalFunctions.LastDateOfMonth(dMonth)
|
|
// return type;
|
|
//}
|
|
|
|
public static double GetFraction(DateTime StartDate, DateTime EndDate)
|
|
{
|
|
double WorkDays;
|
|
double MonDays;
|
|
double TotFract;
|
|
double nFraction = 1;
|
|
TotFract = 0;
|
|
// bool isYearly = ConfigurationManager.GetBoolValue("root", "fractionalcalculationyearly", EnumConfigurationType.Logic);
|
|
//bool isYearly = ConfigurationManager.GetBoolValue("root", "fractionalcalculation", EnumConfigurationType.Logic);
|
|
enumfractionCalculatinType ntype = getFractionateCalType();
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
switch (ntype)
|
|
{
|
|
case enumfractionCalculatinType.Monthly:
|
|
while (StartDate <= EndDate)
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
MonDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(StartDate),
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
if (StartDate.Month == EndDate.Month && EndDate != GlobalFunctions.LastDateOfMonth(EndDate))
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(EndDate), EndDate) + 1;
|
|
}
|
|
TotFract = TotFract + WorkDays / MonDays;
|
|
StartDate = GlobalFunctions.LastDateOfMonth(StartDate).AddDays(1);
|
|
}
|
|
nFraction = TotFract;
|
|
break;
|
|
case enumfractionCalculatinType.Yearly:
|
|
//0.032876712328767123287671232876712
|
|
//0.0328767123
|
|
//if (StartDate == GlobalFunctions.FirstDateOfMonth(StartDate) && EndDate == GlobalFunctions.LastDateOfMonth(EndDate))
|
|
//{
|
|
// WorkDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("m", StartDate, EndDate) + 1;
|
|
// nFraction = WorkDays;
|
|
//}
|
|
//else
|
|
//{
|
|
// WorkDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d", StartDate, EndDate) + 1;
|
|
// double yearlyFraction = 0.0328767123; // which mean 12/365
|
|
|
|
// nFraction = yearlyFraction * WorkDays;
|
|
//}
|
|
nFraction = 0;
|
|
if (Global.DateFunctions.DateDiff("m", GlobalFunctions.FirstDateOfMonth(StartDate),
|
|
GlobalFunctions.LastDateOfMonth(EndDate)) > 2)
|
|
{
|
|
nFraction = Global.DateFunctions.DateDiff("m", GlobalFunctions.FirstDateOfMonth(StartDate.AddMonths(1)),
|
|
GlobalFunctions.LastDateOfMonth(EndDate.AddMonths(-1)));
|
|
|
|
nFraction = nFraction + (Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1) * 0.0328767123;
|
|
nFraction = nFraction + (Global.DateFunctions.DateDiff("d", GlobalFunctions.FirstDateOfMonth(EndDate),
|
|
EndDate) + 1) * 0.0328767123;
|
|
}
|
|
else
|
|
{
|
|
if (StartDate.Month == EndDate.Month && StartDate.Year == EndDate.Year) // if cross two month
|
|
{
|
|
if (StartDate == FirstDateOfMonth(StartDate) && EndDate == LastDateOfMonth(EndDate))
|
|
nFraction = 1;
|
|
else
|
|
nFraction = nFraction + (Global.DateFunctions.DateDiff("d", StartDate,
|
|
EndDate) + 1) * 0.0328767123;
|
|
}
|
|
else
|
|
{
|
|
if (StartDate == FirstDateOfMonth(StartDate) && EndDate == LastDateOfMonth(EndDate))
|
|
nFraction = 1;
|
|
else
|
|
nFraction = nFraction + (Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1) * 0.0328767123;
|
|
|
|
if (EndDate == LastDateOfMonth(EndDate))
|
|
nFraction = nFraction + 1;
|
|
else nFraction = nFraction + (Global.DateFunctions.DateDiff("d", GlobalFunctions.FirstDateOfMonth(EndDate),
|
|
EndDate) + 1) * 0.0328767123;
|
|
}
|
|
}
|
|
//while (StartDate <= EndDate)
|
|
//{
|
|
// if (StartDate.Day != 1 )
|
|
// {
|
|
// nFraction = nFraction + ((double)(Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(EndDate), EndDate) + 1)) * 0.0328767123;
|
|
// }
|
|
// WorkDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d", StartDate,
|
|
// GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
// MonDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(StartDate),
|
|
// GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
// if (StartDate.Month == EndDate.Month && EndDate != GlobalFunctions.LastDateOfMonth(EndDate))
|
|
// {
|
|
// nFraction = nFraction + ((double) (Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(EndDate), EndDate) + 1)) * 0.0328767123;
|
|
// }
|
|
// TotFract = TotFract + WorkDays / MonDays;
|
|
// StartDate = GlobalFunctions.LastDateOfMonth(StartDate).AddDays(1);
|
|
//}
|
|
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonth:
|
|
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
while (StartDate <= EndDate)
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
|
|
MonDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(StartDate), GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(StartDate),
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
else if (tempDaya < 30)
|
|
if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
else WorkDays = WorkDays + 1;
|
|
|
|
MonDays = 30;
|
|
|
|
|
|
if (StartDate.Month == EndDate.Month && EndDate != GlobalFunctions.LastDateOfMonth(EndDate))
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(EndDate), EndDate) + 1;
|
|
MonDays = 30;
|
|
}
|
|
TotFract = TotFract + WorkDays / MonDays;
|
|
StartDate = GlobalFunctions.LastDateOfMonth(StartDate).AddDays(1);
|
|
}
|
|
nFraction = TotFract;
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonthActual:
|
|
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
while (StartDate <= EndDate)
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d", StartDate,
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
|
|
MonDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(StartDate), GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(StartDate),
|
|
GlobalFunctions.LastDateOfMonth(StartDate)) + 1;
|
|
//if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
//else if (tempDaya < 30)
|
|
// if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
// else WorkDays = WorkDays + 1;
|
|
|
|
MonDays = 30;
|
|
|
|
|
|
if (StartDate.Month == EndDate.Month && EndDate != GlobalFunctions.LastDateOfMonth(EndDate))
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(EndDate), EndDate) + 1;
|
|
MonDays = 30;
|
|
}
|
|
double temp = WorkDays / MonDays;
|
|
if (temp > 1) temp = 1;
|
|
TotFract = TotFract + temp;
|
|
StartDate = GlobalFunctions.LastDateOfMonth(StartDate).AddDays(1);
|
|
}
|
|
nFraction = TotFract;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return nFraction;
|
|
}
|
|
|
|
private static int GetRoundOfDigit()
|
|
{
|
|
int RoundofDigit = 2;
|
|
try
|
|
{
|
|
if (RoundofDigit != -1)
|
|
{
|
|
//####
|
|
RoundofDigit = GlobalFunctions.defaultConfigVal.roundOfDigit; // ConfigurationManager.GetIntValue("root", "roundofdegit", EnumConfigurationType.Logic);
|
|
if (RoundofDigit > 4 || RoundofDigit < 0)
|
|
{
|
|
RoundofDigit = -1;
|
|
throw new ServiceException("Round of digit not greater 4 digit. Location: "
|
|
+ "logic-Configuration; Node:Root, Child-Node:RoundOfDegit, Value:" + RoundofDigit.ToString());
|
|
}
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new ServiceException(ex.InnerException.Message);
|
|
}
|
|
|
|
return RoundofDigit;
|
|
}
|
|
private static int GetRoundOfDigit(int roundofDigit)
|
|
{
|
|
|
|
try
|
|
{
|
|
if (roundofDigit > 4 || roundofDigit < 0)
|
|
{
|
|
roundofDigit = -1;
|
|
throw new ServiceException("Round of digit not greater 4 digit. Location: "
|
|
+ "logic-Configuration; Node:Root, Child-Node:RoundOfDegit, Value:" + roundofDigit.ToString());
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new ServiceException(ex.InnerException.Message);
|
|
}
|
|
|
|
return roundofDigit;
|
|
}
|
|
|
|
|
|
public static double GetFractinalOfMonth(DateTime dDate)
|
|
{
|
|
double WorkDays;
|
|
double TotalDays;
|
|
double nFraction = 1;
|
|
WorkDays = Global.DateFunctions.DateDiff("d", dDate,
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
// bool isYearly = ConfigurationManager.GetBoolValue("root", "fractionalcalculationyearly", EnumConfigurationType.Logic);
|
|
enumfractionCalculatinType ntype = getFractionateCalType();
|
|
switch (ntype)
|
|
{
|
|
case enumfractionCalculatinType.Monthly:
|
|
TotalDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
nFraction = (WorkDays / TotalDays);
|
|
break;
|
|
case enumfractionCalculatinType.Yearly:
|
|
double yearlyFraction = 0.0328767123; // which mean 12/365
|
|
if (dDate.Day == 1) // if date is first of month, fractionate should be 1
|
|
nFraction = 1;
|
|
else
|
|
nFraction = yearlyFraction * WorkDays;
|
|
if (nFraction > 1) nFraction = 1; // monthly fraction can't greater 1,
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonth:
|
|
if (dDate == LastDateOfMonth(dDate))
|
|
return 1;
|
|
else
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d", dDate,
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(dDate),
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
else if (tempDaya < 30)
|
|
if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
else WorkDays = WorkDays + 1;
|
|
TotalDays = 30;
|
|
// TotalDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate));
|
|
nFraction = (WorkDays / TotalDays);
|
|
}
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonthActual:
|
|
if (dDate == LastDateOfMonth(dDate))
|
|
return 1;
|
|
else
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d", dDate,
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(dDate),
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
//if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
//else if (tempDaya < 30)
|
|
// if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
// else WorkDays = WorkDays + 1;
|
|
TotalDays = 30;
|
|
// TotalDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate));
|
|
nFraction = (WorkDays / TotalDays);
|
|
}
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return nFraction;
|
|
}
|
|
public static double GetFractinalOfTillDate(DateTime dDate)
|
|
{
|
|
double WorkDays;
|
|
double TotalDays;
|
|
double nFraction = 1;
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(dDate), dDate) + 1;
|
|
enumfractionCalculatinType ntype = getFractionateCalType();
|
|
switch (ntype)
|
|
{
|
|
case enumfractionCalculatinType.Monthly:
|
|
TotalDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
nFraction = (WorkDays / TotalDays);
|
|
break;
|
|
case enumfractionCalculatinType.Yearly:
|
|
double yearlyFraction = 0.0328767123; // which mean 12/365
|
|
if (WorkDays == dDate.Day)
|
|
nFraction = 1;
|
|
else
|
|
nFraction = yearlyFraction * WorkDays;
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonth:
|
|
if (dDate == FirstDateOfMonth(dDate))
|
|
return 1;
|
|
else
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(dDate), dDate) + 1;
|
|
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(dDate),
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
else if (tempDaya < 30)
|
|
if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
else WorkDays = WorkDays + 1;
|
|
|
|
TotalDays = 30;
|
|
// TotalDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate));
|
|
nFraction = (WorkDays / TotalDays);
|
|
}
|
|
break;
|
|
case enumfractionCalculatinType.ThirtyDaysMonthActual:
|
|
if (dDate == FirstDateOfMonth(dDate))
|
|
return 1;
|
|
else
|
|
{
|
|
WorkDays = Global.DateFunctions.DateDiff("d",
|
|
GlobalFunctions.FirstDateOfMonth(dDate), dDate) + 1;
|
|
|
|
int tempDaya = Global.DateFunctions.DateDiff("d", FirstDateOfMonth(dDate),
|
|
GlobalFunctions.LastDateOfMonth(dDate)) + 1;
|
|
//if (tempDaya == 31) WorkDays = WorkDays - 1;
|
|
//else if (tempDaya < 30)
|
|
// if (tempDaya == 28) WorkDays = WorkDays + 2;
|
|
// else WorkDays = WorkDays + 1;
|
|
|
|
TotalDays = 30;
|
|
// TotalDays = Ease.CoreV35.Utility.Global.DateFunctions.DateDiff("d",
|
|
// GlobalFunctions.FirstDateOfMonth(dDate), GlobalFunctions.LastDateOfMonth(dDate));
|
|
nFraction = (WorkDays / TotalDays);
|
|
}
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return nFraction;
|
|
}
|
|
|
|
|
|
|
|
//public static DateTime GetYearEnd()
|
|
//{
|
|
// object yearEndDate = null;
|
|
// try
|
|
// {
|
|
// yearEndDate = Service.GetYearEndDate();
|
|
// }
|
|
// catch (ServiceException e)
|
|
// {
|
|
// throw new ServiceException(e.Message, e);
|
|
// }
|
|
// return Convert.ToDateTime(yearEndDate);
|
|
//}
|
|
|
|
|
|
public static DateTime FirstDateOfMonth(DateTime date)
|
|
{
|
|
return Global.DateFunctions.FirstDateOfMonth(date);
|
|
}
|
|
public static string GetShortAttnType(EnumAttendanceType attnType,
|
|
ref int presentDays, ref int absentDays, ref int lateDays,
|
|
ref int leaveDays, ref int weeklyHolidays, ref int osdDays,
|
|
ref int festivalHolidays)
|
|
{
|
|
string type = string.Empty;
|
|
switch (attnType)
|
|
{
|
|
case EnumAttendanceType.Absent:
|
|
type = "AB";
|
|
absentDays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Delay:
|
|
type = "LP";
|
|
lateDays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Holiday:
|
|
type = "FH";
|
|
festivalHolidays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Late:
|
|
type = "LP";
|
|
lateDays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Leave:
|
|
type = "Lv";
|
|
leaveDays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Present:
|
|
type = "PR";
|
|
presentDays++;
|
|
break;
|
|
|
|
|
|
case EnumAttendanceType.OutSideDuty:
|
|
type = "OD";
|
|
osdDays++;
|
|
break;
|
|
|
|
case EnumAttendanceType.Early:
|
|
type = "E";
|
|
break;
|
|
|
|
case EnumAttendanceType.WeeklyHoliday:
|
|
type = "WD";
|
|
weeklyHolidays++;
|
|
break;
|
|
}
|
|
return type;
|
|
}
|
|
public static string GetLeaveType(int? ReferenceID, List<Leave> _leaves)
|
|
{
|
|
string leaveType = "Lv";
|
|
Leave leave = null;
|
|
if (ReferenceID != 0)
|
|
{
|
|
leave = new Leave();
|
|
leave = _leaves.Where(o => o.ID == ReferenceID).FirstOrDefault();
|
|
if (leave != null)
|
|
{
|
|
leaveType = leave.Code;
|
|
}
|
|
}
|
|
|
|
return leaveType;
|
|
}
|
|
//return Total Hour and Minutes In string Format(Hour.Minutes)
|
|
public static string GetHourMinutes(List<String> hours)
|
|
{
|
|
string HoursMinutes = string.Empty;
|
|
double hour = 0;
|
|
double minutes = 0;
|
|
foreach (String hr in hours)
|
|
{
|
|
//string[] x = hr.ToString("f").Split('.');
|
|
//string xx = hr.ToString();
|
|
if (hr.Contains(":"))
|
|
{
|
|
hour = hour + Convert.ToDouble(hr.Split(':')[0]);
|
|
if (hr.Split('.').Length > 1)
|
|
minutes = minutes + Convert.ToDouble(hr.Split(':')[1]);
|
|
}
|
|
else
|
|
{
|
|
hour = hour + Convert.ToDouble(hr.Split('.')[0]);
|
|
if(hr.Split('.').Length >1)
|
|
minutes = minutes + Convert.ToDouble(hr.Split('.')[1]);
|
|
}
|
|
|
|
}
|
|
|
|
if (minutes > 60)
|
|
{
|
|
//int hr = Convert.ToInt32(minutes) / 60;
|
|
long hr = Convert.ToInt64(minutes) / 60;
|
|
hour = hour + Convert.ToDouble(hr);
|
|
minutes = minutes % 60;
|
|
}
|
|
|
|
return HoursMinutes = Convert.ToString(hour) + ":" + minutes.ToString("00");
|
|
|
|
}
|
|
|
|
public static string TakaFormat(double _Number)
|
|
{
|
|
//Written by Shaila
|
|
string _sign = "";
|
|
string _NumStr;
|
|
string _TakaFormat;
|
|
|
|
if (_Number < 0)
|
|
{
|
|
_sign = "-";
|
|
_Number = (-_Number);
|
|
}
|
|
|
|
_NumStr = _Number.ToString("0.00");
|
|
_TakaFormat = Right(_NumStr, 6);
|
|
if ((_NumStr.Length) <= 6)
|
|
{
|
|
_NumStr = "";
|
|
}
|
|
else
|
|
_NumStr = Left(_NumStr, _NumStr.Length - 6);
|
|
|
|
if (_NumStr == "")
|
|
{
|
|
_TakaFormat = _sign + _TakaFormat;
|
|
return _TakaFormat;
|
|
}
|
|
|
|
int _CommaCount = 1;
|
|
int _DigitCount = 0;
|
|
|
|
do
|
|
{
|
|
if (_CommaCount % 3 == 0)
|
|
{
|
|
_DigitCount = 3;
|
|
}
|
|
else
|
|
_DigitCount = 2;
|
|
|
|
|
|
_TakaFormat = Right(_NumStr, _DigitCount) + "," + _TakaFormat;
|
|
|
|
if (_NumStr.Length <= _DigitCount)
|
|
{
|
|
_NumStr = "";
|
|
}
|
|
else
|
|
_NumStr = Left(_NumStr, _NumStr.Length - _DigitCount);
|
|
|
|
|
|
_CommaCount = _CommaCount + 1;
|
|
} //end do
|
|
while (_NumStr != "");
|
|
_TakaFormat = _sign + _TakaFormat;
|
|
return _TakaFormat;
|
|
|
|
} //End of TakaFormat
|
|
|
|
public static string Right(string _Str, int _Len)
|
|
{
|
|
//Written by Shaila
|
|
string sStr;
|
|
|
|
if (_Len < _Str.Length)
|
|
{
|
|
sStr = _Str.Substring(_Str.Length - _Len, _Len);
|
|
}
|
|
else
|
|
sStr = _Str;
|
|
return sStr;
|
|
} //EndofRight
|
|
|
|
public static string Left(string _Str, int _Len)
|
|
{
|
|
//Written by Shaila
|
|
string sStr;
|
|
if (_Len < _Str.Length)
|
|
{
|
|
sStr = _Str.Substring(0, _Len);
|
|
}
|
|
else
|
|
sStr = _Str;
|
|
return sStr;
|
|
} //EndofLeft
|
|
|
|
public static string GetHourMinutes(double hours)
|
|
{
|
|
var ts = TimeSpan.FromHours(hours);
|
|
return string.Format("{0}:{1}", ts.Hours, ts.Minutes);
|
|
|
|
}
|
|
public static DateTime LastPayProcessDate(DateTime nextPayProcessDate)
|
|
{
|
|
return Global.DateFunctions.LastDateOfMonth(nextPayProcessDate.AddMonths(-1));
|
|
}
|
|
|
|
public static DateTime LastDateOfMonth(DateTime date)
|
|
{
|
|
return Global.DateFunctions.LastDateOfMonth(date);
|
|
}
|
|
|
|
|
|
|
|
public static String NumWordsWrapper(double value)
|
|
{
|
|
string words = "";
|
|
double intPart;
|
|
double decPart = 0;
|
|
if (value == 0)
|
|
return "zero";
|
|
|
|
try
|
|
{
|
|
string[] splitter = value.ToString().Split('.');
|
|
intPart = double.Parse(splitter[0]);
|
|
if (splitter.Length > 1)
|
|
{
|
|
decPart = double.Parse(splitter[1]);
|
|
}
|
|
}
|
|
catch
|
|
{
|
|
intPart = value;
|
|
}
|
|
|
|
words = NumWords(Convert.ToInt32(intPart));
|
|
|
|
if (decPart > 0)
|
|
{
|
|
if (words != "")
|
|
words += " and ";
|
|
int counter = decPart.ToString().Length;
|
|
switch (counter)
|
|
{
|
|
case 1: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// tenths
|
|
case 2: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// hundredths
|
|
case 3: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// thousandths
|
|
case 4: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// ten-thousandths
|
|
case 5: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// hundred-thousandths
|
|
case 6: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// millionths
|
|
case 7: words += NumWords(Convert.ToInt32(decPart)) + ""; break;// ten-millionths
|
|
}
|
|
}
|
|
return words + " Taka Only";
|
|
}
|
|
|
|
private static string NumWords(int Num)
|
|
{
|
|
#region Old Code
|
|
//string[] numbersArr = new string[] { "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen" };
|
|
//string[] tensArr = new string[] { "twenty", "thirty", "fourty", "fifty", "sixty", "seventy", "eighty", "ninty" };
|
|
//string[] suffixesArr = new string[] { "thousand", "million", "billion", "trillion", "quadrillion", "quintillion", "sextillion", "septillion", "octillion", "nonillion", "decillion", "undecillion", "duodecillion", "tredecillion", "Quattuordecillion", "Quindecillion", "Sexdecillion", "Septdecillion", "Octodecillion", "Novemdecillion", "Vigintillion" };
|
|
//string words = "";
|
|
|
|
//bool tens = false;
|
|
|
|
//if (n < 0)
|
|
//{
|
|
// words += "negative ";
|
|
// n *= -1;
|
|
//}
|
|
|
|
//int power = (suffixesArr.Length + 1) * 3;
|
|
|
|
//while (power > 3)
|
|
//{
|
|
// double pow = Math.Pow(10, power);
|
|
// if (n > pow)
|
|
// {
|
|
// if (n % Math.Pow(10, power) > 0)
|
|
// {
|
|
// words += NumWords(Math.Floor(n / pow)) + " " + suffixesArr[(power / 3) - 1] + " and ";
|
|
// }
|
|
// else if (n % pow > 0)
|
|
// {
|
|
// words += NumWords(Math.Floor(n / pow)) + " " + suffixesArr[(power / 3) - 1];
|
|
// }
|
|
// n %= pow;
|
|
// }
|
|
// power -= 3;
|
|
//}
|
|
//if (n >= 1000)
|
|
//{
|
|
// if (n % 1000 > 0) words += NumWords(Math.Floor(n / 1000)) + " thousand and ";
|
|
// else words += NumWords(Math.Floor(n / 1000)) + " thousand";
|
|
// n %= 1000;
|
|
//}
|
|
//if (0 <= n && n <= 999)
|
|
//{
|
|
// if ((int)n / 100 > 0)
|
|
// {
|
|
// words += NumWords(Math.Floor(n / 100)) + " hundred";
|
|
// n %= 100;
|
|
// }
|
|
// if ((int)n / 10 > 1)
|
|
// {
|
|
// if (words != "")
|
|
// words += " ";
|
|
// words += tensArr[(int)n / 10 - 2];
|
|
// tens = true;
|
|
// n %= 10;
|
|
// }
|
|
|
|
// if (n < 20)
|
|
// {
|
|
// if (words != "" && tens == false)
|
|
// words += " ";
|
|
// words += (tens ? "-" + numbersArr[(int)n - 1] : numbersArr[(int)n - 1]);
|
|
// n -= Math.Floor(n);
|
|
// }
|
|
//}
|
|
|
|
//return words;
|
|
#endregion
|
|
string[] Below20 = { "", "One ", "Two ", "Three ", "Four ",
|
|
"Five ", "Six " , "Seven ", "Eight ", "Nine ", "Ten ", "Eleven ",
|
|
"Twelve " , "Thirteen ", "Fourteen ","Fifteen ",
|
|
"Sixteen " , "Seventeen ","Eighteen " , "Nineteen " };
|
|
string[] Below100 = { "", "", "Twenty ", "Thirty ",
|
|
"Forty ", "Fifty ", "Sixty ", "Seventy ", "Eighty ", "Ninety " };
|
|
string InWords = "";
|
|
if (Num >= 1 && Num < 20)
|
|
InWords += Below20[Num];
|
|
if (Num >= 20 && Num <= 99)
|
|
InWords += Below100[Num / 10] + Below20[Num % 10];
|
|
if (Num >= 100 && Num <= 999)
|
|
InWords += NumWords(Num / 100) + " Hundred " + NumWords(Num % 100);
|
|
if (Num >= 1000 && Num <= 99999)
|
|
InWords += NumWords(Num / 1000) + " Thousand " + NumWords(Num % 1000);
|
|
if (Num >= 100000 && Num <= 9999999)
|
|
InWords += NumWords(Num / 100000) + " Lac " + NumWords(Num % 100000);
|
|
if (Num >= 10000000)
|
|
InWords += NumWords(Num / 10000000) + " Crore " + NumWords(Num % 10000000);
|
|
|
|
return InWords;
|
|
}
|
|
public static string MillionToInWords(int no)
|
|
{
|
|
if (no == 0)
|
|
return "zero";
|
|
|
|
if (no < 0)
|
|
return "minus " + MillionToInWords(Math.Abs(no));
|
|
|
|
string stringValue = "";
|
|
|
|
if ((no / 1000000) > 0)
|
|
{
|
|
stringValue += MillionToInWords(no / 1000000) + " million ";
|
|
no %= 1000000;
|
|
}
|
|
|
|
if ((no / 1000) > 0)
|
|
{
|
|
stringValue += MillionToInWords(no / 1000) + " thousand ";
|
|
no %= 1000;
|
|
}
|
|
|
|
if ((no / 100) > 0)
|
|
{
|
|
stringValue += MillionToInWords(no / 100) + " hundred ";
|
|
no %= 100;
|
|
}
|
|
|
|
if (no > 0)
|
|
{
|
|
if (stringValue != "")
|
|
stringValue += "and ";
|
|
|
|
var units = new[] { "zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen" };
|
|
var tens = new[] { "zero", "ten", "twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety" };
|
|
|
|
if (no < 20)
|
|
stringValue += units[no];
|
|
else
|
|
{
|
|
stringValue += tens[no / 10];
|
|
if ((no % 10) > 0)
|
|
stringValue += "-" + units[no % 10];
|
|
}
|
|
}
|
|
|
|
return stringValue;
|
|
}
|
|
}
|
|
|
|
|
|
#region Interface IGlobalFunctionService
|
|
|
|
public interface IGlobalFunctionService
|
|
{
|
|
DateTime GetOperationDate();
|
|
//DateTime GetServerDate();
|
|
//DataTable AvailableUserObject();
|
|
|
|
//DateTime GetCurrentDate();
|
|
|
|
//DateTime GetYearEndDate();
|
|
DefaultConfigurationValue RefreshServerValue();
|
|
|
|
}
|
|
|
|
#endregion
|
|
}
|