/// <summary> /// kiểm tra voucher code đã được dùng hay chưa /// </summary> /// <param name="code">voucher code</param> /// <param name="count">dùng để dưa kết quả của biến count ra ngoài</param> /// <param name="batch">gói voucher</param> public void CheckCode(String code, out int count, out VoucherBatch batch) { /*Điều kiện tìm booking : tìm theo bookingid và booking chưa bị deleted và đã có voucher code và status không phải là cancelled */ int batchid; AbstractCriterion crit = Expression.Eq("Deleted", false); crit = Expression.And(crit, Expression.Or(Expression.Not(Expression.Eq("VoucherCode", null)), Expression.Not(Expression.Eq("VoucherCode", "")))); if (!string.IsNullOrEmpty(Request.QueryString["bookingid"])) { crit = Expression.And(crit, Expression.Not(Expression.Eq("Id", Convert.ToInt32(Request.QueryString["bookingid"])))); crit = Expression.And(crit, Expression.Not(Expression.Eq("Status", StatusType.Cancelled))); } count = 0; var bookingList = Module.GetObject <Booking>(crit, 0, 0); /* kiểm tra voucher nhập vào đã dùng trong các booking vừa tìm hay chưa, nếu trùng tăng biến đếm count * và đưa kết quả ra ngoài để xử lý */ foreach (Booking booking in bookingList) { string[] codeArray = booking.VoucherCode.Split(new char[] { ';' }); for (int i = 0; i < codeArray.Length; i++) { if (code == codeArray[i]) { count++; } } } try { /* giải mã voucher xem nó thuộc gói voucher nào*/ VoucherCodeEncryption.Decrypt(Convert.ToUInt32(code), out batchid); } catch (Exception ex) { throw ex; } /*tìm gói voucher và đưa kết quả ra ngoài để xử lý*/ batch = Module.GetObject <VoucherBatch>(batchid); }
public void VoucherProcess() { if (txtAllVoucher.Text.ToLower() != "ov" && !string.IsNullOrEmpty(txtAllVoucher.Text)) { var trimmedCode = txtAllVoucher.Text.Trim(); if (trimmedCode.EndsWith(";")) { arr = trimmedCode.Remove(trimmedCode.Length - 1).Split(new char[] { ';' }); } else { arr = trimmedCode.Split(new char[] { ';' }); } foreach (string codeString in arr) { var code = Convert.ToUInt32(codeString.Trim()); int batchid; int index; VoucherCodeEncryption.Decrypt(code, out batchid); ICriterion crit = Expression.Eq("Code", code.ToString()); crit = Expression.And(crit, Expression.Not(Expression.Eq("Booking.Id", Booking.Id))); bool isUsed = false; foreach (BookingVoucher bv in Module.GetObject <BookingVoucher>(crit, 0, 0)) { if (bv.Booking.Status == StatusType.Approved || bv.Booking.Status == StatusType.Pending) { isUsed = true; } } if (isUsed) { ShowErrors(string.Format("Voucher code {0} already used!", codeString)); return; } var batch = Module.GetObject <VoucherBatch>(batchid); if (batch == null) { ShowErrors(string.Format("Voucher code {0} invalid!", codeString)); return; } else if (batch.ValidUntil < Booking.StartDate) { ShowErrors(string.Format("Voucher code {0} outdated!", codeString)); return; } Booking.Batch = batch; var bkv = Module.GetBookingVoucher(Booking, codeString); bkv.Voucher = batch; Module.SaveOrUpdate(bkv, UserIdentity); } } Booking.VoucherCode = txtAllVoucher.Text; }
protected void buttonIssuePDF_Click(object sender, EventArgs e) { VoucherBatch batch; if (Request.QueryString["batchid"] != null) { batch = Module.GetObject <VoucherBatch>(Convert.ToInt32(Request.QueryString["batchid"])); } else { return; } var doc = new Document(Server.MapPath("/Userfiles/VoucherTemplates/" + ddlTemplates.SelectedValue)); //var awPrintDoc = new AsposeWordsPrintDocument(doc); #region -- Generate docs -- var table = new DataTable("Voucher"); table.Columns.Add("VoucherName"); table.Columns.Add("Agency"); table.Columns.Add("ApplyFor"); table.Columns.Add("Cruise"); table.Columns.Add("Trip"); table.Columns.Add("Value"); table.Columns.Add("ValidUntil"); table.Columns.Add("IssueDate"); table.Columns.Add("Code"); //double total = 0; for (int ii = 1; ii <= batch.Quantity; ii++) { DataRow row = table.NewRow(); row["VoucherName"] = batch.Name; if (batch.Agency != null) { row["Agency"] = batch.Agency.Name; } if (batch.NumberOfPerson == 1) { row["ApplyFor"] = "Single person"; } else { row["ApplyFor"] = "02 PERSONS, 01 sharing cabin"; } row["Cruise"] = batch.Cruise.Name; row["Trip"] = batch.Trip.Name; row["Value"] = batch.Value; row["ValidUntil"] = batch.ValidUntil.ToString("dd/MM/yyyy"); if (batch.IssueDate.HasValue) { row["IssueDate"] = batch.IssueDate.Value.ToString("dd/MM/yyyy"); } row["Code"] = VoucherCodeEncryption.Encrypt(Convert.ToUInt32(batch.Id * 1000 + ii)); table.Rows.Add(row); } doc.MailMerge.Execute(table); Response.Clear(); Response.Buffer = true; Response.ContentType = "application/pdf"; //Response.ContentType = "application/msword"; Response.AppendHeader("content-disposition", "attachment; filename=" + string.Format("{0}.pdf", "voucher" + batch.Id)); // "attachment; filename=" + string.Format("{0}.doc", "voucher" + batch.Id)); var m = new MemoryStream(); doc.Save(m, SaveFormat.Doc); Response.OutputStream.Write(m.GetBuffer(), 0, m.GetBuffer().Length); Response.OutputStream.Flush(); Response.OutputStream.Close(); m.Close(); Response.End(); #endregion if (!batch.IssueDate.HasValue) { batch.IssueDate = DateTime.Today; batch.Issued = true; Module.SaveOrUpdate(batch, UserIdentity); } }
protected void rptVouchers_ItemDataBound(object sender, RepeaterItemEventArgs e) { var value = (int)e.Item.DataItem; ValueBinder.BindLiteral(e.Item, "litCode", VoucherCodeEncryption.Encrypt(Convert.ToUInt32(value))); }