public DataTable New() { myCreditPkg.NCreditPackageID = -1; DataTable table = myCreditPkg.SelectOne(); DataRow row = table.NewRow(); row["dtLastEditDate"] = ACMS.Convert.ToDateTime(System.DateTime.Today); row["dtPurchaseDate"] = ACMS.Convert.ToDateTime(System.DateTime.Today); row["nEmployeeID"] = User.EmployeeID; row["nStatusID"] = 0; table.Rows.Add(row); return(table); }
public void DeleteCreditPackageUsage(int nPackageID) { int nCreditPackageID; TblServiceSession ssUsage = new TblServiceSession(); ssUsage.NPackageID = nPackageID; DataTable tblUsage = ssUsage.SelectAllWnPackageIDLogic(); if (tblUsage.Rows.Count > 0) { throw new Exception("You Cant deleted a Used Package."); } TblMemberPackage mmbPckg = new TblMemberPackage(); mmbPckg.NPackageID = nPackageID; DataTable table = mmbPckg.SelectOne(); if (table == null || table.Rows.Count == 0) { throw new Exception("The Data has been deleted from database."); } mmbPckg.NStatusID = 2; mmbPckg.Update(); nCreditPackageID = mmbPckg.NCreditPackageID.Value; //Check any package redeemed from this credit package ACMSDAL.TblMemberPackage memberPackage = new TblMemberPackage(); string cmdText = "Select COUNT(*) from TblMemberPackage Where (nStatusID = 0 or nStatusID = 1) AND " + " nCreditPackageID = @nCreditPackageID "; int nExist = (int)memberPackage.ExecuteScalar(cmdText, new string [] { "@nCreditPackageID" }, new object[] { nCreditPackageID }); if (nExist == 0) { TblMemberCreditPackage creditPackage = new TblMemberCreditPackage(); creditPackage.NCreditPackageID = nCreditPackageID; creditPackage.SelectOne(); creditPackage.DtStartDate = SqlDateTime.Null; creditPackage.DtExpiryDate = SqlDateTime.Null; creditPackage.Update(); } }
public DataTable GetPrintBalanceTable(int nCreditPackageID) { TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); memberCreditPackage.NCreditPackageID = nCreditPackageID; DataTable table = memberCreditPackage.SelectOne(); TblCreditPackage creditPackage = new TblCreditPackage(); creditPackage.StrCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; creditPackage.SelectOne(); decimal creditPackageValue = ACMS.Convert.ToDecimal(creditPackage.MCreditAmount); decimal mmbCreditPackageTopupAmt = ACMS.Convert.ToDecimal(memberCreditPackage.MTopupAmount); decimal totalCreditUsage = GetCreditUsageFromMemberPackage(nCreditPackageID); decimal balance = (creditPackageValue + mmbCreditPackageTopupAmt) - totalCreditUsage; DataTable tableToReturn = new DataTable(); DataColumn colCreditPackageID = new DataColumn("nCreditPackageID", System.Type.GetType("System.Int32")); DataColumn colBalance = new DataColumn("Balance", System.Type.GetType("System.Decimal")); DataColumn colExpiryDate = new DataColumn("ExpiryDate", System.Type.GetType("System.DateTime")); tableToReturn.Columns.Add(colBalance); tableToReturn.Columns.Add(colCreditPackageID); tableToReturn.Columns.Add(colExpiryDate); DataRow r = tableToReturn.NewRow(); r["nCreditPackageID"] = nCreditPackageID; r["Balance"] = balance; r["ExpiryDate"] = memberCreditPackage.DtExpiryDate.Value; return(tableToReturn); }
private void TopUpCreditPackage(ACMSDAL.ConnectionProvider connProvider, ACMSLogic.POS pos) { if (pos.NCategoryID == 18) { TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); memberCreditPackage.MainConnectionProvider = connProvider; foreach (DataRow r in pos.ReceiptItemsTable.Rows) { int nCreditPackageID = ACMS.Convert.ToInt32(r["strCode"]); memberCreditPackage.NCreditPackageID = nCreditPackageID; memberCreditPackage.SelectOne(); memberCreditPackage.MTopupAmount = ACMS.Convert.ToDecimal(memberCreditPackage.MTopupAmount) + ACMS.Convert.ToDecimal(r["mSubTotal"]); memberCreditPackage.Update(); } } }
/// <summary> /// Use Member Credit Package means use the credit to buy the package and then store in the tblMemberPackage /// be aware some package is not allow to purchase using credit package. Must check tblCreditPackageRestriction /// </summary> /// <returns></returns> public string[,] UseMemberCreditPackage(string[,] strPackageCode, int nCreditPackageID, string strSignID, string strSigKey, string strPdfExportPath, string remark) { //ACMSDAL.ConnectionProvider connProvider = new ConnectionProvider(); DataRow[] rows, row1s = new DataRow[strPackageCode.Length / 2]; string[,] strUsage = new string[strPackageCode.Length / 2, 3]; //DataColumn[] dc = new DataColumn["Usage",System.Type.GetType("System.Int")]; try { TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); //connProvider.OpenConnection(); //connProvider.BeginTransaction("UseMemberCreditPackage"); //memberCreditPackage.MainConnectionProvider = connProvider; memberCreditPackage.NCreditPackageID = nCreditPackageID; DataTable table = memberCreditPackage.SelectOne(); if (table == null || table.Rows.Count == 0) { throw new Exception("This member credit package been deleted by others"); } if (ACMS.Convert.ToInt32(table.Rows[0]["nStatusID"]) > 0) { throw new Exception("This member credit package has been deleted/expired/suspended."); } string strCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; string strMembershipID = memberCreditPackage.StrMembershipID.Value; TblCreditPackageRestriction restriction = new TblCreditPackageRestriction(); restriction.StrCreditPackageCode = strCreditPackageCode; TblReceipt creditReceipt = new TblReceipt(); if (!memberCreditPackage.StrReceiptNo.IsNull) { creditReceipt.StrReceiptNo = memberCreditPackage.StrReceiptNo.Value; creditReceipt.SelectOne(); } DataTable restricttable = restriction.SelectAllWstrCreditPackageCodeLogic(); DataColumn colQuantity = new DataColumn("colQuantity", System.Type.GetType("System.Int32")); restricttable.Columns.Add(colQuantity); bool isAllowDiscount = false; if (restricttable.Rows.Count == 0) { throw new Exception("No allow to use credit package for this package."); } else { for (int j = 0; j < strPackageCode.Length / 2; j++) { rows = restricttable.Select("strPackageCode = '" + strPackageCode[j, 0] + "'", "strCreditPackageCode"); rows[0]["colQuantity"] = strPackageCode[j, 1]; row1s[j] = rows[0]; } if (row1s.Length == 0) { throw new Exception("No allow to use credit package for this package."); } // check later as got two package now //else //{ // isAllowDiscount = ACMS.Convert.ToBoolean(row1s[0]["fAllowDiscount"]); //} } // Must Check balance is enough to buy a Package or not TblCreditPackage creditPackage = new TblCreditPackage(); creditPackage.StrCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; creditPackage.SelectOne(); decimal creditPackageValue = ACMS.Convert.ToDecimal(creditPackage.MCreditAmount); decimal mmbCreditPackageFreeCredit = ACMS.Convert.ToDecimal(creditPackage.MFreeCredit); decimal mmbCreditPackageTopupAmt = ACMS.Convert.ToDecimal(memberCreditPackage.MTopupAmount); decimal totalCreditUsage = GetCreditUsageFromMemberPackage(nCreditPackageID); decimal balance = (creditPackageValue + mmbCreditPackageTopupAmt + mmbCreditPackageFreeCredit) - totalCreditUsage; if (creditReceipt.MOutstandingAmount > 0 && !memberCreditPackage.StrReceiptNo.IsNull) { DataTable creditUsageMemberPackage = null; RefreshForPackageUsage(strMembershipID, ACMS.Convert.ToInt32(creditPackage.NCategoryID)); creditUsageMemberPackage = myDataTable; double m70PercPaidAmount = 0; if (creditUsageMemberPackage.Rows.Count > 0) { m70PercPaidAmount = ACMS.Convert.ToDouble(creditUsageMemberPackage.Select("nCreditPackageID=" + nCreditPackageID)[0]["PaidAmt"]) * 0.7; } if (totalCreditUsage > ACMS.Convert.ToDecimal(m70PercPaidAmount)) { throw new Exception(string.Format("Total usage is more than 70% of paid amount. \n Please clear the outstanding.")); } } if (balance < 0) { throw new Exception(string.Format("Balance for Member Credit Package : {0} is not enough.\n Please topup your credit.", nCreditPackageID.ToString())); } // Need to know here whether it is 1st use TblMemberPackage mp = new TblMemberPackage(); //mp.MainConnectionProvider = connProvider; mp.NCreditPackageID = nCreditPackageID; DataTable temptable = mp.SelectAllWnCreditPackageIDLogic(); bool is1stUseCreditPck = false; if (Convert.ToInt32(temptable.Compute("COUNT(nStatusID)", "nStatusID=0 or nStatusID=1")) == 0) { //means news insert is1stUseCreditPck = true; } int i = 0; foreach (DataRow drPackage in row1s) { for (int x = 0; x < ACMS.Convert.ToInt32(drPackage[3]); x++) // quantity { MemberPackage memberPackage = new MemberPackage(); DataTable memberPackageTable = memberPackage.New(false, strMembershipID); DataRow memberPackageRow = memberPackageTable.Rows[0]; memberPackageRow["nCreditPackageID"] = nCreditPackageID; memberPackageRow["strMembershipID"] = strMembershipID; memberPackageRow["dtPurchaseDate"] = DateTime.Now; memberPackageRow["strRemarks"] = remark; memberPackageRow["strSignatureID"] = strSignID; memberPackageRow["strSigKey"] = strSigKey; memberPackageRow["strSigPdfPath"] = strPdfExportPath; memberPackageRow["strUtilData"] = strSigKey; memberPackageRow["nStatusID"] = 0; memberPackageRow["strPackageCode"] = drPackage["strPackageCode"]; //strPackageCode; TblPackage package = new TblPackage(); package.StrPackageCode = drPackage["strPackageCode"].ToString(); // strPackageCode; package.SelectOne(); decimal creditUsage = 0; decimal packageListPrice = ACMS.Convert.ToDecimal(package.MListPrice); TblMember sqlMember = new TblMember(); //Check if redeemed spa single treatment from holistic in birthday month, give 50% discount if ((creditPackage.NCategoryID == 36 || creditPackage.NCategoryID == 37) && (package.NCategoryID == 4 || (package.NCategoryID == 6 && package.NMaxSession == 1)) && sqlMember.MembershipThisMonthBirtdayForUtilised(strMembershipID, nCreditPackageID)) { DialogResult result1 = MessageBox.Show("Member is having birthday this months and having 50% discount. Do you want to utilies?", "Warning", MessageBoxButtons.YesNo); if (result1 == DialogResult.Yes) { double discountPercent = 50; memberPackageRow["strPromotionCode"] = "120046SSD"; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { if (ACMS.Convert.ToBoolean(drPackage["fAllowDiscount"])) { double discountPercent = creditPackage.DCreditDiscount.Value; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { creditUsage = packageListPrice; } } } else if (ACMS.Convert.ToBoolean(drPackage["fAllowDiscount"])) { double discountPercent = creditPackage.DCreditDiscount.Value; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { creditUsage = packageListPrice; } decimal previousBal = balance; balance = decimal.Parse(previousBal.ToString("N2")) - decimal.Parse(creditUsage.ToString("N2")); if (balance < 0) { throw new Exception(string.Format("Balance for Member Credit Package : {0} is not enough. \n Please topup your credit.", nCreditPackageID.ToString())); } memberPackageRow["mCreditPackageUsagePrice"] = creditUsage; memberPackageRow["strRemarks"] = memberPackageRow["strRemarks"] + " " + x; //Initially designed for immediate kick start if (memberPackageRow["dtStartDate"].ToString() == "") { int iduration = package.NPackageDuration.Value; DateTime dtNow = DateTime.Now.Date; memberPackageRow["dtStartDate"] = dtNow; if (package.StrDurationUnit.ToString().Trim() == "DAY") { memberPackageRow["dtExpiryDate"] = dtNow.AddDays(iduration - 1).AddDays(0); } else if (package.StrDurationUnit.ToString().Trim() == "WEEK") { iduration = iduration * 7; memberPackageRow["dtExpiryDate"] = dtNow.AddDays(iduration - 1).AddDays(0); } else { memberPackageRow["dtExpiryDate"] = dtNow.AddMonths(iduration).AddDays(-1); } } mp.SaveData(memberPackageTable); strUsage[i, 0] = package.StrDescription.ToString(); strUsage[i, 1] = creditUsage.ToString(); } strUsage[i, 2] = drPackage[3].ToString(); i++; } if (is1stUseCreditPck) { if (memberCreditPackage.DtStartDate.ToString() == "Null") { memberCreditPackage.NCreditPackageID = nCreditPackageID; memberCreditPackage.DtStartDate = DateTime.Now.Date; memberCreditPackage.DtExpiryDate = DateTime.Now.Date.AddMonths(ACMS.Convert.ToInt32(creditPackage.NValidMonths)).AddDays(-1); memberCreditPackage.Update(); } } //connProvider.CommitTransaction(); } catch (Exception) { //connProvider.RollbackTransaction("UseMemberCreditPackage"); throw; } finally { //if (connProvider.CurrentTransaction != null) // connProvider.CurrentTransaction.Dispose(); //if (connProvider.DBConnection != null) //{ // if (connProvider.DBConnection.State == ConnectionState.Open) // connProvider.DBConnection.Close(); //} } return(strUsage); }
private void ActionTakeWhenVoidReceiptForCategory_18(string strReceiptNo, ConnectionProvider connProvider) { //Top-up Spa Credit // need to find back the member credit package that been upgraded. TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); memberCreditPackage.MainConnectionProvider = connProvider; TblReceiptEntries sqlReceiptEntiries = new TblReceiptEntries(); sqlReceiptEntiries.MainConnectionProvider = connProvider; sqlReceiptEntiries.StrReceiptNo= strReceiptNo; DataTable tableReceiptEntries = sqlReceiptEntiries.SelectAllWstrReceiptNoLogic(); if (tableReceiptEntries.Rows.Count > 0) { // Get back the receiptEntries. // refer to Pos, strCode=nCreditPackageID, mSubTotal = topupAmount foreach (DataRow r in tableReceiptEntries.Rows) { if (!CheckIsRegistrationRow(r)) { int nCrdPackageID = ACMS.Convert.ToInt32(r["strCode"]); decimal topupAmt = ACMS.Convert.ToInt32(r["mSubTotal"]); memberCreditPackage.NCreditPackageID = nCrdPackageID; if (memberCreditPackage.SelectOne().Rows.Count > 0) { memberCreditPackage.MTopupAmount = ACMS.Convert.ToInt32(memberCreditPackage.MTopupAmount) - topupAmt; memberCreditPackage.Update(); } } } } }
//Derek Instalment Plan - Void Pay OS - Update Payment Plan public void VoidReceipt(string strReceiptNo, bool VoidPre) { ACMSDAL.ConnectionProvider connProvider = new ConnectionProvider(); try { // Check Access Right here TblReceipt receipt = new TblReceipt(); TblReceiptFreebie sqlReceiptFreebie = new TblReceiptFreebie(); TblRewardsTransaction mRewardTransaction = new TblRewardsTransaction(); TblReceiptPayment sqlReceiptPayment = new TblReceiptPayment(); TblPaymentPlan myPaymentPlan = new TblPaymentPlan(); myPaymentPlan.MainConnectionProvider = connProvider; mRewardTransaction.MainConnectionProvider = connProvider; receipt.MainConnectionProvider = connProvider; sqlReceiptFreebie.MainConnectionProvider = connProvider; sqlReceiptPayment.MainConnectionProvider = connProvider; connProvider.OpenConnection(); connProvider.BeginTransaction("VoidReceipt"); receipt.StrReceiptNo = strReceiptNo; receipt.SelectOne(); int nCategoryID = receipt.NCategoryID.Value; string strBranchCode = receipt.StrBranchCode.Value; if (receipt.DtDate.Value != System.DateTime.Today && VoidPre == false) throw new Exception("Not allow to void previous data receipt. "); if (strBranchCode != User.BranchCode) throw new Exception("Not allow to void other's branches' receipt. "); receipt.FVoid = System.Data.SqlTypes.SqlBoolean.True; receipt.Update(); string strSQL; if (receipt.NCategoryID == 7 || receipt.NCategoryID == 36 || receipt.NCategoryID == 37) strSQL = "select top 1 * from tblMemberCreditPackage where strReceiptNo ='" + receipt.StrReceiptNo.ToString() + "' AND fFree=0"; else strSQL = "select top 1 * from tblMemberPackage where strReceiptNo ='" + receipt.StrReceiptNo.ToString() + "' AND fFree=0"; DataSet _ds1 = new DataSet(); SqlHelper.FillDataset(connection, CommandType.StoredProcedure, "UP_GETDATA", _ds1, new string[] { "table" }, new SqlParameter("@strSQL", strSQL)); //Roll back when package conversion if (_ds1.Tables["table"].Rows.Count > 0) { string strPkgRemark = _ds1.Tables["table"].Rows[0]["strUpgradeFrom"].ToString(); string[] rollbackPackages = strPkgRemark.ToString().Split(','); foreach (string rollbackPackage in rollbackPackages) { if (rollbackPackage.Trim() != "" && rollbackPackage.Trim() != "Null") { if (rollbackPackage.Contains("(C)")) { int nPackageID = Convert.ToInt32(rollbackPackage.Trim().Replace("(C)", "")); TblMemberCreditPackage mp2 = new TblMemberCreditPackage(); mp2.NCreditPackageID = nPackageID; mp2.SelectOne(); mp2.StrUpgradeTo = ""; mp2.StrRemarks = ""; mp2.NStatusID = 0; mp2.Update(); } else if (rollbackPackage.Contains("(B)")) { string strSQL2 = "select * from tblMemberPackage where strUpgradeTo='" + receipt.StrReceiptNo.ToString() + "' "; DataSet _ds2 = new DataSet(); SqlHelper.FillDataset(connection, CommandType.StoredProcedure, "UP_GETDATA", _ds2, new string[] { "table" }, new SqlParameter("@strSQL", strSQL2)); foreach (DataRow drComboPkg in _ds2.Tables["table"].Rows) { TblMemberPackage mp = new TblMemberPackage(); DataTable convertedPkgTable = mp.LoadData("select * from tblMemberPackage where nPackageID=" + drComboPkg["nPackageID"].ToString()); if (convertedPkgTable.Rows.Count > 0) { convertedPkgTable.Rows[0]["nStatusID"] = 0; convertedPkgTable.Rows[0]["strUpgradeTo"] = ""; convertedPkgTable.Rows[0]["strRemarks"] = ""; mp.SaveData(convertedPkgTable); } } } else { int nPackageID = Convert.ToInt32(rollbackPackage.Trim()); TblMemberPackage mp2 = new TblMemberPackage(); mp2.NPackageID = nPackageID; mp2.SelectOne(); mp2.StrUpgradeTo = ""; mp2.StrRemarks = ""; mp2.NStatusID = 0; mp2.Update(); //rollback free package if have any TblMemberPackage mp3 = new TblMemberPackage(); string strFreePackageCode = ""; string strSQL3 = "select strFreePkgCode from tblPackage where strPackageCode='" + Convert.ToString(mp2.StrPackageCode) + "' "; DataSet _ds = new DataSet(); SqlHelper.FillDataset(connection, CommandType.StoredProcedure, "UP_GETDATA", _ds, new string[] { "table" }, new SqlParameter("@strSQL", strSQL3)); if (_ds.Tables["table"].Rows.Count > 0) { strFreePackageCode = _ds.Tables["table"].Rows[0]["strFreePkgCode"].ToString(); } DataTable freePkgTable = mp3.LoadData("select * from tblMemberPackage where strReceiptNo=@strReceiptNo and strPackageCode =@strFreePackageCode ", new string[] { "@strReceiptNo", "@strFreePackageCode" }, new object[] { mp2.StrReceiptNo.ToString(), strFreePackageCode }); if (freePkgTable.Rows.Count > 0) { freePkgTable.Rows[0]["nStatusID"] = 0; freePkgTable.Rows[0]["strUpgradeTo"] = ""; freePkgTable.Rows[0]["strRemarks"] = ""; mp3.SaveData(freePkgTable); } } } } } receipt.MUpgradeAmount = System.Data.SqlTypes.SqlMoney.Null; receipt.StrRemarks = ""; receipt.Update(); #region ====== Added By Albert ====== /* * To remove reward transaction. */ mRewardTransaction.StrReferenceNo = strReceiptNo; mRewardTransaction.SelectAllWReferenceNo(); mRewardTransaction.NTypeID = 3; mRewardTransaction.Update(); #endregion //rollback used cash voucher TblReceiptPayment tblReceiptPayment = new ACMSDAL.TblReceiptPayment(); tblReceiptPayment.StrReceiptNo = strReceiptNo; DataTable tblPayment = tblReceiptPayment.SelectAllWstrReceiptNoLogic(); foreach (DataRow dr in tblPayment.Rows) { if (dr["strPaymentCode"].ToString() == "CASHVOUCHER") { TblCashVoucher sqlCV = new TblCashVoucher(); sqlCV.MainConnectionProvider = connProvider; sqlCV.StrSN = dr["strReferenceNo"].ToString(); DataTable table = sqlCV.SelectOne(); sqlCV.NStatusID = 1; sqlCV.StrRedeemedByID = System.Data.SqlTypes.SqlString.Null; sqlCV.DtRedeemedDate = System.Data.SqlTypes.SqlDateTime.Null; sqlCV.StrRedeemedBranch = System.Data.SqlTypes.SqlString.Null; sqlCV.Update(); sqlCV.SaveData(table); } } if (!receipt.StrChildReceiptNo.IsNull) { int IsVoid = 0; IsVoid = receipt.CheckIfChildReceiptVoid(receipt.StrChildReceiptNo.Value); if (IsVoid == 0) { throw new Exception("The receipt given has child receipt, please void child receipt first before void this receipt"); } } string strDepositReceiptNo = ""; if (!receipt.StrParentReceiptNo.IsNull) { TblReceiptEntries pReceipt = new TblReceiptEntries(); pReceipt.StrReceiptNo = receipt.StrParentReceiptNo.Value; pReceipt.SelectAllWstrReceiptNoLogic(); if (pReceipt.StrCode.Value != "Deposit") { nCategoryID = 0; //Check if pay outstanding receipt, reset category to 0 } else if (pReceipt.StrCode.Value == "Deposit") { strDepositReceiptNo = receipt.StrParentReceiptNo.Value; } pReceipt.Dispose(); } if (strDepositReceiptNo != "") { try { receipt.ReviveDepositForVoidMasterReceipt(strReceiptNo, strDepositReceiptNo); } catch { } } if (nCategoryID == 1 || nCategoryID == 3 || nCategoryID == 4 || nCategoryID == 5 || nCategoryID == 6 || nCategoryID == 8 || nCategoryID == 9 || nCategoryID == 14 || nCategoryID == 23) { ActionTakeWhenVoidReceiptForCategory_1_3_4_5_6_8_9_14_23(strReceiptNo, connProvider); } else if (nCategoryID == 2) { //Fitness GIRO ActionTakeWhenVoidReceiptForCategory_2(strReceiptNo, connProvider); } else if (nCategoryID == 7) { // Spa Credit Account ActionTakeWhenVoidReceiptForCategory_7(strReceiptNo, connProvider); } else if (nCategoryID == 36 || nCategoryID == 37) { // Holistic Credit Account ActionTakeWhenVoidReceiptForCategory_7(strReceiptNo, connProvider); } else if (nCategoryID == 38) { // Cash Voucher ActionTakeWhenVoidReceiptForCategory_38(strReceiptNo, connProvider); } else { DeleteFreeMemberPackage(strReceiptNo, connProvider); if (nCategoryID == 11 || nCategoryID == 12) { //ActionTakeWhenVoidReceiptForCategory_11_12(strReceiptNo, connProvider); } else if (nCategoryID == 21) { // mineral water } else if (nCategoryID == 15) { //Locker Rental } else if (nCategoryID == 0) { // Pay Outstanding ActionTakeWhenVoidReceiptForCategory_0(receipt, connProvider); //Get New Payment Plan //If Table Row Count > 0 Then Update Payment Plan //Derek Instalment Plan - Update tblPaymentPlan (if any) //Reset Payment Plan's Receipt by payment receipt No - Bool 1 Updated 0 Not Found //Get Bool If 1 //Find the Master Receipt No if 1 string strMasterReceiptNo = ""; strMasterReceiptNo = myPaymentPlan.GetInhouseIPPMasterOSReceiptSimple(strReceiptNo); if (strMasterReceiptNo != "") { if (myPaymentPlan.GetInhouseResetIPP_VoidPayOS(strReceiptNo) == 1) { DataTable paymentPlanTable = myPaymentPlan.GetInhouseAdjustedIPP_VoidPayOS(strMasterReceiptNo); if (paymentPlanTable != null && paymentPlanTable.Rows.Count > 0) { foreach (DataRow r in paymentPlanTable.Rows) { if (r["lastestUpdate"].ToString() == "1") { myPaymentPlan.IPPSubsequentUpdate(Convert.ToInt32(r["nPaymentPlanID"]), r["strReceiptNo"].ToString(), Convert.ToInt32(r["nInstalmentNo"]), Convert.ToDecimal(r["mPaidAmount"]), Convert.ToDecimal(r["mAdjustedPaymentPlanAmt"]), Convert.ToDecimal(r["mOutstandingAmt"])); } } //paymentPlanTable.AcceptChanges(); } } } } else if (nCategoryID == 18) { ActionTakeWhenVoidReceiptForCategory_18(strReceiptNo, connProvider); } else if (nCategoryID == 19) { ActionTakeWhenVoidReceiptForCategory_19(strReceiptNo, connProvider); } #region Un-support voiding /* else if (nCategoryID == 17) { //throw new Exception("Forget card's receipt is not allow to void."); //do notthing. Just void the receipt } else if (nCategoryID == 10) { //throw new Exception("Upgrade Package's receipt is not allow to void."); // do notthing. Just void the receipt. } else if (nCategoryID == 20) { //Replace Membership Card //throw new Exception("Replace member card's receipt is not allow to void."); //do notthing, just void the receipt } */ #endregion } connProvider.CommitTransaction(); } catch (Exception ex) { connProvider.RollbackTransaction("VoidReceipt"); throw ex; } finally { if (connProvider.CurrentTransaction != null) connProvider.CurrentTransaction.Dispose(); if (connProvider.DBConnection != null) { if (connProvider.DBConnection.State == ConnectionState.Open) connProvider.DBConnection.Close(); } } }
/// <summary> /// Use Member Credit Package means use the credit to buy the package and then store in the tblMemberPackage /// be aware some package is not allow to purchase using credit package. Must check tblCreditPackageRestriction /// </summary> /// <returns></returns> public string[,] UseMemberCreditPackage(string[,] strPackageCode, int nCreditPackageID, string strSignID, string strSigKey, string strPdfExportPath, string remark) { //ACMSDAL.ConnectionProvider connProvider = new ConnectionProvider(); DataRow[] rows, row1s = new DataRow[strPackageCode.Length / 2]; string[,] strUsage = new string[strPackageCode.Length / 2, 3]; //DataColumn[] dc = new DataColumn["Usage",System.Type.GetType("System.Int")]; try { TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); //connProvider.OpenConnection(); //connProvider.BeginTransaction("UseMemberCreditPackage"); //memberCreditPackage.MainConnectionProvider = connProvider; memberCreditPackage.NCreditPackageID = nCreditPackageID; DataTable table = memberCreditPackage.SelectOne(); if (table == null || table.Rows.Count == 0) throw new Exception("This member credit package been deleted by others"); if (ACMS.Convert.ToInt32(table.Rows[0]["nStatusID"]) > 0) throw new Exception("This member credit package has been deleted/expired/suspended."); string strCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; string strMembershipID = memberCreditPackage.StrMembershipID.Value; TblCreditPackageRestriction restriction = new TblCreditPackageRestriction(); restriction.StrCreditPackageCode = strCreditPackageCode; TblReceipt creditReceipt = new TblReceipt(); if (!memberCreditPackage.StrReceiptNo.IsNull) { creditReceipt.StrReceiptNo = memberCreditPackage.StrReceiptNo.Value; creditReceipt.SelectOne(); } DataTable restricttable = restriction.SelectAllWstrCreditPackageCodeLogic(); DataColumn colQuantity = new DataColumn("colQuantity", System.Type.GetType("System.Int32")); restricttable.Columns.Add(colQuantity); bool isAllowDiscount = false; if (restricttable.Rows.Count == 0) throw new Exception("No allow to use credit package for this package."); else { for (int j = 0; j < strPackageCode.Length / 2; j++) { rows = restricttable.Select("strPackageCode = '" + strPackageCode[j, 0] + "'", "strCreditPackageCode"); rows[0]["colQuantity"] = strPackageCode[j, 1]; row1s[j] = rows[0]; } if (row1s.Length == 0) throw new Exception("No allow to use credit package for this package."); // check later as got two package now //else //{ // isAllowDiscount = ACMS.Convert.ToBoolean(row1s[0]["fAllowDiscount"]); //} } // Must Check balance is enough to buy a Package or not TblCreditPackage creditPackage = new TblCreditPackage(); creditPackage.StrCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; creditPackage.SelectOne(); decimal creditPackageValue = ACMS.Convert.ToDecimal(creditPackage.MCreditAmount); decimal mmbCreditPackageFreeCredit = ACMS.Convert.ToDecimal(creditPackage.MFreeCredit); decimal mmbCreditPackageTopupAmt = ACMS.Convert.ToDecimal(memberCreditPackage.MTopupAmount); decimal totalCreditUsage = GetCreditUsageFromMemberPackage(nCreditPackageID); decimal balance = (creditPackageValue + mmbCreditPackageTopupAmt + mmbCreditPackageFreeCredit) - totalCreditUsage; if (creditReceipt.MOutstandingAmount > 0 && !memberCreditPackage.StrReceiptNo.IsNull) { DataTable creditUsageMemberPackage = null; RefreshForPackageUsage(strMembershipID, ACMS.Convert.ToInt32(creditPackage.NCategoryID)); creditUsageMemberPackage = myDataTable; double m70PercPaidAmount = 0; if (creditUsageMemberPackage.Rows.Count > 0) m70PercPaidAmount = ACMS.Convert.ToDouble(creditUsageMemberPackage.Select("nCreditPackageID=" + nCreditPackageID)[0]["PaidAmt"]) * 0.7; if (totalCreditUsage > ACMS.Convert.ToDecimal(m70PercPaidAmount)) throw new Exception(string.Format("Total usage is more than 70% of paid amount. \n Please clear the outstanding.")); } if (balance < 0) throw new Exception(string.Format("Balance for Member Credit Package : {0} is not enough.\n Please topup your credit.", nCreditPackageID.ToString())); // Need to know here whether it is 1st use TblMemberPackage mp = new TblMemberPackage(); //mp.MainConnectionProvider = connProvider; mp.NCreditPackageID = nCreditPackageID; DataTable temptable = mp.SelectAllWnCreditPackageIDLogic(); bool is1stUseCreditPck = false; if (Convert.ToInt32(temptable.Compute("COUNT(nStatusID)", "nStatusID=0 or nStatusID=1")) == 0) { //means news insert is1stUseCreditPck = true; } int i = 0; foreach (DataRow drPackage in row1s) { for (int x = 0; x < ACMS.Convert.ToInt32(drPackage[3]); x++) // quantity { MemberPackage memberPackage = new MemberPackage(); DataTable memberPackageTable = memberPackage.New(false, strMembershipID); DataRow memberPackageRow = memberPackageTable.Rows[0]; memberPackageRow["nCreditPackageID"] = nCreditPackageID; memberPackageRow["strMembershipID"] = strMembershipID; memberPackageRow["dtPurchaseDate"] = DateTime.Now; memberPackageRow["strRemarks"] = remark; memberPackageRow["strSignatureID"] = strSignID; memberPackageRow["strSigKey"] = strSigKey; memberPackageRow["strSigPdfPath"] = strPdfExportPath; memberPackageRow["strUtilData"] = strSigKey; memberPackageRow["nStatusID"] = 0; memberPackageRow["strPackageCode"] = drPackage["strPackageCode"];//strPackageCode; TblPackage package = new TblPackage(); package.StrPackageCode = drPackage["strPackageCode"].ToString(); // strPackageCode; package.SelectOne(); decimal creditUsage = 0; decimal packageListPrice = ACMS.Convert.ToDecimal(package.MListPrice); TblMember sqlMember = new TblMember(); //Check if redeemed spa single treatment from holistic in birthday month, give 50% discount if ((creditPackage.NCategoryID == 36 || creditPackage.NCategoryID == 37) && (package.NCategoryID == 4 || (package.NCategoryID == 6 && package.NMaxSession == 1)) && sqlMember.MembershipThisMonthBirtdayForUtilised(strMembershipID, nCreditPackageID)) { DialogResult result1 = MessageBox.Show("Member is having birthday this months and having 50% discount. Do you want to utilies?", "Warning", MessageBoxButtons.YesNo); if (result1 == DialogResult.Yes) { double discountPercent = 50; memberPackageRow["strPromotionCode"] = "120046SSD"; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { if (ACMS.Convert.ToBoolean(drPackage["fAllowDiscount"])) { double discountPercent = creditPackage.DCreditDiscount.Value; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { creditUsage = packageListPrice; } } } else if (ACMS.Convert.ToBoolean(drPackage["fAllowDiscount"])) { double discountPercent = creditPackage.DCreditDiscount.Value; // calcualte usage * quantity creditUsage = packageListPrice - (packageListPrice * (decimal)discountPercent / 100); } else { creditUsage = packageListPrice; } decimal previousBal = balance; balance = decimal.Parse(previousBal.ToString("N2")) - decimal.Parse(creditUsage.ToString("N2")); if (balance < 0) throw new Exception(string.Format("Balance for Member Credit Package : {0} is not enough. \n Please topup your credit.", nCreditPackageID.ToString())); memberPackageRow["mCreditPackageUsagePrice"] = creditUsage; memberPackageRow["strRemarks"] = memberPackageRow["strRemarks"] + " " + x; //Initially designed for immediate kick start if (memberPackageRow["dtStartDate"].ToString() == "") { int iduration = package.NPackageDuration.Value; DateTime dtNow = DateTime.Now.Date; memberPackageRow["dtStartDate"] = dtNow; if (package.StrDurationUnit.ToString().Trim() == "DAY") memberPackageRow["dtExpiryDate"] = dtNow.AddDays(iduration - 1).AddDays(0); else if (package.StrDurationUnit.ToString().Trim() == "WEEK") { iduration = iduration * 7; memberPackageRow["dtExpiryDate"] = dtNow.AddDays(iduration - 1).AddDays(0); } else memberPackageRow["dtExpiryDate"] = dtNow.AddMonths(iduration).AddDays(-1); } mp.SaveData(memberPackageTable); strUsage[i, 0] = package.StrDescription.ToString(); strUsage[i, 1] = creditUsage.ToString(); } strUsage[i, 2] = drPackage[3].ToString(); i++; } if (is1stUseCreditPck) { if (memberCreditPackage.DtStartDate.ToString() == "Null") { memberCreditPackage.NCreditPackageID = nCreditPackageID; memberCreditPackage.DtStartDate = DateTime.Now.Date; memberCreditPackage.DtExpiryDate = DateTime.Now.Date.AddMonths(ACMS.Convert.ToInt32(creditPackage.NValidMonths)).AddDays(-1); memberCreditPackage.Update(); } } //connProvider.CommitTransaction(); } catch (Exception) { //connProvider.RollbackTransaction("UseMemberCreditPackage"); throw; } finally { //if (connProvider.CurrentTransaction != null) // connProvider.CurrentTransaction.Dispose(); //if (connProvider.DBConnection != null) //{ // if (connProvider.DBConnection.State == ConnectionState.Open) // connProvider.DBConnection.Close(); //} } return strUsage; }
public DataTable GetPrintBalanceTable(int nCreditPackageID) { TblMemberCreditPackage memberCreditPackage = new TblMemberCreditPackage(); memberCreditPackage.NCreditPackageID = nCreditPackageID; DataTable table = memberCreditPackage.SelectOne(); TblCreditPackage creditPackage = new TblCreditPackage(); creditPackage.StrCreditPackageCode = memberCreditPackage.StrCreditPackageCode.Value; creditPackage.SelectOne(); decimal creditPackageValue = ACMS.Convert.ToDecimal(creditPackage.MCreditAmount); decimal mmbCreditPackageTopupAmt = ACMS.Convert.ToDecimal(memberCreditPackage.MTopupAmount); decimal totalCreditUsage = GetCreditUsageFromMemberPackage(nCreditPackageID); decimal balance = (creditPackageValue + mmbCreditPackageTopupAmt) - totalCreditUsage; DataTable tableToReturn = new DataTable(); DataColumn colCreditPackageID = new DataColumn("nCreditPackageID", System.Type.GetType("System.Int32")); DataColumn colBalance = new DataColumn("Balance", System.Type.GetType("System.Decimal")); DataColumn colExpiryDate = new DataColumn("ExpiryDate", System.Type.GetType("System.DateTime")); tableToReturn.Columns.Add(colBalance); tableToReturn.Columns.Add(colCreditPackageID); tableToReturn.Columns.Add(colExpiryDate); DataRow r = tableToReturn.NewRow(); r["nCreditPackageID"] = nCreditPackageID; r["Balance"] = balance; r["ExpiryDate"] = memberCreditPackage.DtExpiryDate.Value; return tableToReturn; }
public void DeleteCreditPackageUsage(int nPackageID) { int nCreditPackageID; TblServiceSession ssUsage = new TblServiceSession(); ssUsage.NPackageID = nPackageID; DataTable tblUsage = ssUsage.SelectAllWnPackageIDLogic(); if (tblUsage.Rows.Count > 0) throw new Exception("You Cant deleted a Used Package."); TblMemberPackage mmbPckg = new TblMemberPackage(); mmbPckg.NPackageID = nPackageID; DataTable table = mmbPckg.SelectOne(); if (table == null || table.Rows.Count == 0) throw new Exception("The Data has been deleted from database."); mmbPckg.NStatusID = 2; mmbPckg.Update(); nCreditPackageID = mmbPckg.NCreditPackageID.Value; //Check any package redeemed from this credit package ACMSDAL.TblMemberPackage memberPackage = new TblMemberPackage(); string cmdText = "Select COUNT(*) from TblMemberPackage Where (nStatusID = 0 or nStatusID = 1) AND " + " nCreditPackageID = @nCreditPackageID "; int nExist = (int) memberPackage.ExecuteScalar(cmdText, new string [] {"@nCreditPackageID"}, new object[] {nCreditPackageID}); if (nExist==0) { TblMemberCreditPackage creditPackage = new TblMemberCreditPackage(); creditPackage.NCreditPackageID = nCreditPackageID; creditPackage.SelectOne(); creditPackage.DtStartDate = SqlDateTime.Null; creditPackage.DtExpiryDate = SqlDateTime.Null; creditPackage.Update(); } }