Int64 IMDLeaveCategoryDataAccess.Add(MDLeaveCategoryEntity mDLeaveCategoryEntity, DatabaseOperationType option, TransactionRequired reqTran)
        {
            try
            {
                long retValues = -99;

                switch (reqTran)
                {
                case TransactionRequired.No:
                {
                    retValues = Add(mDLeaveCategoryEntity, option);
                    break;
                }

                case TransactionRequired.Yes:
                {
                    retValues = AddTran(mDLeaveCategoryEntity, option);
                    break;
                }

                default:
                {
                    retValues = -99;
                    break;
                }
                }

                return(retValues);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        private void CalculateLeave()
        {
            if (chbxFilter.Checked)
            {
                HREmployeeEntity            hREmployeeEntity      = FCCHREmployee.GetFacadeCreate().GetByID(Int64.Parse(ddlEmployeeID.SelectedValue));
                ACFiscalYearEntity          aCFiscalYearEntity    = FCCACFiscalYear.GetFacadeCreate().GetByID(Int64.Parse(ddlFiscalYearID.SelectedValue));
                MDLeaveCategoryEntity       mDLeaveCategoryEntity = FCCMDLeaveCategory.GetFacadeCreate().GetByID(Int64.Parse(ddlLeaveCategoryID.SelectedValue));
                IList <MDLeavePolicyEntity> mDLeavePolicyList     = FCCMDLeavePolicy.GetFacadeCreate().GetIL(1000, 1, String.Empty, String.Empty, DatabaseOperationType.Load);
                Decimal leaveInDays = 0;
                if (mDLeavePolicyList.Count > 0 && mDLeavePolicyList != null)
                {
                    mDLeavePolicyList[0] = mDLeavePolicyList.Single(x => (x.LeaveCategoryID == mDLeaveCategoryEntity.LeaveCategoryID && x.FiscalYearID == aCFiscalYearEntity.FiscalYearID && x.EmployeeJobTypeID == hREmployeeEntity.EmployeeJobTypeID));

                    if (mDLeavePolicyList[0].LeaveCategoryID == mDLeaveCategoryEntity.LeaveCategoryID && mDLeavePolicyList[0].FiscalYearID == aCFiscalYearEntity.FiscalYearID)
                    {
                        leaveInDays = mDLeavePolicyList[0].LeaveInDays;
                    }

                    if (hREmployeeEntity.EmployeeJobTypeID == MasterDataConstants.MDEmployeeJobType.FULLTIME && hREmployeeEntity.ConfirmDate <= aCFiscalYearEntity.BeginDate)
                    {
                        txtEarnedDays.Text = leaveInDays.ToString().Trim();;
                    }
                    else if (hREmployeeEntity.EmployeeJobTypeID == MasterDataConstants.MDEmployeeJobType.PARTTIMENOTLESS75PERCENT)
                    {
                        txtEarnedDays.Text = leaveInDays.ToString().Trim();
                    }
                    else if (hREmployeeEntity.EmployeeJobTypeID == MasterDataConstants.MDEmployeeJobType.FULLTIME && hREmployeeEntity.ConfirmDate == null)
                    {
                        txtEarnedDays.Text = "0.0";
                    }
                    else if (hREmployeeEntity.EmployeeJobTypeID == MasterDataConstants.MDEmployeeJobType.PARTTIMENOTLESS50PERCENT)
                    {
                        txtEarnedDays.Text = leaveInDays.ToString().Trim();
                    }
                    else if (hREmployeeEntity.EmployeeJobTypeID == MasterDataConstants.MDEmployeeJobType.FULLTIME && (hREmployeeEntity.ConfirmDate <= aCFiscalYearEntity.BeginDate && hREmployeeEntity.ConfirmDate >= aCFiscalYearEntity.EndDate))
                    {
                        DateTime s = aCFiscalYearEntity.EndDate;
                        DateTime e = (DateTime)hREmployeeEntity.ConfirmDate;

                        Decimal Month = s.Subtract(e).Days / (365 / 12);
                        Month = (leaveInDays / 12) * Month;
                        txtEarnedDays.Text = Month.ToString().Trim();;
                    }
                    else
                    {
                        txtEarnedDays.Text = "0";
                    }
                }
                else
                {
                    MiscUtil.ShowMessage(lblMessage, "There is no policy in this fiscal year and may be not active please insert data in Leave Policy.", false);
                }
            }
            else
            {
                txtEarnedDays.Text = String.Empty;
            }
        }
Ejemplo n.º 3
0
        private MDLeaveCategoryEntity BuildMDLeaveCategoryEntity()
        {
            MDLeaveCategoryEntity mDLeaveCategoryEntity = CurrentMDLeaveCategoryEntity;

            mDLeaveCategoryEntity.Name      = txtName.Text.Trim();
            mDLeaveCategoryEntity.IsRemoved = chkIsRemoved.Checked;


            return(mDLeaveCategoryEntity);
        }
Ejemplo n.º 4
0
        private void SaveMDLeaveCategoryEntity()
        {
            if (IsValid)
            {
                try
                {
                    MDLeaveCategoryEntity mDLeaveCategoryEntity = BuildMDLeaveCategoryEntity();

                    Int64 result = -1;

                    if (mDLeaveCategoryEntity.IsNew)
                    {
                        result = FCCMDLeaveCategory.GetFacadeCreate().Add(mDLeaveCategoryEntity, DatabaseOperationType.Add, TransactionRequired.No);
                    }
                    else
                    {
                        String filterExpression = SqlExpressionBuilder.PrepareFilterExpression(MDLeaveCategoryEntity.FLD_NAME_LeaveCategoryID, mDLeaveCategoryEntity.LeaveCategoryID.ToString(), SQLMatchType.Equal);
                        result = FCCMDLeaveCategory.GetFacadeCreate().Update(mDLeaveCategoryEntity, filterExpression, DatabaseOperationType.Update, TransactionRequired.No);
                    }

                    if (result > 0)
                    {
                        _LeaveCategoryID       = 0;
                        _MDLeaveCategoryEntity = new MDLeaveCategoryEntity();
                        PrepareInitialView();
                        BindMDLeaveCategoryList();

                        if (mDLeaveCategoryEntity.IsNew)
                        {
                            MiscUtil.ShowMessage(lblMessage, "Leave Category Information has been added successfully.", false);
                        }
                        else
                        {
                            MiscUtil.ShowMessage(lblMessage, "Leave Category Information has been updated successfully.", false);
                        }
                    }
                    else
                    {
                        if (mDLeaveCategoryEntity.IsNew)
                        {
                            MiscUtil.ShowMessage(lblMessage, "Failed to add Leave Category Information.", false);
                        }
                        else
                        {
                            MiscUtil.ShowMessage(lblMessage, "Failed to update Leave Category Information.", false);
                        }
                    }
                }
                catch (Exception ex)
                {
                    MiscUtil.ShowMessage(lblMessage, ex.Message, true);
                }
            }
        }
        private Int64 UpdateTran(MDLeaveCategoryEntity mDLeaveCategoryEntity, String filterExpression, DatabaseOperationType option)
        {
            long         returnCode = -99;
            const string SP         = "dbo.MDLeaveCategory_SET";

            Database db = DatabaseFactory.CreateDatabase();

            using (DbCommand cmd = db.GetStoredProcCommand(SP))
            {
                AddOptionParameter(cmd, option, db);
                AddOutputParameter(cmd, db);
                AddFilterExpressionParameter(cmd, filterExpression, db);

                db.AddInParameter(cmd, "@LeaveCategoryID", DbType.Int64, mDLeaveCategoryEntity.LeaveCategoryID);
                db.AddInParameter(cmd, "@Name", DbType.String, mDLeaveCategoryEntity.Name);
                db.AddInParameter(cmd, "@IsRemoved", DbType.Boolean, mDLeaveCategoryEntity.IsRemoved);

                DbConnection connection = db.CreateConnection();
                connection.Open();
                DbTransaction transaction = connection.BeginTransaction();

                try
                {
                    using (IDataReader reader = db.ExecuteReader(cmd, transaction))
                    {
                        returnCode = GetReturnCodeFromParameter(cmd);
                    }

                    if (returnCode > 0)
                    {
                        transaction.Commit();
                    }
                    else
                    {
                        throw new ArgumentException("Error Code." + returnCode.ToString());
                    }
                }
                catch (Exception ex)
                {
                    transaction.Rollback();
                    throw ex;
                }
                finally
                {
                    transaction.Dispose();
                    connection.Close();
                    connection = null;
                }
            }

            return(returnCode);
        }
Ejemplo n.º 6
0
        protected void lvMDLeaveCategory_ItemCommand(object sender, ListViewCommandEventArgs e)
        {
            Int64 LeaveCategoryID;

            Int64.TryParse(e.CommandArgument.ToString(), out LeaveCategoryID);

            if (LeaveCategoryID > 0)
            {
                if (string.Equals(e.CommandName, "EditItem"))
                {
                    _LeaveCategoryID = LeaveCategoryID;

                    PrepareEditView();

                    cpeEditor.Collapsed   = false;
                    cpeEditor.ClientState = "false";
                }
                else if (string.Equals(e.CommandName, "DeleteItem"))
                {
                    try
                    {
                        Int64 result = -1;

                        String fe = SqlExpressionBuilder.PrepareFilterExpression(MDLeaveCategoryEntity.FLD_NAME_LeaveCategoryID, LeaveCategoryID.ToString(), SQLMatchType.Equal);

                        MDLeaveCategoryEntity mDLeaveCategoryEntity = new MDLeaveCategoryEntity();


                        result = FCCMDLeaveCategory.GetFacadeCreate().Delete(mDLeaveCategoryEntity, fe, DatabaseOperationType.Delete, TransactionRequired.No);

                        if (result == 0)
                        {
                            _LeaveCategoryID       = 0;
                            _MDLeaveCategoryEntity = new MDLeaveCategoryEntity();
                            PrepareInitialView();
                            BindMDLeaveCategoryList();

                            MiscUtil.ShowMessage(lblMessage, "Leave Category has been successfully deleted.", true);
                        }
                        else
                        {
                            MiscUtil.ShowMessage(lblMessage, "Failed to delete Leave Category.", true);
                        }
                    }
                    catch (Exception ex)
                    {
                        MiscUtil.ShowMessage(lblMessage, ex.Message, true);
                    }
                }
            }
        }
Ejemplo n.º 7
0
        private void PrepareEditView()
        {
            MDLeaveCategoryEntity mDLeaveCategoryEntity = CurrentMDLeaveCategoryEntity;


            if (!mDLeaveCategoryEntity.IsNew)
            {
                txtName.Text         = mDLeaveCategoryEntity.Name.ToString();
                chkIsRemoved.Checked = mDLeaveCategoryEntity.IsRemoved;

                btnSubmit.Text    = "Update";
                btnAddNew.Visible = true;
            }
        }
        private Int64 Update(MDLeaveCategoryEntity mDLeaveCategoryEntity, String filterExpression, DatabaseOperationType option)
        {
            long         returnCode = -99;
            const string SP         = "dbo.MDLeaveCategory_SET";

            using (DbCommand cmd = Database.GetStoredProcCommand(SP))
            {
                AddOptionParameter(cmd, option);
                AddOutputParameter(cmd);
                AddFilterExpressionParameter(cmd, filterExpression);

                Database.AddInParameter(cmd, "@LeaveCategoryID", DbType.Int64, mDLeaveCategoryEntity.LeaveCategoryID);
                Database.AddInParameter(cmd, "@Name", DbType.String, mDLeaveCategoryEntity.Name);
                Database.AddInParameter(cmd, "@IsRemoved", DbType.Boolean, mDLeaveCategoryEntity.IsRemoved);

                using (IDataReader reader = Database.ExecuteReader(cmd))
                {
                    returnCode = GetReturnCodeFromParameter(cmd);

                    switch (returnCode)
                    {
                    case SqlConstants.DB_STATUS_CODE_DATAALREADYEXIST:
                    {
                        throw new ArgumentException("MDLeaveCategoryEntity already exists. Please specify another MDLeaveCategoryEntity.");
                    }

                    case SqlConstants.DB_STATUS_CODE_DATAUPDATEDFROMOTHERSESSION:
                    {
                        throw new ArgumentException("MDLeaveCategoryEntity data already updated from different session.");
                    }

                    case SqlConstants.DB_STATUS_CODE_FAIL_OPERATION:
                    {
                        throw new ArgumentException("MDLeaveCategoryEntity already exists. Please specify another MDLeaveCategoryEntity.");
                    }
                    }
                }
            }

            return(returnCode);
        }
Ejemplo n.º 9
0
 protected void btnAddNew_Click(object sender, EventArgs e)
 {
     _LeaveCategoryID       = 0;
     _MDLeaveCategoryEntity = new MDLeaveCategoryEntity();
     PrepareInitialView();
 }
Ejemplo n.º 10
0
 Int64 IMDLeaveCategoryFacade.Delete(MDLeaveCategoryEntity mDLeaveCategoryEntity, String filterExpression, DatabaseOperationType option, TransactionRequired reqTran)
 {
     return(DataAccessFactory.CreateMDLeaveCategoryDataAccess().Delete(mDLeaveCategoryEntity, filterExpression, option, reqTran));
 }
Ejemplo n.º 11
0
 Int64 IMDLeaveCategoryFacade.Add(MDLeaveCategoryEntity mDLeaveCategoryEntity, DatabaseOperationType option, TransactionRequired reqTran)
 {
     return(DataAccessFactory.CreateMDLeaveCategoryDataAccess().Add(mDLeaveCategoryEntity, option, reqTran));
 }